@aws-solutions-constructs/core
Version:
Core CDK Construct for patterns library
384 lines • 39.5 kB
JavaScript
"use strict";
/**
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance
* with the License. A copy of the License is located at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* or in the 'license' file accompanying this file. This file is distributed on an 'AS IS' BASIS, WITHOUT WARRANTIES
* OR CONDITIONS OF ANY KIND, express or implied. See the License for the specific language governing permissions
* and limitations under the License.
*/
Object.defineProperty(exports, "__esModule", { value: true });
const aws_cdk_lib_1 = require("aws-cdk-lib");
const s3 = require("aws-cdk-lib/aws-s3");
const kms = require("aws-cdk-lib/aws-kms");
const defaults = require("../index");
const utils_1 = require("../lib/utils");
const assertions_1 = require("aws-cdk-lib/assertions");
const test_helper_1 = require("./test-helper");
const test_helper_2 = require("./test-helper");
test('test s3Bucket override versioningConfiguration', () => {
const stack = new aws_cdk_lib_1.Stack();
const defaultProps = defaults.DefaultS3Props();
const inProps = {
versioned: false
};
const outProps = (0, utils_1.overrideProps)(defaultProps, inProps);
new s3.Bucket(stack, 'test-s3-verioning', outProps);
assertions_1.Template.fromStack(stack).hasResourceProperties("AWS::S3::Bucket", {
BucketEncryption: {
ServerSideEncryptionConfiguration: [
{
ServerSideEncryptionByDefault: {
SSEAlgorithm: "AES256"
}
}
]
},
PublicAccessBlockConfiguration: {
BlockPublicAcls: true,
BlockPublicPolicy: true,
IgnorePublicAcls: true,
RestrictPublicBuckets: true
}
});
});
test('test s3Bucket override bucketEncryption', () => {
const stack = new aws_cdk_lib_1.Stack();
const defaultProps = defaults.DefaultS3Props();
const inProps = {
encryption: s3.BucketEncryption.KMS,
encryptionKey: new kms.Key(stack, 'mykeyid')
};
const outProps = (0, utils_1.overrideProps)(defaultProps, inProps);
new s3.Bucket(stack, 'test-s3-encryption', outProps);
assertions_1.Template.fromStack(stack).hasResourceProperties("AWS::S3::Bucket", {
BucketEncryption: {
ServerSideEncryptionConfiguration: [
{
ServerSideEncryptionByDefault: {
KMSMasterKeyID: {
"Fn::GetAtt": [
"mykeyidFA4203B0",
"Arn"
]
},
SSEAlgorithm: "aws:kms"
}
}
]
},
});
});
test('test s3Bucket override publicAccessBlockConfiguration', () => {
const stack = new aws_cdk_lib_1.Stack();
const defaultProps = defaults.DefaultS3Props();
const inProps = {
blockPublicAccess: s3.BlockPublicAccess.BLOCK_ACLS
};
const outProps = (0, utils_1.overrideProps)(defaultProps, inProps);
new s3.Bucket(stack, 'test-s3-publicAccessBlock', outProps);
assertions_1.Template.fromStack(stack).hasResourceProperties("AWS::S3::Bucket", {
PublicAccessBlockConfiguration: {
BlockPublicAcls: true,
IgnorePublicAcls: true
},
});
});
test('test s3Bucket add lifecycleConfiguration', () => {
const stack = new aws_cdk_lib_1.Stack();
const defaultProps = defaults.DefaultS3Props();
const inProps = {
lifecycleRules: [{
expiration: aws_cdk_lib_1.Duration.days(365)
}]
};
const outProps = (0, utils_1.overrideProps)(defaultProps, inProps);
new s3.Bucket(stack, 'test-s3-lifecycle', outProps);
assertions_1.Template.fromStack(stack).hasResourceProperties("AWS::S3::Bucket", {
LifecycleConfiguration: {
Rules: [
{
Status: 'Enabled',
ExpirationInDays: 365,
}
]
}
});
});
test('test s3Bucket override serverAccessLogsBucket', () => {
const stack = new aws_cdk_lib_1.Stack();
const myLoggingBucket = new s3.Bucket(stack, 'MyS3LoggingBucket', defaults.DefaultS3Props());
const myS3Props = defaults.DefaultS3Props(myLoggingBucket);
defaults.buildS3Bucket(stack, {
bucketProps: myS3Props
});
assertions_1.Template.fromStack(stack).hasResourceProperties("AWS::S3::Bucket", {
LoggingConfiguration: {
DestinationBucketName: {
Ref: "MyS3LoggingBucket119BE896"
}
}
});
});
test('test createAlbLoggingBucket()', () => {
const stack = new aws_cdk_lib_1.Stack();
defaults.createAlbLoggingBucket(stack, 'test-bucket', {
bucketName: 'test-name'
});
assertions_1.Template.fromStack(stack).hasResourceProperties("AWS::S3::Bucket", {
BucketName: 'test-name'
});
});
test('Test bucket policy that only accepts SSL requests only', () => {
const stack = new aws_cdk_lib_1.Stack();
defaults.buildS3Bucket(stack, {
bucketProps: {
enforceSSL: true
}
}, 'test-bucket');
assertions_1.Template.fromStack(stack).hasResourceProperties("AWS::S3::BucketPolicy", {
PolicyDocument: {
Statement: [
{
Action: "s3:*",
Condition: {
Bool: {
"aws:SecureTransport": "false"
}
},
Effect: "Deny",
Principal: {
AWS: "*"
},
Resource: [
{
"Fn::GetAtt": [
"testbucketS3Bucket87F6BFFC",
"Arn"
]
},
{
"Fn::Join": [
"",
[
{
"Fn::GetAtt": [
"testbucketS3Bucket87F6BFFC",
"Arn"
]
},
"/*"
]
]
}
]
}
],
Version: "2012-10-17"
}
});
});
test('Test bucket policy that accepts any requests', () => {
const stack = new aws_cdk_lib_1.Stack();
defaults.buildS3Bucket(stack, {
bucketProps: {
enforceSSL: false
}
}, 'test-bucket');
(0, test_helper_1.expectNonexistence)(stack, "AWS::S3::BucketPolicy", {
PolicyDocument: {
Statement: [
{
Action: "s3:*",
Condition: {
Bool: {
"aws:SecureTransport": "false"
}
},
Effect: "Deny",
Principal: {
AWS: "*"
},
Resource: [
{
"Fn::GetAtt": [
"testbucketS3Bucket87F6BFFC",
"Arn"
]
},
{
"Fn::Join": [
"",
[
{
"Fn::GetAtt": [
"testbucketS3Bucket87F6BFFC",
"Arn"
]
},
"/*"
]
]
}
]
}
],
Version: "2012-10-17"
}
});
});
test('Test enforcing SSL when bucketProps is not provided', () => {
const stack = new aws_cdk_lib_1.Stack();
defaults.buildS3Bucket(stack, {}, 'test-bucket');
assertions_1.Template.fromStack(stack).hasResourceProperties("AWS::S3::BucketPolicy", {
PolicyDocument: {
Statement: [
{
Action: "s3:*",
Condition: {
Bool: {
"aws:SecureTransport": "false"
}
},
Effect: "Deny",
Principal: {
AWS: "*"
},
Resource: [
{
"Fn::GetAtt": [
"testbucketS3Bucket87F6BFFC",
"Arn"
]
},
{
"Fn::Join": [
"",
[
{
"Fn::GetAtt": [
"testbucketS3Bucket87F6BFFC",
"Arn"
]
},
"/*"
]
]
}
]
}
],
Version: "2012-10-17"
}
});
});
test('Test enforcing SSL when bucketProps is provided and enforceSSL is not set', () => {
const stack = new aws_cdk_lib_1.Stack();
defaults.buildS3Bucket(stack, {
bucketProps: {
versioned: false,
publicReadAccess: false
}
}, 'test-bucket');
assertions_1.Template.fromStack(stack).hasResourceProperties("AWS::S3::BucketPolicy", {
PolicyDocument: {
Statement: [
{
Action: "s3:*",
Condition: {
Bool: {
"aws:SecureTransport": "false"
}
},
Effect: "Deny",
Principal: {
AWS: "*"
},
Resource: [
{
"Fn::GetAtt": [
"testbucketS3Bucket87F6BFFC",
"Arn"
]
},
{
"Fn::Join": [
"",
[
{
"Fn::GetAtt": [
"testbucketS3Bucket87F6BFFC",
"Arn"
]
},
"/*"
]
]
}
]
}
],
Version: "2012-10-17"
}
});
});
// ---------------------------
// Prop Tests
// ---------------------------
test('Test fail S3 check', () => {
const stack = new aws_cdk_lib_1.Stack();
const props = {
existingBucketObj: (0, test_helper_2.CreateScrapBucket)(stack, "scrapBucket"),
bucketProps: {},
};
const app = () => {
defaults.CheckS3Props(props);
};
// Assertion
expect(app).toThrowError('Error - Either provide bucketProps or existingBucketObj, but not both.\n');
});
test('Test fail existing log bucket and log bucket prop check', () => {
const stack = new aws_cdk_lib_1.Stack();
const props = {
existingLoggingBucketObj: new s3.Bucket(stack, 'logging-bucket'),
loggingBucketProps: {
autoDeleteObjects: true
}
};
const app = () => {
defaults.CheckS3Props(props);
};
// Assertion
expect(app).toThrowError('Error - Either provide existingLoggingBucketObj or loggingBucketProps, but not both.\n');
});
test('Test fail false logS3Accesslogs and loggingBucketProps check', () => {
const stack = new aws_cdk_lib_1.Stack();
const props = {
existingLoggingBucketObj: new s3.Bucket(stack, 'logging-bucket'),
logS3AccessLogs: false
};
const app = () => {
defaults.CheckS3Props(props);
};
// Assertion
expect(app).toThrowError('Error - If logS3AccessLogs is false, supplying loggingBucketProps or existingLoggingBucketObj is invalid.\n');
});
test('Test fail existingBucketObj and loggingBucketProps check', () => {
const stack = new aws_cdk_lib_1.Stack();
const props = {
existingBucketObj: new s3.Bucket(stack, 'temp-bucket'),
loggingBucketProps: {
autoDeleteObjects: true
}
};
const app = () => {
defaults.CheckS3Props(props);
};
// Assertion
expect(app).toThrowError('Error - If existingBucketObj is provided, supplying loggingBucketProps or logS3AccessLogs is an error.\n');
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"s3-bucket.test.js","sourceRoot":"","sources":["s3-bucket.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\nimport { Duration, Stack } from 'aws-cdk-lib';\nimport * as s3 from 'aws-cdk-lib/aws-s3';\nimport * as kms from 'aws-cdk-lib/aws-kms';\nimport * as defaults from '../index';\nimport { overrideProps } from '../lib/utils';\nimport { Template } from 'aws-cdk-lib/assertions';\nimport { expectNonexistence } from \"./test-helper\";\nimport { CreateScrapBucket } from './test-helper';\n\ntest('test s3Bucket override versioningConfiguration', () => {\n  const stack = new Stack();\n  const defaultProps: s3.BucketProps = defaults.DefaultS3Props();\n\n  const inProps: s3.BucketProps = {\n    versioned: false\n  };\n\n  const outProps = overrideProps(defaultProps, inProps);\n  new s3.Bucket(stack, 'test-s3-verioning', outProps);\n\n  Template.fromStack(stack).hasResourceProperties(\"AWS::S3::Bucket\", {\n    BucketEncryption: {\n      ServerSideEncryptionConfiguration: [\n        {\n          ServerSideEncryptionByDefault: {\n            SSEAlgorithm: \"AES256\"\n          }\n        }\n      ]\n    },\n    PublicAccessBlockConfiguration: {\n      BlockPublicAcls: true,\n      BlockPublicPolicy: true,\n      IgnorePublicAcls: true,\n      RestrictPublicBuckets: true\n    }\n  });\n});\n\ntest('test s3Bucket override bucketEncryption', () => {\n  const stack = new Stack();\n  const defaultProps: s3.BucketProps = defaults.DefaultS3Props();\n\n  const inProps: s3.BucketProps = {\n    encryption: s3.BucketEncryption.KMS,\n    encryptionKey: new kms.Key(stack, 'mykeyid')\n  };\n\n  const outProps = overrideProps(defaultProps, inProps);\n  new s3.Bucket(stack, 'test-s3-encryption', outProps);\n\n  Template.fromStack(stack).hasResourceProperties(\"AWS::S3::Bucket\", {\n    BucketEncryption: {\n      ServerSideEncryptionConfiguration: [\n        {\n          ServerSideEncryptionByDefault: {\n            KMSMasterKeyID: {\n              \"Fn::GetAtt\": [\n                \"mykeyidFA4203B0\",\n                \"Arn\"\n              ]\n            },\n            SSEAlgorithm: \"aws:kms\"\n          }\n        }\n      ]\n    },\n  });\n});\n\ntest('test s3Bucket override publicAccessBlockConfiguration', () => {\n  const stack = new Stack();\n  const defaultProps: s3.BucketProps = defaults.DefaultS3Props();\n\n  const inProps: s3.BucketProps = {\n    blockPublicAccess: s3.BlockPublicAccess.BLOCK_ACLS\n  };\n\n  const outProps = overrideProps(defaultProps, inProps);\n  new s3.Bucket(stack, 'test-s3-publicAccessBlock', outProps);\n\n  Template.fromStack(stack).hasResourceProperties(\"AWS::S3::Bucket\", {\n    PublicAccessBlockConfiguration: {\n      BlockPublicAcls: true,\n      IgnorePublicAcls: true\n    },\n  });\n});\n\ntest('test s3Bucket add lifecycleConfiguration', () => {\n  const stack = new Stack();\n  const defaultProps: s3.BucketProps = defaults.DefaultS3Props();\n\n  const inProps: s3.BucketProps = {\n    lifecycleRules: [{\n      expiration: Duration.days(365)\n    }]\n  };\n\n  const outProps = overrideProps(defaultProps, inProps);\n  new s3.Bucket(stack, 'test-s3-lifecycle', outProps);\n\n  Template.fromStack(stack).hasResourceProperties(\"AWS::S3::Bucket\", {\n    LifecycleConfiguration: {\n      Rules: [\n        {\n          Status: 'Enabled',\n          ExpirationInDays: 365,\n        }\n      ]\n    }\n  });\n});\n\ntest('test s3Bucket override serverAccessLogsBucket', () => {\n  const stack = new Stack();\n\n  const myLoggingBucket: s3.Bucket = new s3.Bucket(stack, 'MyS3LoggingBucket', defaults.DefaultS3Props());\n\n  const myS3Props: s3.BucketProps = defaults.DefaultS3Props(myLoggingBucket);\n\n  defaults.buildS3Bucket(stack, {\n    bucketProps: myS3Props\n  });\n\n  Template.fromStack(stack).hasResourceProperties(\"AWS::S3::Bucket\", {\n    LoggingConfiguration: {\n      DestinationBucketName: {\n        Ref: \"MyS3LoggingBucket119BE896\"\n      }\n    }\n  });\n});\n\ntest('test createAlbLoggingBucket()', () => {\n  const stack = new Stack();\n\n  defaults.createAlbLoggingBucket(stack, 'test-bucket', {\n    bucketName: 'test-name'\n  });\n\n  Template.fromStack(stack).hasResourceProperties(\"AWS::S3::Bucket\", {\n    BucketName: 'test-name'\n  });\n});\n\ntest('Test bucket policy that only accepts SSL requests only', () => {\n  const stack = new Stack();\n\n  defaults.buildS3Bucket(stack, {\n    bucketProps: {\n      enforceSSL: true\n    }\n  }, 'test-bucket');\n\n  Template.fromStack(stack).hasResourceProperties(\"AWS::S3::BucketPolicy\", {\n    PolicyDocument: {\n      Statement: [\n        {\n          Action: \"s3:*\",\n          Condition: {\n            Bool: {\n              \"aws:SecureTransport\": \"false\"\n            }\n          },\n          Effect: \"Deny\",\n          Principal: {\n            AWS: \"*\"\n          },\n          Resource: [\n            {\n              \"Fn::GetAtt\": [\n                \"testbucketS3Bucket87F6BFFC\",\n                \"Arn\"\n              ]\n            },\n            {\n              \"Fn::Join\": [\n                \"\",\n                [\n                  {\n                    \"Fn::GetAtt\": [\n                      \"testbucketS3Bucket87F6BFFC\",\n                      \"Arn\"\n                    ]\n                  },\n                  \"/*\"\n                ]\n              ]\n            }\n          ]\n        }\n      ],\n      Version: \"2012-10-17\"\n    }\n  });\n});\n\ntest('Test bucket policy that accepts any requests', () => {\n  const stack = new Stack();\n\n  defaults.buildS3Bucket(stack, {\n    bucketProps: {\n      enforceSSL: false\n    }\n  }, 'test-bucket');\n\n  expectNonexistence(stack, \"AWS::S3::BucketPolicy\", {\n    PolicyDocument: {\n      Statement: [\n        {\n          Action: \"s3:*\",\n          Condition: {\n            Bool: {\n              \"aws:SecureTransport\": \"false\"\n            }\n          },\n          Effect: \"Deny\",\n          Principal: {\n            AWS: \"*\"\n          },\n          Resource: [\n            {\n              \"Fn::GetAtt\": [\n                \"testbucketS3Bucket87F6BFFC\",\n                \"Arn\"\n              ]\n            },\n            {\n              \"Fn::Join\": [\n                \"\",\n                [\n                  {\n                    \"Fn::GetAtt\": [\n                      \"testbucketS3Bucket87F6BFFC\",\n                      \"Arn\"\n                    ]\n                  },\n                  \"/*\"\n                ]\n              ]\n            }\n          ]\n        }\n      ],\n      Version: \"2012-10-17\"\n    }\n  });\n});\n\ntest('Test enforcing SSL when bucketProps is not provided', () => {\n  const stack = new Stack();\n\n  defaults.buildS3Bucket(stack, {}, 'test-bucket');\n\n  Template.fromStack(stack).hasResourceProperties(\"AWS::S3::BucketPolicy\", {\n    PolicyDocument: {\n      Statement: [\n        {\n          Action: \"s3:*\",\n          Condition: {\n            Bool: {\n              \"aws:SecureTransport\": \"false\"\n            }\n          },\n          Effect: \"Deny\",\n          Principal: {\n            AWS: \"*\"\n          },\n          Resource: [\n            {\n              \"Fn::GetAtt\": [\n                \"testbucketS3Bucket87F6BFFC\",\n                \"Arn\"\n              ]\n            },\n            {\n              \"Fn::Join\": [\n                \"\",\n                [\n                  {\n                    \"Fn::GetAtt\": [\n                      \"testbucketS3Bucket87F6BFFC\",\n                      \"Arn\"\n                    ]\n                  },\n                  \"/*\"\n                ]\n              ]\n            }\n          ]\n        }\n      ],\n      Version: \"2012-10-17\"\n    }\n  });\n});\n\ntest('Test enforcing SSL when bucketProps is provided and enforceSSL is not set', () => {\n  const stack = new Stack();\n\n  defaults.buildS3Bucket(stack, {\n    bucketProps: {\n      versioned: false,\n      publicReadAccess: false\n    }\n  }, 'test-bucket');\n\n  Template.fromStack(stack).hasResourceProperties(\"AWS::S3::BucketPolicy\", {\n    PolicyDocument: {\n      Statement: [\n        {\n          Action: \"s3:*\",\n          Condition: {\n            Bool: {\n              \"aws:SecureTransport\": \"false\"\n            }\n          },\n          Effect: \"Deny\",\n          Principal: {\n            AWS: \"*\"\n          },\n          Resource: [\n            {\n              \"Fn::GetAtt\": [\n                \"testbucketS3Bucket87F6BFFC\",\n                \"Arn\"\n              ]\n            },\n            {\n              \"Fn::Join\": [\n                \"\",\n                [\n                  {\n                    \"Fn::GetAtt\": [\n                      \"testbucketS3Bucket87F6BFFC\",\n                      \"Arn\"\n                    ]\n                  },\n                  \"/*\"\n                ]\n              ]\n            }\n          ]\n        }\n      ],\n      Version: \"2012-10-17\"\n    }\n  });\n});\n\n// ---------------------------\n// Prop Tests\n// ---------------------------\ntest('Test fail S3 check', () => {\n  const stack = new Stack();\n\n  const props: defaults.S3Props = {\n    existingBucketObj: CreateScrapBucket(stack, \"scrapBucket\"),\n    bucketProps: {},\n  };\n\n  const app = () => {\n    defaults.CheckS3Props(props);\n  };\n\n  // Assertion\n  expect(app).toThrowError('Error - Either provide bucketProps or existingBucketObj, but not both.\\n');\n});\n\ntest('Test fail existing log bucket and log bucket prop check', () => {\n  const stack = new Stack();\n\n  const props: defaults.S3Props = {\n    existingLoggingBucketObj: new s3.Bucket(stack, 'logging-bucket'),\n    loggingBucketProps: {\n      autoDeleteObjects: true\n    }\n  };\n\n  const app = () => {\n    defaults.CheckS3Props(props);\n  };\n\n  // Assertion\n  expect(app).toThrowError('Error - Either provide existingLoggingBucketObj or loggingBucketProps, but not both.\\n');\n});\n\ntest('Test fail false logS3Accesslogs and loggingBucketProps check', () => {\n  const stack = new Stack();\n\n  const props: defaults.S3Props = {\n    existingLoggingBucketObj: new s3.Bucket(stack, 'logging-bucket'),\n    logS3AccessLogs: false\n  };\n\n  const app = () => {\n    defaults.CheckS3Props(props);\n  };\n\n  // Assertion\n  expect(app).toThrowError('Error - If logS3AccessLogs is false, supplying loggingBucketProps or existingLoggingBucketObj is invalid.\\n');\n});\n\ntest('Test fail existingBucketObj and loggingBucketProps check', () => {\n  const stack = new Stack();\n\n  const props: defaults.S3Props = {\n    existingBucketObj: new s3.Bucket(stack, 'temp-bucket'),\n    loggingBucketProps: {\n      autoDeleteObjects: true\n    }\n  };\n\n  const app = () => {\n    defaults.CheckS3Props(props);\n  };\n\n  // Assertion\n  expect(app).toThrowError('Error - If existingBucketObj is provided, supplying loggingBucketProps or logS3AccessLogs is an error.\\n');\n});\n"]}