# `TMCP036` search_tests returns all tests when unfiltered The user shall be able to call search_tests with no filters and receive all tests in the loaded specifications. :::{dropdown} Is a test for :open: :icon: check-circle-fill :color: primary [`MCP011` Search and filter tests](/requirements/MCP011) ::: :::{dropdown} Automated in :open: :icon: check-circle-fill :color: success {fab}`python` [`test_search_all`](https://github.com/agagniere/speky/blob/master/tests/test_mcp_server.py#L449) ::: :::{dropdown} Source :icon: file-code :color: info __Source file__: [`specs/mcp/test_11.yaml`](https://github.com/agagniere/speky/blob/master/specs/mcp/test_11.yaml) __Loaded from__: [`speky_mcp`](https://github.com/agagniere/speky/blob/master/specs/mcp/mcp.toml) ::: ## Initial state The expected state is the final state of [`TMCP003` Initialize the MCP server](/tests/TMCP003) ## Procedure ### Step 1 The client calls `search_tests` with no arguments ```json { "id": 2, "jsonrpc": "2.0", "method": "tools/call", "params": { "name": "search_tests", "arguments": {} } } ``` ### Step 2 Verify all tests are returned sorted by ID ```json { "id": 2, "jsonrpc": "2.0", "result": { "structuredContent": { "tests": [ {"category": "functional", "id": "T01"}, {"category": "functional", "id": "T02", "short": "Second test"}, {"category": "non-functional", "id": "T03", "short": "Create files"}, {"category": "non-functional", "id": "T04", "short": "Yet another test"} ] } } } ```