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.
Files changed (149) hide show
  1. package/README.md +7 -1
  2. package/bin/wrangler.js +111 -57
  3. package/miniflare-dist/index.mjs +9 -2
  4. package/package.json +156 -154
  5. package/src/__tests__/config-cache-without-cache-dir.test.ts +38 -0
  6. package/src/__tests__/config-cache.test.ts +30 -24
  7. package/src/__tests__/configuration.test.ts +3935 -3476
  8. package/src/__tests__/dev.test.tsx +1128 -979
  9. package/src/__tests__/guess-worker-format.test.ts +68 -68
  10. package/src/__tests__/helpers/cmd-shim.d.ts +6 -6
  11. package/src/__tests__/helpers/faye-websocket.d.ts +4 -4
  12. package/src/__tests__/helpers/mock-account-id.ts +24 -24
  13. package/src/__tests__/helpers/mock-bin.ts +20 -20
  14. package/src/__tests__/helpers/mock-cfetch.ts +92 -92
  15. package/src/__tests__/helpers/mock-console.ts +49 -39
  16. package/src/__tests__/helpers/mock-dialogs.ts +94 -71
  17. package/src/__tests__/helpers/mock-http-server.ts +30 -30
  18. package/src/__tests__/helpers/mock-istty.ts +65 -18
  19. package/src/__tests__/helpers/mock-kv.ts +26 -26
  20. package/src/__tests__/helpers/mock-oauth-flow.ts +223 -228
  21. package/src/__tests__/helpers/mock-process.ts +39 -0
  22. package/src/__tests__/helpers/mock-stdin.ts +82 -77
  23. package/src/__tests__/helpers/mock-web-socket.ts +21 -21
  24. package/src/__tests__/helpers/run-in-tmp.ts +27 -27
  25. package/src/__tests__/helpers/run-wrangler.ts +8 -8
  26. package/src/__tests__/helpers/write-worker-source.ts +16 -16
  27. package/src/__tests__/helpers/write-wrangler-toml.ts +9 -9
  28. package/src/__tests__/https-options.test.ts +104 -104
  29. package/src/__tests__/index.test.ts +239 -234
  30. package/src/__tests__/init.test.ts +1605 -1250
  31. package/src/__tests__/jest.setup.ts +63 -33
  32. package/src/__tests__/kv.test.ts +1128 -1011
  33. package/src/__tests__/logger.test.ts +100 -74
  34. package/src/__tests__/package-manager.test.ts +303 -303
  35. package/src/__tests__/pages.test.ts +1152 -652
  36. package/src/__tests__/parse.test.ts +252 -252
  37. package/src/__tests__/publish.test.ts +6371 -5622
  38. package/src/__tests__/pubsub.test.ts +367 -0
  39. package/src/__tests__/r2.test.ts +133 -133
  40. package/src/__tests__/route.test.ts +18 -18
  41. package/src/__tests__/secret.test.ts +382 -377
  42. package/src/__tests__/tail.test.ts +530 -530
  43. package/src/__tests__/user.test.ts +123 -111
  44. package/src/__tests__/whoami.test.tsx +198 -117
  45. package/src/__tests__/worker-namespace.test.ts +327 -0
  46. package/src/abort.d.ts +1 -1
  47. package/src/api/dev.ts +49 -0
  48. package/src/api/index.ts +1 -0
  49. package/src/bundle-reporter.tsx +29 -0
  50. package/src/bundle.ts +157 -149
  51. package/src/cfetch/index.ts +80 -80
  52. package/src/cfetch/internal.ts +90 -83
  53. package/src/cli.ts +21 -7
  54. package/src/config/config.ts +204 -195
  55. package/src/config/diagnostics.ts +61 -61
  56. package/src/config/environment.ts +390 -357
  57. package/src/config/index.ts +206 -193
  58. package/src/config/validation-helpers.ts +366 -366
  59. package/src/config/validation.ts +1573 -1376
  60. package/src/config-cache.ts +79 -41
  61. package/src/create-worker-preview.ts +206 -136
  62. package/src/create-worker-upload-form.ts +247 -238
  63. package/src/dev/dev-vars.ts +13 -13
  64. package/src/dev/dev.tsx +329 -307
  65. package/src/dev/local.tsx +304 -275
  66. package/src/dev/remote.tsx +366 -224
  67. package/src/dev/use-esbuild.ts +126 -91
  68. package/src/dev.tsx +538 -0
  69. package/src/dialogs.tsx +97 -97
  70. package/src/durable.ts +87 -87
  71. package/src/entry.ts +234 -228
  72. package/src/environment-variables.ts +23 -23
  73. package/src/errors.ts +6 -6
  74. package/src/generate.ts +33 -0
  75. package/src/git-client.ts +42 -0
  76. package/src/https-options.ts +79 -79
  77. package/src/index.tsx +1775 -2763
  78. package/src/init.ts +549 -0
  79. package/src/inspect.ts +593 -593
  80. package/src/intl-polyfill.d.ts +123 -123
  81. package/src/is-interactive.ts +12 -0
  82. package/src/kv.ts +277 -277
  83. package/src/logger.ts +46 -39
  84. package/src/miniflare-cli/enum-keys.ts +8 -8
  85. package/src/miniflare-cli/index.ts +42 -31
  86. package/src/miniflare-cli/request-context.ts +18 -18
  87. package/src/module-collection.ts +212 -212
  88. package/src/open-in-browser.ts +4 -6
  89. package/src/package-manager.ts +123 -123
  90. package/src/pages/build.tsx +202 -0
  91. package/src/pages/constants.ts +7 -0
  92. package/src/pages/deployments.tsx +101 -0
  93. package/src/pages/dev.tsx +964 -0
  94. package/src/pages/functions/buildPlugin.ts +105 -0
  95. package/src/pages/functions/buildWorker.ts +151 -0
  96. package/{pages → src/pages}/functions/filepath-routing.test.ts +113 -113
  97. package/src/pages/functions/filepath-routing.ts +189 -0
  98. package/src/pages/functions/identifiers.ts +78 -0
  99. package/src/pages/functions/routes.ts +151 -0
  100. package/src/pages/index.tsx +84 -0
  101. package/src/pages/projects.tsx +157 -0
  102. package/src/pages/publish.tsx +335 -0
  103. package/src/pages/types.ts +40 -0
  104. package/src/pages/upload.tsx +384 -0
  105. package/src/pages/utils.ts +12 -0
  106. package/src/parse.ts +202 -138
  107. package/src/paths.ts +6 -6
  108. package/src/preview.ts +31 -0
  109. package/src/proxy.ts +400 -402
  110. package/src/publish.ts +667 -621
  111. package/src/pubsub/index.ts +286 -0
  112. package/src/pubsub/pubsub-commands.tsx +577 -0
  113. package/src/r2.ts +19 -19
  114. package/src/selfsigned.d.ts +23 -23
  115. package/src/sites.tsx +271 -225
  116. package/src/tail/filters.ts +108 -108
  117. package/src/tail/index.ts +217 -217
  118. package/src/tail/printing.ts +45 -45
  119. package/src/update-check.ts +11 -11
  120. package/src/user/choose-account.tsx +60 -0
  121. package/src/user/env-vars.ts +46 -0
  122. package/src/user/generate-auth-url.ts +33 -0
  123. package/src/user/generate-random-state.ts +16 -0
  124. package/src/user/index.ts +3 -0
  125. package/src/user/user.tsx +1161 -0
  126. package/src/whoami.tsx +61 -42
  127. package/src/worker-namespace.ts +190 -0
  128. package/src/worker.ts +110 -100
  129. package/src/zones.ts +39 -36
  130. package/templates/checked-fetch.js +17 -0
  131. package/templates/new-worker-scheduled.js +3 -3
  132. package/templates/new-worker-scheduled.ts +15 -15
  133. package/templates/new-worker.js +3 -3
  134. package/templates/new-worker.ts +15 -15
  135. package/templates/no-op-worker.js +10 -0
  136. package/templates/pages-template-plugin.ts +155 -0
  137. package/templates/pages-template-worker.ts +161 -0
  138. package/templates/static-asset-facade.js +31 -31
  139. package/templates/tsconfig.json +95 -95
  140. package/wrangler-dist/cli.js +55383 -54138
  141. package/pages/functions/buildPlugin.ts +0 -105
  142. package/pages/functions/buildWorker.ts +0 -151
  143. package/pages/functions/filepath-routing.ts +0 -189
  144. package/pages/functions/identifiers.ts +0 -78
  145. package/pages/functions/routes.ts +0 -156
  146. package/pages/functions/template-plugin.ts +0 -147
  147. package/pages/functions/template-worker.ts +0 -143
  148. package/src/pages.tsx +0 -2093
  149. package/src/user.tsx +0 -1214
