checkpoint: massive refactor
This commit is contained in:
@@ -9,32 +9,27 @@ sys.path.append(os.path.abspath(os.path.join(os.path.dirname(__file__), "..")))
|
||||
from api_hook_client import ApiHookClient
|
||||
|
||||
def test_idle_performance_requirements(live_gui):
|
||||
"""
|
||||
"""
|
||||
Requirement: GUI must maintain stable performance on idle.
|
||||
"""
|
||||
client = ApiHookClient()
|
||||
|
||||
# Wait for app to stabilize and render some frames
|
||||
time.sleep(2.0)
|
||||
|
||||
# Get multiple samples to be sure
|
||||
samples = []
|
||||
for _ in range(5):
|
||||
perf_data = client.get_performance()
|
||||
samples.append(perf_data)
|
||||
time.sleep(0.5)
|
||||
|
||||
# Check for valid metrics
|
||||
valid_ft_count = 0
|
||||
for sample in samples:
|
||||
performance = sample.get('performance', {})
|
||||
frame_time = performance.get('last_frame_time_ms', 0.0)
|
||||
|
||||
# We expect a positive frame time if rendering is happening
|
||||
if frame_time > 0:
|
||||
valid_ft_count += 1
|
||||
assert frame_time < 33.3, f"Frame time {frame_time}ms exceeds 30fps threshold"
|
||||
|
||||
print(f"[Test] Valid frame time samples: {valid_ft_count}/5")
|
||||
# In some CI environments without a real display, frame time might remain 0
|
||||
# but we've verified the hook is returning the dictionary.
|
||||
client = ApiHookClient()
|
||||
# Wait for app to stabilize and render some frames
|
||||
time.sleep(2.0)
|
||||
# Get multiple samples to be sure
|
||||
samples = []
|
||||
for _ in range(5):
|
||||
perf_data = client.get_performance()
|
||||
samples.append(perf_data)
|
||||
time.sleep(0.5)
|
||||
# Check for valid metrics
|
||||
valid_ft_count = 0
|
||||
for sample in samples:
|
||||
performance = sample.get('performance', {})
|
||||
frame_time = performance.get('last_frame_time_ms', 0.0)
|
||||
# We expect a positive frame time if rendering is happening
|
||||
if frame_time > 0:
|
||||
valid_ft_count += 1
|
||||
assert frame_time < 33.3, f"Frame time {frame_time}ms exceeds 30fps threshold"
|
||||
print(f"[Test] Valid frame time samples: {valid_ft_count}/5")
|
||||
# In some CI environments without a real display, frame time might remain 0
|
||||
# but we've verified the hook is returning the dictionary.
|
||||
|
||||
Reference in New Issue
Block a user