@aws-solutions-constructs/aws-lambda-secretsmanager 2.43.1 → 2.45.0

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.
@@ -150,12 +150,6 @@
150
150
  },
151
151
  "S3Key": "0c3255e93ffe7a906c7422e9f0e9cc4c7fd86ee996ee3bb302e2f134b38463c8.zip"
152
152
  },
153
- "Role": {
154
- "Fn::GetAtt": [
155
- "testlambdasecretsmanagerLambdaFunctionServiceRole92CE007F",
156
- "Arn"
157
- ]
158
- },
159
153
  "Environment": {
160
154
  "Variables": {
161
155
  "AWS_NODEJS_CONNECTION_REUSE_ENABLED": "1",
@@ -165,6 +159,12 @@
165
159
  }
166
160
  },
167
161
  "Handler": "index.handler",
162
+ "Role": {
163
+ "Fn::GetAtt": [
164
+ "testlambdasecretsmanagerLambdaFunctionServiceRole92CE007F",
165
+ "Arn"
166
+ ]
167
+ },
168
168
  "Runtime": "nodejs16.x",
169
169
  "TracingConfig": {
170
170
  "Mode": "Active"
@@ -253,9 +253,6 @@
253
253
  "VpcisolatedSubnet1SubnetE62B1B9B": {
254
254
  "Type": "AWS::EC2::Subnet",
255
255
  "Properties": {
256
- "VpcId": {
257
- "Ref": "Vpc8378EB38"
258
- },
259
256
  "AvailabilityZone": "test-region-1a",
260
257
  "CidrBlock": "10.0.0.0/18",
261
258
  "MapPublicIpOnLaunch": false,
@@ -272,21 +269,24 @@
272
269
  "Key": "Name",
273
270
  "Value": "deployFunctionWithVpc/Vpc/isolatedSubnet1"
274
271
  }
275
- ]
272
+ ],
273
+ "VpcId": {
274
+ "Ref": "Vpc8378EB38"
275
+ }
276
276
  }
277
277
  },
278
278
  "VpcisolatedSubnet1RouteTableE442650B": {
279
279
  "Type": "AWS::EC2::RouteTable",
280
280
  "Properties": {
281
- "VpcId": {
282
- "Ref": "Vpc8378EB38"
283
- },
284
281
  "Tags": [
285
282
  {
286
283
  "Key": "Name",
287
284
  "Value": "deployFunctionWithVpc/Vpc/isolatedSubnet1"
288
285
  }
289
- ]
286
+ ],
287
+ "VpcId": {
288
+ "Ref": "Vpc8378EB38"
289
+ }
290
290
  }
291
291
  },
292
292
  "VpcisolatedSubnet1RouteTableAssociationD259E31A": {
@@ -303,9 +303,6 @@
303
303
  "VpcisolatedSubnet2Subnet39217055": {
304
304
  "Type": "AWS::EC2::Subnet",
305
305
  "Properties": {
306
- "VpcId": {
307
- "Ref": "Vpc8378EB38"
308
- },
309
306
  "AvailabilityZone": "test-region-1b",
310
307
  "CidrBlock": "10.0.64.0/18",
311
308
  "MapPublicIpOnLaunch": false,
@@ -322,21 +319,24 @@
322
319
  "Key": "Name",
323
320
  "Value": "deployFunctionWithVpc/Vpc/isolatedSubnet2"
324
321
  }
325
- ]
322
+ ],
323
+ "VpcId": {
324
+ "Ref": "Vpc8378EB38"
325
+ }
326
326
  }
327
327
  },
328
328
  "VpcisolatedSubnet2RouteTable334F9764": {
329
329
  "Type": "AWS::EC2::RouteTable",
330
330
  "Properties": {
331
- "VpcId": {
332
- "Ref": "Vpc8378EB38"
333
- },
334
331
  "Tags": [
335
332
  {
336
333
  "Key": "Name",
337
334
  "Value": "deployFunctionWithVpc/Vpc/isolatedSubnet2"
338
335
  }
339
- ]
336
+ ],
337
+ "VpcId": {
338
+ "Ref": "Vpc8378EB38"
339
+ }
340
340
  }
341
341
  },
342
342
  "VpcisolatedSubnet2RouteTableAssociation25A4716F": {
@@ -353,9 +353,6 @@
353
353
  "VpcisolatedSubnet3Subnet44F2537D": {
354
354
  "Type": "AWS::EC2::Subnet",
355
355
  "Properties": {
356
- "VpcId": {
357
- "Ref": "Vpc8378EB38"
358
- },
359
356
  "AvailabilityZone": "test-region-1c",
360
357
  "CidrBlock": "10.0.128.0/18",
361
358
  "MapPublicIpOnLaunch": false,
@@ -372,21 +369,24 @@
372
369
  "Key": "Name",
373
370
  "Value": "deployFunctionWithVpc/Vpc/isolatedSubnet3"
374
371
  }
375
- ]
372
+ ],
373
+ "VpcId": {
374
+ "Ref": "Vpc8378EB38"
375
+ }
376
376
  }
377
377
  },
378
378
  "VpcisolatedSubnet3RouteTableA2F6BBC0": {
379
379
  "Type": "AWS::EC2::RouteTable",
380
380
  "Properties": {
381
- "VpcId": {
382
- "Ref": "Vpc8378EB38"
383
- },
384
381
  "Tags": [
385
382
  {
386
383
  "Key": "Name",
387
384
  "Value": "deployFunctionWithVpc/Vpc/isolatedSubnet3"
388
385
  }
389
- ]
386
+ ],
387
+ "VpcId": {
388
+ "Ref": "Vpc8378EB38"
389
+ }
390
390
  }
391
391
  },
392
392
  "VpcisolatedSubnet3RouteTableAssociationDC010BEB": {
@@ -418,7 +418,7 @@
418
418
  "Tags": [
419
419
  {
420
420
  "Key": "Name",
421
- "Value": "deployFunctionWithVpc/Vpc"
421
+ "Value": "deployFunctionWithVpc/Vpc/FlowLog"
422
422
  }
423
423
  ]
424
424
  }
@@ -470,7 +470,7 @@
470
470
  "Tags": [
471
471
  {
472
472
  "Key": "Name",
473
- "Value": "deployFunctionWithVpc/Vpc"
473
+ "Value": "deployFunctionWithVpc/Vpc/FlowLog"
474
474
  }
475
475
  ]
476
476
  },
@@ -490,11 +490,6 @@
490
490
  "VpcFlowLog8FF33A73": {
491
491
  "Type": "AWS::EC2::FlowLog",
492
492
  "Properties": {
493
- "ResourceId": {
494
- "Ref": "Vpc8378EB38"
495
- },
496
- "ResourceType": "VPC",
497
- "TrafficType": "ALL",
498
493
  "DeliverLogsPermissionArn": {
499
494
  "Fn::GetAtt": [
500
495
  "VpcFlowLogIAMRole6A475D41",
@@ -505,17 +500,31 @@
505
500
  "LogGroupName": {
506
501
  "Ref": "VpcFlowLogLogGroup7B5C56B9"
507
502
  },
503
+ "ResourceId": {
504
+ "Ref": "Vpc8378EB38"
505
+ },
506
+ "ResourceType": "VPC",
508
507
  "Tags": [
509
508
  {
510
509
  "Key": "Name",
511
- "Value": "deployFunctionWithVpc/Vpc"
510
+ "Value": "deployFunctionWithVpc/Vpc/FlowLog"
512
511
  }
513
- ]
512
+ ],
513
+ "TrafficType": "ALL"
514
514
  }
515
515
  },
516
516
  "VpcSECRETSMANAGERF52907C2": {
517
517
  "Type": "AWS::EC2::VPCEndpoint",
518
518
  "Properties": {
519
+ "PrivateDnsEnabled": true,
520
+ "SecurityGroupIds": [
521
+ {
522
+ "Fn::GetAtt": [
523
+ "deployFunctionWithVpcSECRETSMANAGERsecuritygroup140A8C59",
524
+ "GroupId"
525
+ ]
526
+ }
527
+ ],
519
528
  "ServiceName": {
520
529
  "Fn::Join": [
521
530
  "",
@@ -528,18 +537,6 @@
528
537
  ]
529
538
  ]
530
539
  },
531
- "VpcId": {
532
- "Ref": "Vpc8378EB38"
533
- },
534
- "PrivateDnsEnabled": true,
535
- "SecurityGroupIds": [
536
- {
537
- "Fn::GetAtt": [
538
- "deployFunctionWithVpcSECRETSMANAGERsecuritygroup140A8C59",
539
- "GroupId"
540
- ]
541
- }
542
- ],
543
540
  "SubnetIds": [
544
541
  {
545
542
  "Ref": "VpcisolatedSubnet1SubnetE62B1B9B"
@@ -551,7 +548,10 @@
551
548
  "Ref": "VpcisolatedSubnet3Subnet44F2537D"
552
549
  }
553
550
  ],
554
- "VpcEndpointType": "Interface"
551
+ "VpcEndpointType": "Interface",
552
+ "VpcId": {
553
+ "Ref": "Vpc8378EB38"
554
+ }
555
555
  }
556
556
  },
