From fe6b5b25a77424a6491b331515c502b51ef069c7 Mon Sep 17 00:00:00 2001 From: Elad Ben-Israel Date: Mon, 4 Feb 2019 23:47:14 +0200 Subject: [PATCH 01/20] feat(core): overrideLogicalId: override IDs of CFN elements Allow users to explicitly override the logical ID of a CloudFormation element (such as "Cfn" resources) by invoking `overrideLogicalId` on the resource object. For example: const bucket = new s3.CfnBucket(this, 'MyBucket'); bucket.overrideLogicalId('YourBucket'); The resulting template will use `YourBucket` as the logical ID. NOTE: the `logicalId` property will now return a stringified token instead of a concrete value. Fixes #1594 --- .../cdk/lib/cloudformation/resource.ts | 2 +- .../cdk/lib/cloudformation/stack-element.ts | 41 +++++++++++++------ .../@aws-cdk/cdk/lib/cloudformation/stack.ts | 39 +++++++++--------- .../test/cloudformation/test.logical-id.ts | 10 ++--- .../cdk/test/cloudformation/test.output.ts | 9 ++-- .../cdk/test/cloudformation/test.parameter.ts | 4 +- .../cdk/test/cloudformation/test.resource.ts | 12 +++--- .../cdk/test/cloudformation/test.stack.ts | 24 +++++++++++ 8 files changed, 91 insertions(+), 50 deletions(-) diff --git a/packages/@aws-cdk/cdk/lib/cloudformation/resource.ts b/packages/@aws-cdk/cdk/lib/cloudformation/resource.ts index f53cbc63bea02..ae06140eb4a32 100644 --- a/packages/@aws-cdk/cdk/lib/cloudformation/resource.ts +++ b/packages/@aws-cdk/cdk/lib/cloudformation/resource.ts @@ -117,7 +117,7 @@ export class Resource extends Referenceable { * @param attributeName The name of the attribute. */ public getAtt(attributeName: string) { - return new CfnReference({ 'Fn::GetAtt': [this.logicalId, attributeName] }, `${this.logicalId}.${attributeName}`, this); + return new CfnReference({ 'Fn::GetAtt': [this.logicalId, attributeName] }, `${this.node.path.replace('/', '.')}.${attributeName}`, this); } /** diff --git a/packages/@aws-cdk/cdk/lib/cloudformation/stack-element.ts b/packages/@aws-cdk/cdk/lib/cloudformation/stack-element.ts index e4c1fc26daaec..39b0ebd292b60 100644 --- a/packages/@aws-cdk/cdk/lib/cloudformation/stack-element.ts +++ b/packages/@aws-cdk/cdk/lib/cloudformation/stack-element.ts @@ -1,4 +1,5 @@ import { Construct, IConstruct, PATH_SEP } from "../core/construct"; +import { Token } from '../core/tokens'; const LOGICAL_ID_MD = 'aws:cdk:logicalId'; @@ -15,24 +16,17 @@ export abstract class StackElement extends Construct { * * @returns The construct as a stack element or undefined if it is not a stack element. */ - public static _asStackElement(construct: IConstruct): StackElement | undefined { - if ('logicalId' in construct && 'toCloudFormation' in construct) { - return construct as StackElement; - } else { - return undefined; - } + public static isStackElement(construct: IConstruct): construct is StackElement { + return ('logicalId' in construct && 'toCloudFormation' in construct); } - /** - * The logical ID for this CloudFormation stack element - */ - public readonly logicalId: string; - /** * The stack this Construct has been made a part of */ protected stack: Stack; + private _logicalId: string; + /** * Creates an entity and binds it to a tree. * Note that the root of the tree must be a Stack object (not just any Root). @@ -50,7 +44,28 @@ export abstract class StackElement extends Construct { this.node.addMetadata(LOGICAL_ID_MD, new (require("../core/tokens/token").Token)(() => this.logicalId), this.constructor); - this.logicalId = this.stack.logicalIds.getLogicalId(this); + this._logicalId = this.stack.logicalIds.getLogicalId(this); + } + + /** + * The logical ID for this CloudFormation stack element. The logical ID of the element + * is calculated from the path of the resource node in the construct tree. + * + * To override this value, use `overrideLogicalId(newLogicalId)`. + * + * @returns the logical ID as a stringified token. This value will only get + * resolved during synthesis. + */ + public get logicalId(): string { + return new Token(() => this._logicalId).toString(); + } + + /** + * Overrides the auto-generated logical ID with a specific ID. + * @param newLogicalId The new logical ID to use for this stack element. + */ + public overrideLogicalId(newLogicalId: string) { + this._logicalId = newLogicalId; } /** @@ -127,7 +142,7 @@ import { CfnReference } from "./cfn-tokens"; */ export class Ref extends CfnReference { constructor(element: StackElement) { - super({ Ref: element.logicalId }, `${element.logicalId}.Ref`, element); + super({ Ref: element.logicalId }, `${element.node.path.replace('/', '.')}.Ref`, element); } } diff --git a/packages/@aws-cdk/cdk/lib/cloudformation/stack.ts b/packages/@aws-cdk/cdk/lib/cloudformation/stack.ts index d0f85247e1e65..80d1c06655516 100644 --- a/packages/@aws-cdk/cdk/lib/cloudformation/stack.ts +++ b/packages/@aws-cdk/cdk/lib/cloudformation/stack.ts @@ -173,7 +173,7 @@ export class Stack extends Construct { // merge in all CloudFormation fragments collected from the tree for (const fragment of fragments) { - merge(template, fragment); + this.merge(template, fragment); } // resolve all tokens and remove all empties @@ -466,23 +466,25 @@ export class Stack extends Construct { } return false; } -} -function merge(template: any, part: any) { - for (const section of Object.keys(part)) { - const src = part[section]; - - // create top-level section if it doesn't exist - let dest = template[section]; - if (!dest) { - template[section] = dest = src; - } else { - // add all entities from source section to destination section - for (const id of Object.keys(src)) { - if (id in dest) { - throw new Error(`section '${section}' already contains '${id}'`); + private merge(template: any, part: any) { + part = this.node.resolve(part); + // console.error({ merge: { part: JSON.stringify(part) }}); + for (const section of Object.keys(part)) { + const src = part[section]; + + // create top-level section if it doesn't exist + let dest = template[section]; + if (!dest) { + template[section] = dest = src; + } else { + // add all entities from source section to destination section + for (const id of Object.keys(src)) { + if (id in dest) { + throw new Error(`section '${section}' already contains '${id}'`); + } + dest[id] = src[id]; } - dest[id] = src[id]; } } } @@ -522,9 +524,8 @@ export interface TemplateOptions { * @returns The same array as is being collected into */ function stackElements(node: IConstruct, into: StackElement[] = []): StackElement[] { - const element = StackElement._asStackElement(node); - if (element) { - into.push(element); + if (StackElement.isStackElement(node)) { + into.push(node); } for (const child of node.node.children) { diff --git a/packages/@aws-cdk/cdk/test/cloudformation/test.logical-id.ts b/packages/@aws-cdk/cdk/test/cloudformation/test.logical-id.ts index 7c63ac07ea106..9fd0ecba1ebe8 100644 --- a/packages/@aws-cdk/cdk/test/cloudformation/test.logical-id.ts +++ b/packages/@aws-cdk/cdk/test/cloudformation/test.logical-id.ts @@ -29,7 +29,7 @@ const uniqueTests = { const r = new Resource(stack, 'MyAwesomeness', { type: 'Resource' }); // THEN - test.equal(r.logicalId, 'MyAwesomeness'); + test.equal(stack.node.resolve(r.logicalId), 'MyAwesomeness'); test.done(); }, @@ -204,13 +204,13 @@ const allSchemesTests: {[name: string]: (scheme: IAddressingScheme, test: Test) stack.node.prepareTree(); test.deepEqual(stack.toCloudFormation(), { Resources: { - [c1.logicalId]: { + NewName: { Type: 'R1' }, - [c2.logicalId]: { + Construct2: { Type: 'R2', Properties: { - ReferenceToR1: { Ref: c1.logicalId } }, - DependsOn: [ c1.logicalId ] } } }); + ReferenceToR1: { Ref: 'NewName' } }, + DependsOn: [ 'NewName' ] } } }); test.done(); }, diff --git a/packages/@aws-cdk/cdk/test/cloudformation/test.output.ts b/packages/@aws-cdk/cdk/test/cloudformation/test.output.ts index b6ee26217d2d7..d84b5f75e7869 100644 --- a/packages/@aws-cdk/cdk/test/cloudformation/test.output.ts +++ b/packages/@aws-cdk/cdk/test/cloudformation/test.output.ts @@ -33,8 +33,9 @@ export = { const output = new Output(stack, 'MyOutput'); const child = new Construct(stack, 'MyConstruct'); const output2 = new Output(child, 'MyOutput2'); - test.equal(output.export, 'MyStack:MyOutput'); - test.equal(output2.export, 'MyStack:MyConstructMyOutput255322D15'); + + test.equal(stack.node.resolve(output.export), 'MyStack:MyOutput'); + test.equal(stack.node.resolve(output2.export), 'MyStack:MyConstructMyOutput255322D15'); test.done(); }, @@ -53,10 +54,10 @@ export = { test.done(); }, - 'is stack name is undefined, we will only use the logical ID for the export name'(test: Test) { + 'if stack name is undefined, we will only use the logical ID for the export name'(test: Test) { const stack = new Stack(); const output = new Output(stack, 'MyOutput'); - test.equal(output.export, 'MyOutput'); + test.equal(stack.node.resolve(output.export), 'MyOutput'); test.done(); }, diff --git a/packages/@aws-cdk/cdk/test/cloudformation/test.parameter.ts b/packages/@aws-cdk/cdk/test/cloudformation/test.parameter.ts index 2a5526c4255f2..2424939dccbac 100644 --- a/packages/@aws-cdk/cdk/test/cloudformation/test.parameter.ts +++ b/packages/@aws-cdk/cdk/test/cloudformation/test.parameter.ts @@ -16,14 +16,14 @@ export = { test.deepEqual(stack.toCloudFormation(), { Parameters: { - [param.logicalId]: { + ChildMyParam3161BF5D: { Default: 10, Type: 'Integer', Description: 'My first parameter' } }, Resources: { Resource: { Type: 'Type', - Properties: { ReferenceToParam: { Ref: param.logicalId } } } } }); + Properties: { ReferenceToParam: { Ref: 'ChildMyParam3161BF5D' } } } } }); test.done(); }, diff --git a/packages/@aws-cdk/cdk/test/cloudformation/test.resource.ts b/packages/@aws-cdk/cdk/test/cloudformation/test.resource.ts index 90e3cf0c5d9a9..71081d413e586 100644 --- a/packages/@aws-cdk/cdk/test/cloudformation/test.resource.ts +++ b/packages/@aws-cdk/cdk/test/cloudformation/test.resource.ts @@ -44,8 +44,8 @@ export = { const res1 = new Resource(level1, 'childoflevel1', { type: 'MyResourceType1' }); const res2 = new Resource(level3, 'childoflevel3', { type: 'MyResourceType2' }); - test.equal(withoutHash(res1.logicalId), 'level1childoflevel1'); - test.equal(withoutHash(res2.logicalId), 'level1level2level3childoflevel3'); + test.equal(withoutHash(stack.node.resolve(res1.logicalId)), 'level1childoflevel1'); + test.equal(withoutHash(stack.node.resolve(res2.logicalId)), 'level1level2level3childoflevel3'); test.done(); }, @@ -327,10 +327,10 @@ export = { MyResource: { Type: 'R', DependsOn: - [ 'MyC1R1FB2A562F', - 'MyC1R2AE2B5066', - 'MyC2R3809EEAD6', - 'MyC3C2R38CE6F9F7' ] } } }); + [ 'MyC1R2AE2B5066', + 'MyC1R1FB2A562F', + 'MyC2R3809EEAD6', + 'MyC3C2R38CE6F9F7' ] } } }); test.done(); }, diff --git a/packages/@aws-cdk/cdk/test/cloudformation/test.stack.ts b/packages/@aws-cdk/cdk/test/cloudformation/test.stack.ts index 880068e92d589..d56bedb34896d 100644 --- a/packages/@aws-cdk/cdk/test/cloudformation/test.stack.ts +++ b/packages/@aws-cdk/cdk/test/cloudformation/test.stack.ts @@ -345,6 +345,30 @@ export = { test.done(); }, + + 'overrideLogicalId(id) can be used to override the logical ID of a resource'(test: Test) { + // GIVEN + const stack = new Stack(); + const bonjour = new Resource(stack, 'BonjourResource', { type: 'Resource::Type' }); + + // { Ref } and { GetAtt } + new Resource(stack, 'RefToBonjour', { type: 'Other::Resource', properties: { + RefToBonjour: bonjour.ref.toString(), + GetAttBonjour: bonjour.getAtt('TheAtt').toString() + }}); + + bonjour.overrideLogicalId('BOOM'); + + // THEN + test.deepEqual(stack.toCloudFormation(), { Resources: + { BOOM: { Type: 'Resource::Type' }, + RefToBonjour: + { Type: 'Other::Resource', + Properties: + { RefToBonjour: { Ref: 'BOOM' }, + GetAttBonjour: { 'Fn::GetAtt': [ 'BOOM', 'TheAtt' ] } } } } }); + test.done(); + } }; class StackWithPostProcessor extends Stack { From 295422e84ddd22ec05dc363ff36fe11a8f192359 Mon Sep 17 00:00:00 2001 From: Elad Ben-Israel Date: Tue, 5 Feb 2019 01:09:37 +0200 Subject: [PATCH 02/20] Auto-mangle token display names There is no good reason to be strict about token display names. We can just replace any disallowed chars with "." and get it over with. --- packages/@aws-cdk/cdk/lib/cloudformation/cfn-tokens.ts | 4 ++++ packages/@aws-cdk/cdk/lib/cloudformation/resource.ts | 5 +++-- packages/@aws-cdk/cdk/lib/cloudformation/stack-element.ts | 2 +- packages/@aws-cdk/cdk/lib/core/tokens/encoding.ts | 7 +------ 4 files changed, 9 insertions(+), 9 deletions(-) diff --git a/packages/@aws-cdk/cdk/lib/cloudformation/cfn-tokens.ts b/packages/@aws-cdk/cdk/lib/cloudformation/cfn-tokens.ts index 9d17016003f6f..b1061f8cac52e 100644 --- a/packages/@aws-cdk/cdk/lib/cloudformation/cfn-tokens.ts +++ b/packages/@aws-cdk/cdk/lib/cloudformation/cfn-tokens.ts @@ -38,6 +38,10 @@ export class CfnReference extends Token { if (typeof(value) === 'function') { throw new Error('CfnReference can only hold CloudFormation intrinsics (not a function)'); } + // prepend scope path to display name + if (displayName && scope) { + displayName = `${scope.node.path}.${displayName}`; + } super(value, displayName); this.replacementTokens = new Map(); this.isReference = true; diff --git a/packages/@aws-cdk/cdk/lib/cloudformation/resource.ts b/packages/@aws-cdk/cdk/lib/cloudformation/resource.ts index ae06140eb4a32..891bec4bae113 100644 --- a/packages/@aws-cdk/cdk/lib/cloudformation/resource.ts +++ b/packages/@aws-cdk/cdk/lib/cloudformation/resource.ts @@ -117,7 +117,7 @@ export class Resource extends Referenceable { * @param attributeName The name of the attribute. */ public getAtt(attributeName: string) { - return new CfnReference({ 'Fn::GetAtt': [this.logicalId, attributeName] }, `${this.node.path.replace('/', '.')}.${attributeName}`, this); + return new CfnReference({ 'Fn::GetAtt': [this.logicalId, attributeName] }, attributeName, this); } /** @@ -305,8 +305,9 @@ export function deepMerge(target: any, source: any) { return target; } + function sortedSet(xs: Set): T[] { const ret = Array.from(xs); ret.sort(); return ret; -} \ No newline at end of file +} diff --git a/packages/@aws-cdk/cdk/lib/cloudformation/stack-element.ts b/packages/@aws-cdk/cdk/lib/cloudformation/stack-element.ts index 39b0ebd292b60..7947ca0bac146 100644 --- a/packages/@aws-cdk/cdk/lib/cloudformation/stack-element.ts +++ b/packages/@aws-cdk/cdk/lib/cloudformation/stack-element.ts @@ -142,7 +142,7 @@ import { CfnReference } from "./cfn-tokens"; */ export class Ref extends CfnReference { constructor(element: StackElement) { - super({ Ref: element.logicalId }, `${element.node.path.replace('/', '.')}.Ref`, element); + super({ Ref: element.logicalId }, 'Ref', element); } } diff --git a/packages/@aws-cdk/cdk/lib/core/tokens/encoding.ts b/packages/@aws-cdk/cdk/lib/core/tokens/encoding.ts index 301698214dbb9..29ba49bee36d2 100644 --- a/packages/@aws-cdk/cdk/lib/core/tokens/encoding.ts +++ b/packages/@aws-cdk/cdk/lib/core/tokens/encoding.ts @@ -95,13 +95,8 @@ export class TokenMap { private register(token: Token, representationHint?: string): string { const counter = Object.keys(this.tokenMap).length; - const representation = representationHint || `TOKEN`; - + const representation = (representationHint || `TOKEN`).replace(new RegExp(`[^${VALID_KEY_CHARS}]`, 'g'), '.'); const key = `${representation}.${counter}`; - if (new RegExp(`[^${VALID_KEY_CHARS}]`).exec(key)) { - throw new Error(`Invalid characters in token representation: ${key}`); - } - this.tokenMap[key] = token; return key; } From 0af932cc3d62bbc7321324d55848e5689890a593 Mon Sep 17 00:00:00 2001 From: Elad Ben-Israel Date: Tue, 5 Feb 2019 01:43:47 +0200 Subject: [PATCH 03/20] Don't create a new token every time logicalId is retrieved --- .../cdk/lib/cloudformation/resource.ts | 10 +++-- .../cdk/lib/cloudformation/stack-element.ts | 25 ++++++----- .../@aws-cdk/cdk/lib/cloudformation/stack.ts | 39 +++++++++--------- .../cdk/test/cloudformation/test.resource.ts | 41 +++++++++++++++++-- 4 files changed, 75 insertions(+), 40 deletions(-) diff --git a/packages/@aws-cdk/cdk/lib/cloudformation/resource.ts b/packages/@aws-cdk/cdk/lib/cloudformation/resource.ts index 891bec4bae113..0f1eb3a56cd2c 100644 --- a/packages/@aws-cdk/cdk/lib/cloudformation/resource.ts +++ b/packages/@aws-cdk/cdk/lib/cloudformation/resource.ts @@ -84,7 +84,7 @@ export class Resource extends Referenceable { * * Is filled during prepare(). */ - private readonly dependsOn = new Set(); + private readonly dependsOn = new Set(); /** * Creates a resource construct. @@ -179,8 +179,12 @@ export class Resource extends Referenceable { this.addPropertyOverride(propertyPath, undefined); } + /** + * Indicates that this resource depends on another resource and cannot be provisioned + * unless the other resource has been successfully provisioned. + */ public addDependsOn(resource: Resource) { - this.dependsOn.add(resource.logicalId); + this.dependsOn.add(resource); } /** @@ -197,7 +201,7 @@ export class Resource extends Referenceable { Type: this.resourceType, Properties: ignoreEmpty(this, properties), // Return a sorted set of dependencies to be consistent across tests - DependsOn: ignoreEmpty(this, sortedSet(this.dependsOn)), + DependsOn: ignoreEmpty(this, sortedSet(this.dependsOn).map(r => r.logicalId)), CreationPolicy: capitalizePropertyNames(this, this.options.creationPolicy), UpdatePolicy: capitalizePropertyNames(this, this.options.updatePolicy), UpdateReplacePolicy: capitalizePropertyNames(this, this.options.updateReplacePolicy), diff --git a/packages/@aws-cdk/cdk/lib/cloudformation/stack-element.ts b/packages/@aws-cdk/cdk/lib/cloudformation/stack-element.ts index 7947ca0bac146..563cd5cb050c7 100644 --- a/packages/@aws-cdk/cdk/lib/cloudformation/stack-element.ts +++ b/packages/@aws-cdk/cdk/lib/cloudformation/stack-element.ts @@ -20,6 +20,17 @@ export abstract class StackElement extends Construct { return ('logicalId' in construct && 'toCloudFormation' in construct); } + /** + * The logical ID for this CloudFormation stack element. The logical ID of the element + * is calculated from the path of the resource node in the construct tree. + * + * To override this value, use `overrideLogicalId(newLogicalId)`. + * + * @returns the logical ID as a stringified token. This value will only get + * resolved during synthesis. + */ + public readonly logicalId: string; + /** * The stack this Construct has been made a part of */ @@ -45,19 +56,7 @@ export abstract class StackElement extends Construct { this.node.addMetadata(LOGICAL_ID_MD, new (require("../core/tokens/token").Token)(() => this.logicalId), this.constructor); this._logicalId = this.stack.logicalIds.getLogicalId(this); - } - - /** - * The logical ID for this CloudFormation stack element. The logical ID of the element - * is calculated from the path of the resource node in the construct tree. - * - * To override this value, use `overrideLogicalId(newLogicalId)`. - * - * @returns the logical ID as a stringified token. This value will only get - * resolved during synthesis. - */ - public get logicalId(): string { - return new Token(() => this._logicalId).toString(); + this.logicalId = new Token(() => this._logicalId).toString(); } /** diff --git a/packages/@aws-cdk/cdk/lib/cloudformation/stack.ts b/packages/@aws-cdk/cdk/lib/cloudformation/stack.ts index 80d1c06655516..52550428a4e2b 100644 --- a/packages/@aws-cdk/cdk/lib/cloudformation/stack.ts +++ b/packages/@aws-cdk/cdk/lib/cloudformation/stack.ts @@ -169,11 +169,11 @@ export class Stack extends Construct { }; const elements = stackElements(this); - const fragments = elements.map(e => e.toCloudFormation()); + const fragments = elements.map(e => this.node.resolve(e.toCloudFormation())); // merge in all CloudFormation fragments collected from the tree for (const fragment of fragments) { - this.merge(template, fragment); + merge(template, fragment); } // resolve all tokens and remove all empties @@ -466,25 +466,24 @@ export class Stack extends Construct { } return false; } +} - private merge(template: any, part: any) { - part = this.node.resolve(part); - // console.error({ merge: { part: JSON.stringify(part) }}); - for (const section of Object.keys(part)) { - const src = part[section]; - - // create top-level section if it doesn't exist - let dest = template[section]; - if (!dest) { - template[section] = dest = src; - } else { - // add all entities from source section to destination section - for (const id of Object.keys(src)) { - if (id in dest) { - throw new Error(`section '${section}' already contains '${id}'`); - } - dest[id] = src[id]; +function merge(template: any, part: any) { + // console.error({ merge: { part: JSON.stringify(part) }}); + for (const section of Object.keys(part)) { + const src = part[section]; + + // create top-level section if it doesn't exist + let dest = template[section]; + if (!dest) { + template[section] = dest = src; + } else { + // add all entities from source section to destination section + for (const id of Object.keys(src)) { + if (id in dest) { + throw new Error(`section '${section}' already contains '${id}'`); } + dest[id] = src[id]; } } } @@ -550,4 +549,4 @@ function findResources(roots: Iterable): Resource[] { ret.push(...root.node.findAll().filter(Resource.isResource)); } return ret; -} \ No newline at end of file +} diff --git a/packages/@aws-cdk/cdk/test/cloudformation/test.resource.ts b/packages/@aws-cdk/cdk/test/cloudformation/test.resource.ts index 71081d413e586..8f3b94092154b 100644 --- a/packages/@aws-cdk/cdk/test/cloudformation/test.resource.ts +++ b/packages/@aws-cdk/cdk/test/cloudformation/test.resource.ts @@ -152,6 +152,39 @@ export = { test.done(); }, + 'if addDependency is called multiple times with the same resource, it will only appear once'(test: Test) { + // GIVEN + const stack = new Stack(); + const r1 = new Counter(stack, 'Counter1', { Count: 1 }); + const dependent = new Resource(stack, 'Dependent', { type: 'R' }); + + // WHEN + dependent.addDependsOn(r1); + dependent.addDependsOn(r1); + dependent.addDependsOn(r1); + dependent.addDependsOn(r1); + dependent.addDependsOn(r1); + + // THEN + test.deepEqual(stack.toCloudFormation(), { + Resources: { + Counter1: { + Type: "My::Counter", + Properties: { + Count: 1 + } + }, + Dependent: { + Type: "R", + DependsOn: [ + "Counter1" + ] + } + } + }); + test.done(); + }, + 'conditions can be attached to a resource'(test: Test) { const stack = new Stack(); const r1 = new Resource(stack, 'Resource', { type: 'Type' }); @@ -327,10 +360,10 @@ export = { MyResource: { Type: 'R', DependsOn: - [ 'MyC1R2AE2B5066', - 'MyC1R1FB2A562F', - 'MyC2R3809EEAD6', - 'MyC3C2R38CE6F9F7' ] } } }); + [ 'MyC1R1FB2A562F', + 'MyC1R2AE2B5066', + 'MyC2R3809EEAD6', + 'MyC3C2R38CE6F9F7' ] } } }); test.done(); }, From bcc808a6a6a01f809accc482e98a0031548d1437 Mon Sep 17 00:00:00 2001 From: Elad Ben-Israel Date: Tue, 5 Feb 2019 02:06:40 +0200 Subject: [PATCH 04/20] fix assets test --- packages/@aws-cdk/assets/test/test.asset.ts | 26 +++++++++++++++++++-- 1 file changed, 24 insertions(+), 2 deletions(-) diff --git a/packages/@aws-cdk/assets/test/test.asset.ts b/packages/@aws-cdk/assets/test/test.asset.ts index 849063ffa7189..5075a42c48a7f 100644 --- a/packages/@aws-cdk/assets/test/test.asset.ts +++ b/packages/@aws-cdk/assets/test/test.asset.ts @@ -18,7 +18,7 @@ export = { // the correct information const entry = asset.node.metadata.find(m => m.type === 'aws:cdk:asset'); test.ok(entry, 'found metadata entry'); - test.deepEqual(entry!.data, { + test.deepEqual(stack.node.resolve(entry!.data), { path: dirPath, id: 'MyAsset', packaging: 'zip', @@ -34,13 +34,35 @@ export = { test.done(); }, + 'verify that the app resolves tokens in metadata'(test: Test) { + const app = new cdk.App(); + const stack = new cdk.Stack(app, 'my-stack'); + const dirPath = path.join(__dirname, 'sample-asset-directory'); + + new ZipDirectoryAsset(stack, 'MyAsset', { + path: dirPath + }); + + const synth = app.synthesizeStack(stack.name); + + test.deepEqual(synth.metadata['/my-stack/MyAsset'][0].data, { + path: "/Users/benisrae/code/cdk/aws-cdk/packages/@aws-cdk/assets/test/sample-asset-directory", + id: "mystackMyAssetD6B1B593", + packaging: "zip", + s3BucketParameter: "MyAssetS3Bucket68C9B344", + s3KeyParameter: "MyAssetS3VersionKey68E1A45D" + }); + + test.done(); + }, + '"file" assets'(test: Test) { const stack = new cdk.Stack(); const filePath = path.join(__dirname, 'file-asset.txt'); const asset = new FileAsset(stack, 'MyAsset', { path: filePath }); const entry = asset.node.metadata.find(m => m.type === 'aws:cdk:asset'); test.ok(entry, 'found metadata entry'); - test.deepEqual(entry!.data, { + test.deepEqual(stack.node.resolve(entry!.data), { path: filePath, packaging: 'file', id: 'MyAsset', From 2a1bd6bda23d67b28ada62b05a8efbbce9cc3a72 Mon Sep 17 00:00:00 2001 From: Elad Ben-Israel Date: Tue, 5 Feb 2019 12:59:01 +0200 Subject: [PATCH 05/20] remove commented out code --- packages/@aws-cdk/cdk/lib/cloudformation/stack.ts | 2 -- 1 file changed, 2 deletions(-) diff --git a/packages/@aws-cdk/cdk/lib/cloudformation/stack.ts b/packages/@aws-cdk/cdk/lib/cloudformation/stack.ts index 52550428a4e2b..82fc3e198fc98 100644 --- a/packages/@aws-cdk/cdk/lib/cloudformation/stack.ts +++ b/packages/@aws-cdk/cdk/lib/cloudformation/stack.ts @@ -239,7 +239,6 @@ export class Stack extends Construct { * Rename a generated logical identities */ public renameLogical(oldId: string, newId: string) { - // tslint:disable-next-line:no-console if (this.node.children.length > 0) { throw new Error("All renames must be set up before adding elements to the stack"); } @@ -469,7 +468,6 @@ export class Stack extends Construct { } function merge(template: any, part: any) { - // console.error({ merge: { part: JSON.stringify(part) }}); for (const section of Object.keys(part)) { const src = part[section]; From dfa06ca92a396ce129b273e8c3b12b4161262bf2 Mon Sep 17 00:00:00 2001 From: Elad Ben-Israel Date: Tue, 5 Feb 2019 13:03:17 +0200 Subject: [PATCH 06/20] sort after mapping to logical IDs --- packages/@aws-cdk/cdk/lib/cloudformation/resource.ts | 8 +------- 1 file changed, 1 insertion(+), 7 deletions(-) diff --git a/packages/@aws-cdk/cdk/lib/cloudformation/resource.ts b/packages/@aws-cdk/cdk/lib/cloudformation/resource.ts index 0f1eb3a56cd2c..a439e8b74d7c0 100644 --- a/packages/@aws-cdk/cdk/lib/cloudformation/resource.ts +++ b/packages/@aws-cdk/cdk/lib/cloudformation/resource.ts @@ -201,7 +201,7 @@ export class Resource extends Referenceable { Type: this.resourceType, Properties: ignoreEmpty(this, properties), // Return a sorted set of dependencies to be consistent across tests - DependsOn: ignoreEmpty(this, sortedSet(this.dependsOn).map(r => r.logicalId)), + DependsOn: ignoreEmpty(this, Array.from(this.dependsOn).map(r => r.logicalId).sort()), CreationPolicy: capitalizePropertyNames(this, this.options.creationPolicy), UpdatePolicy: capitalizePropertyNames(this, this.options.updatePolicy), UpdateReplacePolicy: capitalizePropertyNames(this, this.options.updateReplacePolicy), @@ -309,9 +309,3 @@ export function deepMerge(target: any, source: any) { return target; } - -function sortedSet(xs: Set): T[] { - const ret = Array.from(xs); - ret.sort(); - return ret; -} From bc92bb9add5552efb1890d20818333a79a2da053 Mon Sep 17 00:00:00 2001 From: Elad Ben-Israel Date: Tue, 5 Feb 2019 13:12:42 +0200 Subject: [PATCH 07/20] sort by node path --- packages/@aws-cdk/cdk/lib/cloudformation/resource.ts | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/packages/@aws-cdk/cdk/lib/cloudformation/resource.ts b/packages/@aws-cdk/cdk/lib/cloudformation/resource.ts index a439e8b74d7c0..e6a0be9d772ec 100644 --- a/packages/@aws-cdk/cdk/lib/cloudformation/resource.ts +++ b/packages/@aws-cdk/cdk/lib/cloudformation/resource.ts @@ -201,7 +201,7 @@ export class Resource extends Referenceable { Type: this.resourceType, Properties: ignoreEmpty(this, properties), // Return a sorted set of dependencies to be consistent across tests - DependsOn: ignoreEmpty(this, Array.from(this.dependsOn).map(r => r.logicalId).sort()), + DependsOn: ignoreEmpty(this, renderDependsOn(this.dependsOn)), CreationPolicy: capitalizePropertyNames(this, this.options.creationPolicy), UpdatePolicy: capitalizePropertyNames(this, this.options.updatePolicy), UpdateReplacePolicy: capitalizePropertyNames(this, this.options.updateReplacePolicy), @@ -221,6 +221,15 @@ export class Resource extends Referenceable { // Re-throw throw e; } + + // returns the set of logical ID (tokens) this resource depends on + // sorted by construct paths to ensure test determinism + function renderDependsOn(dependsOn: Set) { + return Array + .from(dependsOn) + .sort((x, y) => x.node.path.localeCompare(y.node.path)) + .map(r => r.logicalId); + } } protected renderProperties(properties: any): { [key: string]: any } { From dbe2204a5df9372f6c66f9d1a5f16e72225ad6e8 Mon Sep 17 00:00:00 2001 From: Elad Ben-Israel Date: Tue, 5 Feb 2019 13:41:37 +0200 Subject: [PATCH 08/20] replace hard-coded path --- packages/@aws-cdk/assets/test/test.asset.ts | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/packages/@aws-cdk/assets/test/test.asset.ts b/packages/@aws-cdk/assets/test/test.asset.ts index 5075a42c48a7f..7d123e5a25733 100644 --- a/packages/@aws-cdk/assets/test/test.asset.ts +++ b/packages/@aws-cdk/assets/test/test.asset.ts @@ -37,7 +37,7 @@ export = { 'verify that the app resolves tokens in metadata'(test: Test) { const app = new cdk.App(); const stack = new cdk.Stack(app, 'my-stack'); - const dirPath = path.join(__dirname, 'sample-asset-directory'); + const dirPath = path.resolve(__dirname, 'sample-asset-directory'); new ZipDirectoryAsset(stack, 'MyAsset', { path: dirPath @@ -46,7 +46,7 @@ export = { const synth = app.synthesizeStack(stack.name); test.deepEqual(synth.metadata['/my-stack/MyAsset'][0].data, { - path: "/Users/benisrae/code/cdk/aws-cdk/packages/@aws-cdk/assets/test/sample-asset-directory", + path: dirPath, id: "mystackMyAssetD6B1B593", packaging: "zip", s3BucketParameter: "MyAssetS3Bucket68C9B344", From d93b57de5c031693314961e8b316150e19d3dfa6 Mon Sep 17 00:00:00 2001 From: Elad Ben-Israel Date: Tue, 5 Feb 2019 15:03:21 +0200 Subject: [PATCH 09/20] fix dep order --- .../aws-elasticloadbalancingv2/test/nlb/test.listener.ts | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/packages/@aws-cdk/aws-elasticloadbalancingv2/test/nlb/test.listener.ts b/packages/@aws-cdk/aws-elasticloadbalancingv2/test/nlb/test.listener.ts index 6b08d52acbb51..b60d0db5801f3 100644 --- a/packages/@aws-cdk/aws-elasticloadbalancingv2/test/nlb/test.listener.ts +++ b/packages/@aws-cdk/aws-elasticloadbalancingv2/test/nlb/test.listener.ts @@ -133,10 +133,10 @@ export = { MyResource: { Type: "Test::Resource", DependsOn: [ - "LBListener49E825B4", // 2nd dependency is there because of the structure of the construct tree. // It does not harm. - "LBListenerGroupGroup79B304FF" + "LBListenerGroupGroup79B304FF", + "LBListener49E825B4", ] } } From e08465b7f084d08e8d3e1c9cc84f1d5dbe7f4055 Mon Sep 17 00:00:00 2001 From: Elad Ben-Israel Date: Tue, 5 Feb 2019 15:29:30 +0200 Subject: [PATCH 10/20] update lambda tests --- .../test/integ.lambda.expected.json | 6 ++--- .../@aws-cdk/aws-lambda/test/test.lambda.ts | 22 +++++++++---------- 2 files changed, 14 insertions(+), 14 deletions(-) diff --git a/packages/@aws-cdk/aws-lambda/test/integ.lambda.expected.json b/packages/@aws-cdk/aws-lambda/test/integ.lambda.expected.json index 72c4017892df1..57ec918f05d8f 100644 --- a/packages/@aws-cdk/aws-lambda/test/integ.lambda.expected.json +++ b/packages/@aws-cdk/aws-lambda/test/integ.lambda.expected.json @@ -68,8 +68,8 @@ "Runtime": "nodejs6.10" }, "DependsOn": [ - "MyLambdaServiceRole4539ECB6", - "MyLambdaServiceRoleDefaultPolicy5BBC6F68" + "MyLambdaServiceRoleDefaultPolicy5BBC6F68", + "MyLambdaServiceRole4539ECB6" ] }, "MyLambdaVersion16CDE3C40": { @@ -96,4 +96,4 @@ } } } -} \ No newline at end of file +} diff --git a/packages/@aws-cdk/aws-lambda/test/test.lambda.ts b/packages/@aws-cdk/aws-lambda/test/test.lambda.ts index 370453b926a1b..777bd071b125d 100644 --- a/packages/@aws-cdk/aws-lambda/test/test.lambda.ts +++ b/packages/@aws-cdk/aws-lambda/test/test.lambda.ts @@ -95,7 +95,7 @@ export = { Handler: 'index.handler', Role: { 'Fn::GetAtt': [ 'MyLambdaServiceRole4539ECB6', 'Arn' ] }, Runtime: 'nodejs6.10' }, - DependsOn: [ 'MyLambdaServiceRole4539ECB6', 'MyLambdaServiceRoleDefaultPolicy5BBC6F68' ] } } } ); + DependsOn: [ 'MyLambdaServiceRoleDefaultPolicy5BBC6F68', 'MyLambdaServiceRole4539ECB6' ] } } } ); test.done(); }, @@ -429,8 +429,8 @@ export = { "FunctionName": "OneFunctionToRuleThemAll" }, "DependsOn": [ - "MyLambdaServiceRole4539ECB6", - "MyLambdaServiceRoleDefaultPolicy5BBC6F68" + "MyLambdaServiceRoleDefaultPolicy5BBC6F68", + "MyLambdaServiceRole4539ECB6" ] } } @@ -539,8 +539,8 @@ export = { } }, "DependsOn": [ - "MyLambdaServiceRole4539ECB6", - "MyLambdaServiceRoleDefaultPolicy5BBC6F68" + "MyLambdaServiceRoleDefaultPolicy5BBC6F68", + "MyLambdaServiceRole4539ECB6" ] } } @@ -717,8 +717,8 @@ export = { } }, "DependsOn": [ - "MyLambdaServiceRole4539ECB6", - "MyLambdaServiceRoleDefaultPolicy5BBC6F68" + "MyLambdaServiceRoleDefaultPolicy5BBC6F68", + "MyLambdaServiceRole4539ECB6" ] } } @@ -827,8 +827,8 @@ export = { } }, "DependsOn": [ - "MyLambdaServiceRole4539ECB6", - "MyLambdaServiceRoleDefaultPolicy5BBC6F68" + "MyLambdaServiceRoleDefaultPolicy5BBC6F68", + "MyLambdaServiceRole4539ECB6", ] } } @@ -906,8 +906,8 @@ export = { } }, "DependsOn": [ + "MyLambdaServiceRoleDefaultPolicy5BBC6F68", "MyLambdaServiceRole4539ECB6", - "MyLambdaServiceRoleDefaultPolicy5BBC6F68" ] }, ResourcePart.CompleteDefinition)); @@ -964,8 +964,8 @@ export = { } }, "DependsOn": [ + "MyLambdaServiceRoleDefaultPolicy5BBC6F68", "MyLambdaServiceRole4539ECB6", - "MyLambdaServiceRoleDefaultPolicy5BBC6F68" ] }, ResourcePart.CompleteDefinition)); From 6afa8cc3348eb49fc88452fac5bc8642c4399ea0 Mon Sep 17 00:00:00 2001 From: Elad Ben-Israel Date: Tue, 5 Feb 2019 15:45:20 +0200 Subject: [PATCH 11/20] fix tests --- packages/@aws-cdk/assets/test/test.asset.ts | 3 +++ packages/@aws-cdk/aws-sns/test/test.sns.ts | 3 ++- 2 files changed, 5 insertions(+), 1 deletion(-) diff --git a/packages/@aws-cdk/assets/test/test.asset.ts b/packages/@aws-cdk/assets/test/test.asset.ts index 7d123e5a25733..1c23f1b49f699 100644 --- a/packages/@aws-cdk/assets/test/test.asset.ts +++ b/packages/@aws-cdk/assets/test/test.asset.ts @@ -18,6 +18,9 @@ export = { // the correct information const entry = asset.node.metadata.find(m => m.type === 'aws:cdk:asset'); test.ok(entry, 'found metadata entry'); + + // console.error(JSON.stringify(stack.node.resolve(entry!.data))); + test.deepEqual(stack.node.resolve(entry!.data), { path: dirPath, id: 'MyAsset', diff --git a/packages/@aws-cdk/aws-sns/test/test.sns.ts b/packages/@aws-cdk/aws-sns/test/test.sns.ts index 7d9b21872bd2a..225c4f36e72c5 100644 --- a/packages/@aws-cdk/aws-sns/test/test.sns.ts +++ b/packages/@aws-cdk/aws-sns/test/test.sns.ts @@ -718,7 +718,8 @@ export = { test.deepEqual(dest1.type, s3n.BucketNotificationDestinationType.Topic); const dep: cdk.Construct = dest1.dependencies![0] as any; - test.deepEqual((dep.node.children[0] as any).logicalId, 'MyTopicPolicy12A5EC17', 'verify topic policy is added as dependency'); + test.deepEqual(stack.node.resolve((dep.node.children[0] as any).logicalId), + 'MyTopicPolicy12A5EC17', 'verify topic policy is added as dependency'); // calling again on the same bucket yields is idempotent const dest2 = topic.asBucketNotificationDestination(bucketArn, bucketId); From 3bf0f73a9fa22d223bc3234c509a83de6bb545ba Mon Sep 17 00:00:00 2001 From: Elad Ben-Israel Date: Tue, 5 Feb 2019 15:50:39 +0200 Subject: [PATCH 12/20] fix rtv test --- .../runtime-values/test/integ.rtv.lambda.expected.json | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/packages/@aws-cdk/runtime-values/test/integ.rtv.lambda.expected.json b/packages/@aws-cdk/runtime-values/test/integ.rtv.lambda.expected.json index 850eb3247efed..cd55408e3416c 100644 --- a/packages/@aws-cdk/runtime-values/test/integ.rtv.lambda.expected.json +++ b/packages/@aws-cdk/runtime-values/test/integ.rtv.lambda.expected.json @@ -105,8 +105,8 @@ } }, "DependsOn": [ - "MyFunctionServiceRole3C357FF2", - "MyFunctionServiceRoleDefaultPolicyB705ABD4" + "MyFunctionServiceRoleDefaultPolicyB705ABD4", + "MyFunctionServiceRole3C357FF2" ] }, "MyQueueURLParameterA4918D6E": { From 1936a9c60a4135e7e7dc84ea1c03299cb233f1b2 Mon Sep 17 00:00:00 2001 From: Elad Ben-Israel Date: Tue, 5 Feb 2019 16:10:19 +0200 Subject: [PATCH 13/20] update apigateway tests --- .../test/integ.restapi.books.expected.json | 8 ++++---- .../aws-apigateway/test/integ.restapi.expected.json | 10 +++++----- packages/@aws-cdk/aws-apigateway/test/test.restapi.ts | 6 +++--- 3 files changed, 12 insertions(+), 12 deletions(-) diff --git a/packages/@aws-cdk/aws-apigateway/test/integ.restapi.books.expected.json b/packages/@aws-cdk/aws-apigateway/test/integ.restapi.books.expected.json index 7ffe53ec51c08..adc51fd27c59b 100644 --- a/packages/@aws-cdk/aws-apigateway/test/integ.restapi.books.expected.json +++ b/packages/@aws-cdk/aws-apigateway/test/integ.restapi.books.expected.json @@ -526,12 +526,12 @@ }, "DependsOn": [ "booksapiANYF4F0CDEB", - "booksapibooks97D84727", + "booksapibooksbookidDELETE214F4059", + "booksapibooksbookidGETCCE21986", + "booksapibooksbookid5264BCA2", "booksapibooksGETA776447A", "booksapibooksPOSTF6C6559D", - "booksapibooksbookid5264BCA2", - "booksapibooksbookidDELETE214F4059", - "booksapibooksbookidGETCCE21986" + "booksapibooks97D84727" ] }, "booksapiDeploymentStageprod55D8E03E": { diff --git a/packages/@aws-cdk/aws-apigateway/test/integ.restapi.expected.json b/packages/@aws-cdk/aws-apigateway/test/integ.restapi.expected.json index 6bf7d6bcb6c7f..0fc3dc465c836 100644 --- a/packages/@aws-cdk/aws-apigateway/test/integ.restapi.expected.json +++ b/packages/@aws-cdk/aws-apigateway/test/integ.restapi.expected.json @@ -15,16 +15,16 @@ "Description": "Automatically created by the RestApi construct" }, "DependsOn": [ - "myapiv113487378", - "myapiv1appliances507FEFF4", "myapiv1appliancesGET8FE872EC", - "myapiv1books1D4BE6C1", + "myapiv1appliances507FEFF4", "myapiv1booksGETC6B996D0", "myapiv1booksPOST53E2832E", - "myapiv1toysA55FCBC4", + "myapiv1books1D4BE6C1", + "myapiv113487378", "myapiv1toysGET7348114D", "myapiv1toysPOST55128058", - "myapiv1toysPUT59AFBBC2" + "myapiv1toysPUT59AFBBC2", + "myapiv1toysA55FCBC4" ], "DeletionPolicy": "Retain" }, diff --git a/packages/@aws-cdk/aws-apigateway/test/test.restapi.ts b/packages/@aws-cdk/aws-apigateway/test/test.restapi.ts index 8af12724e391c..d02a7667e9e36 100644 --- a/packages/@aws-cdk/aws-apigateway/test/test.restapi.ts +++ b/packages/@aws-cdk/aws-apigateway/test/test.restapi.ts @@ -526,12 +526,12 @@ export = { // THEN expect(stack).to(haveResource('My::Resource', { DependsOn: [ - "myapiDeploymentB7EF8EB75c091a668064a3f3a1f6d68a3fb22cf9", - "myapi162F20B8", "myapiAccountC3A4750C", "myapiCloudWatchRoleEB425128", + "myapiDeploymentB7EF8EB75c091a668064a3f3a1f6d68a3fb22cf9", "myapiDeploymentStageprod329F21FF", - "myapiGET9B7CD29E" + "myapiGET9B7CD29E", + "myapi162F20B8" ] }, ResourcePart.CompleteDefinition)); From d48806be342f81a4f086677526911e03ae7e6208 Mon Sep 17 00:00:00 2001 From: Elad Ben-Israel Date: Tue, 5 Feb 2019 16:23:54 +0200 Subject: [PATCH 14/20] update autoscaling test --- packages/@aws-cdk/aws-autoscaling/test/test.lifecyclehooks.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/@aws-cdk/aws-autoscaling/test/test.lifecyclehooks.ts b/packages/@aws-cdk/aws-autoscaling/test/test.lifecyclehooks.ts index c01201c556194..df1d599d2f50f 100644 --- a/packages/@aws-cdk/aws-autoscaling/test/test.lifecyclehooks.ts +++ b/packages/@aws-cdk/aws-autoscaling/test/test.lifecyclehooks.ts @@ -34,8 +34,8 @@ export = { // Lifecycle Hook has a dependency on the policy object expect(stack).to(haveResource('AWS::AutoScaling::LifecycleHook', { DependsOn: [ + "ASGLifecycleHookTransitionRoleDefaultPolicy2E50C7DB", "ASGLifecycleHookTransitionRole3AAA6BB7", - "ASGLifecycleHookTransitionRoleDefaultPolicy2E50C7DB" ] }, ResourcePart.CompleteDefinition)); From 4865c58159cfee288d2ce142884b4fcdd2b6b7b8 Mon Sep 17 00:00:00 2001 From: Elad Ben-Israel Date: Tue, 5 Feb 2019 16:32:16 +0200 Subject: [PATCH 15/20] update lambda-event-sources tests --- .../test/integ.dynamodb.expected.json | 4 ++-- .../aws-lambda-event-sources/test/integ.kinesis.expected.json | 4 ++-- .../aws-lambda-event-sources/test/integ.sqs.expected.json | 4 ++-- 3 files changed, 6 insertions(+), 6 deletions(-) diff --git a/packages/@aws-cdk/aws-lambda-event-sources/test/integ.dynamodb.expected.json b/packages/@aws-cdk/aws-lambda-event-sources/test/integ.dynamodb.expected.json index 95f12af72cf00..cab31fbca8a38 100644 --- a/packages/@aws-cdk/aws-lambda-event-sources/test/integ.dynamodb.expected.json +++ b/packages/@aws-cdk/aws-lambda-event-sources/test/integ.dynamodb.expected.json @@ -82,8 +82,8 @@ "Runtime": "nodejs8.10" }, "DependsOn": [ - "FServiceRole3AC82EE1", - "FServiceRoleDefaultPolicy17A19BFA" + "FServiceRoleDefaultPolicy17A19BFA", + "FServiceRole3AC82EE1" ] }, "FDynamoDBEventSourcelambdaeventsourcedynamodbT7967476AE652DA48": { diff --git a/packages/@aws-cdk/aws-lambda-event-sources/test/integ.kinesis.expected.json b/packages/@aws-cdk/aws-lambda-event-sources/test/integ.kinesis.expected.json index fdd245f5a7cda..d811834a7f0b1 100644 --- a/packages/@aws-cdk/aws-lambda-event-sources/test/integ.kinesis.expected.json +++ b/packages/@aws-cdk/aws-lambda-event-sources/test/integ.kinesis.expected.json @@ -77,8 +77,8 @@ "Runtime": "nodejs8.10" }, "DependsOn": [ - "FServiceRole3AC82EE1", - "FServiceRoleDefaultPolicy17A19BFA" + "FServiceRoleDefaultPolicy17A19BFA", + "FServiceRole3AC82EE1" ] }, "FKinesisEventSourcelambdaeventsourcekinesisQ645CE7DB2D6BCCF5": { diff --git a/packages/@aws-cdk/aws-lambda-event-sources/test/integ.sqs.expected.json b/packages/@aws-cdk/aws-lambda-event-sources/test/integ.sqs.expected.json index e590deace266b..4975bf693e1fd 100644 --- a/packages/@aws-cdk/aws-lambda-event-sources/test/integ.sqs.expected.json +++ b/packages/@aws-cdk/aws-lambda-event-sources/test/integ.sqs.expected.json @@ -81,8 +81,8 @@ "Runtime": "nodejs8.10" }, "DependsOn": [ - "FServiceRole3AC82EE1", - "FServiceRoleDefaultPolicy17A19BFA" + "FServiceRoleDefaultPolicy17A19BFA", + "FServiceRole3AC82EE1" ] }, "FSqsEventSourcelambdaeventsourcesqsQ67DE9201754EC819": { From 314dfe7be3130c54e09e33a38d17c754cd61164d Mon Sep 17 00:00:00 2001 From: Elad Ben-Israel Date: Tue, 5 Feb 2019 16:49:23 +0200 Subject: [PATCH 16/20] update codedeploy tests --- .../test/lambda/integ.deployment-group.expected.json | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/packages/@aws-cdk/aws-codedeploy/test/lambda/integ.deployment-group.expected.json b/packages/@aws-cdk/aws-codedeploy/test/lambda/integ.deployment-group.expected.json index 6dfeb4061a356..d47c94ea745f4 100644 --- a/packages/@aws-cdk/aws-codedeploy/test/lambda/integ.deployment-group.expected.json +++ b/packages/@aws-cdk/aws-codedeploy/test/lambda/integ.deployment-group.expected.json @@ -253,8 +253,8 @@ "Runtime": "nodejs8.10" }, "DependsOn": [ - "PreHookServiceRoleC724B9BA", - "PreHookServiceRoleDefaultPolicy65358F76" + "PreHookServiceRoleDefaultPolicy65358F76", + "PreHookServiceRoleC724B9BA" ] }, "PostHookServiceRoleE8A6AAC2": { From 8dbafa2f5f4cd318922e6a8f689103c56179fe26 Mon Sep 17 00:00:00 2001 From: Elad Ben-Israel Date: Tue, 5 Feb 2019 17:22:15 +0200 Subject: [PATCH 17/20] fix s3-deployment tests --- .../test/integ.bucket-deployment.expected.json | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/packages/@aws-cdk/aws-s3-deployment/test/integ.bucket-deployment.expected.json b/packages/@aws-cdk/aws-s3-deployment/test/integ.bucket-deployment.expected.json index 8a43d05aa3089..6fb73507aebf6 100644 --- a/packages/@aws-cdk/aws-s3-deployment/test/integ.bucket-deployment.expected.json +++ b/packages/@aws-cdk/aws-s3-deployment/test/integ.bucket-deployment.expected.json @@ -338,8 +338,8 @@ "Timeout": 900 }, "DependsOn": [ - "CustomCDKBucketDeployment8693BB64968944B69AAFB0CC9EB8756CServiceRole89A01265", - "CustomCDKBucketDeployment8693BB64968944B69AAFB0CC9EB8756CServiceRoleDefaultPolicy88902FDF" + "CustomCDKBucketDeployment8693BB64968944B69AAFB0CC9EB8756CServiceRoleDefaultPolicy88902FDF", + "CustomCDKBucketDeployment8693BB64968944B69AAFB0CC9EB8756CServiceRole89A01265" ] }, "Destination281A09BDF": { @@ -425,4 +425,4 @@ "Description": "S3 key for asset version \"test-bucket-deployments-1/DeployWithPrefix/Asset\"" } } -} \ No newline at end of file +} From bbed3e5f35b97a05cee012db67c1465657cba9c9 Mon Sep 17 00:00:00 2001 From: Elad Ben-Israel Date: Wed, 6 Feb 2019 15:16:56 +0200 Subject: [PATCH 18/20] update more test expectations --- .../test/integ.docker-asset.lit.expected.json | 6 +++--- ...nteg.cfn-template-from-repo.lit.expected.json | 4 ++-- .../test/integ.lambda-pipeline.expected.json | 4 ++-- .../integ.pipeline-alexa-deploy.expected.json | 4 ++-- ...integ.pipeline-cfn-cross-region.expected.json | 4 ++-- ...g.pipeline-cfn-wtih-action-role.expected.json | 4 ++-- .../test/integ.pipeline-cfn.expected.json | 4 ++-- ...e-build-multiple-inputs-outputs.expected.json | 4 ++-- ...nteg.pipeline-code-commit-build.expected.json | 4 ++-- .../integ.pipeline-code-commit.expected.json | 4 ++-- .../integ.pipeline-code-deploy.expected.json | 4 ++-- .../test/integ.pipeline-ecr-source.expected.json | 4 ++-- .../test/integ.pipeline-events.expected.json | 4 ++-- .../test/integ.pipeline-jenkins.expected.json | 4 ++-- .../integ.pipeline-manual-approval.expected.json | 4 ++-- .../test/integ.pipeline-s3-deploy.expected.json | 4 ++-- .../test/ec2/integ.event-task.lit.expected.json | 16 ++++++++-------- .../test/ec2/integ.lb-awsvpc-nw.expected.json | 16 ++++++++-------- .../test/ec2/integ.lb-bridge-nw.expected.json | 16 ++++++++-------- .../test/fargate/integ.asset-image.expected.json | 8 ++++---- .../aws-ecs/test/fargate/integ.l3.expected.json | 4 ++-- .../fargate/integ.lb-awsvpc-nw.expected.json | 4 ++-- 22 files changed, 65 insertions(+), 65 deletions(-) diff --git a/packages/@aws-cdk/aws-codebuild/test/integ.docker-asset.lit.expected.json b/packages/@aws-cdk/aws-codebuild/test/integ.docker-asset.lit.expected.json index 887a952d0ef7c..14fcfec0b7098 100644 --- a/packages/@aws-cdk/aws-codebuild/test/integ.docker-asset.lit.expected.json +++ b/packages/@aws-cdk/aws-codebuild/test/integ.docker-asset.lit.expected.json @@ -197,8 +197,8 @@ "Timeout": 300 }, "DependsOn": [ - "AdoptEcrRepositorydbc60defc59544bcaa5c28c95d68f62cServiceRoleD788AA17", - "AdoptEcrRepositorydbc60defc59544bcaa5c28c95d68f62cServiceRoleDefaultPolicy6BC8737C" + "AdoptEcrRepositorydbc60defc59544bcaa5c28c95d68f62cServiceRoleDefaultPolicy6BC8737C", + "AdoptEcrRepositorydbc60defc59544bcaa5c28c95d68f62cServiceRoleD788AA17" ] }, "MyProjectRole9BBE5233": { @@ -416,4 +416,4 @@ } } } -} \ No newline at end of file +} diff --git a/packages/@aws-cdk/aws-codepipeline/test/integ.cfn-template-from-repo.lit.expected.json b/packages/@aws-cdk/aws-codepipeline/test/integ.cfn-template-from-repo.lit.expected.json index 552b0ee5903aa..313d1a5f5ac39 100644 --- a/packages/@aws-cdk/aws-codepipeline/test/integ.cfn-template-from-repo.lit.expected.json +++ b/packages/@aws-cdk/aws-codepipeline/test/integ.cfn-template-from-repo.lit.expected.json @@ -272,8 +272,8 @@ ] }, "DependsOn": [ - "PipelineRoleD68726F7", - "PipelineRoleDefaultPolicyC7A05455" + "PipelineRoleDefaultPolicyC7A05455", + "PipelineRoleD68726F7" ] }, "PipelineDeployPrepareChangesRoleD28C853C": { diff --git a/packages/@aws-cdk/aws-codepipeline/test/integ.lambda-pipeline.expected.json b/packages/@aws-cdk/aws-codepipeline/test/integ.lambda-pipeline.expected.json index 9ce5afc38218f..b33012fec4f5e 100644 --- a/packages/@aws-cdk/aws-codepipeline/test/integ.lambda-pipeline.expected.json +++ b/packages/@aws-cdk/aws-codepipeline/test/integ.lambda-pipeline.expected.json @@ -184,8 +184,8 @@ ] }, "DependsOn": [ - "PipelineRoleD68726F7", - "PipelineRoleDefaultPolicyC7A05455" + "PipelineRoleDefaultPolicyC7A05455", + "PipelineRoleD68726F7" ] }, "PipelineEventsRole46BEEA7C": { diff --git a/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-alexa-deploy.expected.json b/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-alexa-deploy.expected.json index f65ac6af5d5f4..d8c834a6bc4de 100644 --- a/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-alexa-deploy.expected.json +++ b/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-alexa-deploy.expected.json @@ -173,8 +173,8 @@ } }, "DependsOn": [ - "PipelineRoleD68726F7", - "PipelineRoleDefaultPolicyC7A05455" + "PipelineRoleDefaultPolicyC7A05455", + "PipelineRoleD68726F7" ] }, "PipelineBucketB967BD35": { diff --git a/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-cfn-cross-region.expected.json b/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-cfn-cross-region.expected.json index 11d129412453c..c6c39076795ce 100644 --- a/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-cfn-cross-region.expected.json +++ b/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-cfn-cross-region.expected.json @@ -222,8 +222,8 @@ ] }, "DependsOn": [ - "MyPipelineRoleC0D47CA4", - "MyPipelineRoleDefaultPolicy34F09EFA" + "MyPipelineRoleDefaultPolicy34F09EFA", + "MyPipelineRoleC0D47CA4" ] }, "CFNDeployRole68D5E8D3": { diff --git a/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-cfn-wtih-action-role.expected.json b/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-cfn-wtih-action-role.expected.json index 996cc24369ad7..6e3db81ef398c 100644 --- a/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-cfn-wtih-action-role.expected.json +++ b/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-cfn-wtih-action-role.expected.json @@ -238,8 +238,8 @@ } }, "DependsOn": [ - "MyPipelineRoleC0D47CA4", - "MyPipelineRoleDefaultPolicy34F09EFA" + "MyPipelineRoleDefaultPolicy34F09EFA", + "MyPipelineRoleC0D47CA4" ] }, "ActionRole60B0EDF7": { diff --git a/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-cfn.expected.json b/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-cfn.expected.json index ce6601744b4fc..a41cc93d39df2 100644 --- a/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-cfn.expected.json +++ b/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-cfn.expected.json @@ -224,8 +224,8 @@ ] }, "DependsOn": [ - "PipelineRoleD68726F7", - "PipelineRoleDefaultPolicyC7A05455" + "PipelineRoleDefaultPolicyC7A05455", + "PipelineRoleD68726F7" ] }, "PipelineBucketB967BD35": { diff --git a/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-code-build-multiple-inputs-outputs.expected.json b/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-code-build-multiple-inputs-outputs.expected.json index edf559a6831b7..e038fb3a5e13b 100644 --- a/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-code-build-multiple-inputs-outputs.expected.json +++ b/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-code-build-multiple-inputs-outputs.expected.json @@ -358,8 +358,8 @@ ] }, "DependsOn": [ - "PipelineRoleD68726F7", - "PipelineRoleDefaultPolicyC7A05455" + "PipelineRoleDefaultPolicyC7A05455", + "PipelineRoleD68726F7" ] }, "PipelineEventsRole46BEEA7C": { diff --git a/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-code-commit-build.expected.json b/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-code-commit-build.expected.json index c0083e6923c60..5bdbf836e3627 100644 --- a/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-code-commit-build.expected.json +++ b/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-code-commit-build.expected.json @@ -222,8 +222,8 @@ ] }, "DependsOn": [ - "PipelineRoleD68726F7", - "PipelineRoleDefaultPolicyC7A05455" + "PipelineRoleDefaultPolicyC7A05455", + "PipelineRoleD68726F7" ] }, "MyBuildProjectRole6B7E2258": { diff --git a/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-code-commit.expected.json b/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-code-commit.expected.json index b6e9ea9fa6c85..147696b2cb636 100644 --- a/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-code-commit.expected.json +++ b/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-code-commit.expected.json @@ -225,8 +225,8 @@ ] }, "DependsOn": [ - "PipelineRoleD68726F7", - "PipelineRoleDefaultPolicyC7A05455" + "PipelineRoleDefaultPolicyC7A05455", + "PipelineRoleD68726F7" ] }, "PipelineEventsRole46BEEA7C": { diff --git a/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-code-deploy.expected.json b/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-code-deploy.expected.json index a1615f8e2905c..5b7f0e88fb948 100644 --- a/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-code-deploy.expected.json +++ b/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-code-deploy.expected.json @@ -330,8 +330,8 @@ ] }, "DependsOn": [ - "PipelineRoleD68726F7", - "PipelineRoleDefaultPolicyC7A05455" + "PipelineRoleDefaultPolicyC7A05455", + "PipelineRoleD68726F7" ] } } diff --git a/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-ecr-source.expected.json b/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-ecr-source.expected.json index 6236aba51716e..d83bf9168554b 100644 --- a/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-ecr-source.expected.json +++ b/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-ecr-source.expected.json @@ -141,8 +141,8 @@ } }, "DependsOn": [ - "MyPipelineRoleC0D47CA4", - "MyPipelineRoleDefaultPolicy34F09EFA" + "MyPipelineRoleDefaultPolicy34F09EFA", + "MyPipelineRoleC0D47CA4" ] }, "MyPipelineEventsRoleFAB99F32": { diff --git a/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-events.expected.json b/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-events.expected.json index b977353f76690..d5dbe738cd94e 100644 --- a/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-events.expected.json +++ b/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-events.expected.json @@ -180,8 +180,8 @@ ] }, "DependsOn": [ - "MyPipelineRoleC0D47CA4", - "MyPipelineRoleDefaultPolicy34F09EFA" + "MyPipelineRoleDefaultPolicy34F09EFA", + "MyPipelineRoleC0D47CA4" ] }, "MyPipelineOnPipelineStateChangeA017E4B1": { diff --git a/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-jenkins.expected.json b/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-jenkins.expected.json index fcd2e2444f8f1..85bfa3a5b6ed1 100644 --- a/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-jenkins.expected.json +++ b/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-jenkins.expected.json @@ -217,8 +217,8 @@ ] }, "DependsOn": [ - "PipelineRoleD68726F7", - "PipelineRoleDefaultPolicyC7A05455" + "PipelineRoleDefaultPolicyC7A05455", + "PipelineRoleD68726F7" ] }, "JenkinsProviderJenkinsBuildProviderResourceD9231CAC": { diff --git a/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-manual-approval.expected.json b/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-manual-approval.expected.json index d27e5e8587ea3..83a73e2128b66 100644 --- a/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-manual-approval.expected.json +++ b/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-manual-approval.expected.json @@ -175,8 +175,8 @@ } }, "DependsOn": [ - "PipelineRoleD68726F7", - "PipelineRoleDefaultPolicyC7A05455" + "PipelineRoleDefaultPolicyC7A05455", + "PipelineRoleD68726F7" ] }, "ManualApprovalTopicResource300641E2": { diff --git a/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-s3-deploy.expected.json b/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-s3-deploy.expected.json index c490f7a2cd023..9165619069674 100644 --- a/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-s3-deploy.expected.json +++ b/packages/@aws-cdk/aws-codepipeline/test/integ.pipeline-s3-deploy.expected.json @@ -203,8 +203,8 @@ } }, "DependsOn": [ - "PipelineRoleD68726F7", - "PipelineRoleDefaultPolicyC7A05455" + "PipelineRoleDefaultPolicyC7A05455", + "PipelineRoleD68726F7" ] }, "PipelineBucketB967BD35": { diff --git a/packages/@aws-cdk/aws-ecs/test/ec2/integ.event-task.lit.expected.json b/packages/@aws-cdk/aws-ecs/test/ec2/integ.event-task.lit.expected.json index c3b9d654c394a..c4e235630290f 100644 --- a/packages/@aws-cdk/aws-ecs/test/ec2/integ.event-task.lit.expected.json +++ b/packages/@aws-cdk/aws-ecs/test/ec2/integ.event-task.lit.expected.json @@ -307,8 +307,8 @@ } }, "DependsOn": [ - "EcsClusterDefaultAutoScalingGroupInstanceRole3C026863", - "EcsClusterDefaultAutoScalingGroupInstanceRoleDefaultPolicy04DC6C80" + "EcsClusterDefaultAutoScalingGroupInstanceRoleDefaultPolicy04DC6C80", + "EcsClusterDefaultAutoScalingGroupInstanceRole3C026863" ] }, "EcsClusterDefaultAutoScalingGroupASGC1A785DB": { @@ -455,8 +455,8 @@ "Timeout": 310 }, "DependsOn": [ - "EcsClusterDefaultAutoScalingGroupDrainECSHookFunctionServiceRole94543EDA", - "EcsClusterDefaultAutoScalingGroupDrainECSHookFunctionServiceRoleDefaultPolicyA45BF396" + "EcsClusterDefaultAutoScalingGroupDrainECSHookFunctionServiceRoleDefaultPolicyA45BF396", + "EcsClusterDefaultAutoScalingGroupDrainECSHookFunctionServiceRole94543EDA" ] }, "EcsClusterDefaultAutoScalingGroupDrainECSHookFunctionTopicE6B1EBA6": { @@ -532,8 +532,8 @@ } }, "DependsOn": [ - "EcsClusterDefaultAutoScalingGroupLifecycleHookDrainHookRoleA38EC83B", - "EcsClusterDefaultAutoScalingGroupLifecycleHookDrainHookRoleDefaultPolicy75002F88" + "EcsClusterDefaultAutoScalingGroupLifecycleHookDrainHookRoleDefaultPolicy75002F88", + "EcsClusterDefaultAutoScalingGroupLifecycleHookDrainHookRoleA38EC83B" ] }, "TaskDefTaskRole1EDB4A67": { @@ -1025,8 +1025,8 @@ "Timeout": 300 }, "DependsOn": [ - "AdoptEcrRepositorydbc60defc59544bcaa5c28c95d68f62cServiceRoleD788AA17", - "AdoptEcrRepositorydbc60defc59544bcaa5c28c95d68f62cServiceRoleDefaultPolicy6BC8737C" + "AdoptEcrRepositorydbc60defc59544bcaa5c28c95d68f62cServiceRoleDefaultPolicy6BC8737C", + "AdoptEcrRepositorydbc60defc59544bcaa5c28c95d68f62cServiceRoleD788AA17" ] }, "TaskLoggingLogGroupC7E938D4": { diff --git a/packages/@aws-cdk/aws-ecs/test/ec2/integ.lb-awsvpc-nw.expected.json b/packages/@aws-cdk/aws-ecs/test/ec2/integ.lb-awsvpc-nw.expected.json index 6e747f4cbf50c..faebed689e251 100644 --- a/packages/@aws-cdk/aws-ecs/test/ec2/integ.lb-awsvpc-nw.expected.json +++ b/packages/@aws-cdk/aws-ecs/test/ec2/integ.lb-awsvpc-nw.expected.json @@ -460,8 +460,8 @@ } }, "DependsOn": [ - "EcsClusterDefaultAutoScalingGroupInstanceRole3C026863", - "EcsClusterDefaultAutoScalingGroupInstanceRoleDefaultPolicy04DC6C80" + "EcsClusterDefaultAutoScalingGroupInstanceRoleDefaultPolicy04DC6C80", + "EcsClusterDefaultAutoScalingGroupInstanceRole3C026863" ] }, "EcsClusterDefaultAutoScalingGroupASGC1A785DB": { @@ -611,8 +611,8 @@ "Timeout": 310 }, "DependsOn": [ - "EcsClusterDefaultAutoScalingGroupDrainECSHookFunctionServiceRole94543EDA", - "EcsClusterDefaultAutoScalingGroupDrainECSHookFunctionServiceRoleDefaultPolicyA45BF396" + "EcsClusterDefaultAutoScalingGroupDrainECSHookFunctionServiceRoleDefaultPolicyA45BF396", + "EcsClusterDefaultAutoScalingGroupDrainECSHookFunctionServiceRole94543EDA" ] }, "EcsClusterDefaultAutoScalingGroupDrainECSHookFunctionTopicE6B1EBA6": { @@ -688,8 +688,8 @@ } }, "DependsOn": [ - "EcsClusterDefaultAutoScalingGroupLifecycleHookDrainHookRoleA38EC83B", - "EcsClusterDefaultAutoScalingGroupLifecycleHookDrainHookRoleDefaultPolicy75002F88" + "EcsClusterDefaultAutoScalingGroupLifecycleHookDrainHookRoleDefaultPolicy75002F88", + "EcsClusterDefaultAutoScalingGroupLifecycleHookDrainHookRoleA38EC83B" ] }, "TaskDefTaskRole1EDB4A67": { @@ -803,8 +803,8 @@ "SchedulingStrategy": "REPLICA" }, "DependsOn": [ - "LBPublicListener6E1F3D94", - "LBPublicListenerECSGroupD6A32205" + "LBPublicListenerECSGroupD6A32205", + "LBPublicListener6E1F3D94" ] }, "ServiceSecurityGroupC96ED6A7": { diff --git a/packages/@aws-cdk/aws-ecs/test/ec2/integ.lb-bridge-nw.expected.json b/packages/@aws-cdk/aws-ecs/test/ec2/integ.lb-bridge-nw.expected.json index c32cbc2c3a1f9..d370fd4ecb3ea 100644 --- a/packages/@aws-cdk/aws-ecs/test/ec2/integ.lb-bridge-nw.expected.json +++ b/packages/@aws-cdk/aws-ecs/test/ec2/integ.lb-bridge-nw.expected.json @@ -481,8 +481,8 @@ } }, "DependsOn": [ - "EcsClusterDefaultAutoScalingGroupInstanceRole3C026863", - "EcsClusterDefaultAutoScalingGroupInstanceRoleDefaultPolicy04DC6C80" + "EcsClusterDefaultAutoScalingGroupInstanceRoleDefaultPolicy04DC6C80", + "EcsClusterDefaultAutoScalingGroupInstanceRole3C026863" ] }, "EcsClusterDefaultAutoScalingGroupASGC1A785DB": { @@ -632,8 +632,8 @@ "Timeout": 310 }, "DependsOn": [ - "EcsClusterDefaultAutoScalingGroupDrainECSHookFunctionServiceRole94543EDA", - "EcsClusterDefaultAutoScalingGroupDrainECSHookFunctionServiceRoleDefaultPolicyA45BF396" + "EcsClusterDefaultAutoScalingGroupDrainECSHookFunctionServiceRoleDefaultPolicyA45BF396", + "EcsClusterDefaultAutoScalingGroupDrainECSHookFunctionServiceRole94543EDA" ] }, "EcsClusterDefaultAutoScalingGroupDrainECSHookFunctionTopicE6B1EBA6": { @@ -709,8 +709,8 @@ } }, "DependsOn": [ - "EcsClusterDefaultAutoScalingGroupLifecycleHookDrainHookRoleA38EC83B", - "EcsClusterDefaultAutoScalingGroupLifecycleHookDrainHookRoleDefaultPolicy75002F88" + "EcsClusterDefaultAutoScalingGroupLifecycleHookDrainHookRoleDefaultPolicy75002F88", + "EcsClusterDefaultAutoScalingGroupLifecycleHookDrainHookRoleA38EC83B" ] }, "TaskDefTaskRole1EDB4A67": { @@ -804,8 +804,8 @@ "SchedulingStrategy": "REPLICA" }, "DependsOn": [ - "LBPublicListener6E1F3D94", - "LBPublicListenerECSGroupD6A32205" + "LBPublicListenerECSGroupD6A32205", + "LBPublicListener6E1F3D94" ] }, "LB8A12904C": { diff --git a/packages/@aws-cdk/aws-ecs/test/fargate/integ.asset-image.expected.json b/packages/@aws-cdk/aws-ecs/test/fargate/integ.asset-image.expected.json index b6dfb75d25df9..7d400938dd934 100644 --- a/packages/@aws-cdk/aws-ecs/test/fargate/integ.asset-image.expected.json +++ b/packages/@aws-cdk/aws-ecs/test/fargate/integ.asset-image.expected.json @@ -512,8 +512,8 @@ "Timeout": 300 }, "DependsOn": [ - "AdoptEcrRepositorydbc60defc59544bcaa5c28c95d68f62cServiceRoleD788AA17", - "AdoptEcrRepositorydbc60defc59544bcaa5c28c95d68f62cServiceRoleDefaultPolicy6BC8737C" + "AdoptEcrRepositorydbc60defc59544bcaa5c28c95d68f62cServiceRoleDefaultPolicy6BC8737C", + "AdoptEcrRepositorydbc60defc59544bcaa5c28c95d68f62cServiceRoleD788AA17" ] }, "FargateServiceTaskDefTaskRole8CDCF85E": { @@ -838,8 +838,8 @@ } }, "DependsOn": [ - "FargateServiceLBPublicListener4B4929CA", - "FargateServiceLBPublicListenerECSGroupBE57E081" + "FargateServiceLBPublicListenerECSGroupBE57E081", + "FargateServiceLBPublicListener4B4929CA" ] }, "FargateServiceSecurityGroup262B61DD": { diff --git a/packages/@aws-cdk/aws-ecs/test/fargate/integ.l3.expected.json b/packages/@aws-cdk/aws-ecs/test/fargate/integ.l3.expected.json index 2b672a5dc4ec3..52dca9d8bc95d 100644 --- a/packages/@aws-cdk/aws-ecs/test/fargate/integ.l3.expected.json +++ b/packages/@aws-cdk/aws-ecs/test/fargate/integ.l3.expected.json @@ -525,8 +525,8 @@ } }, "DependsOn": [ - "L3LBPublicListener156FFC0F", - "L3LBPublicListenerECSGroup648EEA11" + "L3LBPublicListenerECSGroup648EEA11", + "L3LBPublicListener156FFC0F" ] }, "L3ServiceSecurityGroup677B0897": { diff --git a/packages/@aws-cdk/aws-ecs/test/fargate/integ.lb-awsvpc-nw.expected.json b/packages/@aws-cdk/aws-ecs/test/fargate/integ.lb-awsvpc-nw.expected.json index 1c06d537a4645..e49bcc0246480 100644 --- a/packages/@aws-cdk/aws-ecs/test/fargate/integ.lb-awsvpc-nw.expected.json +++ b/packages/@aws-cdk/aws-ecs/test/fargate/integ.lb-awsvpc-nw.expected.json @@ -454,8 +454,8 @@ } }, "DependsOn": [ - "LBPublicListener6E1F3D94", - "LBPublicListenerFargateGroup5EE2FBAF" + "LBPublicListenerFargateGroup5EE2FBAF", + "LBPublicListener6E1F3D94" ] }, "ServiceSecurityGroupC96ED6A7": { From 3a7bd17b61993579f211180d6dafb888b5d38f76 Mon Sep 17 00:00:00 2001 From: Elad Ben-Israel Date: Wed, 6 Feb 2019 15:43:37 +0200 Subject: [PATCH 19/20] remove output test --- .../@aws-cdk/cdk/test/cloudformation/test.output.ts | 13 +------------ 1 file changed, 1 insertion(+), 12 deletions(-) diff --git a/packages/@aws-cdk/cdk/test/cloudformation/test.output.ts b/packages/@aws-cdk/cdk/test/cloudformation/test.output.ts index b12f8606ef726..7ffbbb7c66014 100644 --- a/packages/@aws-cdk/cdk/test/cloudformation/test.output.ts +++ b/packages/@aws-cdk/cdk/test/cloudformation/test.output.ts @@ -28,17 +28,6 @@ export = { test.done(); }, - 'outputs have a default unique export name'(test: Test) { - const stack = new Stack(undefined, 'MyStack'); - const output = new Output(stack, 'MyOutput'); - const child = new Construct(stack, 'MyConstruct'); - const output2 = new Output(child, 'MyOutput2'); - - test.equal(stack.node.resolve(output.export), 'MyStack:MyOutput'); - test.equal(stack.node.resolve(output2.export), 'MyStack:MyConstructMyOutput255322D15'); - test.done(); - }, - 'disableExport can be used to disable the auto-export behavior'(test: Test) { const stack = new Stack(); const output = new Output(stack, 'MyOutput', { disableExport: true }); @@ -94,4 +83,4 @@ export = { test.done(); }, -}; \ No newline at end of file +}; From 1a01918163abc30e7916a66114b5beb3ab10c83b Mon Sep 17 00:00:00 2001 From: Elad Ben-Israel Date: Wed, 6 Feb 2019 16:02:51 +0200 Subject: [PATCH 20/20] update app-delivery expectations --- .../@aws-cdk/app-delivery/test/integ.cicd.expected.json | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/packages/@aws-cdk/app-delivery/test/integ.cicd.expected.json b/packages/@aws-cdk/app-delivery/test/integ.cicd.expected.json index e143489256939..3dfdea3ef5319 100644 --- a/packages/@aws-cdk/app-delivery/test/integ.cicd.expected.json +++ b/packages/@aws-cdk/app-delivery/test/integ.cicd.expected.json @@ -239,8 +239,8 @@ ] }, "DependsOn": [ - "CodePipelineRoleB3A660B4", - "CodePipelineRoleDefaultPolicy8D520A8D" + "CodePipelineRoleDefaultPolicy8D520A8D", + "CodePipelineRoleB3A660B4" ] }, "DeployStackChangeSetRole4923A126": { @@ -261,4 +261,4 @@ } } } -} \ No newline at end of file +}