@@ -6,27 +6,27 @@ import { runWrangler } from "./helpers/run-wrangler";
6
6
  import type { R2BucketInfo } from "../r2";
7
7
 
8
8
  describe("wrangler", () => {
9
- mockAccountId();
10
- mockApiToken();
11
- runInTempDir();
12
- const std = mockConsoleMethods();
13
-
14
- afterEach(() => {
15
- unsetAllMocks();
16
- });
17
-
18
- describe("r2", () => {
19
- describe("bucket", () => {
20
- it("should show the correct help when an invalid command is passed", async () => {
21
- await expect(() =>
22
- runWrangler("r2 bucket foo")
23
- ).rejects.toThrowErrorMatchingInlineSnapshot(`"Unknown argument: foo"`);
24
- expect(std.err).toMatchInlineSnapshot(`
9
+ mockAccountId();
10
+ mockApiToken();
11
+ runInTempDir();
12
+ const std = mockConsoleMethods();
13
+
14
+ afterEach(() => {
15
+ unsetAllMocks();
16
+ });
17
+
18
+ describe("r2", () => {
19
+ describe("bucket", () => {
20
+ it("should show the correct help when an invalid command is passed", async () => {
21
+ await expect(() =>
22
+ runWrangler("r2 bucket foo")
23
+ ).rejects.toThrowErrorMatchingInlineSnapshot(`"Unknown argument: foo"`);
24
+ expect(std.err).toMatchInlineSnapshot(`
25
25
  "X [ERROR] Unknown argument: foo
26
26
 
27
27
  "
28
28
  `);
29
- expect(std.out).toMatchInlineSnapshot(`
29
+ expect(std.out).toMatchInlineSnapshot(`
30
30
  "
31
31
  wrangler r2 bucket
32
32
 
@@ -42,59 +42,59 @@ describe("wrangler", () => {
42
42
  -h, --help Show help [boolean]
43
43
  -v, --version Show version number [boolean]"
44
44
  `);
45
- });
46
-
47
- describe("list", () => {
48
- function mockListRequest(buckets: R2BucketInfo[]) {
49
- const requests = { count: 0 };
50
- setMockResponse(
51
- "/accounts/:accountId/r2/buckets",
52
- ([_url, accountId], init) => {
53
- requests.count++;
54
- expect(accountId).toEqual("some-account-id");
55
- expect(init).toEqual({});
56
- return { buckets };
57
- }
58
- );
59
- return requests;
60
- }
61
-
62
- it("should list buckets", async () => {
63
- const expectedBuckets: R2BucketInfo[] = [
64
- { name: "bucket-1", creation_date: "01-01-2001" },
65
- { name: "bucket-2", creation_date: "01-01-2001" },
66
- ];
67
- mockListRequest(expectedBuckets);
68
- await runWrangler("r2 bucket list");
69
-
70
- expect(std.err).toMatchInlineSnapshot(`""`);
71
- const buckets = JSON.parse(std.out);
72
- expect(buckets).toEqual(expectedBuckets);
73
- });
74
- });
75
-
76
- describe("create", () => {
77
- function mockCreateRequest(expectedBucketName: string) {
78
- const requests = { count: 0 };
79
- setMockResponse(
80
- "/accounts/:accountId/r2/buckets/:bucketName",
81
- "PUT",
82
- ([_url, accountId, bucketName]) => {
83
- expect(accountId).toEqual("some-account-id");
84
- expect(bucketName).toEqual(expectedBucketName);
85
- requests.count += 1;
86
- }
87
- );
88
- return requests;
89
- }
90
-
91
- it("should error if no bucket name is given", async () => {
92
- await expect(
93
- runWrangler("r2 bucket create")
94
- ).rejects.toThrowErrorMatchingInlineSnapshot(
95
- `"Not enough non-option arguments: got 0, need at least 1"`
96
- );
97
- expect(std.out).toMatchInlineSnapshot(`
45
+ });
46
+
47
+ describe("list", () => {
48
+ function mockListRequest(buckets: R2BucketInfo[]) {
49
+ const requests = { count: 0 };
50
+ setMockResponse(
51
+ "/accounts/:accountId/r2/buckets",
52
+ ([_url, accountId], init) => {
53
+ requests.count++;
54
+ expect(accountId).toEqual("some-account-id");
55
+ expect(init).toEqual({});
56
+ return { buckets };
57
+ }
58
+ );
59
+ return requests;
60
+ }
61
+
62
+ it("should list buckets", async () => {
63
+ const expectedBuckets: R2BucketInfo[] = [
64
+ { name: "bucket-1", creation_date: "01-01-2001" },
65
+ { name: "bucket-2", creation_date: "01-01-2001" },
66
+ ];
67
+ mockListRequest(expectedBuckets);
68
+ await runWrangler("r2 bucket list");
69
+
70
+ expect(std.err).toMatchInlineSnapshot(`""`);
71
+ const buckets = JSON.parse(std.out);
72
+ expect(buckets).toEqual(expectedBuckets);
73
+ });
74
+ });
75
+
76
+ describe("create", () => {
77
+ function mockCreateRequest(expectedBucketName: string) {
78
+ const requests = { count: 0 };
79
+ setMockResponse(
80
+ "/accounts/:accountId/r2/buckets/:bucketName",
81
+ "PUT",
82
+ ([_url, accountId, bucketName]) => {
83
+ expect(accountId).toEqual("some-account-id");
84
+ expect(bucketName).toEqual(expectedBucketName);
85
+ requests.count += 1;
86
+ }
87
+ );
88
+ return requests;
89
+ }
90
+
91
+ it("should error if no bucket name is given", async () => {
92
+ await expect(
93
+ runWrangler("r2 bucket create")
94
+ ).rejects.toThrowErrorMatchingInlineSnapshot(
95
+ `"Not enough non-option arguments: got 0, need at least 1"`
96
+ );
97
+ expect(std.out).toMatchInlineSnapshot(`
98
98
  "
99
99
  wrangler r2 bucket create <name>
100
100
 
@@ -108,20 +108,20 @@ describe("wrangler", () => {
108
108
  -h, --help Show help [boolean]
109
109
  -v, --version Show version number [boolean]"
110
110
  `);
111
- expect(std.err).toMatchInlineSnapshot(`
111
+ expect(std.err).toMatchInlineSnapshot(`
112
112
  "X [ERROR] Not enough non-option arguments: got 0, need at least 1
113
113
 
114
114
  "
115
115
  `);
116
- });
117
-
118
- it("should error if the bucket to create contains spaces", async () => {
119
- await expect(
120
- runWrangler("r2 bucket create abc def ghi")
121
- ).rejects.toThrowErrorMatchingInlineSnapshot(
122
- `"Unknown arguments: def, ghi"`
123
- );
124
- expect(std.out).toMatchInlineSnapshot(`
116
+ });
117
+
118
+ it("should error if the bucket to create contains spaces", async () => {
119
+ await expect(
120
+ runWrangler("r2 bucket create abc def ghi")
121
+ ).rejects.toThrowErrorMatchingInlineSnapshot(
122
+ `"Unknown arguments: def, ghi"`
123
+ );
124
+ expect(std.out).toMatchInlineSnapshot(`
125
125
  "
126
126
  wrangler r2 bucket create <name>
127
127
 
@@ -135,46 +135,46 @@ describe("wrangler", () => {
135
135
  -h, --help Show help [boolean]
136
136
  -v, --version Show version number [boolean]"
137
137
  `);
138
- expect(std.err).toMatchInlineSnapshot(`
138
+ expect(std.err).toMatchInlineSnapshot(`
139
139
  "X [ERROR] Unknown arguments: def, ghi
140
140
 
141
141
  "
142
142
  `);
143
- });
143
+ });
144
144
 
145
- it("should create a bucket", async () => {
146
- const requests = mockCreateRequest("testBucket");
147
- await runWrangler("r2 bucket create testBucket");
148
- expect(std.out).toMatchInlineSnapshot(`
145
+ it("should create a bucket", async () => {
146
+ const requests = mockCreateRequest("testBucket");
147
+ await runWrangler("r2 bucket create testBucket");
148
+ expect(std.out).toMatchInlineSnapshot(`
149
149
  "Creating bucket testBucket.
150
150
  Created bucket testBucket."
151
151
  `);
152
- expect(requests.count).toEqual(1);
153
- });
154
- });
155
-
156
- describe("delete", () => {
157
- function mockDeleteRequest(expectedBucketName: string) {
158
- const requests = { count: 0 };
159
- setMockResponse(
160
- "/accounts/:accountId/r2/buckets/:bucketName",
161
- "DELETE",
162
- ([_url, accountId, bucketName]) => {
163
- expect(accountId).toEqual("some-account-id");
164
- expect(bucketName).toEqual(expectedBucketName);
165
- requests.count += 1;
166
- }
167
- );
168
- return requests;
169
- }
170
-
171
- it("should error if no bucket name is given", async () => {
172
- await expect(
173
- runWrangler("r2 bucket delete")
174
- ).rejects.toThrowErrorMatchingInlineSnapshot(
175
- `"Not enough non-option arguments: got 0, need at least 1"`
176
- );
177
- expect(std.out).toMatchInlineSnapshot(`
152
+ expect(requests.count).toEqual(1);
153
+ });
154
+ });
155
+
156
+ describe("delete", () => {
157
+ function mockDeleteRequest(expectedBucketName: string) {
158
+ const requests = { count: 0 };
159
+ setMockResponse(
160
+ "/accounts/:accountId/r2/buckets/:bucketName",
161
+ "DELETE",
162
+ ([_url, accountId, bucketName]) => {
163
+ expect(accountId).toEqual("some-account-id");
164
+ expect(bucketName).toEqual(expectedBucketName);
165
+ requests.count += 1;
166
+ }
167
+ );
168
+ return requests;
169
+ }
170
+
171
+ it("should error if no bucket name is given", async () => {
172
+ await expect(
173
+ runWrangler("r2 bucket delete")
174
+ ).rejects.toThrowErrorMatchingInlineSnapshot(
175
+ `"Not enough non-option arguments: got 0, need at least 1"`
176
+ );
177
+ expect(std.out).toMatchInlineSnapshot(`
178
178
  "
179
179
  wrangler r2 bucket delete <name>
180
180
 
@@ -188,20 +188,20 @@ describe("wrangler", () => {
188
188
  -h, --help Show help [boolean]
189
189
  -v, --version Show version number [boolean]"
190
190
  `);
191
- expect(std.err).toMatchInlineSnapshot(`
191
+ expect(std.err).toMatchInlineSnapshot(`
192
192
  "X [ERROR] Not enough non-option arguments: got 0, need at least 1
193
193
 
194
194
  "
195
195
  `);
196
- });
197
-
198
- it("should error if the bucket name to delete contains spaces", async () => {
199
- await expect(
200
- runWrangler("r2 bucket delete abc def ghi")
201
- ).rejects.toThrowErrorMatchingInlineSnapshot(
202
- `"Unknown arguments: def, ghi"`
203
- );
204
- expect(std.out).toMatchInlineSnapshot(`
196
+ });
197
+
198
+ it("should error if the bucket name to delete contains spaces", async () => {
199
+ await expect(
200
+ runWrangler("r2 bucket delete abc def ghi")
201
+ ).rejects.toThrowErrorMatchingInlineSnapshot(
202
+ `"Unknown arguments: def, ghi"`
203
+ );
204
+ expect(std.out).toMatchInlineSnapshot(`
205
205
  "
206
206
  wrangler r2 bucket delete <name>
207
207
 
@@ -215,19 +215,19 @@ describe("wrangler", () => {
215
215
  -h, --help Show help [boolean]
216
216
  -v, --version Show version number [boolean]"
217
217
  `);
218
- expect(std.err).toMatchInlineSnapshot(`
218
+ expect(std.err).toMatchInlineSnapshot(`
219
219
  "X [ERROR] Unknown arguments: def, ghi
220
220
 
221
221
  "
222
222
  `);
223
- });
224
-
225
- it("should delete a bucket specified by name", async () => {
226
- const requests = mockDeleteRequest("some-bucket");
227
- await runWrangler(`r2 bucket delete some-bucket`);
228
- expect(requests.count).toEqual(1);
229
- });
230
- });
231
- });
232
- });
223
+ });
224
+
225
+ it("should delete a bucket specified by name", async () => {
226
+ const requests = mockDeleteRequest("some-bucket");
227
+ await runWrangler(`r2 bucket delete some-bucket`);
228
+ expect(requests.count).toEqual(1);
229
+ });
230
+ });
231
+ });
232
+ });
233
233
  });
@@ -3,43 +3,43 @@ import { runInTempDir } from "./helpers/run-in-tmp";
3
3
  import { runWrangler } from "./helpers/run-wrangler";
4
4
 
5
5
  describe("wrangler route", () => {
6
- mockConsoleMethods();
7
- runInTempDir();
6
+ mockConsoleMethods();
7
+ runInTempDir();
8
8
 
9
- it("shows a deprecation notice when `wrangler route` is run", async () => {
10
- await expect(runWrangler("route")).rejects
11
- .toThrowErrorMatchingInlineSnapshot(`
9
+ it("shows a deprecation notice when `wrangler route` is run", async () => {
10
+ await expect(runWrangler("route")).rejects
11
+ .toThrowErrorMatchingInlineSnapshot(`
12
12
  "Deprecation:
13
13
  \`wrangler route\` has been deprecated.
14
14
  Please use wrangler.toml and/or \`wrangler publish --routes\` to modify routes"
15
15
  `);
16
- });
16
+ });
17
17
 
18
- it("shows a deprecation notice when `wrangler route delete` is run", async () => {
19
- await expect(runWrangler("route delete")).rejects
20
- .toThrowErrorMatchingInlineSnapshot(`
18
+ it("shows a deprecation notice when `wrangler route delete` is run", async () => {
19
+ await expect(runWrangler("route delete")).rejects
20
+ .toThrowErrorMatchingInlineSnapshot(`
21
21
  "Deprecation:
22
22
  \`wrangler route delete\` has been deprecated.
23
23
  Remove the unwanted route(s) from wrangler.toml and run \`wrangler publish\` to remove your worker from those routes."
24
24
  `);
25
- });
25
+ });
26
26
 
27
- it("shows a deprecation notice when `wrangler route delete <id>` is run", async () => {
28
- await expect(runWrangler("route delete some-zone-id")).rejects
29
- .toThrowErrorMatchingInlineSnapshot(`
27
+ it("shows a deprecation notice when `wrangler route delete <id>` is run", async () => {
28
+ await expect(runWrangler("route delete some-zone-id")).rejects
29
+ .toThrowErrorMatchingInlineSnapshot(`
30
30
  "Deprecation:
31
31
  \`wrangler route delete\` has been deprecated.
32
32
  Remove the unwanted route(s) from wrangler.toml and run \`wrangler publish\` to remove your worker from those routes."
33
33
  `);
34
- });
34
+ });
35
35
 
36
- it("shows a deprecation notice when `wrangler route list` is run", async () => {
37
- await expect(runWrangler("route list")).rejects
38
- .toThrowErrorMatchingInlineSnapshot(`
36
+ it("shows a deprecation notice when `wrangler route list` is run", async () => {
37
+ await expect(runWrangler("route list")).rejects
38
+ .toThrowErrorMatchingInlineSnapshot(`
39
39
  "Deprecation:
40
40
  \`wrangler route list\` has been deprecated.
41
41
  Refer to wrangler.toml for a list of routes the worker will be deployed to upon publishing.
42
42
  Refer to the Cloudflare Dashboard to see the routes this worker is currently running on."
43
43
  `);
44
- });
44
+ });
45
45
  });