add timestamp to stress_test.py
This commit is contained in:
		| @@ -3,6 +3,12 @@ import subprocess | ||||
| import argparse | ||||
| import time | ||||
| import sys | ||||
| from datetime import datetime | ||||
|  | ||||
| def log(message): | ||||
|     """Helper function to log messages with timestamp.""" | ||||
|     print(f"{datetime.now().strftime('%H:%M:%S')} - {message}") | ||||
|  | ||||
|  | ||||
| def run_ssh_command(ip, command, password="test0000", timeout=300, retries=3): | ||||
|     """Execute an SSH command using sshpass with retries and timeout.""" | ||||
| @@ -19,11 +25,11 @@ def run_ssh_command(ip, command, password="test0000", timeout=300, retries=3): | ||||
|             ) | ||||
|             return result.stdout.strip(), result.stderr.strip() | ||||
|         except subprocess.TimeoutExpired: | ||||
|             print(f"SSH command timed out after {timeout} seconds (attempt {attempt}/{retries}): {command}") | ||||
|             log(f"SSH command timed out after {timeout} seconds (attempt {attempt}/{retries}): {command}") | ||||
|             if attempt == retries: | ||||
|                 return None, "Timeout expired" | ||||
|         except subprocess.CalledProcessError as e: | ||||
|             print(f"SSH command error (attempt {attempt}/{retries}): {e}, stderr: {e.stderr}") | ||||
|             log(f"SSH command error (attempt {attempt}/{retries}): {e}, stderr: {e.stderr}") | ||||
|             if attempt == retries: | ||||
|                 return None, e.stderr | ||||
|         time.sleep(5)  # Wait before retrying | ||||
| @@ -32,24 +38,24 @@ def run_ssh_command(ip, command, password="test0000", timeout=300, retries=3): | ||||
|  | ||||
| def get_system_info(ip): | ||||
|     """Retrieve system information using crossystem and cat /etc/lsb-release.""" | ||||
|     print(f"\nCollecting system information for {ip}...") | ||||
|     log(f"\nCollecting system information for {ip}...") | ||||
|      | ||||
|     # Run crossystem | ||||
|     print("\n--- crossystem output ---") | ||||
|     log("\n--- crossystem output ---") | ||||
|     stdout, stderr = run_ssh_command(ip, "crossystem") | ||||
|     if stdout: | ||||
|         print(stdout) | ||||
|         log(stdout) | ||||
|     else: | ||||
|         print(f"Failed to retrieve crossystem info: {stderr}") | ||||
|         log(f"Failed to retrieve crossystem info: {stderr}") | ||||
|      | ||||
|     # Run cat /etc/lsb-release | ||||
|     print("\n--- /etc/lsb-release output ---") | ||||
|     log("\n--- /etc/lsb-release output ---") | ||||
|     stdout, stderr = run_ssh_command(ip, "cat /etc/lsb-release") | ||||
|     if stdout: | ||||
|         print(stdout) | ||||
|         log(stdout) | ||||
|     else: | ||||
|         print(f"Failed to retrieve /etc/lsb-release: {stderr}") | ||||
|     print("\n") | ||||
|         log(f"Failed to retrieve /etc/lsb-release: {stderr}") | ||||
|     log("\n") | ||||
|  | ||||
|  | ||||
| def get_last_eventlog_line(ip): | ||||
| @@ -61,17 +67,17 @@ def get_last_eventlog_line(ip): | ||||
| def run_firmware_update(ip, timeout=300): | ||||
|     """Run the firmware update command and check for success.""" | ||||
|     command = "/usr/local/chromeos-firmwareupdate_joxer_r132 -m factory" | ||||
|     print(f"Firmware update command: {command}") | ||||
|     log(f"Firmware update command: {command}") | ||||
|     stdout, stderr = run_ssh_command(ip, command, timeout=timeout) | ||||
|     # Print stdout and stderr | ||||
|     print(f"\n--- stdout ---\n{stdout if stdout else 'No stdout'}") | ||||
|     print(f"\n--- stderr ---\n{stderr if stderr else 'No stderr'}") | ||||
|     # log stdout and stderr | ||||
|     # log(f"\n--- stdout ---\n{stdout if stdout else 'No stdout'}") | ||||
|     # log(f"\n--- stderr ---\n{stderr if stderr else 'No stderr'}") | ||||
|  | ||||
|     if stdout is None: | ||||
|         print(f"Firmware update failed: No output received (timeout or error).") | ||||
|         log(f"Firmware update failed: No output received (timeout or error).") | ||||
|         return False | ||||
|     if "Firmware updater exits successfully" not in stdout: | ||||
|         print(f"Firmware update failed: Success message not found. Output: {stdout}, Error: {stderr}") | ||||
|         log(f"Firmware update failed: Success message not found. Output: {stdout}, Error: {stderr}") | ||||
|         return False | ||||
|     return True | ||||
|  | ||||
| @@ -79,7 +85,7 @@ def reboot_device(ip): | ||||
|     """Send reboot command to the device and verify it's back online using ping.""" | ||||
|     command = "reboot" | ||||
|     run_ssh_command(ip, command) | ||||
|     print(f"Reboot command sent to {ip}. Waiting for device to restart...") | ||||
|     log(f"Reboot command sent to {ip}. Waiting for device to restart...") | ||||
|  | ||||
|     max_attempts = 3 | ||||
|     wait_time = 60  # Total wait time in seconds | ||||
| @@ -87,7 +93,7 @@ def reboot_device(ip): | ||||
|     time.sleep(wait_time)  | ||||
|  | ||||
|     for attempt in range(1, max_attempts + 1): | ||||
|         print(f"Ping attempt {attempt}/{max_attempts}...") | ||||
|         log(f"Ping attempt {attempt}/{max_attempts}...") | ||||
|         start_time = time.time() | ||||
|         while time.time() - start_time < wait_time: | ||||
|             try: | ||||
| @@ -99,13 +105,13 @@ def reboot_device(ip): | ||||
|                     text=True, | ||||
|                     check=True, | ||||
|                 ) | ||||
|                 print(f"Device {ip} is back online.") | ||||
|                 log(f"Device {ip} is back online.") | ||||
|                 return True | ||||
|             except subprocess.CalledProcessError: | ||||
|                 time.sleep(ping_interval)  # Wait before next ping | ||||
|         print(f"Ping attempt {attempt} failed.") | ||||
|         log(f"Ping attempt {attempt} failed.") | ||||
|      | ||||
|     print(f"Device {ip} did not respond to ping after {max_attempts} attempts.") | ||||
|     log(f"Device {ip} did not respond to ping after {max_attempts} attempts.") | ||||
|     return False | ||||
|  | ||||
| def main(): | ||||
| @@ -121,39 +127,39 @@ def main(): | ||||
|     get_system_info(ip) | ||||
|  | ||||
|     for i in range(1, loops + 1): | ||||
|         print(f"\nStarting loop {i}/{loops}...") | ||||
|         log(f"\nStarting loop {i}/{loops}...") | ||||
|  | ||||
|         # Step 1: Get initial last line of eventlog | ||||
|         initial_log = get_last_eventlog_line(ip) | ||||
|         if not initial_log: | ||||
|             print("Failed to retrieve initial event log. Aborting loop.") | ||||
|             log("Failed to retrieve initial event log. Aborting loop.") | ||||
|             failures += 1 | ||||
|             return | ||||
|         print(f"Initial event log line: {initial_log}") | ||||
|         log(f"Initial event log line: {initial_log}") | ||||
|  | ||||
|         # Step 2: Run firmware update | ||||
|         print("Running firmware update...") | ||||
|         log("Running firmware update...") | ||||
|         if not run_firmware_update(ip): | ||||
|             print("Firmware update failed. Aborting loop.") | ||||
|             log("Firmware update failed. Aborting loop.") | ||||
|             failures += 1 | ||||
|             return False | ||||
|  | ||||
|         # Step 4: Check if event log changed | ||||
|         print("Checking event log before reboot...") | ||||
|         log("Checking event log before reboot...") | ||||
|         time.sleep(10)  | ||||
|  | ||||
|         final_log = get_last_eventlog_line(ip) | ||||
|         if not final_log: | ||||
|             print("Failed to retrieve final event log. Aborting loop.") | ||||
|             log("Failed to retrieve final event log. Aborting loop.") | ||||
|             failures += 1 | ||||
|             return False | ||||
|         print(f"Final event log line: {final_log}") | ||||
|         log(f"Final event log line: {final_log}") | ||||
|  | ||||
|         if final_log == initial_log: | ||||
|             print("Event log did not change after firmware update!") | ||||
|             log("Event log did not change after firmware update!") | ||||
|             failures += 1 | ||||
|         else: | ||||
|             print(f"Event log updated. New line: {final_log}") | ||||
|             log(f"Event log updated. New line: {final_log}") | ||||
|             return False | ||||
|  | ||||
|         # Step 3: Reboot device | ||||
| @@ -161,7 +167,7 @@ def main(): | ||||
|             return False | ||||
|  | ||||
|     # Summary | ||||
|     print(f"\nTest completed. Total loops: {loops}, Failures: {failures}") | ||||
|     log(f"\nTest completed. Total loops: {loops}, Failures: {failures}") | ||||
|     if failures > 0: | ||||
|         sys.exit(1) | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Casper Chang
					Casper Chang