wrangler 2.20.0 → 3.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +4 -4
- package/bin/wrangler.js +9 -75
- package/package.json +5 -13
- package/templates/__tests__/tsconfig.tsbuildinfo +1 -1
- package/templates/checked-fetch.js +1 -1
- package/templates/first-party-worker-module-facade.ts +2 -2
- package/templates/middleware/common.ts +9 -4
- package/templates/middleware/loader-sw.ts +2 -7
- package/templates/new-worker-scheduled.ts +1 -1
- package/templates/new-worker.ts +1 -1
- package/templates/pages-dev-util.ts +4 -1
- package/templates/pages-shim.ts +0 -3
- package/templates/tsconfig.tsbuildinfo +1 -1
- package/wrangler-dist/cli.d.ts +149 -75
- package/wrangler-dist/cli.js +60062 -64338
- package/import_meta_url.js +0 -3
- package/miniflare-config-stubs/.env.empty +0 -0
- package/miniflare-config-stubs/package.empty.json +0 -1
- package/miniflare-config-stubs/wrangler.empty.toml +0 -0
- package/miniflare-dist/index.mjs +0 -6442
- package/src/__tests__/access.test.ts +0 -25
- package/src/__tests__/api-dev.test.ts +0 -238
- package/src/__tests__/api-devregistry.test.ts +0 -121
- package/src/__tests__/api.test.ts +0 -102
- package/src/__tests__/config-cache-without-cache-dir.test.ts +0 -38
- package/src/__tests__/config-cache.test.ts +0 -42
- package/src/__tests__/configuration.test.ts +0 -4517
- package/src/__tests__/constellation.test.ts +0 -371
- package/src/__tests__/d1/d1.test.ts +0 -82
- package/src/__tests__/d1/execute.test.ts +0 -66
- package/src/__tests__/d1/migrate.test.ts +0 -257
- package/src/__tests__/d1/splitter.test.ts +0 -255
- package/src/__tests__/delete.test.ts +0 -272
- package/src/__tests__/deployments.test.ts +0 -369
- package/src/__tests__/dev.test.tsx +0 -1617
- package/src/__tests__/generate.test.ts +0 -237
- package/src/__tests__/get-host-from-url.test.ts +0 -16
- package/src/__tests__/guess-worker-format.test.ts +0 -120
- package/src/__tests__/helpers/clipboardy-mock.js +0 -4
- package/src/__tests__/helpers/cmd-shim.d.ts +0 -11
- package/src/__tests__/helpers/end-event-loop.ts +0 -6
- package/src/__tests__/helpers/mock-account-id.ts +0 -48
- package/src/__tests__/helpers/mock-auth-domain.ts +0 -20
- package/src/__tests__/helpers/mock-bin.ts +0 -36
- package/src/__tests__/helpers/mock-console.ts +0 -112
- package/src/__tests__/helpers/mock-dialogs.ts +0 -139
- package/src/__tests__/helpers/mock-get-pages-upload-token.ts +0 -25
- package/src/__tests__/helpers/mock-get-zone-from-host.ts +0 -11
- package/src/__tests__/helpers/mock-http-server.ts +0 -46
- package/src/__tests__/helpers/mock-istty.ts +0 -74
- package/src/__tests__/helpers/mock-known-routes.ts +0 -12
- package/src/__tests__/helpers/mock-kv.ts +0 -46
- package/src/__tests__/helpers/mock-oauth-flow.ts +0 -263
- package/src/__tests__/helpers/mock-process.ts +0 -34
- package/src/__tests__/helpers/mock-set-timeout.ts +0 -16
- package/src/__tests__/helpers/mock-stdin.ts +0 -108
- package/src/__tests__/helpers/mock-web-socket.ts +0 -29
- package/src/__tests__/helpers/msw/blob-worker.cjs +0 -19
- package/src/__tests__/helpers/msw/handlers/access.ts +0 -13
- package/src/__tests__/helpers/msw/handlers/deployments.ts +0 -160
- package/src/__tests__/helpers/msw/handlers/namespaces.ts +0 -81
- package/src/__tests__/helpers/msw/handlers/oauth.ts +0 -31
- package/src/__tests__/helpers/msw/handlers/r2.ts +0 -60
- package/src/__tests__/helpers/msw/handlers/script.ts +0 -56
- package/src/__tests__/helpers/msw/handlers/user.ts +0 -52
- package/src/__tests__/helpers/msw/handlers/zones.ts +0 -20
- package/src/__tests__/helpers/msw/index.ts +0 -52
- package/src/__tests__/helpers/msw/read-file-sync.js +0 -61
- package/src/__tests__/helpers/run-in-tmp.ts +0 -38
- package/src/__tests__/helpers/run-wrangler.ts +0 -16
- package/src/__tests__/helpers/string-dynamic-values-matcher.ts +0 -28
- package/src/__tests__/helpers/worker-scripts/child-wrangler.toml +0 -1
- package/src/__tests__/helpers/worker-scripts/hello-world-worker.js +0 -5
- package/src/__tests__/helpers/worker-scripts/hello-world-wrangler.toml +0 -1
- package/src/__tests__/helpers/worker-scripts/parent-worker.js +0 -11
- package/src/__tests__/helpers/worker-scripts/parent-wrangler.toml +0 -5
- package/src/__tests__/helpers/write-worker-source.ts +0 -31
- package/src/__tests__/helpers/write-wrangler-toml.ts +0 -17
- package/src/__tests__/https-options.test.ts +0 -163
- package/src/__tests__/index.test.ts +0 -282
- package/src/__tests__/init.test.ts +0 -3196
- package/src/__tests__/jest.setup.ts +0 -179
- package/src/__tests__/kv.test.ts +0 -1799
- package/src/__tests__/logger.test.ts +0 -207
- package/src/__tests__/logout.test.ts +0 -47
- package/src/__tests__/metrics.test.ts +0 -493
- package/src/__tests__/middleware.scheduled.test.ts +0 -145
- package/src/__tests__/middleware.test.ts +0 -816
- package/src/__tests__/mtls-certificates.test.ts +0 -589
- package/src/__tests__/package-manager.test.ts +0 -353
- package/src/__tests__/pages/deployment-list.test.ts +0 -80
- package/src/__tests__/pages/functions-build.test.ts +0 -528
- package/src/__tests__/pages/pages.test.ts +0 -81
- package/src/__tests__/pages/project-create.test.ts +0 -63
- package/src/__tests__/pages/project-list.test.ts +0 -110
- package/src/__tests__/pages/project-upload.test.ts +0 -500
- package/src/__tests__/pages/publish.test.ts +0 -2864
- package/src/__tests__/pages-deployment-tail.test.ts +0 -957
- package/src/__tests__/parse.test.ts +0 -436
- package/src/__tests__/paths.test.ts +0 -39
- package/src/__tests__/publish.test.ts +0 -8849
- package/src/__tests__/pubsub.test.ts +0 -496
- package/src/__tests__/queues.test.ts +0 -532
- package/src/__tests__/r2.test.ts +0 -374
- package/src/__tests__/route.test.ts +0 -45
- package/src/__tests__/secret.test.ts +0 -693
- package/src/__tests__/tail.test.ts +0 -989
- package/src/__tests__/test-old-node-version.js +0 -31
- package/src/__tests__/traverse-module-graph.test.ts +0 -220
- package/src/__tests__/tsconfig-sanity.ts +0 -12
- package/src/__tests__/tsconfig.json +0 -8
- package/src/__tests__/tsconfig.tsbuildinfo +0 -1
- package/src/__tests__/type-generation.test.ts +0 -234
- package/src/__tests__/user.test.ts +0 -118
- package/src/__tests__/utils-collectKeyValues.test.ts +0 -47
- package/src/__tests__/validate-dev-props.test.ts +0 -56
- package/src/__tests__/version.test.ts +0 -35
- package/src/__tests__/whoami.test.tsx +0 -172
- package/src/__tests__/worker-namespace.test.ts +0 -340
- package/src/abort.d.ts +0 -3
- package/src/api/dev.ts +0 -321
- package/src/api/index.ts +0 -11
- package/src/api/mtls-certificate.ts +0 -148
- package/src/api/pages/create-worker-bundle-contents.ts +0 -77
- package/src/api/pages/index.ts +0 -5
- package/src/api/pages/publish.tsx +0 -371
- package/src/bundle-reporter.ts +0 -68
- package/src/bundle.ts +0 -929
- package/src/cfetch/index.ts +0 -158
- package/src/cfetch/internal.ts +0 -258
- package/src/cli.ts +0 -28
- package/src/config/README.md +0 -107
- package/src/config/config.ts +0 -282
- package/src/config/diagnostics.ts +0 -80
- package/src/config/environment.ts +0 -625
- package/src/config/index.ts +0 -403
- package/src/config/validation-helpers.ts +0 -597
- package/src/config/validation.ts +0 -2369
- package/src/config-cache.ts +0 -85
- package/src/constellation/createProject.tsx +0 -51
- package/src/constellation/deleteProject.ts +0 -51
- package/src/constellation/deleteProjectModel.ts +0 -68
- package/src/constellation/index.ts +0 -75
- package/src/constellation/listCatalog.tsx +0 -35
- package/src/constellation/listModel.tsx +0 -41
- package/src/constellation/listProject.tsx +0 -28
- package/src/constellation/listRuntime.tsx +0 -28
- package/src/constellation/options.ts +0 -17
- package/src/constellation/types.ts +0 -17
- package/src/constellation/uploadModel.tsx +0 -64
- package/src/constellation/utils.ts +0 -90
- package/src/create-worker-preview.ts +0 -293
- package/src/create-worker-upload-form.ts +0 -363
- package/src/d1/backups.tsx +0 -219
- package/src/d1/constants.ts +0 -2
- package/src/d1/create.tsx +0 -70
- package/src/d1/delete.ts +0 -53
- package/src/d1/execute.tsx +0 -357
- package/src/d1/formatTimeAgo.ts +0 -14
- package/src/d1/index.ts +0 -100
- package/src/d1/list.tsx +0 -62
- package/src/d1/migrations/apply.tsx +0 -212
- package/src/d1/migrations/create.tsx +0 -79
- package/src/d1/migrations/helpers.ts +0 -169
- package/src/d1/migrations/index.ts +0 -3
- package/src/d1/migrations/list.tsx +0 -95
- package/src/d1/migrations/options.ts +0 -23
- package/src/d1/options.ts +0 -22
- package/src/d1/splitter.ts +0 -161
- package/src/d1/types.ts +0 -25
- package/src/d1/utils.ts +0 -49
- package/src/delete.ts +0 -100
- package/src/deployments.ts +0 -368
- package/src/deprecated/index.ts +0 -144
- package/src/dev/dev-vars.ts +0 -39
- package/src/dev/dev.tsx +0 -605
- package/src/dev/get-local-persistence-path.ts +0 -31
- package/src/dev/local.tsx +0 -952
- package/src/dev/remote.tsx +0 -635
- package/src/dev/start-server.ts +0 -545
- package/src/dev/use-esbuild.ts +0 -215
- package/src/dev/validate-dev-props.ts +0 -40
- package/src/dev-registry.ts +0 -202
- package/src/dev.tsx +0 -934
- package/src/dialogs.ts +0 -136
- package/src/dispatch-namespace.ts +0 -211
- package/src/docs/helpers.ts +0 -50
- package/src/docs/index.ts +0 -54
- package/src/durable.ts +0 -102
- package/src/entry.ts +0 -344
- package/src/environment-variables/factory.ts +0 -89
- package/src/environment-variables/misc-variables.ts +0 -30
- package/src/errors.ts +0 -11
- package/src/generate/index.ts +0 -298
- package/src/git-client.ts +0 -135
- package/src/global-wrangler-config-path.ts +0 -26
- package/src/https-options.ts +0 -127
- package/src/index.ts +0 -768
- package/src/init.ts +0 -1037
- package/src/inspect.ts +0 -883
- package/src/intl-polyfill.d.ts +0 -139
- package/src/is-ci.ts +0 -14
- package/src/is-interactive.ts +0 -16
- package/src/jest.d.ts +0 -4
- package/src/kv/helpers.ts +0 -433
- package/src/kv/index.ts +0 -594
- package/src/logger.ts +0 -123
- package/src/metrics/index.ts +0 -5
- package/src/metrics/metrics-config.ts +0 -239
- package/src/metrics/metrics-dispatcher.ts +0 -96
- package/src/metrics/metrics-usage-headers.ts +0 -24
- package/src/metrics/send-event.ts +0 -99
- package/src/miniflare-cli/README.md +0 -30
- package/src/miniflare-cli/assets.ts +0 -251
- package/src/miniflare-cli/index.ts +0 -210
- package/src/miniflare-cli/request-context.ts +0 -40
- package/src/miniflare-cli/tsconfig.json +0 -9
- package/src/miniflare-cli/tsconfig.tsbuildinfo +0 -1
- package/src/miniflare-cli/types.ts +0 -11
- package/src/module-collection.ts +0 -333
- package/src/mtls-certificate/cli.ts +0 -155
- package/src/open-in-browser.ts +0 -17
- package/src/package-manager.ts +0 -219
- package/src/pages/build.ts +0 -423
- package/src/pages/buildFunctions.ts +0 -140
- package/src/pages/constants.ts +0 -18
- package/src/pages/deployment-tails.ts +0 -281
- package/src/pages/deployments.tsx +0 -84
- package/src/pages/dev.ts +0 -734
- package/src/pages/errors.ts +0 -67
- package/src/pages/functions/buildPlugin.ts +0 -114
- package/src/pages/functions/buildWorker.ts +0 -350
- package/src/pages/functions/filepath-routing.test.ts +0 -234
- package/src/pages/functions/filepath-routing.ts +0 -189
- package/src/pages/functions/identifiers.ts +0 -78
- package/src/pages/functions/routes-consolidation.test.ts +0 -250
- package/src/pages/functions/routes-consolidation.ts +0 -73
- package/src/pages/functions/routes-transformation.test.ts +0 -282
- package/src/pages/functions/routes-transformation.ts +0 -115
- package/src/pages/functions/routes-validation.test.ts +0 -403
- package/src/pages/functions/routes-validation.ts +0 -202
- package/src/pages/functions/routes.ts +0 -151
- package/src/pages/functions/tsconfig.json +0 -8
- package/src/pages/functions/tsconfig.tsbuildinfo +0 -1
- package/src/pages/functions.ts +0 -86
- package/src/pages/hash.ts +0 -13
- package/src/pages/index.ts +0 -102
- package/src/pages/projects.tsx +0 -159
- package/src/pages/prompt-select-project.tsx +0 -31
- package/src/pages/publish.tsx +0 -267
- package/src/pages/types.ts +0 -46
- package/src/pages/upload.tsx +0 -469
- package/src/pages/utils.ts +0 -23
- package/src/parse.ts +0 -308
- package/src/paths.ts +0 -71
- package/src/proxy.ts +0 -694
- package/src/publish/index.ts +0 -274
- package/src/publish/publish.ts +0 -1065
- package/src/pubsub/index.ts +0 -286
- package/src/pubsub/pubsub-commands.ts +0 -623
- package/src/queues/cli/commands/consumer/add.ts +0 -71
- package/src/queues/cli/commands/consumer/index.ts +0 -19
- package/src/queues/cli/commands/consumer/remove.ts +0 -31
- package/src/queues/cli/commands/create.ts +0 -25
- package/src/queues/cli/commands/delete.ts +0 -26
- package/src/queues/cli/commands/index.ts +0 -35
- package/src/queues/cli/commands/list.ts +0 -25
- package/src/queues/client.ts +0 -136
- package/src/queues/utils.ts +0 -18
- package/src/r2/constants.ts +0 -4
- package/src/r2/helpers.ts +0 -132
- package/src/r2/index.ts +0 -289
- package/src/routes.ts +0 -140
- package/src/secret/index.ts +0 -377
- package/src/selfsigned.d.ts +0 -29
- package/src/sites.ts +0 -484
- package/src/tail/createTail.ts +0 -415
- package/src/tail/filters.ts +0 -277
- package/src/tail/index.ts +0 -211
- package/src/tail/printing.ts +0 -132
- package/src/traverse-module-graph.ts +0 -54
- package/src/tsconfig-sanity.ts +0 -16
- package/src/type-generation.ts +0 -181
- package/src/update-check.ts +0 -19
- package/src/user/access.ts +0 -68
- package/src/user/auth-variables.ts +0 -113
- package/src/user/choose-account.tsx +0 -39
- package/src/user/generate-auth-url.ts +0 -33
- package/src/user/generate-random-state.ts +0 -16
- package/src/user/index.ts +0 -2
- package/src/user/user.ts +0 -1234
- package/src/utils/collectKeyValues.ts +0 -14
- package/src/utils/render.ts +0 -93
- package/src/whoami.ts +0 -135
- package/src/worker.ts +0 -279
- package/src/yargs-types.ts +0 -37
- package/src/zones.ts +0 -191
|
@@ -1,139 +0,0 @@
|
|
|
1
|
-
import prompts from "prompts";
|
|
2
|
-
|
|
3
|
-
/**
|
|
4
|
-
* The expected values for a confirmation request.
|
|
5
|
-
*/
|
|
6
|
-
export interface ConfirmExpectation {
|
|
7
|
-
/** The text expected to be seen in the confirmation dialog. */
|
|
8
|
-
text: string;
|
|
9
|
-
|
|
10
|
-
options?: { defaultValue: boolean };
|
|
11
|
-
/** The mock response send back from the confirmation dialog. */
|
|
12
|
-
result: boolean;
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
/**
|
|
16
|
-
* Mock the implementation of `confirm()` that will respond with configured results
|
|
17
|
-
* for configured confirmation text messages.
|
|
18
|
-
*
|
|
19
|
-
* If there is a call to `confirm()` that does not match any of the expectations
|
|
20
|
-
* then an error is thrown.
|
|
21
|
-
*/
|
|
22
|
-
export function mockConfirm(...expectations: ConfirmExpectation[]) {
|
|
23
|
-
for (const expectation of expectations) {
|
|
24
|
-
(prompts as unknown as jest.Mock).mockImplementationOnce(
|
|
25
|
-
({ type, name, message, initial }) => {
|
|
26
|
-
expect({ type, name, message }).toStrictEqual({
|
|
27
|
-
type: "confirm",
|
|
28
|
-
name: "value",
|
|
29
|
-
message: expectation.text,
|
|
30
|
-
});
|
|
31
|
-
if (expectation.options) {
|
|
32
|
-
expect(initial).toStrictEqual(expectation.options?.defaultValue);
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
return Promise.resolve({ value: expectation.result });
|
|
36
|
-
}
|
|
37
|
-
);
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
/**
|
|
42
|
-
* The expected values for a prompt request.
|
|
43
|
-
*/
|
|
44
|
-
export interface PromptExpectation {
|
|
45
|
-
/** The text expected to be seen in the prompt dialog. */
|
|
46
|
-
text: string;
|
|
47
|
-
/** The type of the prompt. */
|
|
48
|
-
options?: {
|
|
49
|
-
defaultValue?: string;
|
|
50
|
-
isSecret?: boolean;
|
|
51
|
-
};
|
|
52
|
-
/** The mock response send back from the prompt dialog. */
|
|
53
|
-
result: string;
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
/**
|
|
57
|
-
* Mock the implementation of `prompt()` that will respond with configured results
|
|
58
|
-
* for configured prompt text messages.
|
|
59
|
-
*
|
|
60
|
-
* If there is a call to `prompt()` that does not match any of the expectations
|
|
61
|
-
* then an error is thrown.
|
|
62
|
-
*/
|
|
63
|
-
export function mockPrompt(...expectations: PromptExpectation[]) {
|
|
64
|
-
for (const expectation of expectations) {
|
|
65
|
-
(prompts as unknown as jest.Mock).mockImplementationOnce(
|
|
66
|
-
({ type, name, message, initial, style }) => {
|
|
67
|
-
expect({ type, name, message }).toStrictEqual({
|
|
68
|
-
type: "text",
|
|
69
|
-
name: "value",
|
|
70
|
-
message: expectation.text,
|
|
71
|
-
});
|
|
72
|
-
if (expectation.options) {
|
|
73
|
-
expect(initial).toStrictEqual(expectation.options?.defaultValue);
|
|
74
|
-
expect(style).toStrictEqual(
|
|
75
|
-
expectation.options?.isSecret ? "password" : "default"
|
|
76
|
-
);
|
|
77
|
-
}
|
|
78
|
-
return Promise.resolve({ value: expectation.result });
|
|
79
|
-
}
|
|
80
|
-
);
|
|
81
|
-
}
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
interface SelectOptions<Values> {
|
|
85
|
-
choices: SelectOption<Values>[];
|
|
86
|
-
defaultOption?: number;
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
interface SelectOption<Values> {
|
|
90
|
-
title: string;
|
|
91
|
-
description?: string;
|
|
92
|
-
value: Values;
|
|
93
|
-
}
|
|
94
|
-
/**
|
|
95
|
-
* The expected values for a select request.
|
|
96
|
-
*/
|
|
97
|
-
export interface SelectExpectation<Values> {
|
|
98
|
-
/** The text expected to be seen in the select dialog. */
|
|
99
|
-
text: string;
|
|
100
|
-
|
|
101
|
-
options?: SelectOptions<Values>;
|
|
102
|
-
/** The mock response send back from the select dialog. */
|
|
103
|
-
result: string;
|
|
104
|
-
}
|
|
105
|
-
|
|
106
|
-
/**
|
|
107
|
-
* Mock the implementation of `select()` that will respond with configured results
|
|
108
|
-
* for configured select text messages.
|
|
109
|
-
*
|
|
110
|
-
* If there is a call to `select()` that does not match any of the expectations
|
|
111
|
-
* then an error is thrown.
|
|
112
|
-
*/
|
|
113
|
-
export function mockSelect<Values>(
|
|
114
|
-
...expectations: SelectExpectation<Values>[]
|
|
115
|
-
) {
|
|
116
|
-
for (const expectation of expectations) {
|
|
117
|
-
(prompts as unknown as jest.Mock).mockImplementationOnce(
|
|
118
|
-
({ type, name, message, choices, initial }) => {
|
|
119
|
-
expect({ type, name, message }).toStrictEqual({
|
|
120
|
-
type: "select",
|
|
121
|
-
name: "value",
|
|
122
|
-
message: expectation.text,
|
|
123
|
-
});
|
|
124
|
-
if (expectation.options) {
|
|
125
|
-
expect(choices).toStrictEqual(expectation.options?.choices);
|
|
126
|
-
expect(initial).toStrictEqual(expectation.options?.defaultOption);
|
|
127
|
-
}
|
|
128
|
-
return Promise.resolve({ value: expectation.result });
|
|
129
|
-
}
|
|
130
|
-
);
|
|
131
|
-
}
|
|
132
|
-
}
|
|
133
|
-
|
|
134
|
-
export function clearDialogs() {
|
|
135
|
-
// No dialog mocks should be left after each test, and so calling the dialog methods should throw
|
|
136
|
-
expect(() => prompts({ type: "select", name: "unknown" })).toThrow(
|
|
137
|
-
"Unexpected call to "
|
|
138
|
-
);
|
|
139
|
-
}
|
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
import { rest } from "msw";
|
|
2
|
-
import { msw } from "./msw";
|
|
3
|
-
|
|
4
|
-
/**
|
|
5
|
-
* Mocks the `/accounts/:accountId/pages/projects/:projectName/upload-token` GET request
|
|
6
|
-
*/
|
|
7
|
-
export function mockGetUploadTokenRequest(
|
|
8
|
-
jwt: string,
|
|
9
|
-
accountId: string,
|
|
10
|
-
projectName: string
|
|
11
|
-
) {
|
|
12
|
-
msw.use(
|
|
13
|
-
rest.get(
|
|
14
|
-
`*/accounts/:accountId/pages/projects/${projectName}/upload-token`,
|
|
15
|
-
(req, res, ctx) => {
|
|
16
|
-
expect(req.params.accountId).toEqual(accountId);
|
|
17
|
-
|
|
18
|
-
return res(
|
|
19
|
-
ctx.status(200),
|
|
20
|
-
ctx.json({ success: true, errors: [], messages: [], result: { jwt } })
|
|
21
|
-
);
|
|
22
|
-
}
|
|
23
|
-
)
|
|
24
|
-
);
|
|
25
|
-
}
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import { rest } from "msw";
|
|
2
|
-
import { msw, createFetchResult } from "./msw";
|
|
3
|
-
|
|
4
|
-
export function mockGetZoneFromHostRequest(host: string, zone?: string) {
|
|
5
|
-
msw.use(
|
|
6
|
-
rest.get("*/zones", (req, res, ctx) => {
|
|
7
|
-
expect(req.url.searchParams.get("name")).toEqual(host);
|
|
8
|
-
return res(ctx.json(createFetchResult(zone ? [{ id: zone }] : [])));
|
|
9
|
-
})
|
|
10
|
-
);
|
|
11
|
-
}
|
|
@@ -1,46 +0,0 @@
|
|
|
1
|
-
import http from "node:http";
|
|
2
|
-
import type { Request } from "undici";
|
|
3
|
-
|
|
4
|
-
/**
|
|
5
|
-
* Setup a mock HTTP server that can be triggered directly without interacting with any network.
|
|
6
|
-
*
|
|
7
|
-
* @returns a `fetch`-like function that will trigger the mock server to handle the request.
|
|
8
|
-
*/
|
|
9
|
-
export function mockHttpServer() {
|
|
10
|
-
let listener: http.RequestListener;
|
|
11
|
-
|
|
12
|
-
beforeEach(() => {
|
|
13
|
-
jest
|
|
14
|
-
.spyOn(http, "createServer")
|
|
15
|
-
.mockImplementation((...args: unknown[]) => {
|
|
16
|
-
listener = args.pop() as http.RequestListener;
|
|
17
|
-
return {
|
|
18
|
-
listen: jest.fn(),
|
|
19
|
-
close(callback?: (err?: Error) => void) {
|
|
20
|
-
callback?.();
|
|
21
|
-
return this;
|
|
22
|
-
},
|
|
23
|
-
} as unknown as http.Server;
|
|
24
|
-
});
|
|
25
|
-
});
|
|
26
|
-
|
|
27
|
-
return async (req: Request) => {
|
|
28
|
-
const resp = new http.ServerResponse(
|
|
29
|
-
// If you squint you can just about see that an `IncomingMessages` is like a `Request`!
|
|
30
|
-
req as unknown as http.IncomingMessage
|
|
31
|
-
);
|
|
32
|
-
|
|
33
|
-
// The listener will attache a callback to the response by calling `resp.end(callback)`.
|
|
34
|
-
// We want to capture that so that we can trigger it after the listener has completed its work.
|
|
35
|
-
const endSpy = jest.spyOn(resp, "end");
|
|
36
|
-
|
|
37
|
-
// The `await` here is important to allow the listener to complete its async work before we end the response.
|
|
38
|
-
await listener(req as unknown as http.IncomingMessage, resp);
|
|
39
|
-
|
|
40
|
-
// Now trigger the end callback.
|
|
41
|
-
const endCallback = endSpy.mock.calls[0].pop();
|
|
42
|
-
endCallback?.();
|
|
43
|
-
|
|
44
|
-
return resp;
|
|
45
|
-
};
|
|
46
|
-
}
|
|
@@ -1,74 +0,0 @@
|
|
|
1
|
-
const ORIGINAL_STDOUT = process.stdout;
|
|
2
|
-
const ORIGINAL_STDIN = process.stdin;
|
|
3
|
-
|
|
4
|
-
/**
|
|
5
|
-
* Mock `process.stdout.isTTY`
|
|
6
|
-
*/
|
|
7
|
-
export function useMockIsTTY() {
|
|
8
|
-
/**
|
|
9
|
-
* Explicitly set `process.stdout.isTTY` to a given value (or to a getter function).
|
|
10
|
-
*/
|
|
11
|
-
const setIsTTY = (
|
|
12
|
-
isTTY:
|
|
13
|
-
| boolean
|
|
14
|
-
| { stdin: boolean | (() => boolean); stdout: boolean | (() => boolean) }
|
|
15
|
-
) => {
|
|
16
|
-
mockStdStream("stdout", ORIGINAL_STDOUT, isTTY);
|
|
17
|
-
mockStdStream("stdin", ORIGINAL_STDIN, isTTY);
|
|
18
|
-
};
|
|
19
|
-
|
|
20
|
-
beforeEach(() => {
|
|
21
|
-
Object.defineProperty(process, "stdout", { value: ORIGINAL_STDOUT });
|
|
22
|
-
Object.defineProperty(process, "stdin", { value: ORIGINAL_STDIN });
|
|
23
|
-
});
|
|
24
|
-
|
|
25
|
-
afterEach(() => {
|
|
26
|
-
Object.defineProperty(process, "stdout", { value: ORIGINAL_STDOUT });
|
|
27
|
-
Object.defineProperty(process, "stdin", { value: ORIGINAL_STDIN });
|
|
28
|
-
});
|
|
29
|
-
|
|
30
|
-
return { setIsTTY };
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
/**
|
|
34
|
-
* Create a mock version of the specified stream which overrides `isTTY`
|
|
35
|
-
* with the given mock responses.
|
|
36
|
-
*
|
|
37
|
-
* @param streamName the property name on `process` for the stream to be mocked.
|
|
38
|
-
* @param originalStream the original stream object from the `process` object to be overridden.
|
|
39
|
-
* @param isTTY the mock behaviour for the `isTTY` property:
|
|
40
|
-
* - boolean or `{ [streamName]: boolean } - use this value for isTTY;
|
|
41
|
-
* - { [streamName]: () => boolean } - use this function as a getter for isTTY.
|
|
42
|
-
*/
|
|
43
|
-
function mockStdStream<T extends object>(
|
|
44
|
-
streamName: "stdout" | "stdin",
|
|
45
|
-
originalStream: T,
|
|
46
|
-
isTTY:
|
|
47
|
-
| boolean
|
|
48
|
-
| { stdin: boolean | (() => boolean); stdout: boolean | (() => boolean) }
|
|
49
|
-
) {
|
|
50
|
-
Object.defineProperty(process, streamName, {
|
|
51
|
-
value: createStdProxy(
|
|
52
|
-
originalStream,
|
|
53
|
-
typeof isTTY === "boolean" ? isTTY : isTTY[streamName]
|
|
54
|
-
),
|
|
55
|
-
});
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
/**
|
|
59
|
-
* Create a proxy wrapper around the given `stream` object that overrides the `isTTY` property.
|
|
60
|
-
*/
|
|
61
|
-
function createStdProxy<T extends object>(
|
|
62
|
-
stream: T,
|
|
63
|
-
isTTY: boolean | (() => boolean)
|
|
64
|
-
): T {
|
|
65
|
-
return new Proxy(stream, {
|
|
66
|
-
get(target, prop) {
|
|
67
|
-
return prop === "isTTY"
|
|
68
|
-
? typeof isTTY === "boolean"
|
|
69
|
-
? isTTY
|
|
70
|
-
: isTTY()
|
|
71
|
-
: target[prop as keyof typeof target];
|
|
72
|
-
},
|
|
73
|
-
});
|
|
74
|
-
}
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import { rest } from "msw";
|
|
2
|
-
import { createFetchResult, msw } from "./msw";
|
|
3
|
-
|
|
4
|
-
export function mockCollectKnownRoutesRequest(
|
|
5
|
-
routes: { pattern: string; script: string }[]
|
|
6
|
-
) {
|
|
7
|
-
msw.use(
|
|
8
|
-
rest.get(`*/zones/:zoneId/workers/routes`, (_, res, ctx) =>
|
|
9
|
-
res.once(ctx.json(createFetchResult(routes)))
|
|
10
|
-
)
|
|
11
|
-
);
|
|
12
|
-
}
|
|
@@ -1,46 +0,0 @@
|
|
|
1
|
-
import { rest } from "msw";
|
|
2
|
-
import { createFetchResult, msw } from "./msw";
|
|
3
|
-
import type { NamespaceKeyInfo } from "../../kv/helpers";
|
|
4
|
-
|
|
5
|
-
export function mockKeyListRequest(
|
|
6
|
-
expectedNamespaceId: string,
|
|
7
|
-
expectedKeys: NamespaceKeyInfo[],
|
|
8
|
-
keysPerRequest = 1000,
|
|
9
|
-
blankCursorValue: "" | undefined | null = undefined
|
|
10
|
-
) {
|
|
11
|
-
const requests = { count: 0 };
|
|
12
|
-
// See https://api.cloudflare.com/#workers-kv-namespace-list-a-namespace-s-keys
|
|
13
|
-
msw.use(
|
|
14
|
-
rest.get(
|
|
15
|
-
"*/accounts/:accountId/storage/kv/namespaces/:namespaceId/keys",
|
|
16
|
-
(req, res, ctx) => {
|
|
17
|
-
requests.count++;
|
|
18
|
-
expect(req.params.accountId).toEqual("some-account-id");
|
|
19
|
-
expect(req.params.namespaceId).toEqual(expectedNamespaceId);
|
|
20
|
-
let response: undefined | NamespaceKeyInfo[];
|
|
21
|
-
if (expectedKeys.length <= keysPerRequest) {
|
|
22
|
-
response = expectedKeys;
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
const start = parseInt(req.url.searchParams.get("cursor") ?? "0") || 0;
|
|
26
|
-
const end = start + keysPerRequest;
|
|
27
|
-
const cursor = end < expectedKeys.length ? end : blankCursorValue;
|
|
28
|
-
|
|
29
|
-
return res(
|
|
30
|
-
ctx.json(
|
|
31
|
-
createFetchResult(
|
|
32
|
-
response ? response : expectedKeys.slice(start, end),
|
|
33
|
-
true,
|
|
34
|
-
[],
|
|
35
|
-
[],
|
|
36
|
-
{
|
|
37
|
-
cursor,
|
|
38
|
-
}
|
|
39
|
-
)
|
|
40
|
-
)
|
|
41
|
-
);
|
|
42
|
-
}
|
|
43
|
-
)
|
|
44
|
-
);
|
|
45
|
-
return requests;
|
|
46
|
-
}
|
|
@@ -1,263 +0,0 @@
|
|
|
1
|
-
import { rest } from "msw";
|
|
2
|
-
import { Request } from "undici";
|
|
3
|
-
import openInBrowser from "../../open-in-browser";
|
|
4
|
-
import { mockHttpServer } from "./mock-http-server";
|
|
5
|
-
import { createFetchResult, msw } from "./msw";
|
|
6
|
-
|
|
7
|
-
export function mockGetMemberships(
|
|
8
|
-
accounts: { id: string; account: { id: string; name: string } }[]
|
|
9
|
-
) {
|
|
10
|
-
msw.use(
|
|
11
|
-
rest.get("*/memberships", (_, res, ctx) => {
|
|
12
|
-
return res.once(ctx.json(createFetchResult(accounts)));
|
|
13
|
-
})
|
|
14
|
-
);
|
|
15
|
-
}
|
|
16
|
-
export function mockGetMembershipsFail() {
|
|
17
|
-
msw.use(
|
|
18
|
-
rest.get("*/memberships", (_, res, ctx) => {
|
|
19
|
-
return res.once(ctx.json(createFetchResult([], false)));
|
|
20
|
-
})
|
|
21
|
-
);
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
/**
|
|
25
|
-
* Functions to help with mocking various parts of the OAuth Flow
|
|
26
|
-
*/
|
|
27
|
-
export const mockOAuthFlow = () => {
|
|
28
|
-
// the response to send when wrangler wants an oauth grant
|
|
29
|
-
let oauthGrantResponse: GrantResponseOptions | "timeout" = {};
|
|
30
|
-
const fetchHttp = mockHttpServer();
|
|
31
|
-
|
|
32
|
-
/**
|
|
33
|
-
* Mock out the callback from a browser to our HttpServer.
|
|
34
|
-
*
|
|
35
|
-
* This function will override `openInBrowser()` so that instead of opening a browser window
|
|
36
|
-
* at the OAuth URL, it will automatically trigger the callback URL on the mock HttpServer that
|
|
37
|
-
* we have created as part of the call to `mockOAuthFlow()`.
|
|
38
|
-
*/
|
|
39
|
-
const mockOAuthServerCallback = (
|
|
40
|
-
respondWith?: "timeout" | "success" | "failure" | GrantResponseOptions
|
|
41
|
-
) => {
|
|
42
|
-
(
|
|
43
|
-
openInBrowser as jest.MockedFunction<typeof openInBrowser>
|
|
44
|
-
).mockImplementation(async (url: string) => {
|
|
45
|
-
if (respondWith) mockGrantAuthorization({ respondWith });
|
|
46
|
-
// We don't support the grant response timing out.
|
|
47
|
-
if (oauthGrantResponse === "timeout") {
|
|
48
|
-
throw "unimplemented";
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
// Create a fake callback request that would be created by the OAuth server
|
|
52
|
-
const { searchParams } = new URL(url);
|
|
53
|
-
const queryParams = toQueryParams(oauthGrantResponse, searchParams);
|
|
54
|
-
const request = new Request(
|
|
55
|
-
`${searchParams.get("redirect_uri")}?${queryParams}`
|
|
56
|
-
);
|
|
57
|
-
|
|
58
|
-
// Trigger the mock HttpServer to handle this fake request to continue the OAuth flow.
|
|
59
|
-
fetchHttp(request).catch((e) => {
|
|
60
|
-
throw new Error(
|
|
61
|
-
"Failed to send OAuth Grant to wrangler, maybe the server was closed?",
|
|
62
|
-
e as Error
|
|
63
|
-
);
|
|
64
|
-
});
|
|
65
|
-
});
|
|
66
|
-
};
|
|
67
|
-
|
|
68
|
-
// Handled in `mockOAuthServerCallback`
|
|
69
|
-
const mockGrantAuthorization = ({
|
|
70
|
-
respondWith,
|
|
71
|
-
}: {
|
|
72
|
-
respondWith: "timeout" | "success" | "failure" | GrantResponseOptions;
|
|
73
|
-
}) => {
|
|
74
|
-
if (respondWith === "failure") {
|
|
75
|
-
oauthGrantResponse = {
|
|
76
|
-
error: "access_denied",
|
|
77
|
-
};
|
|
78
|
-
} else if (respondWith === "success") {
|
|
79
|
-
oauthGrantResponse = {
|
|
80
|
-
code: "test-oauth-code",
|
|
81
|
-
};
|
|
82
|
-
} else if (respondWith === "timeout") {
|
|
83
|
-
oauthGrantResponse = "timeout";
|
|
84
|
-
} else {
|
|
85
|
-
oauthGrantResponse = respondWith;
|
|
86
|
-
}
|
|
87
|
-
};
|
|
88
|
-
|
|
89
|
-
const mockGrantAccessToken = ({
|
|
90
|
-
respondWith,
|
|
91
|
-
domain = "dash.cloudflare.com",
|
|
92
|
-
}: {
|
|
93
|
-
respondWith: MockTokenResponse;
|
|
94
|
-
domain?: string;
|
|
95
|
-
}) => {
|
|
96
|
-
const outcome = {
|
|
97
|
-
actual: "https://example.org",
|
|
98
|
-
expected: `https://${domain}/oauth2/token`,
|
|
99
|
-
};
|
|
100
|
-
msw.use(
|
|
101
|
-
rest.post(outcome.expected, async (req, res, ctx) => {
|
|
102
|
-
// TODO: update Miniflare typings to match full undici Request
|
|
103
|
-
outcome.actual = req.url.toString();
|
|
104
|
-
return res.once(ctx.json(makeTokenResponse(respondWith)));
|
|
105
|
-
})
|
|
106
|
-
);
|
|
107
|
-
|
|
108
|
-
return outcome;
|
|
109
|
-
};
|
|
110
|
-
|
|
111
|
-
function mockDomainUsesAccess({
|
|
112
|
-
usesAccess,
|
|
113
|
-
domain = "dash.cloudflare.com",
|
|
114
|
-
}: {
|
|
115
|
-
usesAccess: boolean;
|
|
116
|
-
domain?: string;
|
|
117
|
-
}) {
|
|
118
|
-
// If the domain relies upon Cloudflare Access, then a request to the domain
|
|
119
|
-
// will result in a redirect to the `cloudflareaccess.com` domain.
|
|
120
|
-
msw.use(
|
|
121
|
-
rest.get(`https://${domain}/`, (_, res, ctx) => {
|
|
122
|
-
let status = 200;
|
|
123
|
-
let headers: Record<string, string> = {
|
|
124
|
-
"Content-Type": "application/json",
|
|
125
|
-
};
|
|
126
|
-
if (usesAccess) {
|
|
127
|
-
status = 302;
|
|
128
|
-
headers = { location: "cloudflareaccess.com" };
|
|
129
|
-
}
|
|
130
|
-
return res.once(ctx.status(status), ctx.set(headers));
|
|
131
|
-
})
|
|
132
|
-
);
|
|
133
|
-
}
|
|
134
|
-
|
|
135
|
-
return {
|
|
136
|
-
mockHttpServer,
|
|
137
|
-
mockDomainUsesAccess,
|
|
138
|
-
mockGrantAccessToken,
|
|
139
|
-
mockOAuthServerCallback,
|
|
140
|
-
mockExchangeRefreshTokenForAccessToken,
|
|
141
|
-
};
|
|
142
|
-
};
|
|
143
|
-
|
|
144
|
-
export function mockExchangeRefreshTokenForAccessToken({
|
|
145
|
-
respondWith,
|
|
146
|
-
domain = "dash.cloudflare.com",
|
|
147
|
-
}: {
|
|
148
|
-
respondWith: "refreshSuccess" | "refreshError" | "badResponse";
|
|
149
|
-
domain?: string;
|
|
150
|
-
}) {
|
|
151
|
-
msw.use(
|
|
152
|
-
rest.post(`https://${domain}/oauth2/token`, async (_, res, ctx) => {
|
|
153
|
-
switch (respondWith) {
|
|
154
|
-
case "refreshSuccess":
|
|
155
|
-
return res.once(
|
|
156
|
-
ctx.status(200),
|
|
157
|
-
ctx.json({
|
|
158
|
-
access_token: "access_token_success_mock",
|
|
159
|
-
expires_in: 1701,
|
|
160
|
-
refresh_token: "refresh_token_success_mock",
|
|
161
|
-
scope: "scope_success_mock",
|
|
162
|
-
token_type: "bearer",
|
|
163
|
-
})
|
|
164
|
-
);
|
|
165
|
-
case "refreshError":
|
|
166
|
-
return res.once(
|
|
167
|
-
ctx.status(400),
|
|
168
|
-
ctx.json({
|
|
169
|
-
error: "invalid_request",
|
|
170
|
-
error_description: "error_description_mock",
|
|
171
|
-
error_hint: "error_hint_mock",
|
|
172
|
-
error_verbose: "error_verbose_mock",
|
|
173
|
-
status_code: 400,
|
|
174
|
-
})
|
|
175
|
-
);
|
|
176
|
-
case "badResponse":
|
|
177
|
-
return res.once(
|
|
178
|
-
ctx.status(400),
|
|
179
|
-
ctx.text(
|
|
180
|
-
`<html> <body> This shouldn't be sent, but should be handled </body> </html>`
|
|
181
|
-
)
|
|
182
|
-
);
|
|
183
|
-
|
|
184
|
-
default:
|
|
185
|
-
throw new Error(
|
|
186
|
-
"Not a respondWith option for `mockExchangeRefreshTokenForAccessToken`"
|
|
187
|
-
);
|
|
188
|
-
}
|
|
189
|
-
})
|
|
190
|
-
);
|
|
191
|
-
}
|
|
192
|
-
|
|
193
|
-
type GrantResponseOptions = {
|
|
194
|
-
code?: string;
|
|
195
|
-
error?: ErrorType | ErrorType[];
|
|
196
|
-
};
|
|
197
|
-
|
|
198
|
-
const toQueryParams = (
|
|
199
|
-
{ code, error }: GrantResponseOptions,
|
|
200
|
-
wranglerRequestParams: URLSearchParams
|
|
201
|
-
): string => {
|
|
202
|
-
const queryParams = [];
|
|
203
|
-
if (code) {
|
|
204
|
-
queryParams.push(`code=${code}`);
|
|
205
|
-
}
|
|
206
|
-
if (error) {
|
|
207
|
-
const stringifiedErr = Array.isArray(error) ? error.join(",") : error;
|
|
208
|
-
queryParams.push(`error=${stringifiedErr}`);
|
|
209
|
-
}
|
|
210
|
-
|
|
211
|
-
queryParams.push(`state=${wranglerRequestParams.get("state")}`);
|
|
212
|
-
|
|
213
|
-
return queryParams.join("&");
|
|
214
|
-
};
|
|
215
|
-
|
|
216
|
-
type ErrorType =
|
|
217
|
-
| "invalid_request"
|
|
218
|
-
| "invalid_grant"
|
|
219
|
-
| "unauthorized_client"
|
|
220
|
-
| "access_denied"
|
|
221
|
-
| "unsupported_response_type"
|
|
222
|
-
| "invalid_scope"
|
|
223
|
-
| "server_error"
|
|
224
|
-
| "temporarily_unavailable"
|
|
225
|
-
| "invalid_client"
|
|
226
|
-
| "unsupported_grant_type"
|
|
227
|
-
| "invalid_json"
|
|
228
|
-
| "invalid_token"
|
|
229
|
-
| "test-token-grant-error";
|
|
230
|
-
|
|
231
|
-
type MockTokenResponse =
|
|
232
|
-
| "ok"
|
|
233
|
-
| "error"
|
|
234
|
-
| {
|
|
235
|
-
access_token: string;
|
|
236
|
-
expires_in: number;
|
|
237
|
-
refresh_token: string;
|
|
238
|
-
scope: string;
|
|
239
|
-
}
|
|
240
|
-
| {
|
|
241
|
-
error: ErrorType;
|
|
242
|
-
};
|
|
243
|
-
|
|
244
|
-
const makeTokenResponse = (partialResponse: MockTokenResponse) => {
|
|
245
|
-
let fullResponse: MockTokenResponse;
|
|
246
|
-
|
|
247
|
-
if (partialResponse === "ok") {
|
|
248
|
-
fullResponse = {
|
|
249
|
-
access_token: "test-access-token",
|
|
250
|
-
expires_in: 100000,
|
|
251
|
-
refresh_token: "test-refresh-token",
|
|
252
|
-
scope: "account:read",
|
|
253
|
-
};
|
|
254
|
-
} else if (partialResponse === "error") {
|
|
255
|
-
fullResponse = {
|
|
256
|
-
error: "test-token-grant-error",
|
|
257
|
-
};
|
|
258
|
-
} else {
|
|
259
|
-
fullResponse = partialResponse;
|
|
260
|
-
}
|
|
261
|
-
|
|
262
|
-
return fullResponse;
|
|
263
|
-
};
|
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* We use this module to mock process methods (write only for now),
|
|
3
|
-
* and optionally assert on the values they're called with in our tests.
|
|
4
|
-
*/
|
|
5
|
-
|
|
6
|
-
let writeSpy: jest.SpyInstance;
|
|
7
|
-
|
|
8
|
-
function captureLastWriteCall(spy: jest.SpyInstance): Buffer | undefined {
|
|
9
|
-
const calls = spy.mock.calls;
|
|
10
|
-
|
|
11
|
-
// Loop through and find the buffer in calls
|
|
12
|
-
// (we don't know the index of the buffer in the calls array)
|
|
13
|
-
const buffer = calls
|
|
14
|
-
.map((call) => call[0])
|
|
15
|
-
.find((call) => call instanceof Buffer);
|
|
16
|
-
|
|
17
|
-
if (buffer instanceof Buffer) {
|
|
18
|
-
return buffer;
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
export function mockProcess() {
|
|
23
|
-
beforeEach(() => {
|
|
24
|
-
writeSpy = jest.spyOn(process.stdout, "write").mockImplementation();
|
|
25
|
-
});
|
|
26
|
-
afterEach(() => {
|
|
27
|
-
writeSpy.mockRestore();
|
|
28
|
-
});
|
|
29
|
-
return {
|
|
30
|
-
get write() {
|
|
31
|
-
return captureLastWriteCall(writeSpy);
|
|
32
|
-
},
|
|
33
|
-
};
|
|
34
|
-
}
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
let setTimeoutSpy: jest.SpyInstance;
|
|
2
|
-
|
|
3
|
-
export function mockSetTimeout() {
|
|
4
|
-
beforeEach(() => {
|
|
5
|
-
setTimeoutSpy = jest
|
|
6
|
-
.spyOn(global, "setTimeout")
|
|
7
|
-
// @ts-expect-error we're using a very simple setTimeout mock here
|
|
8
|
-
.mockImplementation((fn, _period) => {
|
|
9
|
-
setImmediate(fn);
|
|
10
|
-
});
|
|
11
|
-
});
|
|
12
|
-
|
|
13
|
-
afterEach(() => {
|
|
14
|
-
setTimeoutSpy.mockRestore();
|
|
15
|
-
});
|
|
16
|
-
}
|