@aws-solutions-constructs/core
Version:
Core CDK Construct for patterns library
305 lines • 30.8 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 waf = require("aws-cdk-lib/aws-wafv2");
const defaults = require("..");
const assertions_1 = require("aws-cdk-lib/assertions");
const __1 = require("..");
test('Test construct with default props', () => {
// Stack
const stack = new aws_cdk_lib_1.Stack();
// Build WAF web ACL
defaults.buildWebacl(stack, 'REGIONAL', {});
const template = assertions_1.Template.fromStack(stack);
template.hasResourceProperties("AWS::WAFv2::WebACL", {
Scope: "REGIONAL",
VisibilityConfig: {
CloudWatchMetricsEnabled: true,
MetricName: "webACL",
SampledRequestsEnabled: true
},
Rules: [
{
Name: "AWS-AWSManagedRulesBotControlRuleSet",
OverrideAction: {
None: {}
},
Priority: 0,
Statement: {
ManagedRuleGroupStatement: {
Name: "AWSManagedRulesBotControlRuleSet",
VendorName: "AWS"
}
},
VisibilityConfig: {
CloudWatchMetricsEnabled: true,
MetricName: "AWSManagedRulesBotControlRuleSet",
SampledRequestsEnabled: true
}
},
{
Name: "AWS-AWSManagedRulesKnownBadInputsRuleSet",
OverrideAction: {
None: {}
},
Priority: 1,
Statement: {
ManagedRuleGroupStatement: {
Name: "AWSManagedRulesKnownBadInputsRuleSet",
VendorName: "AWS"
}
},
VisibilityConfig: {
CloudWatchMetricsEnabled: true,
MetricName: "AWSManagedRulesKnownBadInputsRuleSet",
SampledRequestsEnabled: true
}
},
{
Name: "AWS-AWSManagedRulesCommonRuleSet",
OverrideAction: {
None: {}
},
Priority: 2,
Statement: {
ManagedRuleGroupStatement: {
Name: "AWSManagedRulesCommonRuleSet",
VendorName: "AWS"
}
},
VisibilityConfig: {
CloudWatchMetricsEnabled: true,
MetricName: "AWSManagedRulesCommonRuleSet",
SampledRequestsEnabled: true
}
},
{
Name: "AWS-AWSManagedRulesAnonymousIpList",
OverrideAction: {
None: {}
},
Priority: 3,
Statement: {
ManagedRuleGroupStatement: {
Name: "AWSManagedRulesAnonymousIpList",
VendorName: "AWS"
}
},
VisibilityConfig: {
CloudWatchMetricsEnabled: true,
MetricName: "AWSManagedRulesAnonymousIpList",
SampledRequestsEnabled: true
}
},
{
Name: "AWS-AWSManagedRulesAmazonIpReputationList",
OverrideAction: {
None: {}
},
Priority: 4,
Statement: {
ManagedRuleGroupStatement: {
Name: "AWSManagedRulesAmazonIpReputationList",
VendorName: "AWS"
}
},
VisibilityConfig: {
CloudWatchMetricsEnabled: true,
MetricName: "AWSManagedRulesAmazonIpReputationList",
SampledRequestsEnabled: true
}
},
{
Name: "AWS-AWSManagedRulesAdminProtectionRuleSet",
OverrideAction: {
None: {}
},
Priority: 5,
Statement: {
ManagedRuleGroupStatement: {
Name: "AWSManagedRulesAdminProtectionRuleSet",
VendorName: "AWS"
}
},
VisibilityConfig: {
CloudWatchMetricsEnabled: true,
MetricName: "AWSManagedRulesAdminProtectionRuleSet",
SampledRequestsEnabled: true
}
},
{
Name: "AWS-AWSManagedRulesSQLiRuleSet",
OverrideAction: {
None: {}
},
Priority: 6,
Statement: {
ManagedRuleGroupStatement: {
Name: "AWSManagedRulesSQLiRuleSet",
VendorName: "AWS"
}
},
VisibilityConfig: {
CloudWatchMetricsEnabled: true,
MetricName: "AWSManagedRulesSQLiRuleSet",
SampledRequestsEnabled: true
}
}
]
});
template.resourceCountIs('AWS::WAFv2::WebACL', 1);
template.resourceCountIs('AWS::WAFv2::WebACLAssociation', 0);
});
test('Test deployment w/ user provided custom properties', () => {
// Stack
const stack = new aws_cdk_lib_1.Stack();
// Build WAF web ACL
const props = {
scope: 'CLOUDFRONT',
defaultAction: {
allow: {}
},
visibilityConfig: {
cloudWatchMetricsEnabled: false,
metricName: 'webACL',
sampledRequestsEnabled: true
},
rules: [
defaults.wrapManagedRuleSet("AWSManagedRulesCommonRuleSet", "AWS", 0),
defaults.wrapManagedRuleSet("AWSManagedRulesWordPressRuleSet", "AWS", 1),
]
};
defaults.buildWebacl(stack, 'CLOUDFRONT', {
webaclProps: props
});
assertions_1.Template.fromStack(stack).hasResourceProperties("AWS::WAFv2::WebACL", {
Scope: "CLOUDFRONT",
VisibilityConfig: {
CloudWatchMetricsEnabled: false,
MetricName: "webACL",
SampledRequestsEnabled: true
},
Rules: [
{
Name: "AWS-AWSManagedRulesCommonRuleSet",
OverrideAction: {
None: {}
},
Priority: 0,
Statement: {
ManagedRuleGroupStatement: {
Name: "AWSManagedRulesCommonRuleSet",
VendorName: "AWS"
}
},
VisibilityConfig: {
CloudWatchMetricsEnabled: true,
MetricName: "AWSManagedRulesCommonRuleSet",
SampledRequestsEnabled: true
}
},
{
Name: "AWS-AWSManagedRulesWordPressRuleSet",
OverrideAction: {
None: {}
},
Priority: 1,
Statement: {
ManagedRuleGroupStatement: {
Name: "AWSManagedRulesWordPressRuleSet",
VendorName: "AWS"
}
},
VisibilityConfig: {
CloudWatchMetricsEnabled: true,
MetricName: "AWSManagedRulesWordPressRuleSet",
SampledRequestsEnabled: true
}
}
]
});
});
test('Test deployment w/ user provided partial custom properties', () => {
// Stack
const stack = new aws_cdk_lib_1.Stack();
const testName = 'test-name';
// Build WAF web ACL
const props = {
name: testName
};
defaults.buildWebacl(stack, 'CLOUDFRONT', {
webaclProps: props
});
assertions_1.Template.fromStack(stack).hasResourceProperties("AWS::WAFv2::WebACL", {
Name: testName
});
});
test('Test deployment w/ existing WAF web ACL provided', () => {
// Stack
const stack = new aws_cdk_lib_1.Stack();
// Build WAF web ACL
const testWaf = (0, __1.buildWebacl)(stack, 'CLOUDFRONT', {});
const newWaf = defaults.buildWebacl(stack, 'CLOUDFRONT', {
existingWebaclObj: testWaf
});
expect(newWaf).toBe(testWaf);
});
// ---------------------------
// Prop Tests
// ---------------------------
test('Test WebACL bad props', () => {
const stack = new aws_cdk_lib_1.Stack();
const wafProps = {
scope: 'CLOUDFRONT',
defaultAction: {
allow: {}
},
visibilityConfig: {
cloudWatchMetricsEnabled: false,
metricName: 'webACL',
sampledRequestsEnabled: true
},
rules: [
defaults.wrapManagedRuleSet("AWSManagedRulesCommonRuleSet", "AWS", 0),
defaults.wrapManagedRuleSet("AWSManagedRulesWordPressRuleSet", "AWS", 1),
]
};
const wafPropsTwo = {
scope: 'CLOUDFRONT',
defaultAction: {
allow: {}
},
visibilityConfig: {
cloudWatchMetricsEnabled: false,
metricName: 'webACL',
sampledRequestsEnabled: true
},
rules: [
defaults.wrapManagedRuleSet("AWSManagedRulesCommonRuleSet", "AWS", 0),
defaults.wrapManagedRuleSet("AWSManagedRulesWordPressRuleSet", "AWS", 1),
]
};
const acl = new waf.CfnWebACL(stack, 'test', wafProps);
const props = {
existingWebaclObj: acl,
webaclProps: wafPropsTwo,
};
const app = () => {
defaults.CheckWafWebAclProps(props);
};
// Assertion
expect(app).toThrowError('Error - Either provide existingWebaclObj or webaclProps, but not both.\n');
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"waf-helper.test.js","sourceRoot":"","sources":["waf-helper.test.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;GAWG;;AAEH,6CAAoC;AACpC,6CAA6C;AAC7C,+BAA+B;AAC/B,uDAAkD;AAClD,0BAAiC;AAEjC,IAAI,CAAC,mCAAmC,EAAE,GAAG,EAAE;IAC7C,QAAQ;IACR,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAC1B,oBAAoB;IACpB,QAAQ,CAAC,WAAW,CAAC,KAAK,EAAE,UAAU,EAAE,EAAE,CAAC,CAAC;IAE5C,MAAM,QAAQ,GAAG,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;IAC3C,QAAQ,CAAC,qBAAqB,CAAC,oBAAoB,EAAE;QACnD,KAAK,EAAE,UAAU;QACjB,gBAAgB,EAAE;YAChB,wBAAwB,EAAE,IAAI;YAC9B,UAAU,EAAE,QAAQ;YACpB,sBAAsB,EAAE,IAAI;SAC7B;QACD,KAAK,EAAE;YACL;gBACE,IAAI,EAAE,sCAAsC;gBAC5C,cAAc,EAAE;oBACd,IAAI,EAAE,EAAE;iBACT;gBACD,QAAQ,EAAE,CAAC;gBACX,SAAS,EAAE;oBACT,yBAAyB,EAAE;wBACzB,IAAI,EAAE,kCAAkC;wBACxC,UAAU,EAAE,KAAK;qBAClB;iBACF;gBACD,gBAAgB,EAAE;oBAChB,wBAAwB,EAAE,IAAI;oBAC9B,UAAU,EAAE,kCAAkC;oBAC9C,sBAAsB,EAAE,IAAI;iBAC7B;aACF;YACD;gBACE,IAAI,EAAE,0CAA0C;gBAChD,cAAc,EAAE;oBACd,IAAI,EAAE,EAAE;iBACT;gBACD,QAAQ,EAAE,CAAC;gBACX,SAAS,EAAE;oBACT,yBAAyB,EAAE;wBACzB,IAAI,EAAE,sCAAsC;wBAC5C,UAAU,EAAE,KAAK;qBAClB;iBACF;gBACD,gBAAgB,EAAE;oBAChB,wBAAwB,EAAE,IAAI;oBAC9B,UAAU,EAAE,sCAAsC;oBAClD,sBAAsB,EAAE,IAAI;iBAC7B;aACF;YACD;gBACE,IAAI,EAAE,kCAAkC;gBACxC,cAAc,EAAE;oBACd,IAAI,EAAE,EAAE;iBACT;gBACD,QAAQ,EAAE,CAAC;gBACX,SAAS,EAAE;oBACT,yBAAyB,EAAE;wBACzB,IAAI,EAAE,8BAA8B;wBACpC,UAAU,EAAE,KAAK;qBAClB;iBACF;gBACD,gBAAgB,EAAE;oBAChB,wBAAwB,EAAE,IAAI;oBAC9B,UAAU,EAAE,8BAA8B;oBAC1C,sBAAsB,EAAE,IAAI;iBAC7B;aACF;YACD;gBACE,IAAI,EAAE,oCAAoC;gBAC1C,cAAc,EAAE;oBACd,IAAI,EAAE,EAAE;iBACT;gBACD,QAAQ,EAAE,CAAC;gBACX,SAAS,EAAE;oBACT,yBAAyB,EAAE;wBACzB,IAAI,EAAE,gCAAgC;wBACtC,UAAU,EAAE,KAAK;qBAClB;iBACF;gBACD,gBAAgB,EAAE;oBAChB,wBAAwB,EAAE,IAAI;oBAC9B,UAAU,EAAE,gCAAgC;oBAC5C,sBAAsB,EAAE,IAAI;iBAC7B;aACF;YACD;gBACE,IAAI,EAAE,2CAA2C;gBACjD,cAAc,EAAE;oBACd,IAAI,EAAE,EAAE;iBACT;gBACD,QAAQ,EAAE,CAAC;gBACX,SAAS,EAAE;oBACT,yBAAyB,EAAE;wBACzB,IAAI,EAAE,uCAAuC;wBAC7C,UAAU,EAAE,KAAK;qBAClB;iBACF;gBACD,gBAAgB,EAAE;oBAChB,wBAAwB,EAAE,IAAI;oBAC9B,UAAU,EAAE,uCAAuC;oBACnD,sBAAsB,EAAE,IAAI;iBAC7B;aACF;YACD;gBACE,IAAI,EAAE,2CAA2C;gBACjD,cAAc,EAAE;oBACd,IAAI,EAAE,EAAE;iBACT;gBACD,QAAQ,EAAE,CAAC;gBACX,SAAS,EAAE;oBACT,yBAAyB,EAAE;wBACzB,IAAI,EAAE,uCAAuC;wBAC7C,UAAU,EAAE,KAAK;qBAClB;iBACF;gBACD,gBAAgB,EAAE;oBAChB,wBAAwB,EAAE,IAAI;oBAC9B,UAAU,EAAE,uCAAuC;oBACnD,sBAAsB,EAAE,IAAI;iBAC7B;aACF;YACD;gBACE,IAAI,EAAE,gCAAgC;gBACtC,cAAc,EAAE;oBACd,IAAI,EAAE,EAAE;iBACT;gBACD,QAAQ,EAAE,CAAC;gBACX,SAAS,EAAE;oBACT,yBAAyB,EAAE;wBACzB,IAAI,EAAE,4BAA4B;wBAClC,UAAU,EAAE,KAAK;qBAClB;iBACF;gBACD,gBAAgB,EAAE;oBAChB,wBAAwB,EAAE,IAAI;oBAC9B,UAAU,EAAE,4BAA4B;oBACxC,sBAAsB,EAAE,IAAI;iBAC7B;aACF;SACF;KACF,CAAC,CAAC;IAEH,QAAQ,CAAC,eAAe,CAAC,oBAAoB,EAAE,CAAC,CAAC,CAAC;IAClD,QAAQ,CAAC,eAAe,CAAC,+BAA+B,EAAE,CAAC,CAAC,CAAC;AAC/D,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,oDAAoD,EAAE,GAAG,EAAE;IAC9D,QAAQ;IACR,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAE1B,oBAAoB;IACpB,MAAM,KAAK,GAAuB;QAChC,KAAK,EAAE,YAAY;QACnB,aAAa,EAAE;YACb,KAAK,EAAE,EAAE;SACV;QACD,gBAAgB,EAAE;YAChB,wBAAwB,EAAE,KAAK;YAC/B,UAAU,EAAE,QAAQ;YACpB,sBAAsB,EAAE,IAAI;SAC7B;QACD,KAAK,EAAE;YACL,QAAQ,CAAC,kBAAkB,CAAC,8BAA8B,EAAE,KAAK,EAAE,CAAC,CAAC;YACrE,QAAQ,CAAC,kBAAkB,CAAC,iCAAiC,EAAE,KAAK,EAAE,CAAC,CAAC;SACzE;KACF,CAAC;IAEF,QAAQ,CAAC,WAAW,CAAC,KAAK,EAAE,YAAY,EAAE;QACxC,WAAW,EAAE,KAAK;KACnB,CAAC,CAAC;IAEH,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,oBAAoB,EAAE;QACpE,KAAK,EAAE,YAAY;QACnB,gBAAgB,EAAE;YAChB,wBAAwB,EAAE,KAAK;YAC/B,UAAU,EAAE,QAAQ;YACpB,sBAAsB,EAAE,IAAI;SAC7B;QACD,KAAK,EAAE;YACL;gBACE,IAAI,EAAE,kCAAkC;gBACxC,cAAc,EAAE;oBACd,IAAI,EAAE,EAAE;iBACT;gBACD,QAAQ,EAAE,CAAC;gBACX,SAAS,EAAE;oBACT,yBAAyB,EAAE;wBACzB,IAAI,EAAE,8BAA8B;wBACpC,UAAU,EAAE,KAAK;qBAClB;iBACF;gBACD,gBAAgB,EAAE;oBAChB,wBAAwB,EAAE,IAAI;oBAC9B,UAAU,EAAE,8BAA8B;oBAC1C,sBAAsB,EAAE,IAAI;iBAC7B;aACF;YACD;gBACE,IAAI,EAAE,qCAAqC;gBAC3C,cAAc,EAAE;oBACd,IAAI,EAAE,EAAE;iBACT;gBACD,QAAQ,EAAE,CAAC;gBACX,SAAS,EAAE;oBACT,yBAAyB,EAAE;wBACzB,IAAI,EAAE,iCAAiC;wBACvC,UAAU,EAAE,KAAK;qBAClB;iBACF;gBACD,gBAAgB,EAAE;oBAChB,wBAAwB,EAAE,IAAI;oBAC9B,UAAU,EAAE,iCAAiC;oBAC7C,sBAAsB,EAAE,IAAI;iBAC7B;aACF;SACF;KACF,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,4DAA4D,EAAE,GAAG,EAAE;IACtE,QAAQ;IACR,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAC1B,MAAM,QAAQ,GAAG,WAAW,CAAC;IAC7B,oBAAoB;IACpB,MAAM,KAAK,GAAG;QACZ,IAAI,EAAE,QAAQ;KACf,CAAC;IAEF,QAAQ,CAAC,WAAW,CAAC,KAAK,EAAE,YAAY,EAAE;QACxC,WAAW,EAAE,KAAK;KACnB,CAAC,CAAC;IAEH,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,oBAAoB,EAAE;QACpE,IAAI,EAAE,QAAQ;KACf,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,kDAAkD,EAAE,GAAG,EAAE;IAC5D,QAAQ;IACR,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAC1B,oBAAoB;IACpB,MAAM,OAAO,GAAG,IAAA,eAAW,EAAC,KAAK,EAAE,YAAY,EAAE,EAAE,CAAC,CAAC;IACrD,MAAM,MAAM,GAAG,QAAQ,CAAC,WAAW,CAAC,KAAK,EAAE,YAAY,EAAE;QACvD,iBAAiB,EAAE,OAAO;KAC3B,CAAC,CAAC;IAEH,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;AAC/B,CAAC,CAAC,CAAC;AAEH,8BAA8B;AAC9B,aAAa;AACb,8BAA8B;AAC9B,IAAI,CAAC,uBAAuB,EAAE,GAAG,EAAE;IACjC,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAC1B,MAAM,QAAQ,GAAuB;QACnC,KAAK,EAAE,YAAY;QACnB,aAAa,EAAE;YACb,KAAK,EAAE,EAAE;SACV;QACD,gBAAgB,EAAE;YAChB,wBAAwB,EAAE,KAAK;YAC/B,UAAU,EAAE,QAAQ;YACpB,sBAAsB,EAAE,IAAI;SAC7B;QACD,KAAK,EAAE;YACL,QAAQ,CAAC,kBAAkB,CAAC,8BAA8B,EAAE,KAAK,EAAE,CAAC,CAAC;YACrE,QAAQ,CAAC,kBAAkB,CAAC,iCAAiC,EAAE,KAAK,EAAE,CAAC,CAAC;SACzE;KACF,CAAC;IAEF,MAAM,WAAW,GAAuB;QACtC,KAAK,EAAE,YAAY;QACnB,aAAa,EAAE;YACb,KAAK,EAAE,EAAE;SACV;QACD,gBAAgB,EAAE;YAChB,wBAAwB,EAAE,KAAK;YAC/B,UAAU,EAAE,QAAQ;YACpB,sBAAsB,EAAE,IAAI;SAC7B;QACD,KAAK,EAAE;YACL,QAAQ,CAAC,kBAAkB,CAAC,8BAA8B,EAAE,KAAK,EAAE,CAAC,CAAC;YACrE,QAAQ,CAAC,kBAAkB,CAAC,iCAAiC,EAAE,KAAK,EAAE,CAAC,CAAC;SACzE;KACF,CAAC;IAEF,MAAM,GAAG,GAAkB,IAAI,GAAG,CAAC,SAAS,CAAC,KAAK,EAAE,MAAM,EAAG,QAAQ,CAAC,CAAC;IAEvE,MAAM,KAAK,GAA4B;QACrC,iBAAiB,EAAE,GAAG;QACtB,WAAW,EAAE,WAAW;KACzB,CAAC;IAEF,MAAM,GAAG,GAAG,GAAG,EAAE;QACf,QAAQ,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC;IACtC,CAAC,CAAC;IAEF,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\nimport { Stack } from 'aws-cdk-lib';\nimport * as waf from \"aws-cdk-lib/aws-wafv2\";\nimport * as defaults from '..';\nimport { Template } from 'aws-cdk-lib/assertions';\nimport { buildWebacl } from '..';\n\ntest('Test construct with default props', () => {\n  // Stack\n  const stack = new Stack();\n  // Build WAF web ACL\n  defaults.buildWebacl(stack, 'REGIONAL', {});\n\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties(\"AWS::WAFv2::WebACL\", {\n    Scope: \"REGIONAL\",\n    VisibilityConfig: {\n      CloudWatchMetricsEnabled: true,\n      MetricName: \"webACL\",\n      SampledRequestsEnabled: true\n    },\n    Rules: [\n      {\n        Name: \"AWS-AWSManagedRulesBotControlRuleSet\",\n        OverrideAction: {\n          None: {}\n        },\n        Priority: 0,\n        Statement: {\n          ManagedRuleGroupStatement: {\n            Name: \"AWSManagedRulesBotControlRuleSet\",\n            VendorName: \"AWS\"\n          }\n        },\n        VisibilityConfig: {\n          CloudWatchMetricsEnabled: true,\n          MetricName: \"AWSManagedRulesBotControlRuleSet\",\n          SampledRequestsEnabled: true\n        }\n      },\n      {\n        Name: \"AWS-AWSManagedRulesKnownBadInputsRuleSet\",\n        OverrideAction: {\n          None: {}\n        },\n        Priority: 1,\n        Statement: {\n          ManagedRuleGroupStatement: {\n            Name: \"AWSManagedRulesKnownBadInputsRuleSet\",\n            VendorName: \"AWS\"\n          }\n        },\n        VisibilityConfig: {\n          CloudWatchMetricsEnabled: true,\n          MetricName: \"AWSManagedRulesKnownBadInputsRuleSet\",\n          SampledRequestsEnabled: true\n        }\n      },\n      {\n        Name: \"AWS-AWSManagedRulesCommonRuleSet\",\n        OverrideAction: {\n          None: {}\n        },\n        Priority: 2,\n        Statement: {\n          ManagedRuleGroupStatement: {\n            Name: \"AWSManagedRulesCommonRuleSet\",\n            VendorName: \"AWS\"\n          }\n        },\n        VisibilityConfig: {\n          CloudWatchMetricsEnabled: true,\n          MetricName: \"AWSManagedRulesCommonRuleSet\",\n          SampledRequestsEnabled: true\n        }\n      },\n      {\n        Name: \"AWS-AWSManagedRulesAnonymousIpList\",\n        OverrideAction: {\n          None: {}\n        },\n        Priority: 3,\n        Statement: {\n          ManagedRuleGroupStatement: {\n            Name: \"AWSManagedRulesAnonymousIpList\",\n            VendorName: \"AWS\"\n          }\n        },\n        VisibilityConfig: {\n          CloudWatchMetricsEnabled: true,\n          MetricName: \"AWSManagedRulesAnonymousIpList\",\n          SampledRequestsEnabled: true\n        }\n      },\n      {\n        Name: \"AWS-AWSManagedRulesAmazonIpReputationList\",\n        OverrideAction: {\n          None: {}\n        },\n        Priority: 4,\n        Statement: {\n          ManagedRuleGroupStatement: {\n            Name: \"AWSManagedRulesAmazonIpReputationList\",\n            VendorName: \"AWS\"\n          }\n        },\n        VisibilityConfig: {\n          CloudWatchMetricsEnabled: true,\n          MetricName: \"AWSManagedRulesAmazonIpReputationList\",\n          SampledRequestsEnabled: true\n        }\n      },\n      {\n        Name: \"AWS-AWSManagedRulesAdminProtectionRuleSet\",\n        OverrideAction: {\n          None: {}\n        },\n        Priority: 5,\n        Statement: {\n          ManagedRuleGroupStatement: {\n            Name: \"AWSManagedRulesAdminProtectionRuleSet\",\n            VendorName: \"AWS\"\n          }\n        },\n        VisibilityConfig: {\n          CloudWatchMetricsEnabled: true,\n          MetricName: \"AWSManagedRulesAdminProtectionRuleSet\",\n          SampledRequestsEnabled: true\n        }\n      },\n      {\n        Name: \"AWS-AWSManagedRulesSQLiRuleSet\",\n        OverrideAction: {\n          None: {}\n        },\n        Priority: 6,\n        Statement: {\n          ManagedRuleGroupStatement: {\n            Name: \"AWSManagedRulesSQLiRuleSet\",\n            VendorName: \"AWS\"\n          }\n        },\n        VisibilityConfig: {\n          CloudWatchMetricsEnabled: true,\n          MetricName: \"AWSManagedRulesSQLiRuleSet\",\n          SampledRequestsEnabled: true\n        }\n      }\n    ]\n  });\n\n  template.resourceCountIs('AWS::WAFv2::WebACL', 1);\n  template.resourceCountIs('AWS::WAFv2::WebACLAssociation', 0);\n});\n\ntest('Test deployment w/ user provided custom properties', () => {\n  // Stack\n  const stack = new Stack();\n\n  // Build WAF web ACL\n  const props: waf.CfnWebACLProps = {\n    scope: 'CLOUDFRONT',\n    defaultAction: {\n      allow: {}\n    },\n    visibilityConfig: {\n      cloudWatchMetricsEnabled: false,\n      metricName: 'webACL',\n      sampledRequestsEnabled: true\n    },\n    rules: [\n      defaults.wrapManagedRuleSet(\"AWSManagedRulesCommonRuleSet\", \"AWS\", 0),\n      defaults.wrapManagedRuleSet(\"AWSManagedRulesWordPressRuleSet\", \"AWS\", 1),\n    ]\n  };\n\n  defaults.buildWebacl(stack, 'CLOUDFRONT', {\n    webaclProps: props\n  });\n\n  Template.fromStack(stack).hasResourceProperties(\"AWS::WAFv2::WebACL\", {\n    Scope: \"CLOUDFRONT\",\n    VisibilityConfig: {\n      CloudWatchMetricsEnabled: false,\n      MetricName: \"webACL\",\n      SampledRequestsEnabled: true\n    },\n    Rules: [\n      {\n        Name: \"AWS-AWSManagedRulesCommonRuleSet\",\n        OverrideAction: {\n          None: {}\n        },\n        Priority: 0,\n        Statement: {\n          ManagedRuleGroupStatement: {\n            Name: \"AWSManagedRulesCommonRuleSet\",\n            VendorName: \"AWS\"\n          }\n        },\n        VisibilityConfig: {\n          CloudWatchMetricsEnabled: true,\n          MetricName: \"AWSManagedRulesCommonRuleSet\",\n          SampledRequestsEnabled: true\n        }\n      },\n      {\n        Name: \"AWS-AWSManagedRulesWordPressRuleSet\",\n        OverrideAction: {\n          None: {}\n        },\n        Priority: 1,\n        Statement: {\n          ManagedRuleGroupStatement: {\n            Name: \"AWSManagedRulesWordPressRuleSet\",\n            VendorName: \"AWS\"\n          }\n        },\n        VisibilityConfig: {\n          CloudWatchMetricsEnabled: true,\n          MetricName: \"AWSManagedRulesWordPressRuleSet\",\n          SampledRequestsEnabled: true\n        }\n      }\n    ]\n  });\n});\n\ntest('Test deployment w/ user provided partial custom properties', () => {\n  // Stack\n  const stack = new Stack();\n  const testName = 'test-name';\n  // Build WAF web ACL\n  const props = {\n    name: testName\n  };\n\n  defaults.buildWebacl(stack, 'CLOUDFRONT', {\n    webaclProps: props\n  });\n\n  Template.fromStack(stack).hasResourceProperties(\"AWS::WAFv2::WebACL\", {\n    Name: testName\n  });\n});\n\ntest('Test deployment w/ existing WAF web ACL provided', () => {\n  // Stack\n  const stack = new Stack();\n  // Build WAF web ACL\n  const testWaf = buildWebacl(stack, 'CLOUDFRONT', {});\n  const newWaf = defaults.buildWebacl(stack, 'CLOUDFRONT', {\n    existingWebaclObj: testWaf\n  });\n\n  expect(newWaf).toBe(testWaf);\n});\n\n// ---------------------------\n// Prop Tests\n// ---------------------------\ntest('Test WebACL bad props', () => {\n  const stack = new Stack();\n  const wafProps: waf.CfnWebACLProps = {\n    scope: 'CLOUDFRONT',\n    defaultAction: {\n      allow: {}\n    },\n    visibilityConfig: {\n      cloudWatchMetricsEnabled: false,\n      metricName: 'webACL',\n      sampledRequestsEnabled: true\n    },\n    rules: [\n      defaults.wrapManagedRuleSet(\"AWSManagedRulesCommonRuleSet\", \"AWS\", 0),\n      defaults.wrapManagedRuleSet(\"AWSManagedRulesWordPressRuleSet\", \"AWS\", 1),\n    ]\n  };\n\n  const wafPropsTwo: waf.CfnWebACLProps = {\n    scope: 'CLOUDFRONT',\n    defaultAction: {\n      allow: {}\n    },\n    visibilityConfig: {\n      cloudWatchMetricsEnabled: false,\n      metricName: 'webACL',\n      sampledRequestsEnabled: true\n    },\n    rules: [\n      defaults.wrapManagedRuleSet(\"AWSManagedRulesCommonRuleSet\", \"AWS\", 0),\n      defaults.wrapManagedRuleSet(\"AWSManagedRulesWordPressRuleSet\", \"AWS\", 1),\n    ]\n  };\n\n  const acl: waf.CfnWebACL = new waf.CfnWebACL(stack, 'test',  wafProps);\n\n  const props: defaults.WafWebAclProps = {\n    existingWebaclObj: acl,\n    webaclProps: wafPropsTwo,\n  };\n\n  const app = () => {\n    defaults.CheckWafWebAclProps(props);\n  };\n\n  // Assertion\n  expect(app).toThrowError('Error - Either provide existingWebaclObj or webaclProps, but not both.\\n');\n});\n"]}