fix(test): poll for push_event to land in test_visual_mma_components
This commit is contained in:
+41
-17
@@ -8,40 +8,53 @@ def test_visual_mma_components(live_gui):
|
||||
client = api_hook_client.ApiHookClient()
|
||||
client.click("btn_reset")
|
||||
time.sleep(2)
|
||||
|
||||
|
||||
assert client.wait_for_server(timeout=15)
|
||||
|
||||
|
||||
# 1. Inject MMA State
|
||||
usage = {
|
||||
'Tier 1': {'input': 100, 'output': 50, 'model': 'gemini-3.1-pro-preview'},
|
||||
'Tier 2': {'input': 200, 'output': 100, 'model': 'gemini-3.1-flash-preview'},
|
||||
'Tier 2': {'input': 200, 'output': 100, 'model': 'gemini-3.1-flash-lite'},
|
||||
'Tier 3': {'input': 300, 'output': 150, 'model': 'gemini-3.1-flash-lite'},
|
||||
'Tier 4': {'input': 400, 'output': 200, 'model': 'gemini-3.1-flash-lite'}
|
||||
}
|
||||
|
||||
|
||||
client.push_event('mma_state_update', {
|
||||
'status': 'running',
|
||||
'tier_usage': usage,
|
||||
'active_tier': 'Tier 2 (Tech Lead)',
|
||||
'tickets': []
|
||||
})
|
||||
|
||||
time.sleep(1)
|
||||
|
||||
|
||||
# Poll until the push_event task is processed. Without this, the
|
||||
# assertion fires BEFORE the active_tier setter runs in the GUI
|
||||
# render loop (race condition surfaced in batched live_gui context).
|
||||
for _ in range(40):
|
||||
status = client.get_mma_status()
|
||||
if status.get('active_tier') == 'Tier 2 (Tech Lead)':
|
||||
break
|
||||
time.sleep(0.25)
|
||||
|
||||
# Verify initial injection
|
||||
status = client.get_mma_status()
|
||||
assert status['mma_status'] == 'running'
|
||||
assert status['active_tier'] == 'Tier 2 (Tech Lead)'
|
||||
|
||||
|
||||
# 2. Verify Tiered Visibility Logic
|
||||
# Set focused tier to Tier 3
|
||||
client.set_value('ui_focus_agent', 'Tier 3 (Worker)')
|
||||
time.sleep(0.5)
|
||||
|
||||
|
||||
# Poll until the focus setter lands
|
||||
for _ in range(40):
|
||||
state = client.get_gui_state()
|
||||
if state.get('ui_focus_agent') == 'Tier 3 (Worker)':
|
||||
break
|
||||
time.sleep(0.25)
|
||||
|
||||
# Verify focused tier
|
||||
state = client.get_gui_state()
|
||||
assert state.get('ui_focus_agent') == 'Tier 3 (Worker)'
|
||||
|
||||
|
||||
# 3. Test Progress Indicators
|
||||
# Increment progress
|
||||
client.push_event('mma_state_update', {
|
||||
@@ -50,13 +63,18 @@ def test_visual_mma_components(live_gui):
|
||||
'active_tier': 'Tier 3 (Worker): task-1',
|
||||
'tickets': [{'id': 'task-1', 'title': 'Task 1', 'status': 'in_progress', 'progress': 0.5}]
|
||||
})
|
||||
|
||||
time.sleep(1)
|
||||
|
||||
|
||||
# Poll until the new active_tier is visible
|
||||
for _ in range(40):
|
||||
status = client.get_mma_status()
|
||||
if status.get('active_tier') == 'Tier 3 (Worker): task-1':
|
||||
break
|
||||
time.sleep(0.25)
|
||||
|
||||
# Verify state updated to Tier 3
|
||||
status = client.get_mma_status()
|
||||
assert status['active_tier'] == 'Tier 3 (Worker): task-1'
|
||||
|
||||
|
||||
# 4. Test Completion
|
||||
client.push_event('mma_state_update', {
|
||||
'status': 'idle',
|
||||
@@ -64,8 +82,14 @@ def test_visual_mma_components(live_gui):
|
||||
'active_tier': None,
|
||||
'tickets': [{'id': 'task-1', 'title': 'Task 1', 'status': 'completed', 'progress': 1.0}]
|
||||
})
|
||||
|
||||
time.sleep(1)
|
||||
|
||||
# Poll until mma_status becomes 'idle'
|
||||
for _ in range(40):
|
||||
status = client.get_mma_status()
|
||||
if status.get('mma_status') == 'idle':
|
||||
break
|
||||
time.sleep(0.25)
|
||||
|
||||
status = client.get_mma_status()
|
||||
assert status['mma_status'] == 'idle'
|
||||
assert status['active_tier'] is None
|
||||
|
||||
Reference in New Issue
Block a user