@aws-cdk-testing/cli-integ 3.1.2 → 3.1.3
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/package.json +4 -4
- package/resources/cdk-apps/app/app.js +34 -0
- package/resources/cli-regression-patches/v2.178.1/NOTES.md +2 -0
- package/resources/cli-regression-patches/v2.178.1/skip-tests.txt +1 -0
- package/tests/cli-integ-tests/cli.integtest.js +52 -1
- package/tests/cli-integ-tests/cli.integtest.ts +67 -0
- package/bin/query-github.d.ts +0 -1
- package/bin/query-github.js +0 -54
- package/bin/run-suite.d.ts +0 -1
- package/bin/run-suite.js +0 -131
- package/bin/stage-distribution.d.ts +0 -1
- package/bin/stage-distribution.js +0 -217
- package/bin/test-root.d.ts +0 -1
- package/bin/test-root.js +0 -6
|
@@ -2252,6 +2252,73 @@ integTest(
|
|
|
2252
2252
|
}),
|
|
2253
2253
|
);
|
|
2254
2254
|
|
|
2255
|
+
/**
|
|
2256
|
+
* Create an S3 bucket, orphan that bucket, then import the bucket, with a NodeJSFunction lambda also in the stack.
|
|
2257
|
+
*
|
|
2258
|
+
* Validates fix for https://github.com/aws/aws-cdk/issues/31999 (import fails)
|
|
2259
|
+
*/
|
|
2260
|
+
integTest(
|
|
2261
|
+
'test resource import with construct that requires bundling',
|
|
2262
|
+
withDefaultFixture(async (fixture) => {
|
|
2263
|
+
// GIVEN
|
|
2264
|
+
const outputsFile = path.join(fixture.integTestDir, 'outputs', 'outputs.json');
|
|
2265
|
+
await fs.mkdir(path.dirname(outputsFile), { recursive: true });
|
|
2266
|
+
|
|
2267
|
+
// First, create a stack that includes a NodeJSFunction lambda and one bucket that will be removed from the stack but NOT deleted from AWS.
|
|
2268
|
+
await fixture.cdkDeploy('importable-stack', {
|
|
2269
|
+
modEnv: { INCLUDE_NODEJS_FUNCTION_LAMBDA: '1', INCLUDE_SINGLE_BUCKET: '1', RETAIN_SINGLE_BUCKET: '1' },
|
|
2270
|
+
options: ['--outputs-file', outputsFile],
|
|
2271
|
+
});
|
|
2272
|
+
|
|
2273
|
+
try {
|
|
2274
|
+
// Second, now the bucket we will remove is in the stack and has a logicalId. We can now make the resource mapping file.
|
|
2275
|
+
// This resource mapping file will be used to tell the import operation what bucket to bring into the stack.
|
|
2276
|
+
const fullStackName = fixture.fullStackName('importable-stack');
|
|
2277
|
+
const outputs = JSON.parse((await fs.readFile(outputsFile, { encoding: 'utf-8' })).toString());
|
|
2278
|
+
const bucketLogicalId = outputs[fullStackName].BucketLogicalId;
|
|
2279
|
+
const bucketName = outputs[fullStackName].BucketName;
|
|
2280
|
+
const bucketResourceMap = {
|
|
2281
|
+
[bucketLogicalId]: {
|
|
2282
|
+
BucketName: bucketName,
|
|
2283
|
+
},
|
|
2284
|
+
};
|
|
2285
|
+
const mappingFile = path.join(fixture.integTestDir, 'outputs', 'mapping.json');
|
|
2286
|
+
await fs.writeFile(mappingFile, JSON.stringify(bucketResourceMap), { encoding: 'utf-8' });
|
|
2287
|
+
|
|
2288
|
+
// Third, remove the bucket from the stack, but don't delete the bucket from AWS.
|
|
2289
|
+
await fixture.cdkDeploy('importable-stack', {
|
|
2290
|
+
modEnv: { INCLUDE_NODEJS_FUNCTION_LAMBDA: '1', INCLUDE_SINGLE_BUCKET: '0', RETAIN_SINGLE_BUCKET: '0' },
|
|
2291
|
+
});
|
|
2292
|
+
const cfnTemplateBeforeImport = await fixture.aws.cloudFormation.send(
|
|
2293
|
+
new GetTemplateCommand({ StackName: fullStackName }),
|
|
2294
|
+
);
|
|
2295
|
+
expect(cfnTemplateBeforeImport.TemplateBody).not.toContain(bucketLogicalId);
|
|
2296
|
+
|
|
2297
|
+
// WHEN
|
|
2298
|
+
await fixture.cdk(['import', '--resource-mapping', mappingFile, fixture.fullStackName('importable-stack')], {
|
|
2299
|
+
modEnv: { INCLUDE_NODEJS_FUNCTION_LAMBDA: '1', INCLUDE_SINGLE_BUCKET: '1', RETAIN_SINGLE_BUCKET: '0' },
|
|
2300
|
+
});
|
|
2301
|
+
|
|
2302
|
+
// THEN
|
|
2303
|
+
const describeStacksResponse = await fixture.aws.cloudFormation.send(
|
|
2304
|
+
new DescribeStacksCommand({ StackName: fullStackName }),
|
|
2305
|
+
);
|
|
2306
|
+
const cfnTemplateAfterImport = await fixture.aws.cloudFormation.send(
|
|
2307
|
+
new GetTemplateCommand({ StackName: fullStackName }),
|
|
2308
|
+
);
|
|
2309
|
+
|
|
2310
|
+
// If bundling is skipped during import for NodeJSFunction lambda, then the operation should fail and exit
|
|
2311
|
+
expect(describeStacksResponse.Stacks![0].StackStatus).toEqual('IMPORT_COMPLETE');
|
|
2312
|
+
|
|
2313
|
+
// If the import operation is successful, the template should contain the imported bucket
|
|
2314
|
+
expect(cfnTemplateAfterImport.TemplateBody).toContain(bucketLogicalId);
|
|
2315
|
+
} finally {
|
|
2316
|
+
// Clean up the resources we created
|
|
2317
|
+
await fixture.cdkDestroy('importable-stack');
|
|
2318
|
+
}
|
|
2319
|
+
}),
|
|
2320
|
+
);
|
|
2321
|
+
|
|
2255
2322
|
/**
|
|
2256
2323
|
* Create a queue, orphan that queue, then import the queue.
|
|
2257
2324
|
*
|
package/bin/query-github.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
package/bin/query-github.js
DELETED
|
@@ -1,54 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const yargs = require("yargs");
|
|
4
|
-
const github_1 = require("../lib/github");
|
|
5
|
-
async function main() {
|
|
6
|
-
var _a;
|
|
7
|
-
const args = await yargs
|
|
8
|
-
.option('token', {
|
|
9
|
-
descripton: 'GitHub token (default: from environment GITHUB_TOKEN)',
|
|
10
|
-
alias: 't',
|
|
11
|
-
type: 'string',
|
|
12
|
-
requiresArg: true,
|
|
13
|
-
})
|
|
14
|
-
.command('last-release', 'Query the last release', cmd => cmd
|
|
15
|
-
.option('prior-to', {
|
|
16
|
-
description: 'Return the most recent release before the given version',
|
|
17
|
-
alias: 'p',
|
|
18
|
-
type: 'string',
|
|
19
|
-
requiresArg: true,
|
|
20
|
-
})
|
|
21
|
-
.option('major', {
|
|
22
|
-
description: 'Return the most recent release that matches',
|
|
23
|
-
alias: 'm',
|
|
24
|
-
type: 'string',
|
|
25
|
-
requiresArg: true,
|
|
26
|
-
}))
|
|
27
|
-
.demandCommand()
|
|
28
|
-
.help()
|
|
29
|
-
.showHelpOnFail(false)
|
|
30
|
-
.argv;
|
|
31
|
-
const command = args._[0];
|
|
32
|
-
const token = (_a = args.token) !== null && _a !== void 0 ? _a : process.env.GITHUB_TOKEN;
|
|
33
|
-
if (!token) {
|
|
34
|
-
throw new Error('Either pass --token or set GITHUB_TOKEN.');
|
|
35
|
-
}
|
|
36
|
-
switch (command) {
|
|
37
|
-
case 'last-release':
|
|
38
|
-
if (args['prior-to'] && args.major) {
|
|
39
|
-
throw new Error('Cannot pass both `--prior-to and --major at the same time');
|
|
40
|
-
}
|
|
41
|
-
// eslint-disable-next-line no-console
|
|
42
|
-
console.log(await (0, github_1.fetchPreviousVersion)(token, {
|
|
43
|
-
priorTo: args['prior-to'],
|
|
44
|
-
majorVersion: args.major,
|
|
45
|
-
}));
|
|
46
|
-
break;
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
main().catch(e => {
|
|
50
|
-
// eslint-disable-next-line no-console
|
|
51
|
-
console.error(e);
|
|
52
|
-
process.exitCode = 1;
|
|
53
|
-
});
|
|
54
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicXVlcnktZ2l0aHViLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsicXVlcnktZ2l0aHViLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsK0JBQStCO0FBQy9CLDBDQUFxRDtBQUVyRCxLQUFLLFVBQVUsSUFBSTs7SUFDakIsTUFBTSxJQUFJLEdBQUcsTUFBTSxLQUFLO1NBQ3JCLE1BQU0sQ0FBQyxPQUFPLEVBQUU7UUFDZixVQUFVLEVBQUUsdURBQXVEO1FBQ25FLEtBQUssRUFBRSxHQUFHO1FBQ1YsSUFBSSxFQUFFLFFBQVE7UUFDZCxXQUFXLEVBQUUsSUFBSTtLQUNsQixDQUFDO1NBQ0QsT0FBTyxDQUFDLGNBQWMsRUFBRSx3QkFBd0IsRUFBRSxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUc7U0FDMUQsTUFBTSxDQUFDLFVBQVUsRUFBRTtRQUNsQixXQUFXLEVBQUUseURBQXlEO1FBQ3RFLEtBQUssRUFBRSxHQUFHO1FBQ1YsSUFBSSxFQUFFLFFBQVE7UUFDZCxXQUFXLEVBQUUsSUFBSTtLQUNsQixDQUFDO1NBQ0QsTUFBTSxDQUFDLE9BQU8sRUFBRTtRQUNmLFdBQVcsRUFBRSw2Q0FBNkM7UUFDMUQsS0FBSyxFQUFFLEdBQUc7UUFDVixJQUFJLEVBQUUsUUFBUTtRQUNkLFdBQVcsRUFBRSxJQUFJO0tBQ2xCLENBQUMsQ0FBQztTQUNKLGFBQWEsRUFBRTtTQUNmLElBQUksRUFBRTtTQUNOLGNBQWMsQ0FBQyxLQUFLLENBQUM7U0FDckIsSUFBSSxDQUFDO0lBRVIsTUFBTSxPQUFPLEdBQUcsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUUxQixNQUFNLEtBQUssR0FBRyxNQUFBLElBQUksQ0FBQyxLQUFLLG1DQUFJLE9BQU8sQ0FBQyxHQUFHLENBQUMsWUFBWSxDQUFDO0lBQ3JELElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUNYLE1BQU0sSUFBSSxLQUFLLENBQUMsMENBQTBDLENBQUMsQ0FBQztJQUM5RCxDQUFDO0lBRUQsUUFBUSxPQUFPLEVBQUUsQ0FBQztRQUNoQixLQUFLLGNBQWM7WUFDakIsSUFBSSxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDO2dCQUNuQyxNQUFNLElBQUksS0FBSyxDQUFDLDJEQUEyRCxDQUFDLENBQUM7WUFDL0UsQ0FBQztZQUVELHNDQUFzQztZQUN0QyxPQUFPLENBQUMsR0FBRyxDQUFDLE1BQU0sSUFBQSw2QkFBb0IsRUFBQyxLQUFLLEVBQUU7Z0JBQzVDLE9BQU8sRUFBRSxJQUFJLENBQUMsVUFBVSxDQUFDO2dCQUN6QixZQUFZLEVBQUUsSUFBSSxDQUFDLEtBQUs7YUFDekIsQ0FBQyxDQUFDLENBQUM7WUFDSixNQUFNO0lBQ1YsQ0FBQztBQUNILENBQUM7QUFFRCxJQUFJLEVBQUUsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLEVBQUU7SUFDZixzQ0FBc0M7SUFDdEMsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNqQixPQUFPLENBQUMsUUFBUSxHQUFHLENBQUMsQ0FBQztBQUN2QixDQUFDLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIHlhcmdzIGZyb20gJ3lhcmdzJztcbmltcG9ydCB7IGZldGNoUHJldmlvdXNWZXJzaW9uIH0gZnJvbSAnLi4vbGliL2dpdGh1Yic7XG5cbmFzeW5jIGZ1bmN0aW9uIG1haW4oKSB7XG4gIGNvbnN0IGFyZ3MgPSBhd2FpdCB5YXJnc1xuICAgIC5vcHRpb24oJ3Rva2VuJywge1xuICAgICAgZGVzY3JpcHRvbjogJ0dpdEh1YiB0b2tlbiAoZGVmYXVsdDogZnJvbSBlbnZpcm9ubWVudCBHSVRIVUJfVE9LRU4pJyxcbiAgICAgIGFsaWFzOiAndCcsXG4gICAgICB0eXBlOiAnc3RyaW5nJyxcbiAgICAgIHJlcXVpcmVzQXJnOiB0cnVlLFxuICAgIH0pXG4gICAgLmNvbW1hbmQoJ2xhc3QtcmVsZWFzZScsICdRdWVyeSB0aGUgbGFzdCByZWxlYXNlJywgY21kID0+IGNtZFxuICAgICAgLm9wdGlvbigncHJpb3ItdG8nLCB7XG4gICAgICAgIGRlc2NyaXB0aW9uOiAnUmV0dXJuIHRoZSBtb3N0IHJlY2VudCByZWxlYXNlIGJlZm9yZSB0aGUgZ2l2ZW4gdmVyc2lvbicsXG4gICAgICAgIGFsaWFzOiAncCcsXG4gICAgICAgIHR5cGU6ICdzdHJpbmcnLFxuICAgICAgICByZXF1aXJlc0FyZzogdHJ1ZSxcbiAgICAgIH0pXG4gICAgICAub3B0aW9uKCdtYWpvcicsIHtcbiAgICAgICAgZGVzY3JpcHRpb246ICdSZXR1cm4gdGhlIG1vc3QgcmVjZW50IHJlbGVhc2UgdGhhdCBtYXRjaGVzJyxcbiAgICAgICAgYWxpYXM6ICdtJyxcbiAgICAgICAgdHlwZTogJ3N0cmluZycsXG4gICAgICAgIHJlcXVpcmVzQXJnOiB0cnVlLFxuICAgICAgfSkpXG4gICAgLmRlbWFuZENvbW1hbmQoKVxuICAgIC5oZWxwKClcbiAgICAuc2hvd0hlbHBPbkZhaWwoZmFsc2UpXG4gICAgLmFyZ3Y7XG5cbiAgY29uc3QgY29tbWFuZCA9IGFyZ3MuX1swXTtcblxuICBjb25zdCB0b2tlbiA9IGFyZ3MudG9rZW4gPz8gcHJvY2Vzcy5lbnYuR0lUSFVCX1RPS0VOO1xuICBpZiAoIXRva2VuKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdFaXRoZXIgcGFzcyAtLXRva2VuIG9yIHNldCBHSVRIVUJfVE9LRU4uJyk7XG4gIH1cblxuICBzd2l0Y2ggKGNvbW1hbmQpIHtcbiAgICBjYXNlICdsYXN0LXJlbGVhc2UnOlxuICAgICAgaWYgKGFyZ3NbJ3ByaW9yLXRvJ10gJiYgYXJncy5tYWpvcikge1xuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoJ0Nhbm5vdCBwYXNzIGJvdGggYC0tcHJpb3ItdG8gYW5kIC0tbWFqb3IgYXQgdGhlIHNhbWUgdGltZScpO1xuICAgICAgfVxuXG4gICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tY29uc29sZVxuICAgICAgY29uc29sZS5sb2coYXdhaXQgZmV0Y2hQcmV2aW91c1ZlcnNpb24odG9rZW4sIHtcbiAgICAgICAgcHJpb3JUbzogYXJnc1sncHJpb3ItdG8nXSxcbiAgICAgICAgbWFqb3JWZXJzaW9uOiBhcmdzLm1ham9yLFxuICAgICAgfSkpO1xuICAgICAgYnJlYWs7XG4gIH1cbn1cblxubWFpbigpLmNhdGNoKGUgPT4ge1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tY29uc29sZVxuICBjb25zb2xlLmVycm9yKGUpO1xuICBwcm9jZXNzLmV4aXRDb2RlID0gMTtcbn0pO1xuIl19
|
package/bin/run-suite.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
package/bin/run-suite.js
DELETED
|
@@ -1,131 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
/* eslint-disable no-console */
|
|
4
|
-
const path = require("path");
|
|
5
|
-
const jest = require("jest");
|
|
6
|
-
const yargs = require("yargs");
|
|
7
|
-
const release_source_1 = require("../lib/package-sources/release-source");
|
|
8
|
-
const repo_source_1 = require("../lib/package-sources/repo-source");
|
|
9
|
-
const subprocess_1 = require("../lib/package-sources/subprocess");
|
|
10
|
-
async function main() {
|
|
11
|
-
var _a;
|
|
12
|
-
const args = await yargs
|
|
13
|
-
.usage('$0 <SUITENAME>')
|
|
14
|
-
.positional('SUITENAME', {
|
|
15
|
-
descripton: 'Name of the test suite to run',
|
|
16
|
-
type: 'string',
|
|
17
|
-
demandOption: true,
|
|
18
|
-
})
|
|
19
|
-
.option('test', {
|
|
20
|
-
descripton: 'Test pattern to selectively run tests',
|
|
21
|
-
alias: 't',
|
|
22
|
-
type: 'string',
|
|
23
|
-
requiresArg: true,
|
|
24
|
-
})
|
|
25
|
-
.option('test-file', {
|
|
26
|
-
description: 'The specific test file to run',
|
|
27
|
-
type: 'string',
|
|
28
|
-
requiresArg: true,
|
|
29
|
-
})
|
|
30
|
-
.option('use-source', {
|
|
31
|
-
descripton: 'Use TypeScript packages from the given source repository (or "auto")',
|
|
32
|
-
alias: 's',
|
|
33
|
-
type: 'string',
|
|
34
|
-
requiresArg: true,
|
|
35
|
-
})
|
|
36
|
-
.option('use-cli-release', {
|
|
37
|
-
descripton: 'Run the current tests against the CLI at the given version',
|
|
38
|
-
alias: 'u',
|
|
39
|
-
type: 'string',
|
|
40
|
-
requiresArg: true,
|
|
41
|
-
})
|
|
42
|
-
.option('auto-source', {
|
|
43
|
-
alias: 'a',
|
|
44
|
-
description: 'Automatically find the source tree from the current working directory',
|
|
45
|
-
type: 'boolean',
|
|
46
|
-
requiresArg: false,
|
|
47
|
-
})
|
|
48
|
-
.option('runInBand', {
|
|
49
|
-
descripton: 'Run all tests in one Node process',
|
|
50
|
-
alias: 'i',
|
|
51
|
-
type: 'boolean',
|
|
52
|
-
})
|
|
53
|
-
.options('framework-version', {
|
|
54
|
-
description: 'Framework version to use, if different than the CLI version (not all suites respect this)',
|
|
55
|
-
alias: 'f',
|
|
56
|
-
type: 'string',
|
|
57
|
-
})
|
|
58
|
-
.options('verbose', {
|
|
59
|
-
alias: 'v',
|
|
60
|
-
description: 'Run in verbose mode',
|
|
61
|
-
type: 'boolean',
|
|
62
|
-
requiresArg: false,
|
|
63
|
-
})
|
|
64
|
-
.options('passWithNoTests', {
|
|
65
|
-
description: 'Allow passing if the test suite is not found (default true when IS_CANARY mode, false otherwise)',
|
|
66
|
-
type: 'boolean',
|
|
67
|
-
requiresArg: false,
|
|
68
|
-
})
|
|
69
|
-
.help()
|
|
70
|
-
.showHelpOnFail(false)
|
|
71
|
-
.argv;
|
|
72
|
-
const suiteName = args._[0];
|
|
73
|
-
if (!suiteName) {
|
|
74
|
-
throw new Error('Usage: run-suite <SUITENAME>');
|
|
75
|
-
}
|
|
76
|
-
let packageSource;
|
|
77
|
-
function usePackageSource(s) {
|
|
78
|
-
if (packageSource) {
|
|
79
|
-
throw new Error('Cannot specify two package sources');
|
|
80
|
-
}
|
|
81
|
-
packageSource = s;
|
|
82
|
-
}
|
|
83
|
-
if (args['use-source'] || args['auto-source']) {
|
|
84
|
-
if (args['framework-version']) {
|
|
85
|
-
throw new Error('Cannot use --framework-version with --use-source');
|
|
86
|
-
}
|
|
87
|
-
const root = args['use-source'] && args['use-source'] !== 'auto'
|
|
88
|
-
? args['use-source']
|
|
89
|
-
: await (0, repo_source_1.autoFindRoot)();
|
|
90
|
-
usePackageSource(new repo_source_1.RepoPackageSourceSetup(root));
|
|
91
|
-
}
|
|
92
|
-
else if (args['use-cli-release']) {
|
|
93
|
-
usePackageSource(new release_source_1.ReleasePackageSourceSetup(args['use-cli-release'], args['framework-version']));
|
|
94
|
-
}
|
|
95
|
-
if (!packageSource) {
|
|
96
|
-
throw new Error('Specify either --use-source or --use-cli-release');
|
|
97
|
-
}
|
|
98
|
-
console.log(`Package source: ${packageSource.description}`);
|
|
99
|
-
console.log(`Test suite: ${suiteName}`);
|
|
100
|
-
await packageSource.prepare();
|
|
101
|
-
(0, subprocess_1.serializeForSubprocess)(packageSource);
|
|
102
|
-
if (args.verbose) {
|
|
103
|
-
process.env.VERBOSE = '1';
|
|
104
|
-
}
|
|
105
|
-
// Motivation behind this behavior: when adding a new test suite to the pipeline, because of the way our
|
|
106
|
-
// Pipeline package works, the suite would be added to the pipeline AND as a canary immediately. The canary
|
|
107
|
-
// would fail until the package was actually released, so for canaries we make an exception so that the initial
|
|
108
|
-
// canary would succeed even if the suite wasn't yet available. The fact that the suite is not optional in
|
|
109
|
-
// the pipeline protects us from typos.
|
|
110
|
-
const passWithNoTests = (_a = args.passWithNoTests) !== null && _a !== void 0 ? _a : !!process.env.IS_CANARY;
|
|
111
|
-
// Communicate with the config file (integ.jest.config.js)
|
|
112
|
-
process.env.TEST_SUITE_NAME = suiteName;
|
|
113
|
-
try {
|
|
114
|
-
await jest.run([
|
|
115
|
-
...args.runInBand ? ['-i'] : [],
|
|
116
|
-
...args.test ? ['-t', args.test] : [],
|
|
117
|
-
...args.verbose ? ['--verbose'] : [],
|
|
118
|
-
...passWithNoTests ? ['--passWithNoTests'] : [],
|
|
119
|
-
...args['test-file'] ? [args['test-file']] : [],
|
|
120
|
-
], path.resolve(__dirname, '..', 'resources', 'integ.jest.config.js'));
|
|
121
|
-
}
|
|
122
|
-
finally {
|
|
123
|
-
await packageSource.cleanup();
|
|
124
|
-
}
|
|
125
|
-
}
|
|
126
|
-
main().catch(e => {
|
|
127
|
-
// eslint-disable-next-line no-console
|
|
128
|
-
console.error(e);
|
|
129
|
-
process.exitCode = 1;
|
|
130
|
-
});
|
|
131
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"run-suite.js","sourceRoot":"","sources":["run-suite.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable no-console */\nimport * as path from 'path';\nimport * as jest from 'jest';\nimport * as yargs from 'yargs';\nimport { ReleasePackageSourceSetup } from '../lib/package-sources/release-source';\nimport { RepoPackageSourceSetup, autoFindRoot } from '../lib/package-sources/repo-source';\nimport { IPackageSourceSetup } from '../lib/package-sources/source';\nimport { serializeForSubprocess } from '../lib/package-sources/subprocess';\n\nasync function main() {\n  const args = await yargs\n    .usage('$0 <SUITENAME>')\n    .positional('SUITENAME', {\n      descripton: 'Name of the test suite to run',\n      type: 'string',\n      demandOption: true,\n    })\n    .option('test', {\n      descripton: 'Test pattern to selectively run tests',\n      alias: 't',\n      type: 'string',\n      requiresArg: true,\n    })\n    .option('test-file', {\n      description: 'The specific test file to run',\n      type: 'string',\n      requiresArg: true,\n    })\n    .option('use-source', {\n      descripton: 'Use TypeScript packages from the given source repository (or \"auto\")',\n      alias: 's',\n      type: 'string',\n      requiresArg: true,\n    })\n    .option('use-cli-release', {\n      descripton: 'Run the current tests against the CLI at the given version',\n      alias: 'u',\n      type: 'string',\n      requiresArg: true,\n    })\n    .option('auto-source', {\n      alias: 'a',\n      description: 'Automatically find the source tree from the current working directory',\n      type: 'boolean',\n      requiresArg: false,\n    })\n    .option('runInBand', {\n      descripton: 'Run all tests in one Node process',\n      alias: 'i',\n      type: 'boolean',\n    })\n    .options('framework-version', {\n      description: 'Framework version to use, if different than the CLI version (not all suites respect this)',\n      alias: 'f',\n      type: 'string',\n    })\n    .options('verbose', {\n      alias: 'v',\n      description: 'Run in verbose mode',\n      type: 'boolean',\n      requiresArg: false,\n    })\n    .options('passWithNoTests', {\n      description: 'Allow passing if the test suite is not found (default true when IS_CANARY mode, false otherwise)',\n      type: 'boolean',\n      requiresArg: false,\n    })\n    .help()\n    .showHelpOnFail(false)\n    .argv;\n\n  const suiteName = args._[0] as string;\n  if (!suiteName) {\n    throw new Error('Usage: run-suite <SUITENAME>');\n  }\n\n  let packageSource: undefined | IPackageSourceSetup;\n  function usePackageSource(s: IPackageSourceSetup) {\n    if (packageSource) {\n      throw new Error('Cannot specify two package sources');\n    }\n    packageSource = s;\n  }\n\n  if (args['use-source'] || args['auto-source']) {\n    if (args['framework-version']) {\n      throw new Error('Cannot use --framework-version with --use-source');\n    }\n\n    const root = args['use-source'] && args['use-source'] !== 'auto'\n      ? args['use-source']\n      : await autoFindRoot();\n\n    usePackageSource(new RepoPackageSourceSetup(root));\n  } else if (args['use-cli-release']) {\n    usePackageSource(new ReleasePackageSourceSetup(args['use-cli-release'], args['framework-version']));\n  }\n  if (!packageSource) {\n    throw new Error('Specify either --use-source or --use-cli-release');\n  }\n\n  console.log(`Package source: ${packageSource.description}`);\n  console.log(`Test suite:     ${suiteName}`);\n\n  await packageSource.prepare();\n  serializeForSubprocess(packageSource);\n\n  if (args.verbose) {\n    process.env.VERBOSE = '1';\n  }\n\n  // Motivation behind this behavior: when adding a new test suite to the pipeline, because of the way our\n  // Pipeline package works, the suite would be added to the pipeline AND as a canary immediately. The canary\n  // would fail until the package was actually released, so for canaries we make an exception so that the initial\n  // canary would succeed even if the suite wasn't yet available. The fact that the suite is not optional in\n  // the pipeline protects us from typos.\n  const passWithNoTests = args.passWithNoTests ?? !!process.env.IS_CANARY;\n\n  // Communicate with the config file (integ.jest.config.js)\n  process.env.TEST_SUITE_NAME = suiteName;\n\n  try {\n    await jest.run([\n      ...args.runInBand ? ['-i'] : [],\n      ...args.test ? ['-t', args.test] : [],\n      ...args.verbose ? ['--verbose'] : [],\n      ...passWithNoTests ? ['--passWithNoTests'] : [],\n      ...args['test-file'] ? [args['test-file']] : [],\n    ], path.resolve(__dirname, '..', 'resources', 'integ.jest.config.js'));\n\n  } finally {\n    await packageSource.cleanup();\n  }\n}\n\nmain().catch(e => {\n  // eslint-disable-next-line no-console\n  console.error(e);\n  process.exitCode = 1;\n});\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1,217 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
/* eslint-disable no-console */
|
|
4
|
-
const path = require("path");
|
|
5
|
-
const fs = require("fs-extra");
|
|
6
|
-
const glob = require("glob");
|
|
7
|
-
const yargs = require("yargs");
|
|
8
|
-
const lib_1 = require("../lib");
|
|
9
|
-
const codeartifact_1 = require("../lib/staging/codeartifact");
|
|
10
|
-
const maven_1 = require("../lib/staging/maven");
|
|
11
|
-
const npm_1 = require("../lib/staging/npm");
|
|
12
|
-
const nuget_1 = require("../lib/staging/nuget");
|
|
13
|
-
const pypi_1 = require("../lib/staging/pypi");
|
|
14
|
-
const usage_dir_1 = require("../lib/staging/usage-dir");
|
|
15
|
-
async function main() {
|
|
16
|
-
await yargs
|
|
17
|
-
.usage('$0 <command>')
|
|
18
|
-
.option('npm', {
|
|
19
|
-
description: 'Upload NPM packages only',
|
|
20
|
-
type: 'boolean',
|
|
21
|
-
requiresArg: false,
|
|
22
|
-
})
|
|
23
|
-
.option('python', {
|
|
24
|
-
description: 'Upload Python packages only',
|
|
25
|
-
type: 'boolean',
|
|
26
|
-
requiresArg: false,
|
|
27
|
-
})
|
|
28
|
-
.option('java', {
|
|
29
|
-
description: 'Upload Java packages only',
|
|
30
|
-
type: 'boolean',
|
|
31
|
-
requiresArg: false,
|
|
32
|
-
})
|
|
33
|
-
.option('dotnet', {
|
|
34
|
-
description: 'Upload Dotnet packages only',
|
|
35
|
-
type: 'boolean',
|
|
36
|
-
requiresArg: false,
|
|
37
|
-
})
|
|
38
|
-
.option('regression', {
|
|
39
|
-
description: 'Enable access to previous versions of the staged packages (this is expensive for CodeArtifact so we only do it when necessary)',
|
|
40
|
-
type: 'boolean',
|
|
41
|
-
requiresArg: false,
|
|
42
|
-
default: false,
|
|
43
|
-
})
|
|
44
|
-
.command('publish <DIRECTORY>', 'Publish a given directory', cmd => cmd
|
|
45
|
-
.positional('DIRECTORY', {
|
|
46
|
-
descripton: 'Directory distribution',
|
|
47
|
-
type: 'string',
|
|
48
|
-
demandOption: true,
|
|
49
|
-
})
|
|
50
|
-
.option('name', {
|
|
51
|
-
alias: 'n',
|
|
52
|
-
description: 'Name of the repository to create (default: generate unique name)',
|
|
53
|
-
type: 'string',
|
|
54
|
-
requiresArg: true,
|
|
55
|
-
}), async (args) => {
|
|
56
|
-
await validateDirectory(args);
|
|
57
|
-
const repo = await (args.name ? codeartifact_1.TestRepository.newWithName(args.name) : codeartifact_1.TestRepository.newRandom());
|
|
58
|
-
const usageDir = usage_dir_1.UsageDir.default();
|
|
59
|
-
await doLogin(repo, usageDir, args);
|
|
60
|
-
await publish(repo, usageDir, args);
|
|
61
|
-
header('Done');
|
|
62
|
-
usageDir.advertise();
|
|
63
|
-
})
|
|
64
|
-
.command('login', 'Login to a given repository', cmd => cmd
|
|
65
|
-
.option('name', {
|
|
66
|
-
alias: 'n',
|
|
67
|
-
description: 'Name of the repository to log in to',
|
|
68
|
-
type: 'string',
|
|
69
|
-
requiresArg: true,
|
|
70
|
-
demandOption: true,
|
|
71
|
-
}), async (args) => {
|
|
72
|
-
const repo = codeartifact_1.TestRepository.existing(args.name);
|
|
73
|
-
const usageDir = usage_dir_1.UsageDir.default();
|
|
74
|
-
await doLogin(repo, usageDir, args);
|
|
75
|
-
usageDir.advertise();
|
|
76
|
-
})
|
|
77
|
-
.command('run <DIRECTORY> <COMMAND..>', 'Publish and run a command', cmd => cmd
|
|
78
|
-
.positional('DIRECTORY', {
|
|
79
|
-
descripton: 'Directory distribution',
|
|
80
|
-
type: 'string',
|
|
81
|
-
demandOption: true,
|
|
82
|
-
})
|
|
83
|
-
.positional('COMMAND', {
|
|
84
|
-
alias: 'c',
|
|
85
|
-
description: 'Run the given command with the packages staged',
|
|
86
|
-
type: 'string',
|
|
87
|
-
array: true,
|
|
88
|
-
demandOption: true,
|
|
89
|
-
})
|
|
90
|
-
.option('cleanup', {
|
|
91
|
-
alias: 'C',
|
|
92
|
-
description: 'Cleanup the repository afterwards',
|
|
93
|
-
type: 'boolean',
|
|
94
|
-
default: true,
|
|
95
|
-
requiresArg: false,
|
|
96
|
-
}), async (args) => {
|
|
97
|
-
var _a;
|
|
98
|
-
await validateDirectory(args);
|
|
99
|
-
const repo = await codeartifact_1.TestRepository.newRandom();
|
|
100
|
-
const usageDir = usage_dir_1.UsageDir.default();
|
|
101
|
-
await doLogin(repo, usageDir, args);
|
|
102
|
-
await publish(repo, usageDir, args);
|
|
103
|
-
try {
|
|
104
|
-
await usageDir.activateInCurrentProcess();
|
|
105
|
-
await (0, lib_1.shell)((_a = args.COMMAND) !== null && _a !== void 0 ? _a : [], {
|
|
106
|
-
shell: true,
|
|
107
|
-
show: 'always',
|
|
108
|
-
});
|
|
109
|
-
}
|
|
110
|
-
finally {
|
|
111
|
-
if (args.cleanup) {
|
|
112
|
-
await repo.delete();
|
|
113
|
-
}
|
|
114
|
-
}
|
|
115
|
-
})
|
|
116
|
-
.command('cleanup', 'Clean up testing repository', cmd => cmd
|
|
117
|
-
.option('name', {
|
|
118
|
-
alias: 'n',
|
|
119
|
-
description: 'Name of the repository to cleanup (default: most recent)',
|
|
120
|
-
type: 'string',
|
|
121
|
-
requiresArg: true,
|
|
122
|
-
}), async (args) => {
|
|
123
|
-
const usageDir = usage_dir_1.UsageDir.default();
|
|
124
|
-
let repositoryName = args.name;
|
|
125
|
-
if (!repositoryName) {
|
|
126
|
-
repositoryName = (await usageDir.currentEnv()).CODEARTIFACT_REPO;
|
|
127
|
-
}
|
|
128
|
-
if (!repositoryName) {
|
|
129
|
-
console.log(`No --name given and no $CODEARTIFACT_REPO found in ${usageDir.directory}, nothing cleaned up`);
|
|
130
|
-
return;
|
|
131
|
-
}
|
|
132
|
-
const repo = codeartifact_1.TestRepository.existing(repositoryName);
|
|
133
|
-
await repo.delete();
|
|
134
|
-
})
|
|
135
|
-
.command('gc', 'Clean up day-old testing repositories', cmd => cmd, async () => {
|
|
136
|
-
await codeartifact_1.TestRepository.gc();
|
|
137
|
-
})
|
|
138
|
-
.demandCommand(1, 'You must supply a command')
|
|
139
|
-
.help()
|
|
140
|
-
.showHelpOnFail(false)
|
|
141
|
-
.parse();
|
|
142
|
-
}
|
|
143
|
-
async function validateDirectory(args) {
|
|
144
|
-
if (!await fs.pathExists(path.join(args.DIRECTORY, 'build.json'))) {
|
|
145
|
-
throw new Error(`${args.DIRECTORY} does not look like a CDK dist directory (build.json missing)`);
|
|
146
|
-
}
|
|
147
|
-
}
|
|
148
|
-
async function doLogin(repo, usageDir, args) {
|
|
149
|
-
const login = await repo.loginInformation();
|
|
150
|
-
const oldEnv = await usageDir.currentEnv();
|
|
151
|
-
await usageDir.clean();
|
|
152
|
-
await usageDir.addToEnv({
|
|
153
|
-
CODEARTIFACT_REPO: login.repositoryName,
|
|
154
|
-
});
|
|
155
|
-
if (oldEnv.BUILD_VERSION) {
|
|
156
|
-
await usageDir.addToEnv({
|
|
157
|
-
BUILD_VERSION: oldEnv.BUILD_VERSION,
|
|
158
|
-
});
|
|
159
|
-
}
|
|
160
|
-
const doRepo = whichRepos(args);
|
|
161
|
-
await doRepo.npm(() => (0, npm_1.npmLogin)(login, usageDir));
|
|
162
|
-
await doRepo.python(() => (0, pypi_1.pypiLogin)(login, usageDir));
|
|
163
|
-
await doRepo.java(() => (0, maven_1.mavenLogin)(login, usageDir));
|
|
164
|
-
await doRepo.dotnet(() => (0, nuget_1.nugetLogin)(login, usageDir));
|
|
165
|
-
}
|
|
166
|
-
async function publish(repo, usageDir, args) {
|
|
167
|
-
const directory = `${args.DIRECTORY}`;
|
|
168
|
-
const login = await repo.loginInformation();
|
|
169
|
-
const doRepo = whichRepos(args);
|
|
170
|
-
const buildJson = await fs.readJson(path.join(directory, 'build.json'));
|
|
171
|
-
await usageDir.addToEnv({
|
|
172
|
-
BUILD_VERSION: buildJson.version,
|
|
173
|
-
});
|
|
174
|
-
await doRepo.npm(async () => {
|
|
175
|
-
header('NPM');
|
|
176
|
-
await (0, npm_1.uploadNpmPackages)(glob.sync(path.join(directory, 'js', '*.tgz')), login, usageDir);
|
|
177
|
-
});
|
|
178
|
-
await doRepo.python(async () => {
|
|
179
|
-
header('Python');
|
|
180
|
-
await (0, pypi_1.uploadPythonPackages)(glob.sync(path.join(directory, 'python', '*')), login);
|
|
181
|
-
});
|
|
182
|
-
await doRepo.java(async () => {
|
|
183
|
-
header('Java');
|
|
184
|
-
await (0, maven_1.uploadJavaPackages)(glob.sync(path.join(directory, 'java', '**', '*.pom')), login, usageDir);
|
|
185
|
-
});
|
|
186
|
-
await doRepo.dotnet(async () => {
|
|
187
|
-
header('.NET');
|
|
188
|
-
await (0, nuget_1.uploadDotnetPackages)(glob.sync(path.join(directory, 'dotnet', '**', '*.nupkg')), usageDir);
|
|
189
|
-
});
|
|
190
|
-
if (args.regression) {
|
|
191
|
-
console.log('🛍 Configuring packages for upstream versions');
|
|
192
|
-
await repo.markAllUpstreamAllow();
|
|
193
|
-
}
|
|
194
|
-
}
|
|
195
|
-
function whichRepos(args) {
|
|
196
|
-
const all = args.npm === undefined && args.python === undefined && args.java === undefined && args.dotnet === undefined;
|
|
197
|
-
const invoke = (block) => block();
|
|
198
|
-
const skip = () => { };
|
|
199
|
-
return {
|
|
200
|
-
npm: args.npm || all ? invoke : skip,
|
|
201
|
-
python: args.python || all ? invoke : skip,
|
|
202
|
-
java: args.java || all ? invoke : skip,
|
|
203
|
-
dotnet: args.dotnet || all ? invoke : skip,
|
|
204
|
-
};
|
|
205
|
-
}
|
|
206
|
-
function header(caption) {
|
|
207
|
-
console.log('');
|
|
208
|
-
console.log('/'.repeat(70));
|
|
209
|
-
console.log(`// ${caption}`);
|
|
210
|
-
console.log('');
|
|
211
|
-
}
|
|
212
|
-
main().catch(e => {
|
|
213
|
-
// eslint-disable-next-line no-console
|
|
214
|
-
console.error(e);
|
|
215
|
-
process.exitCode = 1;
|
|
216
|
-
});
|
|
217
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stage-distribution.js","sourceRoot":"","sources":["stage-distribution.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable no-console */\nimport * as path from 'path';\nimport * as fs from 'fs-extra';\nimport * as glob from 'glob';\nimport * as yargs from 'yargs';\nimport { shell } from '../lib';\nimport { TestRepository } from '../lib/staging/codeartifact';\nimport { uploadJavaPackages, mavenLogin } from '../lib/staging/maven';\nimport { uploadNpmPackages, npmLogin } from '../lib/staging/npm';\nimport { uploadDotnetPackages, nugetLogin } from '../lib/staging/nuget';\nimport { uploadPythonPackages, pypiLogin } from '../lib/staging/pypi';\nimport { UsageDir } from '../lib/staging/usage-dir';\n\nasync function main() {\n  await yargs\n    .usage('$0 <command>')\n    .option('npm', {\n      description: 'Upload NPM packages only',\n      type: 'boolean',\n      requiresArg: false,\n    })\n    .option('python', {\n      description: 'Upload Python packages only',\n      type: 'boolean',\n      requiresArg: false,\n    })\n    .option('java', {\n      description: 'Upload Java packages only',\n      type: 'boolean',\n      requiresArg: false,\n    })\n    .option('dotnet', {\n      description: 'Upload Dotnet packages only',\n      type: 'boolean',\n      requiresArg: false,\n    })\n    .option('regression', {\n      description: 'Enable access to previous versions of the staged packages (this is expensive for CodeArtifact so we only do it when necessary)',\n      type: 'boolean',\n      requiresArg: false,\n      default: false,\n    })\n    .command('publish <DIRECTORY>', 'Publish a given directory', cmd => cmd\n      .positional('DIRECTORY', {\n        descripton: 'Directory distribution',\n        type: 'string',\n        demandOption: true,\n      })\n      .option('name', {\n        alias: 'n',\n        description: 'Name of the repository to create (default: generate unique name)',\n        type: 'string',\n        requiresArg: true,\n      }), async (args) => {\n\n      await validateDirectory(args);\n      const repo = await (args.name ? TestRepository.newWithName(args.name) : TestRepository.newRandom());\n      const usageDir = UsageDir.default();\n\n      await doLogin(repo, usageDir, args);\n      await publish(repo, usageDir, args);\n\n      header('Done');\n      usageDir.advertise();\n    })\n    .command('login', 'Login to a given repository', cmd => cmd\n      .option('name', {\n        alias: 'n',\n        description: 'Name of the repository to log in to',\n        type: 'string',\n        requiresArg: true,\n        demandOption: true,\n      }), async (args) => {\n\n      const repo = TestRepository.existing(args.name);\n      const usageDir = UsageDir.default();\n\n      await doLogin(repo, usageDir, args);\n\n      usageDir.advertise();\n    })\n    .command('run <DIRECTORY> <COMMAND..>', 'Publish and run a command', cmd => cmd\n      .positional('DIRECTORY', {\n        descripton: 'Directory distribution',\n        type: 'string',\n        demandOption: true,\n      })\n      .positional('COMMAND', {\n        alias: 'c',\n        description: 'Run the given command with the packages staged',\n        type: 'string',\n        array: true,\n        demandOption: true,\n      })\n      .option('cleanup', {\n        alias: 'C',\n        description: 'Cleanup the repository afterwards',\n        type: 'boolean',\n        default: true,\n        requiresArg: false,\n      }), async (args) => {\n\n      await validateDirectory(args);\n      const repo = await TestRepository.newRandom();\n      const usageDir = UsageDir.default();\n\n      await doLogin(repo, usageDir, args);\n      await publish(repo, usageDir, args);\n\n      try {\n        await usageDir.activateInCurrentProcess();\n\n        await shell(args.COMMAND ?? [], {\n          shell: true,\n          show: 'always',\n        });\n\n      } finally {\n        if (args.cleanup) {\n          await repo.delete();\n        }\n      }\n    })\n    .command('cleanup', 'Clean up testing repository', cmd => cmd\n      .option('name', {\n        alias: 'n',\n        description: 'Name of the repository to cleanup (default: most recent)',\n        type: 'string',\n        requiresArg: true,\n      }), async (args) => {\n\n      const usageDir = UsageDir.default();\n\n      let repositoryName = args.name;\n      if (!repositoryName) {\n        repositoryName = (await usageDir.currentEnv()).CODEARTIFACT_REPO;\n      }\n\n      if (!repositoryName) {\n        console.log(`No --name given and no $CODEARTIFACT_REPO found in ${usageDir.directory}, nothing cleaned up`);\n        return;\n      }\n\n      const repo = TestRepository.existing(repositoryName);\n      await repo.delete();\n    })\n    .command('gc', 'Clean up day-old testing repositories', cmd => cmd, async () => {\n      await TestRepository.gc();\n    })\n    .demandCommand(1, 'You must supply a command')\n    .help()\n    .showHelpOnFail(false)\n    .parse();\n}\n\nasync function validateDirectory(args: {\n  DIRECTORY: string;\n}) {\n  if (!await fs.pathExists(path.join(args.DIRECTORY, 'build.json'))) {\n    throw new Error(`${args.DIRECTORY} does not look like a CDK dist directory (build.json missing)`);\n  }\n}\n\nasync function doLogin(repo: TestRepository, usageDir: UsageDir, args: {\n  npm?: boolean;\n  python?: boolean;\n  java?: boolean;\n  dotnet?: boolean;\n}) {\n  const login = await repo.loginInformation();\n\n  const oldEnv = await usageDir.currentEnv();\n\n  await usageDir.clean();\n  await usageDir.addToEnv({\n    CODEARTIFACT_REPO: login.repositoryName,\n  });\n\n  if (oldEnv.BUILD_VERSION) {\n    await usageDir.addToEnv({\n      BUILD_VERSION: oldEnv.BUILD_VERSION,\n    });\n  }\n\n  const doRepo = whichRepos(args);\n\n  await doRepo.npm(() => npmLogin(login, usageDir));\n  await doRepo.python(() => pypiLogin(login, usageDir));\n  await doRepo.java(() => mavenLogin(login, usageDir));\n  await doRepo.dotnet(() => nugetLogin(login, usageDir));\n}\n\nasync function publish(repo: TestRepository, usageDir: UsageDir, args: {\n  DIRECTORY: string;\n  npm?: boolean;\n  python?: boolean;\n  java?: boolean;\n  dotnet?: boolean;\n  regression?: boolean;\n}) {\n  const directory = `${args.DIRECTORY}`;\n  const login = await repo.loginInformation();\n\n  const doRepo = whichRepos(args);\n\n  const buildJson = await fs.readJson(path.join(directory, 'build.json'));\n  await usageDir.addToEnv({\n    BUILD_VERSION: buildJson.version,\n  });\n\n  await doRepo.npm(async () => {\n    header('NPM');\n    await uploadNpmPackages(glob.sync(path.join(directory, 'js', '*.tgz')), login, usageDir);\n  });\n\n  await doRepo.python(async () => {\n    header('Python');\n    await uploadPythonPackages(glob.sync(path.join(directory, 'python', '*')), login);\n  });\n\n  await doRepo.java(async () => {\n    header('Java');\n    await uploadJavaPackages(glob.sync(path.join(directory, 'java', '**', '*.pom')), login, usageDir);\n  });\n\n  await doRepo.dotnet(async () => {\n    header('.NET');\n    await uploadDotnetPackages(glob.sync(path.join(directory, 'dotnet', '**', '*.nupkg')), usageDir);\n  });\n\n  if (args.regression) {\n    console.log('🛍 Configuring packages for upstream versions');\n    await repo.markAllUpstreamAllow();\n  }\n}\n\nfunction whichRepos(args: {\n  npm?: boolean;\n  python?: boolean;\n  java?: boolean;\n  dotnet?: boolean;\n}) {\n  const all = args.npm === undefined && args.python === undefined && args.java === undefined && args.dotnet === undefined;\n\n  const invoke = (block: () => Promise<void>) => block();\n  const skip = () => { };\n\n  return {\n    npm: args.npm || all ? invoke : skip,\n    python: args.python || all ? invoke : skip,\n    java: args.java || all ? invoke : skip,\n    dotnet: args.dotnet || all ? invoke : skip,\n  };\n}\n\nfunction header(caption: string) {\n  console.log('');\n  console.log('/'.repeat(70));\n  console.log(`//  ${caption}`);\n  console.log('');\n}\n\nmain().catch(e => {\n  // eslint-disable-next-line no-console\n  console.error(e);\n  process.exitCode = 1;\n});\n"]}
|
package/bin/test-root.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
package/bin/test-root.js
DELETED
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const path = require("path");
|
|
4
|
-
// eslint-disable-next-line no-console
|
|
5
|
-
console.log(path.resolve(__dirname, '..'));
|
|
6
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdC1yb290LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsidGVzdC1yb290LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsNkJBQTZCO0FBQzdCLHNDQUFzQztBQUN0QyxPQUFPLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsU0FBUyxFQUFFLElBQUksQ0FBQyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBwYXRoIGZyb20gJ3BhdGgnO1xuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLWNvbnNvbGVcbmNvbnNvbGUubG9nKHBhdGgucmVzb2x2ZShfX2Rpcm5hbWUsICcuLicpKTtcbiJdfQ==
|