Skip to content

Commit

Permalink
[PR #9935/0c312496 backport][3.12] Add benchmark for routing sub_appl…
Browse files Browse the repository at this point in the history
…ications (#9938)

**This is a backport of PR #9935 as merged into master
(0c31249).**

Router should be optimized for handling 2 kind of prefix resources
(sub_apps and static files are handled equally now):
1. sub_apps are placed under non-overlapped top-level single-segment
prefixed. `test_resolve_gitapi_subapps` benchmark test this case
already.
2. sub_apps shares the same prefix segments, e.g.
`/api/manager/plugin/{name}`.

This PR covers the second case.

Co-authored-by: Andrew Svetlov <[email protected]>
  • Loading branch information
patchback[bot] and asvetlov authored Nov 17, 2024
1 parent 4a80add commit 5ca7604
Showing 1 changed file with 34 additions and 0 deletions.
34 changes: 34 additions & 0 deletions tests/test_benchmarks_web_urldispatcher.py
Original file line number Diff line number Diff line change
Expand Up @@ -377,3 +377,37 @@ async def run_url_dispatcher_benchmark() -> None:
@benchmark
def _run() -> None:
loop.run_until_complete(run_url_dispatcher_benchmark())


def test_resolve_prefix_resources_many_prefix_many_plain(
loop: asyncio.AbstractEventLoop,
benchmark: BenchmarkFixture,
) -> None:
"""Resolve prefix resource (sub_app) whene 250 PlainResources registered and there are 250 subapps that shares the same sub_app path prefix."""

async def handler(request: web.Request) -> NoReturn:
assert False

app = web.Application()
for count in range(250):
app.router.add_get(f"/api/server/other/{count}/update", handler)
for count in range(250):
subapp = web.Application()
# sub_apps exists for handling deep enough nested route trees
subapp.router.add_get("/deep/enough/sub/path", handler)
app.add_subapp(f"/api/path/to/plugin/{count}", subapp)
app.freeze()
router = app.router

requests = [
_mock_request(method="GET", path="/api/path/to/plugin/249/deep/enough/sub/path")
for customer in range(250)
]

async def run_url_dispatcher_benchmark() -> None:
for request in requests:
await router.resolve(request)

@benchmark
def _run() -> None:
loop.run_until_complete(run_url_dispatcher_benchmark())

0 comments on commit 5ca7604

Please sign in to comment.