Compare commits

...

2 Commits

Author SHA1 Message Date
Josiah Baldwin
df25652ba6 Fixed run_commands parsing return from multiple devices incorrectly 2025-01-08 13:42:39 -08:00
Josiah Baldwin
9668e4d507 Added test for using run_command on multiple nodes 2025-01-08 13:38:49 -08:00
2 changed files with 9 additions and 4 deletions

View File

@@ -1463,6 +1463,7 @@ class Session(object):
result.setdefault(node, {})["complete"] = True result.setdefault(node, {})["complete"] = True
if all(_["complete"] for key, _ in result.items()): if all(_["complete"] for key, _ in result.items()):
break break
continue
elif (event["value"].startswith("Run commands")): elif (event["value"].startswith("Run commands")):
continue continue
result[node]["result"].append(event["value"]) result[node]["result"].append(event["value"])

View File

@@ -187,21 +187,22 @@ async def test_mesh_device(env):
assert r[0].description == "New description", "Description either failed to change, or was changed by a user without permission to do so" assert r[0].description == "New description", "Description either failed to change, or was changed by a user without permission to do so"
with env.create_agent(mesh.short_meshid) as agent: with env.create_agent(mesh.short_meshid) as agent,\
env.create_agent(mesh.short_meshid) as agent2:
# Test agent added to device group being propagated correctly # Test agent added to device group being propagated correctly
# Create agent isn't so good at waiting for the agent to show in the sessions. Give it a couple seconds to appear. # Create agent isn't so good at waiting for the agent to show in the sessions. Give it a couple seconds to appear.
for i in range(3): for i in range(3):
try: try:
r = await admin_session.list_devices(timeout=10) r = await admin_session.list_devices(timeout=10)
print("\ninfo list_devices: {}\n".format(r)) print("\ninfo list_devices: {}\n".format(r))
assert len(r) == 1, "Incorrect number of agents connected" assert len(r) == 2, "Incorrect number of agents connected"
except: except:
if i == 2: if i == 2:
raise raise
await asyncio.sleep(1) await asyncio.sleep(1)
else: else:
break break
assert len(await privileged_session.list_devices(timeout=10)) == 1, "Incorrect number of agents connected" assert len(await privileged_session.list_devices(timeout=10)) == 2, "Incorrect number of agents connected"
assert len(await unprivileged_session.list_devices(timeout=10)) == 0, "Unprivileged account has access to agent it should not" assert len(await unprivileged_session.list_devices(timeout=10)) == 0, "Unprivileged account has access to agent it should not"
r = await admin_session.list_devices(details=True, timeout=10) r = await admin_session.list_devices(details=True, timeout=10)
@@ -221,9 +222,12 @@ async def test_mesh_device(env):
assert await admin_session.edit_device(agent.nodeid, consent=meshctrl.constants.ConsentFlags.none, timeout=10), "Failed to edit device info" assert await admin_session.edit_device(agent.nodeid, consent=meshctrl.constants.ConsentFlags.none, timeout=10), "Failed to edit device info"
# Test run_commands # Test run_commands
r = await admin_session.run_command(agent.nodeid, "ls", timeout=10) r = await admin_session.run_command([agent.nodeid, agent2.nodeid], "ls", timeout=10)
print("\ninfo run_command: {}\n".format(r)) print("\ninfo run_command: {}\n".format(r))
assert "meshagent" in r[agent.nodeid]["result"], "ls gave incorrect data" assert "meshagent" in r[agent.nodeid]["result"], "ls gave incorrect data"
assert "meshagent" in r[agent2.nodeid]["result"], "ls gave incorrect data"
assert "Run commands completed." not in r[agent.nodeid]["result"], "Didn't parse run command ending correctly"
assert "Run commands completed." not in r[agent2.nodeid]["result"], "Didn't parse run command ending correctly"
assert "meshagent" in (await privileged_session.run_command(agent.nodeid, "ls", timeout=10))[agent.nodeid]["result"], "ls gave incorrect data" assert "meshagent" in (await privileged_session.run_command(agent.nodeid, "ls", timeout=10))[agent.nodeid]["result"], "ls gave incorrect data"
# Test run commands with ndividual device permissions # Test run commands with ndividual device permissions