-
-
Notifications
You must be signed in to change notification settings - Fork 2k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Routes Testing (mostly for endpoints) #983
Comments
It is in fact possible to call endpoints programmatically, once you've built the app — the
Try this, for example: import { installFetch } from '@sveltejs/kit/install-fetch';
import { Server } from './.svelte-kit/output/server/index.js';
import { manifest } from './.svelte-kit/output/server/manifest.js';
installFetch(); // we're in Node, so we need to polyfill `fetch` and `Request` etc
const server = new Server(manifest);
const request = new Request('https://example.com/my-endpoint');
const response = await server.respond(request);
console.log(await response.json()); These files aren't exactly documented, and could change without notice. In theory we could promote them to public API so that they have semver guarantees, though to be honest I think it's always going to be better to test it via a server (whether Anyway, I'm going to close this issue because there's no action needed here, but thanks for sharing your experience. |
I found a simpler way to accomplish this using vite-test-utils. I made a little demo app with some explanations: https://github.com/danielres/how-to-test-sveltekit-api-routes |
Context
I'm building an app that use endpoints routes as a full backend. I'm my specific case it have a mongodb database, which cannot be accessed from outside (aka frontend) for obvious security reasons. An important part of backend is testing, so I found a way to test it, and decide to share/discuss how to do it, as others will probably want to do the same.
I saw #19 is open about how to run tests, but it discuss more about unity testing and not how to retrieve routes, so I opened a new issue.
How I made it work
Both jest and uvu have the option use setup and teardown hooks (jest global setup, uvu context), so I decided to spin up the dev server using it. At first I thought about calling the function that does it in svelte/kit, but gave up since it's tightly couple with the cli code.
I ended up with the following configuration (I'm using jest):
.jest/kit.cjs
.jest/setup.cjs
.jest/teardown.cjs
Improvements
I used a child process because the code that spins up the server is currently coupled with the cli, it would look much nicer if there was a function to do it instead.
Discussion
I understand that this is not the best idea, the ideal would be to render routes (ou endpoints) programatically. I look at the code for a way to do this, but vite doesn't seem to support or like it. As the routes are based on the file system, it is a ton of work to do this, so I think it's reasonable to spin up a server instead.
Also, I decided to spin up the dev server (
npm run dev
) because it's much more useful when running tests in watch mode.A glimpse of what the test looks like:
The text was updated successfully, but these errors were encountered: