wrangler 2.0.12 → 2.0.16
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 +7 -1
- package/bin/wrangler.js +111 -57
- package/miniflare-dist/index.mjs +9 -2
- package/package.json +156 -154
- package/src/__tests__/config-cache-without-cache-dir.test.ts +38 -0
- package/src/__tests__/config-cache.test.ts +30 -24
- package/src/__tests__/configuration.test.ts +3935 -3476
- package/src/__tests__/dev.test.tsx +1128 -979
- package/src/__tests__/guess-worker-format.test.ts +68 -68
- package/src/__tests__/helpers/cmd-shim.d.ts +6 -6
- package/src/__tests__/helpers/faye-websocket.d.ts +4 -4
- package/src/__tests__/helpers/mock-account-id.ts +24 -24
- package/src/__tests__/helpers/mock-bin.ts +20 -20
- package/src/__tests__/helpers/mock-cfetch.ts +92 -92
- package/src/__tests__/helpers/mock-console.ts +49 -39
- package/src/__tests__/helpers/mock-dialogs.ts +94 -71
- package/src/__tests__/helpers/mock-http-server.ts +30 -30
- package/src/__tests__/helpers/mock-istty.ts +65 -18
- package/src/__tests__/helpers/mock-kv.ts +26 -26
- package/src/__tests__/helpers/mock-oauth-flow.ts +223 -228
- package/src/__tests__/helpers/mock-process.ts +39 -0
- package/src/__tests__/helpers/mock-stdin.ts +82 -77
- package/src/__tests__/helpers/mock-web-socket.ts +21 -21
- package/src/__tests__/helpers/run-in-tmp.ts +27 -27
- package/src/__tests__/helpers/run-wrangler.ts +8 -8
- package/src/__tests__/helpers/write-worker-source.ts +16 -16
- package/src/__tests__/helpers/write-wrangler-toml.ts +9 -9
- package/src/__tests__/https-options.test.ts +104 -104
- package/src/__tests__/index.test.ts +239 -234
- package/src/__tests__/init.test.ts +1605 -1250
- package/src/__tests__/jest.setup.ts +63 -33
- package/src/__tests__/kv.test.ts +1128 -1011
- package/src/__tests__/logger.test.ts +100 -74
- package/src/__tests__/package-manager.test.ts +303 -303
- package/src/__tests__/pages.test.ts +1152 -652
- package/src/__tests__/parse.test.ts +252 -252
- package/src/__tests__/publish.test.ts +6371 -5622
- package/src/__tests__/pubsub.test.ts +367 -0
- package/src/__tests__/r2.test.ts +133 -133
- package/src/__tests__/route.test.ts +18 -18
- package/src/__tests__/secret.test.ts +382 -377
- package/src/__tests__/tail.test.ts +530 -530
- package/src/__tests__/user.test.ts +123 -111
- package/src/__tests__/whoami.test.tsx +198 -117
- package/src/__tests__/worker-namespace.test.ts +327 -0
- package/src/abort.d.ts +1 -1
- package/src/api/dev.ts +49 -0
- package/src/api/index.ts +1 -0
- package/src/bundle-reporter.tsx +29 -0
- package/src/bundle.ts +157 -149
- package/src/cfetch/index.ts +80 -80
- package/src/cfetch/internal.ts +90 -83
- package/src/cli.ts +21 -7
- package/src/config/config.ts +204 -195
- package/src/config/diagnostics.ts +61 -61
- package/src/config/environment.ts +390 -357
- package/src/config/index.ts +206 -193
- package/src/config/validation-helpers.ts +366 -366
- package/src/config/validation.ts +1573 -1376
- package/src/config-cache.ts +79 -41
- package/src/create-worker-preview.ts +206 -136
- package/src/create-worker-upload-form.ts +247 -238
- package/src/dev/dev-vars.ts +13 -13
- package/src/dev/dev.tsx +329 -307
- package/src/dev/local.tsx +304 -275
- package/src/dev/remote.tsx +366 -224
- package/src/dev/use-esbuild.ts +126 -91
- package/src/dev.tsx +538 -0
- package/src/dialogs.tsx +97 -97
- package/src/durable.ts +87 -87
- package/src/entry.ts +234 -228
- package/src/environment-variables.ts +23 -23
- package/src/errors.ts +6 -6
- package/src/generate.ts +33 -0
- package/src/git-client.ts +42 -0
- package/src/https-options.ts +79 -79
- package/src/index.tsx +1775 -2763
- package/src/init.ts +549 -0
- package/src/inspect.ts +593 -593
- package/src/intl-polyfill.d.ts +123 -123
- package/src/is-interactive.ts +12 -0
- package/src/kv.ts +277 -277
- package/src/logger.ts +46 -39
- package/src/miniflare-cli/enum-keys.ts +8 -8
- package/src/miniflare-cli/index.ts +42 -31
- package/src/miniflare-cli/request-context.ts +18 -18
- package/src/module-collection.ts +212 -212
- package/src/open-in-browser.ts +4 -6
- package/src/package-manager.ts +123 -123
- package/src/pages/build.tsx +202 -0
- package/src/pages/constants.ts +7 -0
- package/src/pages/deployments.tsx +101 -0
- package/src/pages/dev.tsx +964 -0
- package/src/pages/functions/buildPlugin.ts +105 -0
- package/src/pages/functions/buildWorker.ts +151 -0
- package/{pages → src/pages}/functions/filepath-routing.test.ts +113 -113
- package/src/pages/functions/filepath-routing.ts +189 -0
- package/src/pages/functions/identifiers.ts +78 -0
- package/src/pages/functions/routes.ts +151 -0
- package/src/pages/index.tsx +84 -0
- package/src/pages/projects.tsx +157 -0
- package/src/pages/publish.tsx +335 -0
- package/src/pages/types.ts +40 -0
- package/src/pages/upload.tsx +384 -0
- package/src/pages/utils.ts +12 -0
- package/src/parse.ts +202 -138
- package/src/paths.ts +6 -6
- package/src/preview.ts +31 -0
- package/src/proxy.ts +400 -402
- package/src/publish.ts +667 -621
- package/src/pubsub/index.ts +286 -0
- package/src/pubsub/pubsub-commands.tsx +577 -0
- package/src/r2.ts +19 -19
- package/src/selfsigned.d.ts +23 -23
- package/src/sites.tsx +271 -225
- package/src/tail/filters.ts +108 -108
- package/src/tail/index.ts +217 -217
- package/src/tail/printing.ts +45 -45
- package/src/update-check.ts +11 -11
- package/src/user/choose-account.tsx +60 -0
- package/src/user/env-vars.ts +46 -0
- package/src/user/generate-auth-url.ts +33 -0
- package/src/user/generate-random-state.ts +16 -0
- package/src/user/index.ts +3 -0
- package/src/user/user.tsx +1161 -0
- package/src/whoami.tsx +61 -42
- package/src/worker-namespace.ts +190 -0
- package/src/worker.ts +110 -100
- package/src/zones.ts +39 -36
- package/templates/checked-fetch.js +17 -0
- package/templates/new-worker-scheduled.js +3 -3
- package/templates/new-worker-scheduled.ts +15 -15
- package/templates/new-worker.js +3 -3
- package/templates/new-worker.ts +15 -15
- package/templates/no-op-worker.js +10 -0
- package/templates/pages-template-plugin.ts +155 -0
- package/templates/pages-template-worker.ts +161 -0
- package/templates/static-asset-facade.js +31 -31
- package/templates/tsconfig.json +95 -95
- package/wrangler-dist/cli.js +55383 -54138
- package/pages/functions/buildPlugin.ts +0 -105
- package/pages/functions/buildWorker.ts +0 -151
- package/pages/functions/filepath-routing.ts +0 -189
- package/pages/functions/identifiers.ts +0 -78
- package/pages/functions/routes.ts +0 -156
- package/pages/functions/template-plugin.ts +0 -147
- package/pages/functions/template-worker.ts +0 -143
- package/src/pages.tsx +0 -2093
- package/src/user.tsx +0 -1214
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import fetchMock from "jest-fetch-mock";
|
|
2
2
|
import {
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
3
|
+
fetchInternal,
|
|
4
|
+
fetchKVGetValue,
|
|
5
|
+
getCloudflareAPIBaseURL,
|
|
6
6
|
} from "../cfetch/internal";
|
|
7
7
|
import { confirm, prompt } from "../dialogs";
|
|
8
8
|
import { mockFetchInternal, mockFetchKVGetValue } from "./helpers/mock-cfetch";
|
|
@@ -10,29 +10,29 @@ import { MockWebSocket } from "./helpers/mock-web-socket";
|
|
|
10
10
|
|
|
11
11
|
// Mock out getPort since we don't actually care about what ports are open in unit tests.
|
|
12
12
|
jest.mock("get-port", () => {
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
13
|
+
return {
|
|
14
|
+
__esModule: true,
|
|
15
|
+
default: jest.fn().mockImplementation(async (options) => options.port),
|
|
16
|
+
};
|
|
17
17
|
});
|
|
18
18
|
|
|
19
19
|
jest.mock("ws", () => {
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
20
|
+
return {
|
|
21
|
+
__esModule: true,
|
|
22
|
+
default: MockWebSocket,
|
|
23
|
+
};
|
|
24
24
|
});
|
|
25
25
|
|
|
26
26
|
jest.mock("undici", () => {
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
27
|
+
return {
|
|
28
|
+
...jest.requireActual("undici"),
|
|
29
|
+
fetch: jest.requireActual("jest-fetch-mock"),
|
|
30
|
+
};
|
|
31
31
|
});
|
|
32
32
|
|
|
33
33
|
fetchMock.doMock(() => {
|
|
34
|
-
|
|
35
|
-
|
|
34
|
+
// Any un-mocked fetches should throw
|
|
35
|
+
throw new Error("Unexpected fetch request");
|
|
36
36
|
});
|
|
37
37
|
|
|
38
38
|
jest.mock("../package-manager");
|
|
@@ -41,37 +41,67 @@ jest.mock("../cfetch/internal");
|
|
|
41
41
|
(fetchInternal as jest.Mock).mockImplementation(mockFetchInternal);
|
|
42
42
|
(fetchKVGetValue as jest.Mock).mockImplementation(mockFetchKVGetValue);
|
|
43
43
|
(getCloudflareAPIBaseURL as jest.Mock).mockReturnValue(
|
|
44
|
-
|
|
44
|
+
"https://api.cloudflare.com/client/v4"
|
|
45
45
|
);
|
|
46
46
|
|
|
47
47
|
jest.mock("../dialogs");
|
|
48
48
|
|
|
49
49
|
// By default (if not configured by mockConfirm()) calls to `confirm()` should throw.
|
|
50
50
|
(confirm as jest.Mock).mockImplementation((text: string) => {
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
51
|
+
throw new Error(
|
|
52
|
+
`Unexpected call to \`confirm("${text}")\`.\nYou should use \`mockConfirm()\` to mock calls to \`confirm()\` with expectations. Search the codebase for \`mockConfirm\` to learn more.`
|
|
53
|
+
);
|
|
54
54
|
});
|
|
55
55
|
|
|
56
56
|
// By default (if not configured by mockPrompt()) calls to `prompt()` should throw.
|
|
57
57
|
(prompt as jest.Mock).mockImplementation((text: string) => {
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
58
|
+
throw new Error(
|
|
59
|
+
`Unexpected call to \`prompt(${text}, ...)\`.\nYou should use \`mockPrompt()\` to mock calls to \`prompt()\` with expectations. Search the codebase for \`mockPrompt\` to learn more.`
|
|
60
|
+
);
|
|
61
61
|
});
|
|
62
62
|
|
|
63
63
|
jest.mock("../dev/dev", () => {
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
64
|
+
const { useApp } = jest.requireActual("ink");
|
|
65
|
+
const { useEffect } = jest.requireActual("react");
|
|
66
|
+
return jest.fn().mockImplementation(() => {
|
|
67
|
+
const { exit } = useApp();
|
|
68
|
+
useEffect(() => {
|
|
69
|
+
exit();
|
|
70
|
+
});
|
|
71
|
+
return null;
|
|
72
|
+
});
|
|
73
73
|
});
|
|
74
74
|
|
|
75
75
|
// Make sure that we don't accidentally try to open a browser window when running tests.
|
|
76
76
|
// We will actually provide a mock implementation for `openInBrowser()` within relevant tests.
|
|
77
77
|
jest.mock("../open-in-browser");
|
|
78
|
+
|
|
79
|
+
// Mock the functions involved in getAuthURL so we don't take snapshots of the constantly changing URL.
|
|
80
|
+
jest.mock("../user/generate-auth-url", () => {
|
|
81
|
+
return {
|
|
82
|
+
generateRandomState: jest.fn().mockImplementation(() => "MOCK_STATE_PARAM"),
|
|
83
|
+
generateAuthUrl: jest
|
|
84
|
+
.fn()
|
|
85
|
+
.mockImplementation(({ authUrl, clientId, callbackUrl, scopes }) => {
|
|
86
|
+
return (
|
|
87
|
+
authUrl +
|
|
88
|
+
`?response_type=code&` +
|
|
89
|
+
`client_id=${encodeURIComponent(clientId)}&` +
|
|
90
|
+
`redirect_uri=${encodeURIComponent(callbackUrl)}&` +
|
|
91
|
+
// we add offline_access manually for every request
|
|
92
|
+
`scope=${encodeURIComponent(
|
|
93
|
+
[...scopes, "offline_access"].join(" ")
|
|
94
|
+
)}&` +
|
|
95
|
+
`state=MOCK_STATE_PARAM&` +
|
|
96
|
+
`code_challenge=${encodeURIComponent("MOCK_CODE_CHALLENGE")}&` +
|
|
97
|
+
`code_challenge_method=S256`
|
|
98
|
+
);
|
|
99
|
+
}),
|
|
100
|
+
};
|
|
101
|
+
});
|
|
102
|
+
|
|
103
|
+
jest.mock("../user/generate-random-state", () => {
|
|
104
|
+
return {
|
|
105
|
+
generateRandomState: jest.fn().mockImplementation(() => "MOCK_STATE_PARAM"),
|
|
106
|
+
};
|
|
107
|
+
});
|