26 lines
1.1 KiB
TypeScript
26 lines
1.1 KiB
TypeScript
|
// test/index.spec.ts
|
||
|
import { env, createExecutionContext, waitOnExecutionContext, SELF } from 'cloudflare:test';
|
||
|
import { describe, it, expect } from 'vitest';
|
||
|
import worker from '../src/index';
|
||
|
|
||
|
// For now, you'll need to do something like this to get a correctly-typed
|
||
|
// `Request` to pass to `worker.fetch()`.
|
||
|
const IncomingRequest = Request<unknown, IncomingRequestCfProperties>;
|
||
|
|
||
|
describe('Hello World worker', () => {
|
||
|
it('responds with Hello World! (unit style)', async () => {
|
||
|
const request = new IncomingRequest('http://example.com');
|
||
|
// Create an empty context to pass to `worker.fetch()`.
|
||
|
const ctx = createExecutionContext();
|
||
|
const response = await worker.fetch(request, env, ctx);
|
||
|
// Wait for all `Promise`s passed to `ctx.waitUntil()` to settle before running test assertions
|
||
|
await waitOnExecutionContext(ctx);
|
||
|
expect(await response.text()).toMatchInlineSnapshot(`"Hello World!"`);
|
||
|
});
|
||
|
|
||
|
it('responds with Hello World! (integration style)', async () => {
|
||
|
const response = await SELF.fetch('https://example.com');
|
||
|
expect(await response.text()).toMatchInlineSnapshot(`"Hello World!"`);
|
||
|
});
|
||
|
});
|