From 38a989447effaf29bf78f24e09cfdadd3ac61830 Mon Sep 17 00:00:00 2001 From: Elad Ben-Israel <benisrae@amazon.com> Date: Thu, 30 May 2019 10:05:43 +0300 Subject: [PATCH] fix(cx-api): improve compatibility messages for cli <=> app (#2676) Emit a legacy manifest (cdk.out) to output directory with the new protocol version so that pre 0.33.0 CLI will emit a proper compatibility message which reads: CDK Toolkit >= 0.33.0 is required in order to interact with this program. Improve wording for the case where a new CLI is used with old apps: CDK CLI can only be used with apps created by CDK >= 0.33.0 --- packages/@aws-cdk/cdk/test/test.synthesis.ts | 4 +++- packages/@aws-cdk/cx-api/lib/cloud-assembly.ts | 9 +++++++-- packages/@aws-cdk/cx-api/lib/versioning.ts | 5 +++-- packages/@aws-cdk/cx-api/test/cloud-assembly.test.ts | 4 ++-- 4 files changed, 15 insertions(+), 7 deletions(-) diff --git a/packages/@aws-cdk/cdk/test/test.synthesis.ts b/packages/@aws-cdk/cdk/test/test.synthesis.ts index 8512a07fd9613..9b6f8e64f4bb1 100644 --- a/packages/@aws-cdk/cdk/test/test.synthesis.ts +++ b/packages/@aws-cdk/cdk/test/test.synthesis.ts @@ -25,7 +25,7 @@ export = { // THEN test.same(app.run(), session); // same session if we run() again - test.deepEqual(list(session.directory), [ 'manifest.json' ]); + test.deepEqual(list(session.directory), [ 'cdk.out', 'manifest.json' ]); test.deepEqual(readJson(session.directory, 'manifest.json').artifacts, {}); test.done(); }, @@ -40,6 +40,7 @@ export = { // THEN test.deepEqual(list(session.directory), [ + 'cdk.out', 'manifest.json', 'one-stack.template.json' ]); @@ -71,6 +72,7 @@ export = { // THEN test.deepEqual(list(session.directory), [ + 'cdk.out', 'foo.json', 'manifest.json', 'one-stack.template.json' diff --git a/packages/@aws-cdk/cx-api/lib/cloud-assembly.ts b/packages/@aws-cdk/cx-api/lib/cloud-assembly.ts index b985d63790c18..f4c0f9c037c83 100644 --- a/packages/@aws-cdk/cx-api/lib/cloud-assembly.ts +++ b/packages/@aws-cdk/cx-api/lib/cloud-assembly.ts @@ -117,7 +117,7 @@ export class CloudAssemblyBuilder { // we leverage the fact that outdir is long-lived to avoid staging assets into it // that were already staged (copying can be expensive). this is achieved by the fact - // that assets use a source hash as their name. other artifacts, and the manifest, + // that assets use a source hash as their name. other artifacts, and the manifest itself, // will overwrite existing files as needed. if (fs.existsSync(this.outdir)) { @@ -143,6 +143,11 @@ export class CloudAssemblyBuilder { const manifestFilePath = path.join(this.outdir, MANIFEST_FILE); fs.writeFileSync(manifestFilePath, JSON.stringify(manifest, undefined, 2)); + // "backwards compatibility": in order for the old CLI to tell the user they + // need a new version, we'll emit the legacy manifest with only "version". + // this will result in an error "CDK Toolkit >= 0.33.0 is required in order to interact with this program." + fs.writeFileSync(path.join(this.outdir, 'cdk.out'), JSON.stringify({ version: CLOUD_ASSEMBLY_VERSION })); + return new CloudAssembly(this.outdir); } } @@ -201,4 +206,4 @@ function filterUndefined(obj: any): any { function ignore(_x: any) { return; -} \ No newline at end of file +} diff --git a/packages/@aws-cdk/cx-api/lib/versioning.ts b/packages/@aws-cdk/cx-api/lib/versioning.ts index c84e83f21c8f0..281e7242f6b66 100644 --- a/packages/@aws-cdk/cx-api/lib/versioning.ts +++ b/packages/@aws-cdk/cx-api/lib/versioning.ts @@ -27,12 +27,13 @@ export function verifyManifestVersion(manifetVersion: string) { // if framework > cli, we require a newer cli version if (semver.gt(frameworkVersion, toolkitVersion)) { - throw new Error(`CLI >= ${frameworkVersion} is required to interact with this app`); + throw new Error(`CDK CLI >= ${frameworkVersion} is required to interact with this app`); } // if framework < cli, we require a newer framework version if (semver.lt(frameworkVersion, toolkitVersion)) { - throw new Error(`App used framework v${frameworkVersion} but it must be >= v${CLOUD_ASSEMBLY_VERSION} in order to interact with this CLI`); + throw new Error( + `CDK CLI can only be used with apps created by CDK >= ${CLOUD_ASSEMBLY_VERSION}`); } } diff --git a/packages/@aws-cdk/cx-api/test/cloud-assembly.test.ts b/packages/@aws-cdk/cx-api/test/cloud-assembly.test.ts index 671abaf29aa8a..41d11d12094f4 100644 --- a/packages/@aws-cdk/cx-api/test/cloud-assembly.test.ts +++ b/packages/@aws-cdk/cx-api/test/cloud-assembly.test.ts @@ -95,6 +95,6 @@ test('fails for invalid dependencies', () => { test('verifyManifestVersion', () => { verifyManifestVersion('0.33.0'); - expect(() => verifyManifestVersion('0.31.0')).toThrow('App used framework v0.31.0 but it must be >= v0.33.0 in order to interact with this CLI'); - expect(() => verifyManifestVersion('0.34.0')).toThrow('CLI >= 0.34.0 is required to interact with this app'); + expect(() => verifyManifestVersion('0.31.0')).toThrow('CDK CLI can only be used with apps created by CDK >= 0.33.0'); + expect(() => verifyManifestVersion('0.34.0')).toThrow('CDK CLI >= 0.34.0 is required to interact with this app'); }); \ No newline at end of file