Skip to content

Commit

Permalink
fix: add test exposing issue with subpaths
Browse files Browse the repository at this point in the history
Any base path matched by a subpath with a different root will also return the nodes
of the subpath (which is obviously erroneous)
  • Loading branch information
Remy Noel committed May 12, 2023
1 parent a3e0a62 commit 1af70bf
Showing 1 changed file with 34 additions and 0 deletions.
34 changes: 34 additions & 0 deletions tests/service/test_standard_interfaces.py
Original file line number Diff line number Diff line change
Expand Up @@ -83,6 +83,40 @@ async def test_introspectable_interface():
bus2.disconnect()


@pytest.mark.asyncio
async def test_introspect_matching_sub_paths():
bus1 = await MessageBus().connect()
bus2 = await MessageBus().connect()

interface = ExampleInterface("test.interface1")

bus1.export("/a/test/path1", interface)
bus1.export("/a/subpath/a/test/path2", interface)

async def introspect_subpath(path, expected_subnodes):
reply = await bus2.call(
Message(
destination=bus1.unique_name,
path=path,
interface="org.freedesktop.DBus.Introspectable",
member="Introspect",
)
)
assert reply.signature == "s"
node = intr.Node.parse(reply.body[0])
assert {n.name for n in node.nodes} == expected_subnodes

await introspect_subpath("/", {"a"})
await introspect_subpath("/a", {"test", "subpath"})
await introspect_subpath("/a/test", {"path1"})
await introspect_subpath("/a/test/path1", set())
await introspect_subpath("/a/subpath/a/test", {"path2"})
await introspect_subpath("/a/subpath/a/test/path2", set())

bus1.disconnect()
bus2.disconnect()


@pytest.mark.asyncio
async def test_peer_interface():
bus1 = await MessageBus().connect()
Expand Down

0 comments on commit 1af70bf

Please sign in to comment.