+++ title = "Test suite: GET /api/quotes/random — 200 with quote, 404 when database is empty" priority = 5 status = "todo" ticket_type = "task" dependencies = ["9b581f", "2ce22e"] +++ Integration tests live in `tests/` and exercise the API binary against a temporary SQLite database. They run with `cargo test` and must not require a running Cloudflare environment. The test harness spawns the API server on a random port and returns the base URL. Write the `GET /api/quotes/random` test suite in `tests/test_random_quote.rs` (or similar). Test cases: 1. 200 with a valid quote object when the database has quotes 2. 404 with `{"error": "..."}` when the database is empty - Use the shared test harness from ticket 9b581f. - Test the 404 case against a fresh empty database (no seeded quotes). - For the 200 case, seed at least one quote first. Use `superpowers:verification-before-completion` before closing. Run in order from the `quotesdb/` directory: ```sh cargo fmt cargo check cargo clippy cargo test ``` `test(quotesdb): add GET /api/quotes/random test suite`