From c86353140ab8ee6d1366d27c14f9d503567bcf50 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=C2=B5?= Date: Wed, 7 Aug 2024 13:06:14 +0000 Subject: [PATCH] test_root_register_add_member_senate.py: drop dependence on exact line numbers, change magic constant 1 to netuid This fixed a prior dependence on line numbers, but the solution is still useful as it captures the order of responses rather than words occurring somewhere in the output. --- .../test_root_register_add_member_senate.py | 59 +++++++++++++------ 1 file changed, 41 insertions(+), 18 deletions(-) diff --git a/tests/e2e_tests/subcommands/root/test_root_register_add_member_senate.py b/tests/e2e_tests/subcommands/root/test_root_register_add_member_senate.py index 7d45e5abcb..6bbbd4c22c 100644 --- a/tests/e2e_tests/subcommands/root/test_root_register_add_member_senate.py +++ b/tests/e2e_tests/subcommands/root/test_root_register_add_member_senate.py @@ -13,8 +13,25 @@ from ...utils import setup_wallet +def assert_sequence(lines, sequence): + sequence_ptr = 0 + for line in lines: + lineset = set(line.split()) + seqset = sequence[sequence_ptr] + if lineset.intersection(seqset) == seqset: + sequence_ptr += 1 + if sequence_ptr >= len(sequence): + # all items seen + break + assert sequence_ptr == len( + sequence + ), f"Did not find sequence[{sequence_ptr}] = '{sequence[sequence_ptr]}' in output" + + def test_root_register_add_member_senate(local_chain, capsys): logging.info("Testing test_root_register_add_member_senate") + netuid = 1 + # Register root as Alice - the subnet owner alice_keypair, exec_command, wallet = setup_wallet("//Alice") exec_command(RegisterSubnetworkCommand, ["s", "create"]) @@ -26,7 +43,7 @@ def test_root_register_add_member_senate(local_chain, capsys): "s", "register", "--netuid", - "1", + str(netuid), ], ) @@ -45,9 +62,8 @@ def test_root_register_add_member_senate(local_chain, capsys): exec_command(SetTakeCommand, ["r", "set_take", "--take", "0.8"]) - captured = capsys.readouterr() - # Verify subnet 1 created successfully - assert local_chain.query("SubtensorModule", "NetworksAdded", [1]).serialize() + # Verify subnet created successfully + assert local_chain.query("SubtensorModule", "NetworksAdded", [netuid]).serialize() # Query local chain for senate members members = local_chain.query("SenateMembers", "Members").serialize() assert len(members) == 3, f"Expected 3 senate members, found {len(members)}" @@ -68,12 +84,16 @@ def test_root_register_add_member_senate(local_chain, capsys): captured = capsys.readouterr() # assert output is graph Titling "Senate" with names and addresses - assert "Senate" in captured.out - assert "NAME" in captured.out - assert "ADDRESS" in captured.out - assert "5CiPPseXPECbkjWCa6MnjNokrgYjMqmKndv2rSnekmSK2DjL" in captured.out - assert "5DAAnrj7VHTznn2AWBemMuyBwZWs6FNFjdyVXUeYum3PTXFy" in captured.out - assert "5HGjWAeFDfFCWPsjFQdVV2Msvz2XtMktvgocEZcCj68kUMaw" in captured.out + assert_sequence( + captured.out.split('\n'), + ( + {"Senate"}, + {"NAME", "ADDRESS"}, + {"5CiPPseXPECbkjWCa6MnjNokrgYjMqmKndv2rSnekmSK2DjL"}, + {"5DAAnrj7VHTznn2AWBemMuyBwZWs6FNFjdyVXUeYum3PTXFy"}, + {"5HGjWAeFDfFCWPsjFQdVV2Msvz2XtMktvgocEZcCj68kUMaw"}, + ), + ) exec_command( RootRegisterCommand, @@ -110,11 +130,14 @@ def test_root_register_add_member_senate(local_chain, capsys): captured = capsys.readouterr() # assert output is graph Titling "Senate" with names and addresses - - assert "Senate" in captured.out - assert "NAME" in captured.out - assert "ADDRESS" in captured.out - assert "5CiPPseXPECbkjWCa6MnjNokrgYjMqmKndv2rSnekmSK2DjL" in captured.out - assert "5DAAnrj7VHTznn2AWBemMuyBwZWs6FNFjdyVXUeYum3PTXFy" in captured.out - assert "5GrwvaEF5zXb26Fz9rcQpDWS57CtERHpNehXCPcNoHGKutQY" in captured.out - assert "5HGjWAeFDfFCWPsjFQdVV2Msvz2XtMktvgocEZcCj68kUMaw" in captured.out + assert_sequence( + captured.out.split('\n'), + ( + {"Senate"}, + {"NAME", "ADDRESS"}, + {"5CiPPseXPECbkjWCa6MnjNokrgYjMqmKndv2rSnekmSK2DjL"}, + {"5DAAnrj7VHTznn2AWBemMuyBwZWs6FNFjdyVXUeYum3PTXFy"}, + {"5GrwvaEF5zXb26Fz9rcQpDWS57CtERHpNehXCPcNoHGKutQY"}, + {"5HGjWAeFDfFCWPsjFQdVV2Msvz2XtMktvgocEZcCj68kUMaw"}, + ), + )