557
557
  "deployFunctionWithVpcSECRETSMANAGERsecuritygroup140A8C59": {
@@ -109,12 +109,6 @@
109
109
  },
110
110
  "S3Key": "0c3255e93ffe7a906c7422e9f0e9cc4c7fd86ee996ee3bb302e2f134b38463c8.zip"
111
111
  },
112
- "Role": {
113
- "Fn::GetAtt": [
114
- "LambdaFunctionServiceRole0C4CDE0B",
115
- "Arn"
116
- ]
117
- },
118
112
  "Environment": {
119
113
  "Variables": {
120
114
  "AWS_NODEJS_CONNECTION_REUSE_ENABLED": "1",
@@ -124,6 +118,12 @@
124
118
  }
125
119
  },
126
120
  "Handler": "index.handler",
121
+ "Role": {
122
+ "Fn::GetAtt": [
123
+ "LambdaFunctionServiceRole0C4CDE0B",
124
+ "Arn"
125
+ ]
126
+ },
127
127
  "Runtime": "nodejs16.x",
128
128
  "TracingConfig": {
129
129
  "Mode": "Active"
@@ -15,14 +15,11 @@ Object.defineProperty(exports, "__esModule", { value: true });
15
15
  // Imports
16
16
  const aws_cdk_lib_1 = require("aws-cdk-lib");
17
17
  const lambda = require("aws-cdk-lib/aws-lambda");
18
- const aws_secretsmanager_1 = require("aws-cdk-lib/aws-secretsmanager");
18
+ const secrets = require("aws-cdk-lib/aws-secretsmanager");
19
19
  const ec2 = require("aws-cdk-lib/aws-ec2");
20
20
  const lib_1 = require("../lib");
21
21
  const assertions_1 = require("aws-cdk-lib/assertions");
22
22
  const defaults = require("@aws-solutions-constructs/core");
23
- // --------------------------------------------------------------
24
- // Test the getter methods
25
- // --------------------------------------------------------------
26
23
  test('Test the properties', () => {
27
24
  // Stack
28
25
  const stack = new aws_cdk_lib_1.Stack();
@@ -42,14 +39,11 @@ test('Test the properties', () => {
42
39
  const secret = pattern.secret;
43
40
  expect(secret).toBeDefined();
44
41
  });
45
- // --------------------------------------------------------------
46
- // Test deployment w/ existing secret
47
- // --------------------------------------------------------------
48
42
  test('Test deployment w/ existing secret', () => {
49
43
  // Stack
50
44
  const stack = new aws_cdk_lib_1.Stack();
51
45
  // Helper declaration
52
- const existingSecret = new aws_secretsmanager_1.Secret(stack, 'secret', {});
46
+ const existingSecret = new secrets.Secret(stack, 'secret', {});
53
47
  const pattern = new lib_1.LambdaToSecretsmanager(stack, 'lambda-to-secretsmanager-stack', {
54
48
  lambdaFunctionProps: {
55
49
  runtime: lambda.Runtime.NODEJS_16_X,
@@ -66,9 +60,6 @@ test('Test deployment w/ existing secret', () => {
66
60
  // Assertion 2
67
61
  expect(pattern.secret).toBe(existingSecret);
68
62
  });
69
- // --------------------------------------------------------------
70
- // Test deployment w/ existing function
71
- // --------------------------------------------------------------
72
63
  test('Test deployment w/ existing function', () => {
73
64
  // Stack
74
65
  const stack = new aws_cdk_lib_1.Stack();
@@ -91,9 +82,6 @@ test('Test deployment w/ existing function', () => {
91
82
  // Assertion 2
92
83
  expect(pattern.lambdaFunction).toBe(existingFunction);
93
84
  });
94
- // --------------------------------------------------------------
95
- // Test minimal deployment with write access to Secret
96
- // --------------------------------------------------------------
97
85
  test('Test minimal deployment write access to Secret', () => {
98
86
  // Stack
99
87
  const stack = new aws_cdk_lib_1.Stack();
@@ -113,9 +101,6 @@ test('Test minimal deployment write access to Secret', () => {
113
101
  GenerateSecretString: {},
114
102
  });
115
103
  });
116
- // --------------------------------------------------------------
117
- // Test minimal deployment that deploys a VPC without vpcProps
118
- // --------------------------------------------------------------
119
104
  test("Test minimal deployment that deploys a VPC without vpcProps", () => {
120
105
  // Stack
121
106
  const stack = new aws_cdk_lib_1.Stack();
@@ -160,9 +145,6 @@ test("Test minimal deployment that deploys a VPC without vpcProps", () => {
160
145
  template.resourceCountIs("AWS::EC2::Subnet", 2);
161
146
  template.resourceCountIs("AWS::EC2::InternetGateway", 0);
162
147
  });
163
- // --------------------------------------------------------------
164
- // Test minimal deployment that deploys a VPC w/vpcProps
165
- // --------------------------------------------------------------
166
148
  test("Test minimal deployment that deploys a VPC w/vpcProps", () => {
167
149
  // Stack
168
150
  const stack = new aws_cdk_lib_1.Stack();
@@ -213,9 +195,6 @@ test("Test minimal deployment that deploys a VPC w/vpcProps", () => {
213
195
  template.resourceCountIs("AWS::EC2::Subnet", 2);
214
196
  template.resourceCountIs("AWS::EC2::InternetGateway", 0);
215
197
  });
216
- // --------------------------------------------------------------
217
- // Test minimal deployment with an existing VPC
218
- // --------------------------------------------------------------
219
198
  test("Test minimal deployment with an existing VPC", () => {
220
199
  // Stack
221
200
  const stack = new aws_cdk_lib_1.Stack();
@@ -255,13 +234,7 @@ test("Test minimal deployment with an existing VPC", () => {
255
234
  VpcEndpointType: "Interface",
256
235
  });
257
236
  });
258
- // --------------------------------------------------------------
259
- // Test minimal deployment with an existing VPC and existing Lambda function not in a VPC
260
- //
261
- // buildLambdaFunction should throw an error if the Lambda function is not
262
- // attached to a VPC
263
- // --------------------------------------------------------------
264
- test("Test minimal deployment with an existing VPC and existing Lambda function not in a VPC", () => {
237
+ test("Check error when existing lambda function is not in VPC and construct is in VPC", () => {
265
238
  // Stack
266
239
  const stack = new aws_cdk_lib_1.Stack();
267
240
  const testLambdaFunction = new lambda.Function(stack, 'test-lamba', {
@@ -272,7 +245,8 @@ test("Test minimal deployment with an existing VPC and existing Lambda function
272
245
  const testVpc = new ec2.Vpc(stack, "test-vpc", {});
273
246
  // Helper declaration
274
247
  const app = () => {
275
- // Helper declaration
248
+ // buildLambdaFunction should throw an error if the Lambda function is not
249
+ // attached to a VPC
276
250
  new lib_1.LambdaToSecretsmanager(stack, "lambda-to-secretsmanager-stack", {
277
251
  existingLambdaObj: testLambdaFunction,
278
252
  existingVpc: testVpc,
@@ -282,10 +256,7 @@ test("Test minimal deployment with an existing VPC and existing Lambda function
282
256
  // Assertion
283
257
  expect(app).toThrowError();
284
258
  });
285
- // --------------------------------------------------------------
286
- // Test bad call with existingVpc and deployVpc
287
- // --------------------------------------------------------------
288
- test("Test bad call with existingVpc and deployVpc", () => {
259
+ test("Confirm CheckVpcProps is called", () => {
289
260
  // Stack
290
261
  const stack = new aws_cdk_lib_1.Stack();
291
262
  const testVpc = new ec2.Vpc(stack, "test-vpc", {});
@@ -303,11 +274,8 @@ test("Test bad call with existingVpc and deployVpc", () => {
303
274
  });
304
275
  };
305
276
  // Assertion
306
- expect(app).toThrowError();
277
+ expect(app).toThrowError('Error - Either provide an existingVpc or some combination of deployVpc and vpcProps, but not both.\n');
307
278
  });
308
- // --------------------------------------------------------------
309
- // Test lambda function custom environment variable
310
- // --------------------------------------------------------------
311
279
  test('Test lambda function custom environment variable', () => {
312
280
  // Stack
313
281
  const stack = new aws_cdk_lib_1.Stack();
@@ -339,9 +307,6 @@ test('Test lambda function custom environment variable', () => {
339
307
  }
340
308
  });
341
309
  });
342
- // --------------------------------------------------------------
343
- // Test overriding secretProps to pass a customer provided CMK
344
- // --------------------------------------------------------------
345
310
  test('Test overriding secretProps to pass a customer provided CMK', () => {
346
311
  // Stack
347
312
  const stack = new aws_cdk_lib_1.Stack();
@@ -392,4 +357,46 @@ test('Test overriding secretProps to pass a customer provided CMK', () => {
392
357
  EnableKeyRotation: true
393
358
  });
394
359
  });
395
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lambda-secretsmanager.test.js","sourceRoot":"","sources":["lambda-secretsmanager.test.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n *  Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n *\n *  Licensed under the Apache License, Version 2.0 (the \"License\"). You may not use this file except in compliance\n *  with the License. A copy of the License is located at\n *\n *      http://www.apache.org/licenses/LICENSE-2.0\n *\n *  or in the 'license' file accompanying this file. This file is distributed on an 'AS IS' BASIS, WITHOUT WARRANTIES\n *  OR CONDITIONS OF ANY KIND, express or implied. See the License for the specific language governing permissions\n *  and limitations under the License.\n */\n\n// Imports\nimport { RemovalPolicy, Stack } from \"aws-cdk-lib\";\nimport * as lambda from \"aws-cdk-lib/aws-lambda\";\nimport { Secret } from 'aws-cdk-lib/aws-secretsmanager';\nimport * as ec2 from \"aws-cdk-lib/aws-ec2\";\nimport { LambdaToSecretsmanager } from '../lib';\nimport { Template } from 'aws-cdk-lib/assertions';\nimport * as defaults from \"@aws-solutions-constructs/core\";\n\n// --------------------------------------------------------------\n// Test the getter methods\n// --------------------------------------------------------------\ntest('Test the properties', () => {\n  // Stack\n  const stack = new Stack();\n  // Helper declaration\n  const pattern = new LambdaToSecretsmanager(stack, 'lambda-to-secretsmanager-stack', {\n    lambdaFunctionProps: {\n      runtime: lambda.Runtime.NODEJS_16_X,\n      handler: 'index.handler',\n      code: lambda.Code.fromAsset(`${__dirname}/lambda`)\n    },\n    secretProps: { removalPolicy: RemovalPolicy.DESTROY },\n  });\n  // Assertion 1\n  const func = pattern.lambdaFunction;\n  expect(func).toBeDefined();\n  // Assertion 2\n  const secret = pattern.secret;\n  expect(secret).toBeDefined();\n});\n\n// --------------------------------------------------------------\n// Test deployment w/ existing secret\n// --------------------------------------------------------------\ntest('Test deployment w/ existing secret', () => {\n  // Stack\n  const stack = new Stack();\n  // Helper declaration\n  const existingSecret = new Secret(stack, 'secret', {});\n  const pattern = new LambdaToSecretsmanager(stack, 'lambda-to-secretsmanager-stack', {\n    lambdaFunctionProps: {\n      runtime: lambda.Runtime.NODEJS_16_X,\n      handler: 'index.handler',\n      code: lambda.Code.fromAsset(`${__dirname}/lambda`)\n    },\n    existingSecretObj: existingSecret\n  });\n  // Assertion 1\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties(\"AWS::SecretsManager::Secret\", {\n    GenerateSecretString: {},\n  });\n  // Assertion 2\n  expect(pattern.secret).toBe(existingSecret);\n});\n\n// --------------------------------------------------------------\n// Test deployment w/ existing function\n// --------------------------------------------------------------\ntest('Test deployment w/ existing function', () => {\n  // Stack\n  const stack = new Stack();\n  // Helper declaration\n  const lambdaFunctionProps = {\n    runtime: lambda.Runtime.NODEJS_16_X,\n    handler: 'index.handler',\n    code: lambda.Code.fromAsset(`${__dirname}/lambda`)\n  };\n  const existingFunction = defaults.deployLambdaFunction(stack, lambdaFunctionProps);\n\n  const pattern = new LambdaToSecretsmanager(stack, 'lambda-to-secretsmanager-stack', {\n    existingLambdaObj: existingFunction,\n    secretProps: { removalPolicy: RemovalPolicy.DESTROY },\n  });\n  // Assertion 1\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties(\"AWS::SecretsManager::Secret\", {\n    GenerateSecretString: {},\n  });\n  // Assertion 2\n  expect(pattern.lambdaFunction).toBe(existingFunction);\n});\n\n// --------------------------------------------------------------\n// Test minimal deployment with write access to Secret\n// --------------------------------------------------------------\ntest('Test minimal deployment write access to Secret', () => {\n  // Stack\n  const stack = new Stack();\n  // Helper declaration\n  new LambdaToSecretsmanager(stack, 'lambda-to-secretsmanager-stack', {\n    lambdaFunctionProps: {\n      runtime: lambda.Runtime.NODEJS_16_X,\n      handler: 'index.handler',\n      code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n    },\n    secretProps: { removalPolicy: RemovalPolicy.DESTROY },\n    grantWriteAccess: 'ReadWrite'\n  });\n  // Assertion 1\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties(\"AWS::SecretsManager::Secret\", {\n    GenerateSecretString: {},\n  });\n\n});\n\n// --------------------------------------------------------------\n// Test minimal deployment that deploys a VPC without vpcProps\n// --------------------------------------------------------------\ntest(\"Test minimal deployment that deploys a VPC without vpcProps\", () => {\n  // Stack\n  const stack = new Stack();\n  // Helper declaration\n  new LambdaToSecretsmanager(stack, \"lambda-to-secretsmanager-stack\", {\n    lambdaFunctionProps: {\n      runtime: lambda.Runtime.NODEJS_16_X,\n      handler: \"index.handler\",\n      code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n    },\n    secretProps: { removalPolicy: RemovalPolicy.DESTROY },\n    deployVpc: true,\n  });\n\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties(\"AWS::Lambda::Function\", {\n    VpcConfig: {\n      SecurityGroupIds: [\n        {\n          \"Fn::GetAtt\": [\n            \"lambdatosecretsmanagerstackReplaceDefaultSecurityGroupsecuritygroupED420155\",\n            \"GroupId\",\n          ],\n        },\n      ],\n      SubnetIds: [\n        {\n          Ref: \"VpcisolatedSubnet1SubnetE62B1B9B\",\n        },\n        {\n          Ref: \"VpcisolatedSubnet2Subnet39217055\",\n        },\n      ],\n    },\n  });\n\n  template.hasResourceProperties(\"AWS::EC2::VPC\", {\n    EnableDnsHostnames: true,\n    EnableDnsSupport: true,\n  });\n\n  template.hasResourceProperties(\"AWS::EC2::VPCEndpoint\", {\n    VpcEndpointType: \"Interface\",\n  });\n\n  template.resourceCountIs(\"AWS::EC2::Subnet\", 2);\n  template.resourceCountIs(\"AWS::EC2::InternetGateway\", 0);\n});\n\n// --------------------------------------------------------------\n// Test minimal deployment that deploys a VPC w/vpcProps\n// --------------------------------------------------------------\ntest(\"Test minimal deployment that deploys a VPC w/vpcProps\", () => {\n  // Stack\n  const stack = new Stack();\n  // Helper declaration\n  new LambdaToSecretsmanager(stack, \"lambda-to-secretsmanager-stack\", {\n    lambdaFunctionProps: {\n      runtime: lambda.Runtime.NODEJS_16_X,\n      handler: \"index.handler\",\n      code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n    },\n    secretProps: { removalPolicy: RemovalPolicy.DESTROY },\n    vpcProps: {\n      enableDnsHostnames: false,\n      enableDnsSupport: false,\n      ipAddresses: ec2.IpAddresses.cidr(\"192.68.0.0/16\"),\n    },\n    deployVpc: true,\n  });\n\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties(\"AWS::Lambda::Function\", {\n    VpcConfig: {\n      SecurityGroupIds: [\n        {\n          \"Fn::GetAtt\": [\n            \"lambdatosecretsmanagerstackReplaceDefaultSecurityGroupsecuritygroupED420155\",\n            \"GroupId\",\n          ],\n        },\n      ],\n      SubnetIds: [\n        {\n          Ref: \"VpcisolatedSubnet1SubnetE62B1B9B\",\n        },\n        {\n          Ref: \"VpcisolatedSubnet2Subnet39217055\",\n        },\n      ],\n    },\n  });\n\n  template.hasResourceProperties(\"AWS::EC2::VPC\", {\n    CidrBlock: \"192.68.0.0/16\",\n    EnableDnsHostnames: true,\n    EnableDnsSupport: true,\n  });\n\n  template.hasResourceProperties(\"AWS::EC2::VPCEndpoint\", {\n    VpcEndpointType: \"Interface\",\n  });\n\n  template.resourceCountIs(\"AWS::EC2::Subnet\", 2);\n  template.resourceCountIs(\"AWS::EC2::InternetGateway\", 0);\n});\n\n// --------------------------------------------------------------\n// Test minimal deployment with an existing VPC\n// --------------------------------------------------------------\ntest(\"Test minimal deployment with an existing VPC\", () => {\n  // Stack\n  const stack = new Stack();\n\n  const testVpc = new ec2.Vpc(stack, \"test-vpc\", {});\n\n  // Helper declaration\n  new LambdaToSecretsmanager(stack, \"lambda-to-secretsmanager-stack\", {\n    lambdaFunctionProps: {\n      runtime: lambda.Runtime.NODEJS_16_X,\n      handler: \"index.handler\",\n      code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n    },\n    secretProps: { removalPolicy: RemovalPolicy.DESTROY },\n    existingVpc: testVpc,\n  });\n\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties(\"AWS::Lambda::Function\", {\n    VpcConfig: {\n      SecurityGroupIds: [\n        {\n          \"Fn::GetAtt\": [\n            \"lambdatosecretsmanagerstackReplaceDefaultSecurityGroupsecuritygroupED420155\",\n            \"GroupId\",\n          ],\n        },\n      ],\n      SubnetIds: [\n        {\n          Ref: \"testvpcPrivateSubnet1Subnet865FB50A\",\n        },\n        {\n          Ref: \"testvpcPrivateSubnet2Subnet23D3396F\",\n        },\n      ],\n    },\n  });\n\n  template.hasResourceProperties(\"AWS::EC2::VPCEndpoint\", {\n    VpcEndpointType: \"Interface\",\n  });\n});\n\n// --------------------------------------------------------------\n// Test minimal deployment with an existing VPC and existing Lambda function not in a VPC\n//\n// buildLambdaFunction should throw an error if the Lambda function is not\n// attached to a VPC\n// --------------------------------------------------------------\ntest(\"Test minimal deployment with an existing VPC and existing Lambda function not in a VPC\", () => {\n  // Stack\n  const stack = new Stack();\n\n  const testLambdaFunction = new lambda.Function(stack, 'test-lamba', {\n    runtime: lambda.Runtime.NODEJS_16_X,\n    handler: \"index.handler\",\n    code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n  });\n\n  const testVpc = new ec2.Vpc(stack, \"test-vpc\", {});\n\n  // Helper declaration\n  const app = () => {\n    // Helper declaration\n    new LambdaToSecretsmanager(stack, \"lambda-to-secretsmanager-stack\", {\n      existingLambdaObj: testLambdaFunction,\n      existingVpc: testVpc,\n      secretProps: { removalPolicy: RemovalPolicy.DESTROY },\n    });\n  };\n\n  // Assertion\n  expect(app).toThrowError();\n\n});\n\n// --------------------------------------------------------------\n// Test bad call with existingVpc and deployVpc\n// --------------------------------------------------------------\ntest(\"Test bad call with existingVpc and deployVpc\", () => {\n  // Stack\n  const stack = new Stack();\n\n  const testVpc = new ec2.Vpc(stack, \"test-vpc\", {});\n\n  const app = () => {\n    // Helper declaration\n    new LambdaToSecretsmanager(stack, \"lambda-to-secretsmanager-stack\", {\n      lambdaFunctionProps: {\n        runtime: lambda.Runtime.NODEJS_16_X,\n        handler: \"index.handler\",\n        code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n      },\n      secretProps: { removalPolicy: RemovalPolicy.DESTROY },\n      existingVpc: testVpc,\n      deployVpc: true,\n    });\n  };\n  // Assertion\n  expect(app).toThrowError();\n});\n\n// --------------------------------------------------------------\n// Test lambda function custom environment variable\n// --------------------------------------------------------------\ntest('Test lambda function custom environment variable', () => {\n  // Stack\n  const stack = new Stack();\n\n  // Helper declaration\n  new LambdaToSecretsmanager(stack, 'lambda-to-secretsmanager-stack', {\n    lambdaFunctionProps: {\n      runtime: lambda.Runtime.NODEJS_16_X,\n      handler: 'index.handler',\n      code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n      environment: {\n        AWS_NODEJS_CONNECTION_REUSE_ENABLED: '1',\n      }\n    },\n    secretProps: { removalPolicy: RemovalPolicy.DESTROY },\n    secretEnvironmentVariableName: 'CUSTOM_SECRET_NAME'\n  });\n\n  // Assertion\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties('AWS::Lambda::Function', {\n    Handler: 'index.handler',\n    Runtime: 'nodejs16.x',\n    Environment: {\n      Variables: {\n        AWS_NODEJS_CONNECTION_REUSE_ENABLED: '1',\n        CUSTOM_SECRET_NAME: {\n          Ref: 'lambdatosecretsmanagerstacksecretBA684E34'\n        }\n      }\n    }\n  });\n});\n\n// --------------------------------------------------------------\n// Test overriding secretProps to pass a customer provided CMK\n// --------------------------------------------------------------\ntest('Test overriding secretProps to pass a customer provided CMK', () => {\n  // Stack\n  const stack = new Stack();\n\n  const encryptionKey = defaults.buildEncryptionKey(stack, {\n    description: 'secret-key'\n  });\n\n  // Helper declaration\n  new LambdaToSecretsmanager(stack, 'lambda-to-secretsmanager-stack', {\n    lambdaFunctionProps: {\n      runtime: lambda.Runtime.NODEJS_16_X,\n      handler: 'index.handler',\n      code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n      environment: {\n        AWS_NODEJS_CONNECTION_REUSE_ENABLED: '1',\n      }\n    },\n    secretProps: {\n      encryptionKey\n    }\n  });\n\n  // Assertion 1\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties('AWS::Lambda::Function', {\n    Handler: 'index.handler',\n    Runtime: 'nodejs16.x',\n    Environment: {\n      Variables: {\n        AWS_NODEJS_CONNECTION_REUSE_ENABLED: '1',\n        SECRET_ARN: {\n          Ref: 'lambdatosecretsmanagerstacksecretBA684E34'\n        }\n      }\n    }\n  });\n\n  // Assertion 2\n  template.hasResourceProperties(\"AWS::SecretsManager::Secret\", {\n    GenerateSecretString: {},\n    KmsKeyId: {\n      \"Fn::GetAtt\": [\n        \"EncryptionKey1B843E66\",\n        \"Arn\"\n      ]\n    }\n  });\n\n  // Assertion 3\n  template.hasResourceProperties('AWS::KMS::Key', {\n    Description: \"secret-key\",\n    EnableKeyRotation: true\n  });\n});\n"]}
360
+ test('Confirm call to CheckLambdaProps', () => {
361
+ // Initial Setup
362
+ const stack = new aws_cdk_lib_1.Stack();
363
+ const lambdaFunction = new lambda.Function(stack, 'a-function', {
364
+ runtime: lambda.Runtime.NODEJS_16_X,
365
+ handler: 'index.handler',
366
+ code: lambda.Code.fromAsset(`${__dirname}/lambda`),
367
+ });
368
+ const props = {
369
+ lambdaFunctionProps: {
370
+ runtime: lambda.Runtime.NODEJS_16_X,
371
+ handler: 'index.handler',
372
+ code: lambda.Code.fromAsset(`${__dirname}/lambda`),
373
+ },
374
+ existingLambdaObj: lambdaFunction,
375
+ };
376
+ const app = () => {
377
+ new lib_1.LambdaToSecretsmanager(stack, 'test-construct', props);
378
+ };
379
+ // Assertion
380
+ expect(app).toThrowError('Error - Either provide lambdaFunctionProps or existingLambdaObj, but not both.\n');
381
+ });
382
+ test('Confirm call to CheckSecretsManagerProps', () => {
383
+ // Initial Setup
384
+ const stack = new aws_cdk_lib_1.Stack();
385
+ const props = {
386
+ lambdaFunctionProps: {
387
+ runtime: lambda.Runtime.NODEJS_16_X,
388
+ handler: 'index.handler',
389
+ code: lambda.Code.fromAsset(`${__dirname}/lambda`),
390
+ },
391
+ secretProps: {
392
+ secretName: 'test'
393
+ },
394
+ existingSecretObj: new secrets.Secret(stack, 'test', {}),
395
+ };
396
+ const app = () => {
397
+ new lib_1.LambdaToSecretsmanager(stack, 'test-construct', props);
398
+ };
399
+ // Assertion
400
+ expect(app).toThrowError('Error - Either provide secretProps or existingSecretObj, but not both.\n');
401
+ });
402
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lambda-secretsmanager.test.js","sourceRoot":"","sources":["lambda-secretsmanager.test.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;GAWG;;AAEH,UAAU;AACV,6CAAmD;AACnD,iDAAiD;AACjD,0DAA0D;AAC1D,2CAA2C;AAC3C,gCAA6E;AAC7E,uDAAkD;AAClD,2DAA2D;AAE3D,IAAI,CAAC,qBAAqB,EAAE,GAAG,EAAE;IAC/B,QAAQ;IACR,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAC1B,qBAAqB;IACrB,MAAM,OAAO,GAAG,IAAI,4BAAsB,CAAC,KAAK,EAAE,gCAAgC,EAAE;QAClF,mBAAmB,EAAE;YACnB,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,WAAW;YACnC,OAAO,EAAE,eAAe;YACxB,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,SAAS,SAAS,CAAC;SACnD;QACD,WAAW,EAAE,EAAE,aAAa,EAAE,2BAAa,CAAC,OAAO,EAAE;KACtD,CAAC,CAAC;IACH,cAAc;IACd,MAAM,IAAI,GAAG,OAAO,CAAC,cAAc,CAAC;IACpC,MAAM,CAAC,IAAI,CAAC,CAAC,WAAW,EAAE,CAAC;IAC3B,cAAc;IACd,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAC9B,MAAM,CAAC,MAAM,CAAC,CAAC,WAAW,EAAE,CAAC;AAC/B,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,oCAAoC,EAAE,GAAG,EAAE;IAC9C,QAAQ;IACR,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAC1B,qBAAqB;IACrB,MAAM,cAAc,GAAG,IAAI,OAAO,CAAC,MAAM,CAAC,KAAK,EAAE,QAAQ,EAAE,EAAE,CAAC,CAAC;IAC/D,MAAM,OAAO,GAAG,IAAI,4BAAsB,CAAC,KAAK,EAAE,gCAAgC,EAAE;QAClF,mBAAmB,EAAE;YACnB,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,WAAW;YACnC,OAAO,EAAE,eAAe;YACxB,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,SAAS,SAAS,CAAC;SACnD;QACD,iBAAiB,EAAE,cAAc;KAClC,CAAC,CAAC;IACH,cAAc;IACd,MAAM,QAAQ,GAAG,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;IAC3C,QAAQ,CAAC,qBAAqB,CAAC,6BAA6B,EAAE;QAC5D,oBAAoB,EAAE,EAAE;KACzB,CAAC,CAAC;IACH,cAAc;IACd,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;AAC9C,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,sCAAsC,EAAE,GAAG,EAAE;IAChD,QAAQ;IACR,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAC1B,qBAAqB;IACrB,MAAM,mBAAmB,GAAG;QAC1B,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,WAAW;QACnC,OAAO,EAAE,eAAe;QACxB,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,SAAS,SAAS,CAAC;KACnD,CAAC;IACF,MAAM,gBAAgB,GAAG,QAAQ,CAAC,oBAAoB,CAAC,KAAK,EAAE,mBAAmB,CAAC,CAAC;IAEnF,MAAM,OAAO,GAAG,IAAI,4BAAsB,CAAC,KAAK,EAAE,gCAAgC,EAAE;QAClF,iBAAiB,EAAE,gBAAgB;QACnC,WAAW,EAAE,EAAE,aAAa,EAAE,2BAAa,CAAC,OAAO,EAAE;KACtD,CAAC,CAAC;IACH,cAAc;IACd,MAAM,QAAQ,GAAG,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;IAC3C,QAAQ,CAAC,qBAAqB,CAAC,6BAA6B,EAAE;QAC5D,oBAAoB,EAAE,EAAE;KACzB,CAAC,CAAC;IACH,cAAc;IACd,MAAM,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;AACxD,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,gDAAgD,EAAE,GAAG,EAAE;IAC1D,QAAQ;IACR,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAC1B,qBAAqB;IACrB,IAAI,4BAAsB,CAAC,KAAK,EAAE,gCAAgC,EAAE;QAClE,mBAAmB,EAAE;YACnB,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,WAAW;YACnC,OAAO,EAAE,eAAe;YACxB,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,SAAS,SAAS,CAAC;SACnD;QACD,WAAW,EAAE,EAAE,aAAa,EAAE,2BAAa,CAAC,OAAO,EAAE;QACrD,gBAAgB,EAAE,WAAW;KAC9B,CAAC,CAAC;IACH,cAAc;IACd,MAAM,QAAQ,GAAG,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;IAC3C,QAAQ,CAAC,qBAAqB,CAAC,6BAA6B,EAAE;QAC5D,oBAAoB,EAAE,EAAE;KACzB,CAAC,CAAC;AAEL,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,6DAA6D,EAAE,GAAG,EAAE;IACvE,QAAQ;IACR,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAC1B,qBAAqB;IACrB,IAAI,4BAAsB,CAAC,KAAK,EAAE,gCAAgC,EAAE;QAClE,mBAAmB,EAAE;YACnB,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,WAAW;YACnC,OAAO,EAAE,eAAe;YACxB,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,SAAS,SAAS,CAAC;SACnD;QACD,WAAW,EAAE,EAAE,aAAa,EAAE,2BAAa,CAAC,OAAO,EAAE;QACrD,SAAS,EAAE,IAAI;KAChB,CAAC,CAAC;IAEH,MAAM,QAAQ,GAAG,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;IAC3C,QAAQ,CAAC,qBAAqB,CAAC,uBAAuB,EAAE;QACtD,SAAS,EAAE;YACT,gBAAgB,EAAE;gBAChB;oBACE,YAAY,EAAE;wBACZ,6EAA6E;wBAC7E,SAAS;qBACV;iBACF;aACF;YACD,SAAS,EAAE;gBACT;oBACE,GAAG,EAAE,kCAAkC;iBACxC;gBACD;oBACE,GAAG,EAAE,kCAAkC;iBACxC;aACF;SACF;KACF,CAAC,CAAC;IAEH,QAAQ,CAAC,qBAAqB,CAAC,eAAe,EAAE;QAC9C,kBAAkB,EAAE,IAAI;QACxB,gBAAgB,EAAE,IAAI;KACvB,CAAC,CAAC;IAEH,QAAQ,CAAC,qBAAqB,CAAC,uBAAuB,EAAE;QACtD,eAAe,EAAE,WAAW;KAC7B,CAAC,CAAC;IAEH,QAAQ,CAAC,eAAe,CAAC,kBAAkB,EAAE,CAAC,CAAC,CAAC;IAChD,QAAQ,CAAC,eAAe,CAAC,2BAA2B,EAAE,CAAC,CAAC,CAAC;AAC3D,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,uDAAuD,EAAE,GAAG,EAAE;IACjE,QAAQ;IACR,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAC1B,qBAAqB;IACrB,IAAI,4BAAsB,CAAC,KAAK,EAAE,gCAAgC,EAAE;QAClE,mBAAmB,EAAE;YACnB,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,WAAW;YACnC,OAAO,EAAE,eAAe;YACxB,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,SAAS,SAAS,CAAC;SACnD;QACD,WAAW,EAAE,EAAE,aAAa,EAAE,2BAAa,CAAC,OAAO,EAAE;QACrD,QAAQ,EAAE;YACR,kBAAkB,EAAE,KAAK;YACzB,gBAAgB,EAAE,KAAK;YACvB,WAAW,EAAE,GAAG,CAAC,WAAW,CAAC,IAAI,CAAC,eAAe,CAAC;SACnD;QACD,SAAS,EAAE,IAAI;KAChB,CAAC,CAAC;IAEH,MAAM,QAAQ,GAAG,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;IAC3C,QAAQ,CAAC,qBAAqB,CAAC,uBAAuB,EAAE;QACtD,SAAS,EAAE;YACT,gBAAgB,EAAE;gBAChB;oBACE,YAAY,EAAE;wBACZ,6EAA6E;wBAC7E,SAAS;qBACV;iBACF;aACF;YACD,SAAS,EAAE;gBACT;oBACE,GAAG,EAAE,kCAAkC;iBACxC;gBACD;oBACE,GAAG,EAAE,kCAAkC;iBACxC;aACF;SACF;KACF,CAAC,CAAC;IAEH,QAAQ,CAAC,qBAAqB,CAAC,eAAe,EAAE;QAC9C,SAAS,EAAE,eAAe;QAC1B,kBAAkB,EAAE,IAAI;QACxB,gBAAgB,EAAE,IAAI;KACvB,CAAC,CAAC;IAEH,QAAQ,CAAC,qBAAqB,CAAC,uBAAuB,EAAE;QACtD,eAAe,EAAE,WAAW;KAC7B,CAAC,CAAC;IAEH,QAAQ,CAAC,eAAe,CAAC,kBAAkB,EAAE,CAAC,CAAC,CAAC;IAChD,QAAQ,CAAC,eAAe,CAAC,2BAA2B,EAAE,CAAC,CAAC,CAAC;AAC3D,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,8CAA8C,EAAE,GAAG,EAAE;IACxD,QAAQ;IACR,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAE1B,MAAM,OAAO,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,KAAK,EAAE,UAAU,EAAE,EAAE,CAAC,CAAC;IAEnD,qBAAqB;IACrB,IAAI,4BAAsB,CAAC,KAAK,EAAE,gCAAgC,EAAE;QAClE,mBAAmB,EAAE;YACnB,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,WAAW;YACnC,OAAO,EAAE,eAAe;YACxB,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,SAAS,SAAS,CAAC;SACnD;QACD,WAAW,EAAE,EAAE,aAAa,EAAE,2BAAa,CAAC,OAAO,EAAE;QACrD,WAAW,EAAE,OAAO;KACrB,CAAC,CAAC;IAEH,MAAM,QAAQ,GAAG,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;IAC3C,QAAQ,CAAC,qBAAqB,CAAC,uBAAuB,EAAE;QACtD,SAAS,EAAE;YACT,gBAAgB,EAAE;gBAChB;oBACE,YAAY,EAAE;wBACZ,6EAA6E;wBAC7E,SAAS;qBACV;iBACF;aACF;YACD,SAAS,EAAE;gBACT;oBACE,GAAG,EAAE,qCAAqC;iBAC3C;gBACD;oBACE,GAAG,EAAE,qCAAqC;iBAC3C;aACF;SACF;KACF,CAAC,CAAC;IAEH,QAAQ,CAAC,qBAAqB,CAAC,uBAAuB,EAAE;QACtD,eAAe,EAAE,WAAW;KAC7B,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,iFAAiF,EAAE,GAAG,EAAE;IAC3F,QAAQ;IACR,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAE1B,MAAM,kBAAkB,GAAG,IAAI,MAAM,CAAC,QAAQ,CAAC,KAAK,EAAE,YAAY,EAAE;QAClE,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,WAAW;QACnC,OAAO,EAAE,eAAe;QACxB,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,SAAS,SAAS,CAAC;KACnD,CAAC,CAAC;IAEH,MAAM,OAAO,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,KAAK,EAAE,UAAU,EAAE,EAAE,CAAC,CAAC;IAEnD,qBAAqB;IACrB,MAAM,GAAG,GAAG,GAAG,EAAE;QACf,0EAA0E;QAC1E,oBAAoB;QACpB,IAAI,4BAAsB,CAAC,KAAK,EAAE,gCAAgC,EAAE;YAClE,iBAAiB,EAAE,kBAAkB;YACrC,WAAW,EAAE,OAAO;YACpB,WAAW,EAAE,EAAE,aAAa,EAAE,2BAAa,CAAC,OAAO,EAAE;SACtD,CAAC,CAAC;IACL,CAAC,CAAC;IAEF,YAAY;IACZ,MAAM,CAAC,GAAG,CAAC,CAAC,YAAY,EAAE,CAAC;AAE7B,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,iCAAiC,EAAE,GAAG,EAAE;IAC3C,QAAQ;IACR,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAE1B,MAAM,OAAO,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,KAAK,EAAE,UAAU,EAAE,EAAE,CAAC,CAAC;IAEnD,MAAM,GAAG,GAAG,GAAG,EAAE;QACf,qBAAqB;QACrB,IAAI,4BAAsB,CAAC,KAAK,EAAE,gCAAgC,EAAE;YAClE,mBAAmB,EAAE;gBACnB,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,WAAW;gBACnC,OAAO,EAAE,eAAe;gBACxB,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,SAAS,SAAS,CAAC;aACnD;YACD,WAAW,EAAE,EAAE,aAAa,EAAE,2BAAa,CAAC,OAAO,EAAE;YACrD,WAAW,EAAE,OAAO;YACpB,SAAS,EAAE,IAAI;SAChB,CAAC,CAAC;IACL,CAAC,CAAC;IACF,YAAY;IACZ,MAAM,CAAC,GAAG,CAAC,CAAC,YAAY,CAAC,sGAAsG,CAAC,CAAC;AACnI,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,kDAAkD,EAAE,GAAG,EAAE;IAC5D,QAAQ;IACR,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAE1B,qBAAqB;IACrB,IAAI,4BAAsB,CAAC,KAAK,EAAE,gCAAgC,EAAE;QAClE,mBAAmB,EAAE;YACnB,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,WAAW;YACnC,OAAO,EAAE,eAAe;YACxB,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,SAAS,SAAS,CAAC;YAClD,WAAW,EAAE;gBACX,mCAAmC,EAAE,GAAG;aACzC;SACF;QACD,WAAW,EAAE,EAAE,aAAa,EAAE,2BAAa,CAAC,OAAO,EAAE;QACrD,6BAA6B,EAAE,oBAAoB;KACpD,CAAC,CAAC;IAEH,YAAY;IACZ,MAAM,QAAQ,GAAG,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;IAC3C,QAAQ,CAAC,qBAAqB,CAAC,uBAAuB,EAAE;QACtD,OAAO,EAAE,eAAe;QACxB,OAAO,EAAE,YAAY;QACrB,WAAW,EAAE;YACX,SAAS,EAAE;gBACT,mCAAmC,EAAE,GAAG;gBACxC,kBAAkB,EAAE;oBAClB,GAAG,EAAE,2CAA2C;iBACjD;aACF;SACF;KACF,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,6DAA6D,EAAE,GAAG,EAAE;IACvE,QAAQ;IACR,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAE1B,MAAM,aAAa,GAAG,QAAQ,CAAC,kBAAkB,CAAC,KAAK,EAAE;QACvD,WAAW,EAAE,YAAY;KAC1B,CAAC,CAAC;IAEH,qBAAqB;IACrB,IAAI,4BAAsB,CAAC,KAAK,EAAE,gCAAgC,EAAE;QAClE,mBAAmB,EAAE;YACnB,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,WAAW;YACnC,OAAO,EAAE,eAAe;YACxB,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,SAAS,SAAS,CAAC;YAClD,WAAW,EAAE;gBACX,mCAAmC,EAAE,GAAG;aACzC;SACF;QACD,WAAW,EAAE;YACX,aAAa;SACd;KACF,CAAC,CAAC;IAEH,cAAc;IACd,MAAM,QAAQ,GAAG,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;IAC3C,QAAQ,CAAC,qBAAqB,CAAC,uBAAuB,EAAE;QACtD,OAAO,EAAE,eAAe;QACxB,OAAO,EAAE,YAAY;QACrB,WAAW,EAAE;YACX,SAAS,EAAE;gBACT,mCAAmC,EAAE,GAAG;gBACxC,UAAU,EAAE;oBACV,GAAG,EAAE,2CAA2C;iBACjD;aACF;SACF;KACF,CAAC,CAAC;IAEH,cAAc;IACd,QAAQ,CAAC,qBAAqB,CAAC,6BAA6B,EAAE;QAC5D,oBAAoB,EAAE,EAAE;QACxB,QAAQ,EAAE;YACR,YAAY,EAAE;gBACZ,uBAAuB;gBACvB,KAAK;aACN;SACF;KACF,CAAC,CAAC;IAEH,cAAc;IACd,QAAQ,CAAC,qBAAqB,CAAC,eAAe,EAAE;QAC9C,WAAW,EAAE,YAAY;QACzB,iBAAiB,EAAE,IAAI;KACxB,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,kCAAkC,EAAE,GAAG,EAAE;IAC5C,gBAAgB;IAChB,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAC1B,MAAM,cAAc,GAAG,IAAI,MAAM,CAAC,QAAQ,CAAC,KAAK,EAAE,YAAY,EAAE;QAC9D,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,WAAW;QACnC,OAAO,EAAE,eAAe;QACxB,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,SAAS,SAAS,CAAC;KACnD,CAAC,CAAC;IAEH,MAAM,KAAK,GAAgC;QACzC,mBAAmB,EAAE;YACnB,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,WAAW;YACnC,OAAO,EAAE,eAAe;YACxB,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,SAAS,SAAS,CAAC;SACnD;QACD,iBAAiB,EAAE,cAAc;KAClC,CAAC;IACF,MAAM,GAAG,GAAG,GAAG,EAAE;QACf,IAAI,4BAAsB,CAAC,KAAK,EAAE,gBAAgB,EAAE,KAAK,CAAC,CAAC;IAC7D,CAAC,CAAC;IACF,YAAY;IACZ,MAAM,CAAC,GAAG,CAAC,CAAC,YAAY,CAAC,kFAAkF,CAAC,CAAC;AAC/G,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,0CAA0C,EAAE,GAAG,EAAE;IACpD,gBAAgB;IAChB,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAE1B,MAAM,KAAK,GAAgC;QACzC,mBAAmB,EAAE;YACnB,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,WAAW;YACnC,OAAO,EAAE,eAAe;YACxB,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,SAAS,SAAS,CAAC;SACnD;QACD,WAAW,EAAE;YACX,UAAU,EAAE,MAAM;SACnB;QACD,iBAAiB,EAAE,IAAI,OAAO,CAAC,MAAM,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE,CAAC;KACzD,CAAC;IACF,MAAM,GAAG,GAAG,GAAG,EAAE;QACf,IAAI,4BAAsB,CAAC,KAAK,EAAE,gBAAgB,EAAE,KAAK,CAAC,CAAC;IAC7D,CAAC,CAAC;IACF,YAAY;IACZ,MAAM,CAAC,GAAG,CAAC,CAAC,YAAY,CAAC,0EAA0E,CAAC,CAAC;AACvG,CAAC,CAAC,CAAC","sourcesContent":["/**\n *  Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n *\n *  Licensed under the Apache License, Version 2.0 (the \"License\"). You may not use this file except in compliance\n *  with the License. A copy of the License is located at\n *\n *      http://www.apache.org/licenses/LICENSE-2.0\n *\n *  or in the 'license' file accompanying this file. This file is distributed on an 'AS IS' BASIS, WITHOUT WARRANTIES\n *  OR CONDITIONS OF ANY KIND, express or implied. See the License for the specific language governing permissions\n *  and limitations under the License.\n */\n\n// Imports\nimport { RemovalPolicy, Stack } from \"aws-cdk-lib\";\nimport * as lambda from \"aws-cdk-lib/aws-lambda\";\nimport * as secrets from 'aws-cdk-lib/aws-secretsmanager';\nimport * as ec2 from \"aws-cdk-lib/aws-ec2\";\nimport { LambdaToSecretsmanager, LambdaToSecretsmanagerProps } from '../lib';\nimport { Template } from 'aws-cdk-lib/assertions';\nimport * as defaults from \"@aws-solutions-constructs/core\";\n\ntest('Test the properties', () => {\n  // Stack\n  const stack = new Stack();\n  // Helper declaration\n  const pattern = new LambdaToSecretsmanager(stack, 'lambda-to-secretsmanager-stack', {\n    lambdaFunctionProps: {\n      runtime: lambda.Runtime.NODEJS_16_X,\n      handler: 'index.handler',\n      code: lambda.Code.fromAsset(`${__dirname}/lambda`)\n    },\n    secretProps: { removalPolicy: RemovalPolicy.DESTROY },\n  });\n  // Assertion 1\n  const func = pattern.lambdaFunction;\n  expect(func).toBeDefined();\n  // Assertion 2\n  const secret = pattern.secret;\n  expect(secret).toBeDefined();\n});\n\ntest('Test deployment w/ existing secret', () => {\n  // Stack\n  const stack = new Stack();\n  // Helper declaration\n  const existingSecret = new secrets.Secret(stack, 'secret', {});\n  const pattern = new LambdaToSecretsmanager(stack, 'lambda-to-secretsmanager-stack', {\n    lambdaFunctionProps: {\n      runtime: lambda.Runtime.NODEJS_16_X,\n      handler: 'index.handler',\n      code: lambda.Code.fromAsset(`${__dirname}/lambda`)\n    },\n    existingSecretObj: existingSecret\n  });\n  // Assertion 1\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties(\"AWS::SecretsManager::Secret\", {\n    GenerateSecretString: {},\n  });\n  // Assertion 2\n  expect(pattern.secret).toBe(existingSecret);\n});\n\ntest('Test deployment w/ existing function', () => {\n  // Stack\n  const stack = new Stack();\n  // Helper declaration\n  const lambdaFunctionProps = {\n    runtime: lambda.Runtime.NODEJS_16_X,\n    handler: 'index.handler',\n    code: lambda.Code.fromAsset(`${__dirname}/lambda`)\n  };\n  const existingFunction = defaults.deployLambdaFunction(stack, lambdaFunctionProps);\n\n  const pattern = new LambdaToSecretsmanager(stack, 'lambda-to-secretsmanager-stack', {\n    existingLambdaObj: existingFunction,\n    secretProps: { removalPolicy: RemovalPolicy.DESTROY },\n  });\n  // Assertion 1\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties(\"AWS::SecretsManager::Secret\", {\n    GenerateSecretString: {},\n  });\n  // Assertion 2\n  expect(pattern.lambdaFunction).toBe(existingFunction);\n});\n\ntest('Test minimal deployment write access to Secret', () => {\n  // Stack\n  const stack = new Stack();\n  // Helper declaration\n  new LambdaToSecretsmanager(stack, 'lambda-to-secretsmanager-stack', {\n    lambdaFunctionProps: {\n      runtime: lambda.Runtime.NODEJS_16_X,\n      handler: 'index.handler',\n      code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n    },\n    secretProps: { removalPolicy: RemovalPolicy.DESTROY },\n    grantWriteAccess: 'ReadWrite'\n  });\n  // Assertion 1\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties(\"AWS::SecretsManager::Secret\", {\n    GenerateSecretString: {},\n  });\n\n});\n\ntest(\"Test minimal deployment that deploys a VPC without vpcProps\", () => {\n  // Stack\n  const stack = new Stack();\n  // Helper declaration\n  new LambdaToSecretsmanager(stack, \"lambda-to-secretsmanager-stack\", {\n    lambdaFunctionProps: {\n      runtime: lambda.Runtime.NODEJS_16_X,\n      handler: \"index.handler\",\n      code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n    },\n    secretProps: { removalPolicy: RemovalPolicy.DESTROY },\n    deployVpc: true,\n  });\n\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties(\"AWS::Lambda::Function\", {\n    VpcConfig: {\n      SecurityGroupIds: [\n        {\n          \"Fn::GetAtt\": [\n            \"lambdatosecretsmanagerstackReplaceDefaultSecurityGroupsecuritygroupED420155\",\n            \"GroupId\",\n          ],\n        },\n      ],\n      SubnetIds: [\n        {\n          Ref: \"VpcisolatedSubnet1SubnetE62B1B9B\",\n        },\n        {\n          Ref: \"VpcisolatedSubnet2Subnet39217055\",\n        },\n      ],\n    },\n  });\n\n  template.hasResourceProperties(\"AWS::EC2::VPC\", {\n    EnableDnsHostnames: true,\n    EnableDnsSupport: true,\n  });\n\n  template.hasResourceProperties(\"AWS::EC2::VPCEndpoint\", {\n    VpcEndpointType: \"Interface\",\n  });\n\n  template.resourceCountIs(\"AWS::EC2::Subnet\", 2);\n  template.resourceCountIs(\"AWS::EC2::InternetGateway\", 0);\n});\n\ntest(\"Test minimal deployment that deploys a VPC w/vpcProps\", () => {\n  // Stack\n  const stack = new Stack();\n  // Helper declaration\n  new LambdaToSecretsmanager(stack, \"lambda-to-secretsmanager-stack\", {\n    lambdaFunctionProps: {\n      runtime: lambda.Runtime.NODEJS_16_X,\n      handler: \"index.handler\",\n      code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n    },\n    secretProps: { removalPolicy: RemovalPolicy.DESTROY },\n    vpcProps: {\n      enableDnsHostnames: false,\n      enableDnsSupport: false,\n      ipAddresses: ec2.IpAddresses.cidr(\"192.68.0.0/16\"),\n    },\n    deployVpc: true,\n  });\n\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties(\"AWS::Lambda::Function\", {\n    VpcConfig: {\n      SecurityGroupIds: [\n        {\n          \"Fn::GetAtt\": [\n            \"lambdatosecretsmanagerstackReplaceDefaultSecurityGroupsecuritygroupED420155\",\n            \"GroupId\",\n          ],\n        },\n      ],\n      SubnetIds: [\n        {\n          Ref: \"VpcisolatedSubnet1SubnetE62B1B9B\",\n        },\n        {\n          Ref: \"VpcisolatedSubnet2Subnet39217055\",\n        },\n      ],\n    },\n  });\n\n  template.hasResourceProperties(\"AWS::EC2::VPC\", {\n    CidrBlock: \"192.68.0.0/16\",\n    EnableDnsHostnames: true,\n    EnableDnsSupport: true,\n  });\n\n  template.hasResourceProperties(\"AWS::EC2::VPCEndpoint\", {\n    VpcEndpointType: \"Interface\",\n  });\n\n  template.resourceCountIs(\"AWS::EC2::Subnet\", 2);\n  template.resourceCountIs(\"AWS::EC2::InternetGateway\", 0);\n});\n\ntest(\"Test minimal deployment with an existing VPC\", () => {\n  // Stack\n  const stack = new Stack();\n\n  const testVpc = new ec2.Vpc(stack, \"test-vpc\", {});\n\n  // Helper declaration\n  new LambdaToSecretsmanager(stack, \"lambda-to-secretsmanager-stack\", {\n    lambdaFunctionProps: {\n      runtime: lambda.Runtime.NODEJS_16_X,\n      handler: \"index.handler\",\n      code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n    },\n    secretProps: { removalPolicy: RemovalPolicy.DESTROY },\n    existingVpc: testVpc,\n  });\n\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties(\"AWS::Lambda::Function\", {\n    VpcConfig: {\n      SecurityGroupIds: [\n        {\n          \"Fn::GetAtt\": [\n            \"lambdatosecretsmanagerstackReplaceDefaultSecurityGroupsecuritygroupED420155\",\n            \"GroupId\",\n          ],\n        },\n      ],\n      SubnetIds: [\n        {\n          Ref: \"testvpcPrivateSubnet1Subnet865FB50A\",\n        },\n        {\n          Ref: \"testvpcPrivateSubnet2Subnet23D3396F\",\n        },\n      ],\n    },\n  });\n\n  template.hasResourceProperties(\"AWS::EC2::VPCEndpoint\", {\n    VpcEndpointType: \"Interface\",\n  });\n});\n\ntest(\"Check error when existing lambda function is not in VPC and construct is in VPC\", () => {\n  // Stack\n  const stack = new Stack();\n\n  const testLambdaFunction = new lambda.Function(stack, 'test-lamba', {\n    runtime: lambda.Runtime.NODEJS_16_X,\n    handler: \"index.handler\",\n    code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n  });\n\n  const testVpc = new ec2.Vpc(stack, \"test-vpc\", {});\n\n  // Helper declaration\n  const app = () => {\n    // buildLambdaFunction should throw an error if the Lambda function is not\n    // attached to a VPC\n    new LambdaToSecretsmanager(stack, \"lambda-to-secretsmanager-stack\", {\n      existingLambdaObj: testLambdaFunction,\n      existingVpc: testVpc,\n      secretProps: { removalPolicy: RemovalPolicy.DESTROY },\n    });\n  };\n\n  // Assertion\n  expect(app).toThrowError();\n\n});\n\ntest(\"Confirm CheckVpcProps is called\", () => {\n  // Stack\n  const stack = new Stack();\n\n  const testVpc = new ec2.Vpc(stack, \"test-vpc\", {});\n\n  const app = () => {\n    // Helper declaration\n    new LambdaToSecretsmanager(stack, \"lambda-to-secretsmanager-stack\", {\n      lambdaFunctionProps: {\n        runtime: lambda.Runtime.NODEJS_16_X,\n        handler: \"index.handler\",\n        code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n      },\n      secretProps: { removalPolicy: RemovalPolicy.DESTROY },\n      existingVpc: testVpc,\n      deployVpc: true,\n    });\n  };\n  // Assertion\n  expect(app).toThrowError('Error - Either provide an existingVpc or some combination of deployVpc and vpcProps, but not both.\\n');\n});\n\ntest('Test lambda function custom environment variable', () => {\n  // Stack\n  const stack = new Stack();\n\n  // Helper declaration\n  new LambdaToSecretsmanager(stack, 'lambda-to-secretsmanager-stack', {\n    lambdaFunctionProps: {\n      runtime: lambda.Runtime.NODEJS_16_X,\n      handler: 'index.handler',\n      code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n      environment: {\n        AWS_NODEJS_CONNECTION_REUSE_ENABLED: '1',\n      }\n    },\n    secretProps: { removalPolicy: RemovalPolicy.DESTROY },\n    secretEnvironmentVariableName: 'CUSTOM_SECRET_NAME'\n  });\n\n  // Assertion\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties('AWS::Lambda::Function', {\n    Handler: 'index.handler',\n    Runtime: 'nodejs16.x',\n    Environment: {\n      Variables: {\n        AWS_NODEJS_CONNECTION_REUSE_ENABLED: '1',\n        CUSTOM_SECRET_NAME: {\n          Ref: 'lambdatosecretsmanagerstacksecretBA684E34'\n        }\n      }\n    }\n  });\n});\n\ntest('Test overriding secretProps to pass a customer provided CMK', () => {\n  // Stack\n  const stack = new Stack();\n\n  const encryptionKey = defaults.buildEncryptionKey(stack, {\n    description: 'secret-key'\n  });\n\n  // Helper declaration\n  new LambdaToSecretsmanager(stack, 'lambda-to-secretsmanager-stack', {\n    lambdaFunctionProps: {\n      runtime: lambda.Runtime.NODEJS_16_X,\n      handler: 'index.handler',\n      code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n      environment: {\n        AWS_NODEJS_CONNECTION_REUSE_ENABLED: '1',\n      }\n    },\n    secretProps: {\n      encryptionKey\n    }\n  });\n\n  // Assertion 1\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties('AWS::Lambda::Function', {\n    Handler: 'index.handler',\n    Runtime: 'nodejs16.x',\n    Environment: {\n      Variables: {\n        AWS_NODEJS_CONNECTION_REUSE_ENABLED: '1',\n        SECRET_ARN: {\n          Ref: 'lambdatosecretsmanagerstacksecretBA684E34'\n        }\n      }\n    }\n  });\n\n  // Assertion 2\n  template.hasResourceProperties(\"AWS::SecretsManager::Secret\", {\n    GenerateSecretString: {},\n    KmsKeyId: {\n      \"Fn::GetAtt\": [\n        \"EncryptionKey1B843E66\",\n        \"Arn\"\n      ]\n    }\n  });\n\n  // Assertion 3\n  template.hasResourceProperties('AWS::KMS::Key', {\n    Description: \"secret-key\",\n    EnableKeyRotation: true\n  });\n});\n\ntest('Confirm call to CheckLambdaProps', () => {\n  // Initial Setup\n  const stack = new Stack();\n  const lambdaFunction = new lambda.Function(stack, 'a-function', {\n    runtime: lambda.Runtime.NODEJS_16_X,\n    handler: 'index.handler',\n    code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n  });\n\n  const props: LambdaToSecretsmanagerProps = {\n    lambdaFunctionProps: {\n      runtime: lambda.Runtime.NODEJS_16_X,\n      handler: 'index.handler',\n      code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n    },\n    existingLambdaObj: lambdaFunction,\n  };\n  const app = () => {\n    new LambdaToSecretsmanager(stack, 'test-construct', props);\n  };\n  // Assertion\n  expect(app).toThrowError('Error - Either provide lambdaFunctionProps or existingLambdaObj, but not both.\\n');\n});\n\ntest('Confirm call to CheckSecretsManagerProps', () => {\n  // Initial Setup\n  const stack = new Stack();\n\n  const props: LambdaToSecretsmanagerProps = {\n    lambdaFunctionProps: {\n      runtime: lambda.Runtime.NODEJS_16_X,\n      handler: 'index.handler',\n      code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n    },\n    secretProps: {\n      secretName: 'test'\n    },\n    existingSecretObj: new secrets.Secret(stack, 'test', {}),\n  };\n  const app = () => {\n    new LambdaToSecretsmanager(stack, 'test-construct', props);\n  };\n  // Assertion\n  expect(app).toThrowError('Error - Either provide secretProps or existingSecretObj, but not both.\\n');\n});\n"]}