@positronic/cli 0.0.3 → 0.0.5
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/dist/src/commands/helpers.js +57 -27
- package/dist/types/commands/helpers.d.ts.map +1 -1
- package/package.json +5 -1
- package/dist/src/commands/brain.test.js +0 -2936
- package/dist/src/commands/helpers.test.js +0 -832
- package/dist/src/commands/project.test.js +0 -1201
- package/dist/src/commands/resources.test.js +0 -2511
- package/dist/src/commands/schedule.test.js +0 -1235
- package/dist/src/commands/secret.test.d.js +0 -1
- package/dist/src/commands/secret.test.js +0 -761
- package/dist/src/commands/server.test.js +0 -1237
- package/dist/src/commands/test-utils.js +0 -737
- package/dist/src/components/secret-sync.js +0 -303
- package/dist/src/test/mock-api-client.js +0 -371
- package/dist/src/test/test-dev-server.js +0 -1376
- package/dist/types/commands/test-utils.d.ts +0 -45
- package/dist/types/commands/test-utils.d.ts.map +0 -1
- package/dist/types/components/secret-sync.d.ts +0 -9
- package/dist/types/components/secret-sync.d.ts.map +0 -1
- package/dist/types/test/mock-api-client.d.ts +0 -25
- package/dist/types/test/mock-api-client.d.ts.map +0 -1
- package/dist/types/test/test-dev-server.d.ts +0 -129
- package/dist/types/test/test-dev-server.d.ts.map +0 -1
- package/src/cli.ts +0 -997
- package/src/commands/backend.ts +0 -63
- package/src/commands/brain.test.ts +0 -1004
- package/src/commands/brain.ts +0 -215
- package/src/commands/helpers.test.ts +0 -487
- package/src/commands/helpers.ts +0 -870
- package/src/commands/project-config-manager.ts +0 -152
- package/src/commands/project.test.ts +0 -502
- package/src/commands/project.ts +0 -109
- package/src/commands/resources.test.ts +0 -1052
- package/src/commands/resources.ts +0 -97
- package/src/commands/schedule.test.ts +0 -481
- package/src/commands/schedule.ts +0 -65
- package/src/commands/secret.test.ts +0 -210
- package/src/commands/secret.ts +0 -50
- package/src/commands/server.test.ts +0 -493
- package/src/commands/server.ts +0 -353
- package/src/commands/test-utils.ts +0 -324
- package/src/components/brain-history.tsx +0 -198
- package/src/components/brain-list.tsx +0 -105
- package/src/components/brain-rerun.tsx +0 -111
- package/src/components/brain-show.tsx +0 -92
- package/src/components/error.tsx +0 -24
- package/src/components/project-add.tsx +0 -59
- package/src/components/project-create.tsx +0 -83
- package/src/components/project-list.tsx +0 -83
- package/src/components/project-remove.tsx +0 -55
- package/src/components/project-select.tsx +0 -200
- package/src/components/project-show.tsx +0 -58
- package/src/components/resource-clear.tsx +0 -127
- package/src/components/resource-delete.tsx +0 -160
- package/src/components/resource-list.tsx +0 -177
- package/src/components/resource-sync.tsx +0 -170
- package/src/components/resource-types.tsx +0 -55
- package/src/components/resource-upload.tsx +0 -182
- package/src/components/schedule-create.tsx +0 -90
- package/src/components/schedule-delete.tsx +0 -116
- package/src/components/schedule-list.tsx +0 -186
- package/src/components/schedule-runs.tsx +0 -151
- package/src/components/secret-bulk.tsx +0 -79
- package/src/components/secret-create.tsx +0 -49
- package/src/components/secret-delete.tsx +0 -41
- package/src/components/secret-list.tsx +0 -41
- package/src/components/watch.tsx +0 -155
- package/src/hooks/useApi.ts +0 -183
- package/src/positronic.ts +0 -40
- package/src/test/data/resources/config.json +0 -1
- package/src/test/data/resources/data/config.json +0 -1
- package/src/test/data/resources/data/logo.png +0 -2
- package/src/test/data/resources/docs/api.md +0 -3
- package/src/test/data/resources/docs/readme.md +0 -3
- package/src/test/data/resources/example.md +0 -3
- package/src/test/data/resources/file with spaces.txt +0 -1
- package/src/test/data/resources/readme.md +0 -3
- package/src/test/data/resources/test.txt +0 -1
- package/src/test/mock-api-client.ts +0 -145
- package/src/test/test-dev-server.ts +0 -1003
- package/tsconfig.json +0 -11
|
@@ -1,761 +0,0 @@
|
|
|
1
|
-
function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
|
|
2
|
-
try {
|
|
3
|
-
var info = gen[key](arg);
|
|
4
|
-
var value = info.value;
|
|
5
|
-
} catch (error) {
|
|
6
|
-
reject(error);
|
|
7
|
-
return;
|
|
8
|
-
}
|
|
9
|
-
if (info.done) {
|
|
10
|
-
resolve(value);
|
|
11
|
-
} else {
|
|
12
|
-
Promise.resolve(value).then(_next, _throw);
|
|
13
|
-
}
|
|
14
|
-
}
|
|
15
|
-
function _async_to_generator(fn) {
|
|
16
|
-
return function() {
|
|
17
|
-
var self = this, args = arguments;
|
|
18
|
-
return new Promise(function(resolve, reject) {
|
|
19
|
-
var gen = fn.apply(self, args);
|
|
20
|
-
function _next(value) {
|
|
21
|
-
asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);
|
|
22
|
-
}
|
|
23
|
-
function _throw(err) {
|
|
24
|
-
asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);
|
|
25
|
-
}
|
|
26
|
-
_next(undefined);
|
|
27
|
-
});
|
|
28
|
-
};
|
|
29
|
-
}
|
|
30
|
-
function _ts_generator(thisArg, body) {
|
|
31
|
-
var f, y, t, _ = {
|
|
32
|
-
label: 0,
|
|
33
|
-
sent: function() {
|
|
34
|
-
if (t[0] & 1) throw t[1];
|
|
35
|
-
return t[1];
|
|
36
|
-
},
|
|
37
|
-
trys: [],
|
|
38
|
-
ops: []
|
|
39
|
-
}, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype);
|
|
40
|
-
return g.next = verb(0), g["throw"] = verb(1), g["return"] = verb(2), typeof Symbol === "function" && (g[Symbol.iterator] = function() {
|
|
41
|
-
return this;
|
|
42
|
-
}), g;
|
|
43
|
-
function verb(n) {
|
|
44
|
-
return function(v) {
|
|
45
|
-
return step([
|
|
46
|
-
n,
|
|
47
|
-
v
|
|
48
|
-
]);
|
|
49
|
-
};
|
|
50
|
-
}
|
|
51
|
-
function step(op) {
|
|
52
|
-
if (f) throw new TypeError("Generator is already executing.");
|
|
53
|
-
while(g && (g = 0, op[0] && (_ = 0)), _)try {
|
|
54
|
-
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
|
|
55
|
-
if (y = 0, t) op = [
|
|
56
|
-
op[0] & 2,
|
|
57
|
-
t.value
|
|
58
|
-
];
|
|
59
|
-
switch(op[0]){
|
|
60
|
-
case 0:
|
|
61
|
-
case 1:
|
|
62
|
-
t = op;
|
|
63
|
-
break;
|
|
64
|
-
case 4:
|
|
65
|
-
_.label++;
|
|
66
|
-
return {
|
|
67
|
-
value: op[1],
|
|
68
|
-
done: false
|
|
69
|
-
};
|
|
70
|
-
case 5:
|
|
71
|
-
_.label++;
|
|
72
|
-
y = op[1];
|
|
73
|
-
op = [
|
|
74
|
-
0
|
|
75
|
-
];
|
|
76
|
-
continue;
|
|
77
|
-
case 7:
|
|
78
|
-
op = _.ops.pop();
|
|
79
|
-
_.trys.pop();
|
|
80
|
-
continue;
|
|
81
|
-
default:
|
|
82
|
-
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {
|
|
83
|
-
_ = 0;
|
|
84
|
-
continue;
|
|
85
|
-
}
|
|
86
|
-
if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {
|
|
87
|
-
_.label = op[1];
|
|
88
|
-
break;
|
|
89
|
-
}
|
|
90
|
-
if (op[0] === 6 && _.label < t[1]) {
|
|
91
|
-
_.label = t[1];
|
|
92
|
-
t = op;
|
|
93
|
-
break;
|
|
94
|
-
}
|
|
95
|
-
if (t && _.label < t[2]) {
|
|
96
|
-
_.label = t[2];
|
|
97
|
-
_.ops.push(op);
|
|
98
|
-
break;
|
|
99
|
-
}
|
|
100
|
-
if (t[2]) _.ops.pop();
|
|
101
|
-
_.trys.pop();
|
|
102
|
-
continue;
|
|
103
|
-
}
|
|
104
|
-
op = body.call(thisArg, _);
|
|
105
|
-
} catch (e) {
|
|
106
|
-
op = [
|
|
107
|
-
6,
|
|
108
|
-
e
|
|
109
|
-
];
|
|
110
|
-
y = 0;
|
|
111
|
-
} finally{
|
|
112
|
-
f = t = 0;
|
|
113
|
-
}
|
|
114
|
-
if (op[0] & 5) throw op[1];
|
|
115
|
-
return {
|
|
116
|
-
value: op[0] ? op[1] : void 0,
|
|
117
|
-
done: true
|
|
118
|
-
};
|
|
119
|
-
}
|
|
120
|
-
}
|
|
121
|
-
import { describe, it, expect } from '@jest/globals';
|
|
122
|
-
import { createTestEnv } from './test-utils.js';
|
|
123
|
-
import * as fs from 'fs';
|
|
124
|
-
import * as path from 'path';
|
|
125
|
-
describe('secret commands', function() {
|
|
126
|
-
describe('secret create', function() {
|
|
127
|
-
it('should pass through to backend', function() {
|
|
128
|
-
return _async_to_generator(function() {
|
|
129
|
-
var env, px;
|
|
130
|
-
return _ts_generator(this, function(_state) {
|
|
131
|
-
switch(_state.label){
|
|
132
|
-
case 0:
|
|
133
|
-
return [
|
|
134
|
-
4,
|
|
135
|
-
createTestEnv()
|
|
136
|
-
];
|
|
137
|
-
case 1:
|
|
138
|
-
env = _state.sent();
|
|
139
|
-
return [
|
|
140
|
-
4,
|
|
141
|
-
env.start()
|
|
142
|
-
];
|
|
143
|
-
case 2:
|
|
144
|
-
px = _state.sent();
|
|
145
|
-
_state.label = 3;
|
|
146
|
-
case 3:
|
|
147
|
-
_state.trys.push([
|
|
148
|
-
3,
|
|
149
|
-
,
|
|
150
|
-
5,
|
|
151
|
-
7
|
|
152
|
-
]);
|
|
153
|
-
// Just verify it runs without error
|
|
154
|
-
return [
|
|
155
|
-
4,
|
|
156
|
-
px([
|
|
157
|
-
'secret',
|
|
158
|
-
'create',
|
|
159
|
-
'TEST_SECRET',
|
|
160
|
-
'--value=test-value'
|
|
161
|
-
])
|
|
162
|
-
];
|
|
163
|
-
case 4:
|
|
164
|
-
_state.sent();
|
|
165
|
-
return [
|
|
166
|
-
3,
|
|
167
|
-
7
|
|
168
|
-
];
|
|
169
|
-
case 5:
|
|
170
|
-
return [
|
|
171
|
-
4,
|
|
172
|
-
env.stopAndCleanup()
|
|
173
|
-
];
|
|
174
|
-
case 6:
|
|
175
|
-
_state.sent();
|
|
176
|
-
return [
|
|
177
|
-
7
|
|
178
|
-
];
|
|
179
|
-
case 7:
|
|
180
|
-
return [
|
|
181
|
-
2
|
|
182
|
-
];
|
|
183
|
-
}
|
|
184
|
-
});
|
|
185
|
-
})();
|
|
186
|
-
});
|
|
187
|
-
});
|
|
188
|
-
describe('secret list', function() {
|
|
189
|
-
it('should pass through to backend', function() {
|
|
190
|
-
return _async_to_generator(function() {
|
|
191
|
-
var env, px;
|
|
192
|
-
return _ts_generator(this, function(_state) {
|
|
193
|
-
switch(_state.label){
|
|
194
|
-
case 0:
|
|
195
|
-
return [
|
|
196
|
-
4,
|
|
197
|
-
createTestEnv()
|
|
198
|
-
];
|
|
199
|
-
case 1:
|
|
200
|
-
env = _state.sent();
|
|
201
|
-
return [
|
|
202
|
-
4,
|
|
203
|
-
env.start()
|
|
204
|
-
];
|
|
205
|
-
case 2:
|
|
206
|
-
px = _state.sent();
|
|
207
|
-
_state.label = 3;
|
|
208
|
-
case 3:
|
|
209
|
-
_state.trys.push([
|
|
210
|
-
3,
|
|
211
|
-
,
|
|
212
|
-
5,
|
|
213
|
-
7
|
|
214
|
-
]);
|
|
215
|
-
// Just verify it runs without error
|
|
216
|
-
return [
|
|
217
|
-
4,
|
|
218
|
-
px([
|
|
219
|
-
'secret',
|
|
220
|
-
'list'
|
|
221
|
-
])
|
|
222
|
-
];
|
|
223
|
-
case 4:
|
|
224
|
-
_state.sent();
|
|
225
|
-
return [
|
|
226
|
-
3,
|
|
227
|
-
7
|
|
228
|
-
];
|
|
229
|
-
case 5:
|
|
230
|
-
return [
|
|
231
|
-
4,
|
|
232
|
-
env.stopAndCleanup()
|
|
233
|
-
];
|
|
234
|
-
case 6:
|
|
235
|
-
_state.sent();
|
|
236
|
-
return [
|
|
237
|
-
7
|
|
238
|
-
];
|
|
239
|
-
case 7:
|
|
240
|
-
return [
|
|
241
|
-
2
|
|
242
|
-
];
|
|
243
|
-
}
|
|
244
|
-
});
|
|
245
|
-
})();
|
|
246
|
-
});
|
|
247
|
-
});
|
|
248
|
-
describe('secret delete', function() {
|
|
249
|
-
it('should pass through to backend', function() {
|
|
250
|
-
return _async_to_generator(function() {
|
|
251
|
-
var env, px;
|
|
252
|
-
return _ts_generator(this, function(_state) {
|
|
253
|
-
switch(_state.label){
|
|
254
|
-
case 0:
|
|
255
|
-
return [
|
|
256
|
-
4,
|
|
257
|
-
createTestEnv()
|
|
258
|
-
];
|
|
259
|
-
case 1:
|
|
260
|
-
env = _state.sent();
|
|
261
|
-
return [
|
|
262
|
-
4,
|
|
263
|
-
env.start()
|
|
264
|
-
];
|
|
265
|
-
case 2:
|
|
266
|
-
px = _state.sent();
|
|
267
|
-
_state.label = 3;
|
|
268
|
-
case 3:
|
|
269
|
-
_state.trys.push([
|
|
270
|
-
3,
|
|
271
|
-
,
|
|
272
|
-
5,
|
|
273
|
-
7
|
|
274
|
-
]);
|
|
275
|
-
// Just verify it runs without error
|
|
276
|
-
return [
|
|
277
|
-
4,
|
|
278
|
-
px([
|
|
279
|
-
'secret',
|
|
280
|
-
'delete',
|
|
281
|
-
'TEST_SECRET'
|
|
282
|
-
])
|
|
283
|
-
];
|
|
284
|
-
case 4:
|
|
285
|
-
_state.sent();
|
|
286
|
-
return [
|
|
287
|
-
3,
|
|
288
|
-
7
|
|
289
|
-
];
|
|
290
|
-
case 5:
|
|
291
|
-
return [
|
|
292
|
-
4,
|
|
293
|
-
env.stopAndCleanup()
|
|
294
|
-
];
|
|
295
|
-
case 6:
|
|
296
|
-
_state.sent();
|
|
297
|
-
return [
|
|
298
|
-
7
|
|
299
|
-
];
|
|
300
|
-
case 7:
|
|
301
|
-
return [
|
|
302
|
-
2
|
|
303
|
-
];
|
|
304
|
-
}
|
|
305
|
-
});
|
|
306
|
-
})();
|
|
307
|
-
});
|
|
308
|
-
});
|
|
309
|
-
describe('secret bulk', function() {
|
|
310
|
-
it('should bulk upload secrets from .env file', function() {
|
|
311
|
-
return _async_to_generator(function() {
|
|
312
|
-
var env, px, _ref, waitForOutput, instance, calls, bulkCall, secrets, secretNames;
|
|
313
|
-
return _ts_generator(this, function(_state) {
|
|
314
|
-
switch(_state.label){
|
|
315
|
-
case 0:
|
|
316
|
-
return [
|
|
317
|
-
4,
|
|
318
|
-
createTestEnv()
|
|
319
|
-
];
|
|
320
|
-
case 1:
|
|
321
|
-
env = _state.sent();
|
|
322
|
-
// Create a test .env file
|
|
323
|
-
env.setup(function(dir) {
|
|
324
|
-
var envContent = "TEST_API_KEY=sk-test123\nTEST_DATABASE_URL=postgres://user:pass@localhost:5432/db\nTEST_REDIS_URL=redis://localhost:6379";
|
|
325
|
-
fs.writeFileSync(path.join(dir, '.env'), envContent);
|
|
326
|
-
});
|
|
327
|
-
return [
|
|
328
|
-
4,
|
|
329
|
-
env.start()
|
|
330
|
-
];
|
|
331
|
-
case 2:
|
|
332
|
-
px = _state.sent();
|
|
333
|
-
_state.label = 3;
|
|
334
|
-
case 3:
|
|
335
|
-
_state.trys.push([
|
|
336
|
-
3,
|
|
337
|
-
,
|
|
338
|
-
6,
|
|
339
|
-
8
|
|
340
|
-
]);
|
|
341
|
-
return [
|
|
342
|
-
4,
|
|
343
|
-
px([
|
|
344
|
-
'secret',
|
|
345
|
-
'bulk'
|
|
346
|
-
])
|
|
347
|
-
];
|
|
348
|
-
case 4:
|
|
349
|
-
_ref = _state.sent(), waitForOutput = _ref.waitForOutput, instance = _ref.instance;
|
|
350
|
-
// Since bulk command passes through to backend,
|
|
351
|
-
// we can't check for output. Just wait a bit for completion.
|
|
352
|
-
return [
|
|
353
|
-
4,
|
|
354
|
-
new Promise(function(resolve) {
|
|
355
|
-
return setTimeout(resolve, 100);
|
|
356
|
-
})
|
|
357
|
-
];
|
|
358
|
-
case 5:
|
|
359
|
-
_state.sent();
|
|
360
|
-
// Verify server method was called
|
|
361
|
-
calls = env.server.getLogs();
|
|
362
|
-
bulkCall = calls.find(function(c) {
|
|
363
|
-
return c.method === 'bulkSecrets';
|
|
364
|
-
});
|
|
365
|
-
expect(bulkCall).toBeDefined();
|
|
366
|
-
// Verify the server received the correct secret names
|
|
367
|
-
secrets = env.server.getSecrets();
|
|
368
|
-
expect(secrets.length).toBe(3);
|
|
369
|
-
secretNames = secrets.map(function(s) {
|
|
370
|
-
return s.name;
|
|
371
|
-
});
|
|
372
|
-
expect(secretNames).toContain('TEST_API_KEY');
|
|
373
|
-
expect(secretNames).toContain('TEST_DATABASE_URL');
|
|
374
|
-
expect(secretNames).toContain('TEST_REDIS_URL');
|
|
375
|
-
return [
|
|
376
|
-
3,
|
|
377
|
-
8
|
|
378
|
-
];
|
|
379
|
-
case 6:
|
|
380
|
-
return [
|
|
381
|
-
4,
|
|
382
|
-
env.stopAndCleanup()
|
|
383
|
-
];
|
|
384
|
-
case 7:
|
|
385
|
-
_state.sent();
|
|
386
|
-
return [
|
|
387
|
-
7
|
|
388
|
-
];
|
|
389
|
-
case 8:
|
|
390
|
-
return [
|
|
391
|
-
2
|
|
392
|
-
];
|
|
393
|
-
}
|
|
394
|
-
});
|
|
395
|
-
})();
|
|
396
|
-
});
|
|
397
|
-
it('should handle custom .env file path', function() {
|
|
398
|
-
return _async_to_generator(function() {
|
|
399
|
-
var env, px, secrets, secretNames;
|
|
400
|
-
return _ts_generator(this, function(_state) {
|
|
401
|
-
switch(_state.label){
|
|
402
|
-
case 0:
|
|
403
|
-
return [
|
|
404
|
-
4,
|
|
405
|
-
createTestEnv()
|
|
406
|
-
];
|
|
407
|
-
case 1:
|
|
408
|
-
env = _state.sent();
|
|
409
|
-
env.setup(function(dir) {
|
|
410
|
-
var envContent = "SECRET_KEY=my-secret-key\nAPI_TOKEN=token123";
|
|
411
|
-
fs.writeFileSync(path.join(dir, '.env.production'), envContent);
|
|
412
|
-
});
|
|
413
|
-
return [
|
|
414
|
-
4,
|
|
415
|
-
env.start()
|
|
416
|
-
];
|
|
417
|
-
case 2:
|
|
418
|
-
px = _state.sent();
|
|
419
|
-
_state.label = 3;
|
|
420
|
-
case 3:
|
|
421
|
-
_state.trys.push([
|
|
422
|
-
3,
|
|
423
|
-
,
|
|
424
|
-
6,
|
|
425
|
-
8
|
|
426
|
-
]);
|
|
427
|
-
return [
|
|
428
|
-
4,
|
|
429
|
-
px([
|
|
430
|
-
'secret',
|
|
431
|
-
'bulk',
|
|
432
|
-
'.env.production'
|
|
433
|
-
])
|
|
434
|
-
];
|
|
435
|
-
case 4:
|
|
436
|
-
_state.sent();
|
|
437
|
-
// Since bulk command passes through to backend,
|
|
438
|
-
// we can't check for output. Just wait a bit for completion.
|
|
439
|
-
return [
|
|
440
|
-
4,
|
|
441
|
-
new Promise(function(resolve) {
|
|
442
|
-
return setTimeout(resolve, 100);
|
|
443
|
-
})
|
|
444
|
-
];
|
|
445
|
-
case 5:
|
|
446
|
-
_state.sent();
|
|
447
|
-
// Verify the server received the correct secret names
|
|
448
|
-
secrets = env.server.getSecrets();
|
|
449
|
-
expect(secrets.length).toBe(2);
|
|
450
|
-
secretNames = secrets.map(function(s) {
|
|
451
|
-
return s.name;
|
|
452
|
-
});
|
|
453
|
-
expect(secretNames).toContain('SECRET_KEY');
|
|
454
|
-
expect(secretNames).toContain('API_TOKEN');
|
|
455
|
-
return [
|
|
456
|
-
3,
|
|
457
|
-
8
|
|
458
|
-
];
|
|
459
|
-
case 6:
|
|
460
|
-
return [
|
|
461
|
-
4,
|
|
462
|
-
env.stopAndCleanup()
|
|
463
|
-
];
|
|
464
|
-
case 7:
|
|
465
|
-
_state.sent();
|
|
466
|
-
return [
|
|
467
|
-
7
|
|
468
|
-
];
|
|
469
|
-
case 8:
|
|
470
|
-
return [
|
|
471
|
-
2
|
|
472
|
-
];
|
|
473
|
-
}
|
|
474
|
-
});
|
|
475
|
-
})();
|
|
476
|
-
});
|
|
477
|
-
it('should handle successful bulk upload', function() {
|
|
478
|
-
return _async_to_generator(function() {
|
|
479
|
-
var env, px, calls, bulkCall;
|
|
480
|
-
return _ts_generator(this, function(_state) {
|
|
481
|
-
switch(_state.label){
|
|
482
|
-
case 0:
|
|
483
|
-
return [
|
|
484
|
-
4,
|
|
485
|
-
createTestEnv()
|
|
486
|
-
];
|
|
487
|
-
case 1:
|
|
488
|
-
env = _state.sent();
|
|
489
|
-
env.setup(function(dir) {
|
|
490
|
-
var envContent = "KEY1=value1\nKEY2=value2\nKEY3=value3";
|
|
491
|
-
fs.writeFileSync(path.join(dir, '.env'), envContent);
|
|
492
|
-
});
|
|
493
|
-
return [
|
|
494
|
-
4,
|
|
495
|
-
env.start()
|
|
496
|
-
];
|
|
497
|
-
case 2:
|
|
498
|
-
px = _state.sent();
|
|
499
|
-
_state.label = 3;
|
|
500
|
-
case 3:
|
|
501
|
-
_state.trys.push([
|
|
502
|
-
3,
|
|
503
|
-
,
|
|
504
|
-
6,
|
|
505
|
-
8
|
|
506
|
-
]);
|
|
507
|
-
return [
|
|
508
|
-
4,
|
|
509
|
-
px([
|
|
510
|
-
'secret',
|
|
511
|
-
'bulk'
|
|
512
|
-
])
|
|
513
|
-
];
|
|
514
|
-
case 4:
|
|
515
|
-
_state.sent();
|
|
516
|
-
// Since bulk command passes through to backend,
|
|
517
|
-
// we can't check for output. Just wait a bit for completion.
|
|
518
|
-
return [
|
|
519
|
-
4,
|
|
520
|
-
new Promise(function(resolve) {
|
|
521
|
-
return setTimeout(resolve, 100);
|
|
522
|
-
})
|
|
523
|
-
];
|
|
524
|
-
case 5:
|
|
525
|
-
_state.sent();
|
|
526
|
-
// Verify bulkSecrets was called
|
|
527
|
-
calls = env.server.getLogs();
|
|
528
|
-
bulkCall = calls.find(function(c) {
|
|
529
|
-
return c.method === 'bulkSecrets';
|
|
530
|
-
});
|
|
531
|
-
expect(bulkCall).toBeDefined();
|
|
532
|
-
return [
|
|
533
|
-
3,
|
|
534
|
-
8
|
|
535
|
-
];
|
|
536
|
-
case 6:
|
|
537
|
-
return [
|
|
538
|
-
4,
|
|
539
|
-
env.stopAndCleanup()
|
|
540
|
-
];
|
|
541
|
-
case 7:
|
|
542
|
-
_state.sent();
|
|
543
|
-
return [
|
|
544
|
-
7
|
|
545
|
-
];
|
|
546
|
-
case 8:
|
|
547
|
-
return [
|
|
548
|
-
2
|
|
549
|
-
];
|
|
550
|
-
}
|
|
551
|
-
});
|
|
552
|
-
})();
|
|
553
|
-
});
|
|
554
|
-
it('should handle file not found error', function() {
|
|
555
|
-
return _async_to_generator(function() {
|
|
556
|
-
var env, px, waitForOutput, foundError;
|
|
557
|
-
return _ts_generator(this, function(_state) {
|
|
558
|
-
switch(_state.label){
|
|
559
|
-
case 0:
|
|
560
|
-
return [
|
|
561
|
-
4,
|
|
562
|
-
createTestEnv()
|
|
563
|
-
];
|
|
564
|
-
case 1:
|
|
565
|
-
env = _state.sent();
|
|
566
|
-
return [
|
|
567
|
-
4,
|
|
568
|
-
env.start()
|
|
569
|
-
];
|
|
570
|
-
case 2:
|
|
571
|
-
px = _state.sent();
|
|
572
|
-
_state.label = 3;
|
|
573
|
-
case 3:
|
|
574
|
-
_state.trys.push([
|
|
575
|
-
3,
|
|
576
|
-
,
|
|
577
|
-
6,
|
|
578
|
-
8
|
|
579
|
-
]);
|
|
580
|
-
return [
|
|
581
|
-
4,
|
|
582
|
-
px([
|
|
583
|
-
'secret',
|
|
584
|
-
'bulk',
|
|
585
|
-
'nonexistent.env'
|
|
586
|
-
])
|
|
587
|
-
];
|
|
588
|
-
case 4:
|
|
589
|
-
waitForOutput = _state.sent().waitForOutput;
|
|
590
|
-
return [
|
|
591
|
-
4,
|
|
592
|
-
waitForOutput(/No .env file found/i, 30)
|
|
593
|
-
];
|
|
594
|
-
case 5:
|
|
595
|
-
foundError = _state.sent();
|
|
596
|
-
expect(foundError).toBe(true);
|
|
597
|
-
return [
|
|
598
|
-
3,
|
|
599
|
-
8
|
|
600
|
-
];
|
|
601
|
-
case 6:
|
|
602
|
-
return [
|
|
603
|
-
4,
|
|
604
|
-
env.stopAndCleanup()
|
|
605
|
-
];
|
|
606
|
-
case 7:
|
|
607
|
-
_state.sent();
|
|
608
|
-
return [
|
|
609
|
-
7
|
|
610
|
-
];
|
|
611
|
-
case 8:
|
|
612
|
-
return [
|
|
613
|
-
2
|
|
614
|
-
];
|
|
615
|
-
}
|
|
616
|
-
});
|
|
617
|
-
})();
|
|
618
|
-
});
|
|
619
|
-
it('should handle empty .env file', function() {
|
|
620
|
-
return _async_to_generator(function() {
|
|
621
|
-
var env, px, waitForOutput, foundError;
|
|
622
|
-
return _ts_generator(this, function(_state) {
|
|
623
|
-
switch(_state.label){
|
|
624
|
-
case 0:
|
|
625
|
-
return [
|
|
626
|
-
4,
|
|
627
|
-
createTestEnv()
|
|
628
|
-
];
|
|
629
|
-
case 1:
|
|
630
|
-
env = _state.sent();
|
|
631
|
-
env.setup(function(dir) {
|
|
632
|
-
// Create empty .env file
|
|
633
|
-
fs.writeFileSync(path.join(dir, '.env'), '');
|
|
634
|
-
});
|
|
635
|
-
return [
|
|
636
|
-
4,
|
|
637
|
-
env.start()
|
|
638
|
-
];
|
|
639
|
-
case 2:
|
|
640
|
-
px = _state.sent();
|
|
641
|
-
_state.label = 3;
|
|
642
|
-
case 3:
|
|
643
|
-
_state.trys.push([
|
|
644
|
-
3,
|
|
645
|
-
,
|
|
646
|
-
6,
|
|
647
|
-
8
|
|
648
|
-
]);
|
|
649
|
-
return [
|
|
650
|
-
4,
|
|
651
|
-
px([
|
|
652
|
-
'secret',
|
|
653
|
-
'bulk'
|
|
654
|
-
])
|
|
655
|
-
];
|
|
656
|
-
case 4:
|
|
657
|
-
waitForOutput = _state.sent().waitForOutput;
|
|
658
|
-
return [
|
|
659
|
-
4,
|
|
660
|
-
waitForOutput(/No secrets found in the .env file/i, 30)
|
|
661
|
-
];
|
|
662
|
-
case 5:
|
|
663
|
-
foundError = _state.sent();
|
|
664
|
-
expect(foundError).toBe(true);
|
|
665
|
-
return [
|
|
666
|
-
3,
|
|
667
|
-
8
|
|
668
|
-
];
|
|
669
|
-
case 6:
|
|
670
|
-
return [
|
|
671
|
-
4,
|
|
672
|
-
env.stopAndCleanup()
|
|
673
|
-
];
|
|
674
|
-
case 7:
|
|
675
|
-
_state.sent();
|
|
676
|
-
return [
|
|
677
|
-
7
|
|
678
|
-
];
|
|
679
|
-
case 8:
|
|
680
|
-
return [
|
|
681
|
-
2
|
|
682
|
-
];
|
|
683
|
-
}
|
|
684
|
-
});
|
|
685
|
-
})();
|
|
686
|
-
});
|
|
687
|
-
it('should handle mixed create/update results', function() {
|
|
688
|
-
return _async_to_generator(function() {
|
|
689
|
-
var env, px, waitForOutput;
|
|
690
|
-
return _ts_generator(this, function(_state) {
|
|
691
|
-
switch(_state.label){
|
|
692
|
-
case 0:
|
|
693
|
-
return [
|
|
694
|
-
4,
|
|
695
|
-
createTestEnv()
|
|
696
|
-
];
|
|
697
|
-
case 1:
|
|
698
|
-
env = _state.sent();
|
|
699
|
-
// Pre-create a secret so we can test update behavior
|
|
700
|
-
env.server.addSecret('EXISTING_KEY', 'old-value');
|
|
701
|
-
env.setup(function(dir) {
|
|
702
|
-
var envContent = "NEW_KEY=new-value\nEXISTING_KEY=updated-value";
|
|
703
|
-
fs.writeFileSync(path.join(dir, '.env'), envContent);
|
|
704
|
-
});
|
|
705
|
-
return [
|
|
706
|
-
4,
|
|
707
|
-
env.start()
|
|
708
|
-
];
|
|
709
|
-
case 2:
|
|
710
|
-
px = _state.sent();
|
|
711
|
-
_state.label = 3;
|
|
712
|
-
case 3:
|
|
713
|
-
_state.trys.push([
|
|
714
|
-
3,
|
|
715
|
-
,
|
|
716
|
-
6,
|
|
717
|
-
8
|
|
718
|
-
]);
|
|
719
|
-
return [
|
|
720
|
-
4,
|
|
721
|
-
px([
|
|
722
|
-
'secret',
|
|
723
|
-
'bulk'
|
|
724
|
-
])
|
|
725
|
-
];
|
|
726
|
-
case 4:
|
|
727
|
-
waitForOutput = _state.sent().waitForOutput;
|
|
728
|
-
// Since bulk command passes through to backend,
|
|
729
|
-
// we can't check for output. Just wait a bit for completion.
|
|
730
|
-
return [
|
|
731
|
-
4,
|
|
732
|
-
new Promise(function(resolve) {
|
|
733
|
-
return setTimeout(resolve, 100);
|
|
734
|
-
})
|
|
735
|
-
];
|
|
736
|
-
case 5:
|
|
737
|
-
_state.sent();
|
|
738
|
-
return [
|
|
739
|
-
3,
|
|
740
|
-
8
|
|
741
|
-
];
|
|
742
|
-
case 6:
|
|
743
|
-
return [
|
|
744
|
-
4,
|
|
745
|
-
env.stopAndCleanup()
|
|
746
|
-
];
|
|
747
|
-
case 7:
|
|
748
|
-
_state.sent();
|
|
749
|
-
return [
|
|
750
|
-
7
|
|
751
|
-
];
|
|
752
|
-
case 8:
|
|
753
|
-
return [
|
|
754
|
-
2
|
|
755
|
-
];
|
|
756
|
-
}
|
|
757
|
-
});
|
|
758
|
-
})();
|
|
759
|
-
});
|
|
760
|
-
});
|
|
761
|
-
});
|