mirror of
https://github.com/actions/runner-images-sangeeth.git
synced 2025-12-31 22:18:12 +08:00
Update stresstest.yml
This commit is contained in:
238
.github/workflows/stresstest.yml
vendored
238
.github/workflows/stresstest.yml
vendored
@@ -4,14 +4,12 @@ on:
|
||||
workflow_dispatch:
|
||||
|
||||
jobs:
|
||||
benchmark-memory-speed:
|
||||
name: Test
|
||||
runs-on: ${{ matrix.os }}
|
||||
performance:
|
||||
name: macOS Performance Benchmark
|
||||
strategy:
|
||||
fail-fast: false
|
||||
matrix:
|
||||
os: ['macos-13','macos-13-xlarge', 'macos-14', 'macos-14-large','macos-14-xlarge','macos-15', 'macos-15-large','macos-15-xlarge']
|
||||
#os: ['macos-15-xlarge']
|
||||
os: [macos-13, macos-13-xlarge, macos-14-large, macos-14-xlarge, macos-15-large, macos-15-xlarge]
|
||||
runs-on: ${{ matrix.os }}
|
||||
|
||||
steps:
|
||||
- name: Memory Metrics Test
|
||||
@@ -279,7 +277,7 @@ jobs:
|
||||
run: |
|
||||
VM_OPS_START=200 # Initial value
|
||||
VM_OPS_INCREMENT=100 # Step increment
|
||||
VM_OPS_MAX=2000 # Maximum limit
|
||||
VM_OPS_MAX=3000 # Maximum limit
|
||||
VM_BYTES=2G # Memory allocation
|
||||
LOG_FILE="stress_test_results.log"
|
||||
|
||||
@@ -374,6 +372,53 @@ jobs:
|
||||
# echo "CPU Stress test completed. Check $LOG_FILE for details." | tee -a $LOG_FILE
|
||||
|
||||
|
||||
# # Add Incremental CPU Stress Test here
|
||||
# - name: Run Incremental CPU Stress Test
|
||||
# shell: bash
|
||||
# continue-on-error: true # Allows next steps to execute even if this one fails
|
||||
# run: |
|
||||
# # Get the number of CPU cores available on the system (for macOS)
|
||||
# CPU_CORES=$(sysctl -n hw.physicalcpu) # macOS command to get the number of physical CPU cores
|
||||
# echo "Detected $CPU_CORES CPU cores."
|
||||
|
||||
# # Define the starting and maximum stressors and the increment
|
||||
# CPU_CORES_START=2 # Start with 2 CPU stressors
|
||||
# CPU_CORES_INCREMENT=2 # Increase by 2 each iteration
|
||||
# CPU_CORES_MAX=$CPU_CORES # Maximum number of CPU stressors (set to the number of cores detected)
|
||||
|
||||
# # Set initial operations per stressor. This can be dynamically calculated based on the number of cores.
|
||||
# BASE_CPU_OPS=1000 # Base number of operations per stressor for initial low load
|
||||
# CPU_OPS=$((BASE_CPU_OPS * CPU_CORES)) # Multiply base operations with the number of cores to increase load with more stressors
|
||||
# LOG_FILE="cpu_stress_results.log" # Log file for results
|
||||
|
||||
# echo "Testing with stressors from $CPU_CORES_START to $CPU_CORES_MAX (based on $CPU_CORES cores)." | tee -a $LOG_FILE
|
||||
# echo "Initial operations per stressor: $CPU_OPS" | tee -a $LOG_FILE
|
||||
|
||||
# # Incrementally increase CPU stressors and operations per stressor
|
||||
# for ((cpu_cores=$CPU_CORES_START; cpu_cores<=$CPU_CORES_MAX; cpu_cores+=$CPU_CORES_INCREMENT)); do
|
||||
# # Set the number of stressors to twice the number of cores
|
||||
# CPU_STRESSORS=$((cpu_cores * 2)) # Increase stressors to double the number of cores
|
||||
|
||||
# # Adjust operations based on the number of cores for higher load
|
||||
# CPU_OPS=$((BASE_CPU_OPS * CPU_STRESSORS)) # Increasing number of operations with stressor count
|
||||
|
||||
# echo "Running stress-ng with --cpu $CPU_STRESSORS --cpu-ops $CPU_OPS" | tee -a $LOG_FILE
|
||||
|
||||
# # Run the CPU stress test with increasing CPU stressors
|
||||
# if stress-ng --cpu $CPU_STRESSORS --cpu-method matrixprod --cpu-ops $CPU_OPS --metrics-brief --verbose; then
|
||||
# echo "✅ Passed: --cpu=$CPU_STRESSORS with $CPU_OPS operations" | tee -a $LOG_FILE
|
||||
# else
|
||||
# echo "❌ Failed: --cpu=$CPU_STRESSORS with $CPU_OPS operations" | tee -a $LOG_FILE
|
||||
# echo "⚠️ Stopping further increments as failure occurred at --cpu=$CPU_STRESSORS" | tee -a $LOG_FILE
|
||||
# break # Stop the test if failure occurs
|
||||
# fi
|
||||
|
||||
# echo "---------------------------------------------" | tee -a $LOG_FILE
|
||||
# done
|
||||
|
||||
# echo "CPU Stress test completed. Check $LOG_FILE for details." | tee -a $LOG_FILE
|
||||
|
||||
|
||||
# Add Incremental CPU Stress Test here
|
||||
- name: Run Incremental CPU Stress Test
|
||||
shell: bash
|
||||
@@ -382,44 +427,42 @@ jobs:
|
||||
# Get the number of CPU cores available on the system (for macOS)
|
||||
CPU_CORES=$(sysctl -n hw.physicalcpu) # macOS command to get the number of physical CPU cores
|
||||
echo "Detected $CPU_CORES CPU cores."
|
||||
|
||||
|
||||
# Define the starting and maximum stressors and the increment
|
||||
CPU_CORES_START=2 # Start with 2 CPU stressors
|
||||
CPU_CORES_INCREMENT=2 # Increase by 2 each iteration
|
||||
CPU_CORES_MAX=$CPU_CORES # Maximum number of CPU stressors (set to the number of cores detected)
|
||||
|
||||
CPU_CORES_MAX=$((CPU_CORES * 2)) # Maximum number of CPU stressors (set to 2 * number of cores detected)
|
||||
|
||||
# Set initial operations per stressor. This can be dynamically calculated based on the number of cores.
|
||||
BASE_CPU_OPS=1000 # Base number of operations per stressor for initial low load
|
||||
BASE_CPU_OPS=5000 # Base number of operations per stressor for initial low load
|
||||
CPU_OPS=$((BASE_CPU_OPS * CPU_CORES)) # Multiply base operations with the number of cores to increase load with more stressors
|
||||
LOG_FILE="cpu_stress_results.log" # Log file for results
|
||||
|
||||
|
||||
echo "Testing with stressors from $CPU_CORES_START to $CPU_CORES_MAX (based on $CPU_CORES cores)." | tee -a $LOG_FILE
|
||||
echo "Initial operations per stressor: $CPU_OPS" | tee -a $LOG_FILE
|
||||
|
||||
|
||||
# Incrementally increase CPU stressors and operations per stressor
|
||||
for ((cpu_cores=$CPU_CORES_START; cpu_cores<=$CPU_CORES_MAX; cpu_cores+=$CPU_CORES_INCREMENT)); do
|
||||
# Set the number of stressors to twice the number of cores
|
||||
CPU_STRESSORS=$((cpu_cores * 2)) # Increase stressors to double the number of cores
|
||||
|
||||
# Adjust operations based on the number of cores for higher load
|
||||
CPU_OPS=$((BASE_CPU_OPS * CPU_STRESSORS)) # Increasing number of operations with stressor count
|
||||
|
||||
echo "Running stress-ng with --cpu $CPU_STRESSORS --cpu-ops $CPU_OPS" | tee -a $LOG_FILE
|
||||
|
||||
CPU_OPS=$((BASE_CPU_OPS * cpu_cores)) # Increasing number of operations with stressor count
|
||||
|
||||
echo "Running stress-ng with --cpu $cpu_cores --cpu-ops $CPU_OPS" | tee -a $LOG_FILE
|
||||
|
||||
# Run the CPU stress test with increasing CPU stressors
|
||||
if stress-ng --cpu $CPU_STRESSORS --cpu-method matrixprod --cpu-ops $CPU_OPS --metrics-brief --verbose; then
|
||||
echo "✅ Passed: --cpu=$CPU_STRESSORS with $CPU_OPS operations" | tee -a $LOG_FILE
|
||||
if stress-ng --cpu $cpu_cores --cpu-method matrixprod --cpu-ops $CPU_OPS --metrics-brief --verbose; then
|
||||
echo "✅ Passed: --cpu=$cpu_cores with $CPU_OPS operations" | tee -a $LOG_FILE
|
||||
else
|
||||
echo "❌ Failed: --cpu=$CPU_STRESSORS with $CPU_OPS operations" | tee -a $LOG_FILE
|
||||
echo "⚠️ Stopping further increments as failure occurred at --cpu=$CPU_STRESSORS" | tee -a $LOG_FILE
|
||||
echo "❌ Failed: --cpu=$cpu_cores with $CPU_OPS operations" | tee -a $LOG_FILE
|
||||
echo "⚠️ Stopping further increments as failure occurred at --cpu=$cpu_cores" | tee -a $LOG_FILE
|
||||
break # Stop the test if failure occurs
|
||||
fi
|
||||
|
||||
|
||||
echo "---------------------------------------------" | tee -a $LOG_FILE
|
||||
done
|
||||
|
||||
|
||||
echo "CPU Stress test completed. Check $LOG_FILE for details." | tee -a $LOG_FILE
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
@@ -431,8 +474,8 @@ jobs:
|
||||
# Define test parameters
|
||||
DISK_OPS_START=1000 # Start with 1000 disk operations
|
||||
DISK_OPS_INCREMENT=1000 # Increase by 1000 disk operations each iteration
|
||||
DISK_OPS_MAX=10000 # Maximum number of disk operations (adjust as needed)
|
||||
DISK_SIZE=4G # Size of the test file to use for stress
|
||||
DISK_OPS_MAX=20000 # Maximum number of disk operations (adjust as needed)
|
||||
DISK_SIZE=5G # Size of the test file to use for stress
|
||||
LOG_FILE="disk_stress_results.log" # Log file for results
|
||||
|
||||
echo "Starting incremental disk I/O stress test..." | tee $LOG_FILE
|
||||
@@ -481,7 +524,7 @@ jobs:
|
||||
# Define test parameters
|
||||
MEM_OPS_START=1000 # Start with 1000 memory read/write operations
|
||||
MEM_OPS_INCREMENT=1000 # Increase by 1000 operations each iteration
|
||||
MEM_OPS_MAX=10000 # Maximum number of operations
|
||||
MEM_OPS_MAX=20000 # Maximum number of operations
|
||||
MEM_SIZE=2G # Starting size of memory to stress
|
||||
LOG_FILE="memory_stress_results.log" # Log file for results
|
||||
|
||||
@@ -504,7 +547,81 @@ jobs:
|
||||
done
|
||||
|
||||
echo "Memory Read/Write stress test completed. Check $LOG_FILE for details." | tee -a $LOG_FILE
|
||||
|
||||
|
||||
|
||||
# Incremental file system stress test
|
||||
- name: Run Incremental File System Stress Test
|
||||
shell: bash
|
||||
continue-on-error: true # Allows next steps to execute even if this one fails
|
||||
run: |
|
||||
# Define variables for the incremental file system stress test
|
||||
FALLOCATE_OPS_START=1000 # Initial number of allocate operations
|
||||
FALLOCATE_OPS_INCREMENT=500 # Increment step for allocate operations
|
||||
FALLOCATE_OPS_MAX=8000 # Maximum value for allocate operations
|
||||
LOG_FILE="filesystem_stress_results.log" # Log file for file system stress test results
|
||||
|
||||
echo "Starting incremental file system stress test..." | tee $LOG_FILE
|
||||
|
||||
# Loop through file system allocation increments
|
||||
for ((fallocate_ops=$FALLOCATE_OPS_START; fallocate_ops<=$FALLOCATE_OPS_MAX; fallocate_ops+=$FALLOCATE_OPS_INCREMENT)); do
|
||||
# Print which iteration is being run
|
||||
echo "Running stress-ng with --fallocate-ops=$fallocate_ops" | tee -a $LOG_FILE
|
||||
|
||||
# Run the file system stress test with the current number of allocate operations
|
||||
if stress-ng --fallocate 2 --fallocate-ops $fallocate_ops --metrics-brief --verbose; then
|
||||
echo "✅ Passed: --fallocate-ops=$fallocate_ops" | tee -a $LOG_FILE # Log success
|
||||
else
|
||||
echo "❌ Failed: --fallocate-ops=$fallocate_ops" | tee -a $LOG_FILE # Log failure
|
||||
echo "⚠️ Stopping further increments as failure occurred at --fallocate-ops=$fallocate_ops" | tee -a $LOG_FILE
|
||||
break # Stop further increments if failure occurs
|
||||
fi
|
||||
|
||||
echo "---------------------------------------------" | tee -a $LOG_FILE
|
||||
done
|
||||
|
||||
echo "File system stress test completed. Check $LOG_FILE for details." | tee -a $LOG_FILE
|
||||
|
||||
|
||||
|
||||
# Network stress test
|
||||
- name: Run Incremental Ping Stress Test to Google
|
||||
shell: bash
|
||||
continue-on-error: true # Allows next steps to execute even if this one fails
|
||||
run: |
|
||||
# Define parameters for the incremental ping stress test
|
||||
PACKET_SIZE_START=64 # Starting packet size (bytes)
|
||||
PACKET_SIZE_INCREMENT=64 # Increment for packet size
|
||||
PACKET_SIZE_MAX=3500 # Maximum packet size (bytes)
|
||||
PING_DURATION=60 # Duration for each test (seconds)
|
||||
LOG_FILE="network_stress_results_ping.log" # Log file for results
|
||||
|
||||
echo "Starting incremental ping stress test to Google..." | tee $LOG_FILE
|
||||
|
||||
# Loop through increasing packet sizes
|
||||
current_size=$PACKET_SIZE_START
|
||||
while [[ "$current_size" -le "$PACKET_SIZE_MAX" ]]; do
|
||||
echo "Running ping with packet size $current_size bytes" | tee -a $LOG_FILE
|
||||
|
||||
# Run the ping stress test
|
||||
if ping -f -s $current_size google.com -w $PING_DURATION; then
|
||||
echo "✅ Passed: packet size=$current_size bytes" | tee -a $LOG_FILE
|
||||
else
|
||||
echo "❌ Failed: packet size=$current_size bytes" | tee -a $LOG_FILE
|
||||
echo "⚠️ Stopping further increments as failure occurred at packet size=$current_size bytes" | tee -a $LOG_FILE
|
||||
break # Stop further increments if failure occurs
|
||||
fi
|
||||
|
||||
# Increase the packet size for the next iteration
|
||||
current_size=$((current_size + PACKET_SIZE_INCREMENT))
|
||||
|
||||
echo "---------------------------------------------" | tee -a $LOG_FILE
|
||||
done
|
||||
|
||||
echo "Ping stress test completed. Check $LOG_FILE for details." | tee -a $LOG_FILE
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
# # Add Incremental Network Stress Test by Pinging Google here
|
||||
@@ -625,7 +742,66 @@ jobs:
|
||||
# echo "⚠️ Warning: CPU Load is High ($cpu_load%)"
|
||||
# else
|
||||
# echo "✅ CPU Load is Normal ($cpu_load%)"
|
||||
# fi
|
||||
# fi
|
||||
|
||||
|
||||
# Step 2: Install Homebrew (if not already installed)
|
||||
- name: Install Homebrew (if not installed)
|
||||
shell: bash
|
||||
run: |
|
||||
if ! command -v brew &> /dev/null
|
||||
then
|
||||
echo "Homebrew not found, installing..."
|
||||
/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"
|
||||
else
|
||||
echo "Homebrew is already installed"
|
||||
fi
|
||||
|
||||
# Step 3: Install iperf3 using Homebrew
|
||||
- name: Install iperf3
|
||||
shell: bash
|
||||
run: |
|
||||
echo "Installing iperf3..."
|
||||
brew install iperf3
|
||||
|
||||
# Step 4: Run Incremental Iperf3 Network Stress Test
|
||||
- name: Run Incremental Iperf3 Network Stress Test
|
||||
shell: bash
|
||||
continue-on-error: true # Allows next steps to execute even if this one fails
|
||||
run: |
|
||||
# Define parameters for the incremental iperf3 network stress test
|
||||
BANDWIDTH_START=1000000 # Start with 1Mbps (in bits)
|
||||
BANDWIDTH_INCREMENT=1000000 # Increment by 1Mbps (in bits)
|
||||
BANDWIDTH_MAX=10000000 # Maximum bandwidth limit (10Mbps in bits)
|
||||
TEST_DURATION=60 # Test duration (in seconds)
|
||||
SERVER_IP="192.168.1.2" # IP address of the iperf3 server
|
||||
LOG_FILE="iperf3_network_stress_results.log" # Log file for iperf3 results
|
||||
|
||||
|
||||
echo "Starting incremental iperf3 network stress test..." | tee $LOG_FILE
|
||||
|
||||
# Loop through increasing bandwidth values
|
||||
current_bandwidth=$BANDWIDTH_START
|
||||
while [[ "$current_bandwidth" -le "$BANDWIDTH_MAX" ]]; do
|
||||
echo "Running iperf3 with bandwidth $current_bandwidth" | tee -a $LOG_FILE
|
||||
|
||||
# Run the iperf3 network test with the current bandwidth value
|
||||
if iperf3 -c $SERVER_IP -t $TEST_DURATION -b $current_bandwidth -i 1; then
|
||||
echo "✅ Passed: bandwidth=$current_bandwidth" | tee -a $LOG_FILE
|
||||
else
|
||||
echo "❌ Failed: bandwidth=$current_bandwidth" | tee -a $LOG_FILE
|
||||
echo "⚠️ Stopping further increments as failure occurred at bandwidth=$current_bandwidth" | tee -a $LOG_FILE
|
||||
break # Stop further increments if failure occurs
|
||||
fi
|
||||
|
||||
# Increase the bandwidth for the next iteration
|
||||
current_bandwidth=$(($current_bandwidth + $BANDWIDTH_INCREMENT))
|
||||
|
||||
echo "---------------------------------------------" | tee -a $LOG_FILE
|
||||
done
|
||||
|
||||
echo "Iperf3 network stress test completed. Check $LOG_FILE for details." | tee -a $LOG_FILE
|
||||
|
||||
- name: Clean up (optional)
|
||||
shell: bash
|
||||
run: |
|
||||
|
||||
Reference in New Issue
Block a user