@aws-solutions-constructs/core
Version:
Core CDK Construct for patterns library
454 lines • 48.1 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 defaults = require("../index");
const assertions_1 = require("aws-cdk-lib/assertions");
const ec2 = require("aws-cdk-lib/aws-ec2");
function deployES(stack, domainName, clientDomainProps, lambdaRoleARN, vpc) {
const userpool = defaults.buildUserPool(stack);
const userpoolclient = defaults.buildUserPoolClient(stack, userpool, {
userPoolClientName: 'test',
userPool: userpool
});
const identitypool = defaults.buildIdentityPool(stack, userpool, userpoolclient);
const cognitoAuthorizedRole = defaults.setupCognitoForSearchService(stack, 'test-domain', {
userpool,
userpoolclient,
identitypool
});
if (lambdaRoleARN) {
return defaults.buildElasticSearch(stack, {
userpool,
identitypool,
cognitoAuthorizedRoleARN: cognitoAuthorizedRole.roleArn,
serviceRoleARN: lambdaRoleARN,
vpc,
domainName,
clientDomainProps
});
}
else {
return defaults.buildElasticSearch(stack, {
userpool,
identitypool,
cognitoAuthorizedRoleARN: cognitoAuthorizedRole.roleArn,
vpc,
domainName,
clientDomainProps
});
}
}
test('Test override SnapshotOptions for buildElasticSearch', () => {
const stack = new aws_cdk_lib_1.Stack(undefined, undefined, {
env: { account: "123456789012", region: 'us-east-1' },
});
const buildElasticSearchResponse = deployES(stack, 'test-domain', {
snapshotOptions: {
automatedSnapshotStartHour: 5
}
});
expect(buildElasticSearchResponse.domain).toBeDefined();
expect(buildElasticSearchResponse.role).toBeDefined();
const template = assertions_1.Template.fromStack(stack);
template.hasResourceProperties('AWS::Elasticsearch::Domain', {
AccessPolicies: {
Statement: [
{
Action: "es:ESHttp*",
Effect: "Allow",
Principal: {
AWS: {
"Fn::GetAtt": [
"CognitoAuthorizedRole14E74FE0",
"Arn"
]
}
},
Resource: {
"Fn::Join": [
"",
[
"arn:",
{
Ref: "AWS::Partition"
},
":es:",
{
Ref: "AWS::Region"
},
":",
{
Ref: "AWS::AccountId"
},
":domain/test-domain/*"
]
]
}
}
],
Version: "2012-10-17"
},
CognitoOptions: {
Enabled: true,
IdentityPoolId: {
Ref: "CognitoIdentityPool"
},
RoleArn: {
"Fn::GetAtt": [
"CognitoKibanaConfigureRole62CCE76A",
"Arn"
]
},
UserPoolId: {
Ref: "CognitoUserPool53E37E69"
}
},
DomainEndpointOptions: {
EnforceHTTPS: true,
TLSSecurityPolicy: 'Policy-Min-TLS-1-2-2019-07',
},
DomainName: "test-domain",
EBSOptions: {
EBSEnabled: true,
VolumeSize: 10
},
ElasticsearchClusterConfig: {
DedicatedMasterCount: 3,
DedicatedMasterEnabled: true,
InstanceCount: 3,
ZoneAwarenessConfig: {
AvailabilityZoneCount: 3
},
ZoneAwarenessEnabled: true
},
ElasticsearchVersion: "6.3",
EncryptionAtRestOptions: {
Enabled: true
},
NodeToNodeEncryptionOptions: {
Enabled: true
},
SnapshotOptions: {
AutomatedSnapshotStartHour: 5
}
});
});
test('Test VPC with 1 AZ, Zone Awareness Disabled', () => {
const stack = new aws_cdk_lib_1.Stack(undefined, undefined, {
env: { account: "123456789012", region: 'us-east-1' },
});
const vpc = defaults.getTestVpc(stack, false);
const buildElasticSearchResponse = deployES(stack, 'test-domain', {
elasticsearchClusterConfig: {
dedicatedMasterEnabled: true,
dedicatedMasterCount: 3,
instanceCount: 3,
zoneAwarenessEnabled: false
}
}, undefined, vpc);
expect(buildElasticSearchResponse.domain).toBeDefined();
expect(buildElasticSearchResponse.role).toBeDefined();
const template = assertions_1.Template.fromStack(stack);
template.hasResourceProperties('AWS::Elasticsearch::Domain', {
DomainName: "test-domain",
ElasticsearchClusterConfig: {
DedicatedMasterCount: 3,
DedicatedMasterEnabled: true,
InstanceCount: 3,
ZoneAwarenessEnabled: false
}
});
});
test('Test VPC with 2 AZ, Zone Awareness Enabled', () => {
// If no environment is specified, a VPC will use 2 AZs by default.
// If an environment is specified, a VPC will use 3 AZs by default.
const stack = new aws_cdk_lib_1.Stack(undefined, undefined, {});
const vpc = defaults.getTestVpc(stack, false);
const buildElasticSearchResponse = deployES(stack, 'test-domain', {}, undefined, vpc);
expect(buildElasticSearchResponse.domain).toBeDefined();
expect(buildElasticSearchResponse.role).toBeDefined();
const template = assertions_1.Template.fromStack(stack);
template.hasResourceProperties('AWS::Elasticsearch::Domain', {
DomainName: "test-domain",
ElasticsearchClusterConfig: {
DedicatedMasterCount: 3,
DedicatedMasterEnabled: true,
InstanceCount: 2,
ZoneAwarenessEnabled: true
}
});
});
test('Test VPC with 3 AZ, Zone Awareness Enabled', () => {
// If no environment is specified, a VPC will use 2 AZs by default.
// If an environment is specified, a VPC will use 3 AZs by default.
const stack = new aws_cdk_lib_1.Stack(undefined, undefined, {
env: { account: "123456789012", region: 'us-east-1' },
});
const vpc = defaults.getTestVpc(stack);
const buildElasticSearchResponse = deployES(stack, 'test-domain', {}, undefined, vpc);
expect(buildElasticSearchResponse.domain).toBeDefined();
expect(buildElasticSearchResponse.role).toBeDefined();
const template = assertions_1.Template.fromStack(stack);
template.hasResourceProperties('AWS::Elasticsearch::Domain', {
DomainName: "test-domain",
ElasticsearchClusterConfig: {
DedicatedMasterCount: 3,
DedicatedMasterEnabled: true,
InstanceCount: 3,
ZoneAwarenessEnabled: true
}
});
});
test('Test deployment with an existing private VPC', () => {
const stack = new aws_cdk_lib_1.Stack(undefined, undefined, {
env: { account: "123456789012", region: 'us-east-1' },
});
const vpc = new ec2.Vpc(stack, 'existing-private-vpc-test', {
natGateways: 1,
subnetConfiguration: [
{
cidrMask: 24,
name: 'application',
subnetType: ec2.SubnetType.PRIVATE_WITH_EGRESS,
},
{
cidrMask: 24,
name: "public",
subnetType: ec2.SubnetType.PUBLIC,
}
]
});
const buildElasticSearchResponse = deployES(stack, 'test-domain', {}, undefined, vpc);
expect(buildElasticSearchResponse.domain).toBeDefined();
expect(buildElasticSearchResponse.role).toBeDefined();
const template = assertions_1.Template.fromStack(stack);
template.hasResourceProperties('AWS::Elasticsearch::Domain', {
DomainName: "test-domain",
ElasticsearchClusterConfig: {
DedicatedMasterCount: 3,
DedicatedMasterEnabled: true,
InstanceCount: 3,
ZoneAwarenessEnabled: true
}
});
});
test('Test error thrown with no private subnet configurations', () => {
const stack = new aws_cdk_lib_1.Stack(undefined, undefined, {
env: { account: "123456789012", region: 'us-east-1' },
});
const vpc = defaults.buildVpc(stack, {
defaultVpcProps: {
subnetConfiguration: [
{
cidrMask: 18,
name: "public",
subnetType: ec2.SubnetType.PUBLIC,
}
]
}
});
const app = () => {
deployES(stack, 'test-domain', {}, undefined, vpc);
};
expect(app).toThrowError('Error - No isolated or private subnets available in VPC');
});
test('Test override ES version for buildElasticSearch', () => {
const stack = new aws_cdk_lib_1.Stack(undefined, undefined, {
env: { account: "123456789012", region: 'us-east-1' },
});
const response = deployES(stack, 'test-domain', {
elasticsearchVersion: '7.0'
});
expect(response.domain).toBeDefined();
expect(response.role).toBeDefined();
const template = assertions_1.Template.fromStack(stack);
template.hasResourceProperties('AWS::Elasticsearch::Domain', {
AccessPolicies: {
Statement: [
{
Action: "es:ESHttp*",
Effect: "Allow",
Principal: {
AWS: {
"Fn::GetAtt": [
"CognitoAuthorizedRole14E74FE0",
"Arn"
]
}
},
Resource: {
"Fn::Join": [
"",
[
"arn:",
{
Ref: "AWS::Partition"
},
":es:",
{
Ref: "AWS::Region"
},
":",
{
Ref: "AWS::AccountId"
},
":domain/test-domain/*"
]
]
}
}
],
Version: "2012-10-17"
},
CognitoOptions: {
Enabled: true,
IdentityPoolId: {
Ref: "CognitoIdentityPool"
},
RoleArn: {
"Fn::GetAtt": [
"CognitoKibanaConfigureRole62CCE76A",
"Arn"
]
},
UserPoolId: {
Ref: "CognitoUserPool53E37E69"
}
},
DomainName: "test-domain",
EBSOptions: {
EBSEnabled: true,
VolumeSize: 10
},
ElasticsearchClusterConfig: {
DedicatedMasterCount: 3,
DedicatedMasterEnabled: true,
InstanceCount: 3,
ZoneAwarenessConfig: {
AvailabilityZoneCount: 3
},
ZoneAwarenessEnabled: true
},
ElasticsearchVersion: "7.0",
EncryptionAtRestOptions: {
Enabled: true
},
NodeToNodeEncryptionOptions: {
Enabled: true
},
SnapshotOptions: {
AutomatedSnapshotStartHour: 1
}
});
});
test('Test ES with lambdaRoleARN', () => {
const stack = new aws_cdk_lib_1.Stack(undefined, undefined, {
env: { account: "123456789012", region: 'us-east-1' },
});
const buildElasticSearchResponse = deployES(stack, 'test-domain', {}, 'arn:aws:us-east-1:mylambdaRoleARN');
expect(buildElasticSearchResponse.domain).toBeDefined();
expect(buildElasticSearchResponse.role).toBeDefined();
const template = assertions_1.Template.fromStack(stack);
template.hasResourceProperties('AWS::Elasticsearch::Domain', {
AccessPolicies: {
Statement: [
{
Action: "es:ESHttp*",
Effect: "Allow",
Principal: {
AWS: [
{
"Fn::GetAtt": [
"CognitoAuthorizedRole14E74FE0",
"Arn"
]
},
"arn:aws:us-east-1:mylambdaRoleARN"
]
},
Resource: {
"Fn::Join": [
"",
[
"arn:",
{
Ref: "AWS::Partition"
},
":es:",
{
Ref: "AWS::Region"
},
":",
{
Ref: "AWS::AccountId"
},
":domain/test-domain/*"
]
]
}
}
],
Version: "2012-10-17"
},
CognitoOptions: {
Enabled: true,
IdentityPoolId: {
Ref: "CognitoIdentityPool"
},
RoleArn: {
"Fn::GetAtt": [
"CognitoKibanaConfigureRole62CCE76A",
"Arn"
]
},
UserPoolId: {
Ref: "CognitoUserPool53E37E69"
}
},
DomainName: "test-domain",
EBSOptions: {
EBSEnabled: true,
VolumeSize: 10
},
ElasticsearchClusterConfig: {
DedicatedMasterCount: 3,
DedicatedMasterEnabled: true,
InstanceCount: 3,
ZoneAwarenessConfig: {
AvailabilityZoneCount: 3
},
ZoneAwarenessEnabled: true
},
ElasticsearchVersion: "6.3",
EncryptionAtRestOptions: {
Enabled: true
},
NodeToNodeEncryptionOptions: {
Enabled: true
},
SnapshotOptions: {
AutomatedSnapshotStartHour: 1
}
});
});
test('Count ES CW Alarms', () => {
const stack = new aws_cdk_lib_1.Stack();
const buildElasticSearchResponse = deployES(stack, 'test-domain');
expect(buildElasticSearchResponse.domain).toBeDefined();
expect(buildElasticSearchResponse.role).toBeDefined();
const cwList = defaults.buildElasticSearchCWAlarms(stack);
expect(cwList.length).toEqual(9);
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elasticsearch-helper.test.js","sourceRoot":"","sources":["elasticsearch-helper.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 { Stack } from 'aws-cdk-lib';\nimport * as elasticsearch from 'aws-cdk-lib/aws-elasticsearch';\nimport * as defaults from '../index';\nimport { Template } from 'aws-cdk-lib/assertions';\nimport * as ec2 from 'aws-cdk-lib/aws-ec2';\n\nfunction deployES(stack: Stack, domainName: string, clientDomainProps?: elasticsearch.CfnDomainProps,\n  lambdaRoleARN?: string, vpc?: ec2.IVpc): defaults.BuildElasticSearchResponse {\n  const userpool = defaults.buildUserPool(stack);\n  const userpoolclient = defaults.buildUserPoolClient(stack, userpool, {\n    userPoolClientName: 'test',\n    userPool: userpool\n  });\n  const identitypool = defaults.buildIdentityPool(stack, userpool, userpoolclient);\n\n  const cognitoAuthorizedRole = defaults.setupCognitoForSearchService(stack, 'test-domain', {\n    userpool,\n    userpoolclient,\n    identitypool\n  });\n\n  if (lambdaRoleARN) {\n    return defaults.buildElasticSearch(stack, {\n      userpool,\n      identitypool,\n      cognitoAuthorizedRoleARN: cognitoAuthorizedRole.roleArn,\n      serviceRoleARN: lambdaRoleARN,\n      vpc,\n      domainName,\n      clientDomainProps\n    });\n  } else {\n    return defaults.buildElasticSearch(stack, {\n      userpool,\n      identitypool,\n      cognitoAuthorizedRoleARN: cognitoAuthorizedRole.roleArn,\n      vpc,\n      domainName,\n      clientDomainProps\n    });\n  }\n}\n\ntest('Test override SnapshotOptions for buildElasticSearch', () => {\n  const stack = new Stack(undefined, undefined, {\n    env: { account: \"123456789012\", region: 'us-east-1' },\n  });\n\n  const buildElasticSearchResponse = deployES(stack, 'test-domain', {\n    snapshotOptions: {\n      automatedSnapshotStartHour: 5\n    }\n  });\n\n  expect(buildElasticSearchResponse.domain).toBeDefined();\n  expect(buildElasticSearchResponse.role).toBeDefined();\n\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties('AWS::Elasticsearch::Domain', {\n    AccessPolicies: {\n      Statement: [\n        {\n          Action: \"es:ESHttp*\",\n          Effect: \"Allow\",\n          Principal: {\n            AWS: {\n              \"Fn::GetAtt\": [\n                \"CognitoAuthorizedRole14E74FE0\",\n                \"Arn\"\n              ]\n            }\n          },\n          Resource: {\n            \"Fn::Join\": [\n              \"\",\n              [\n                \"arn:\",\n                {\n                  Ref: \"AWS::Partition\"\n                },\n                \":es:\",\n                {\n                  Ref: \"AWS::Region\"\n                },\n                \":\",\n                {\n                  Ref: \"AWS::AccountId\"\n                },\n                \":domain/test-domain/*\"\n              ]\n            ]\n          }\n        }\n      ],\n      Version: \"2012-10-17\"\n    },\n    CognitoOptions: {\n      Enabled: true,\n      IdentityPoolId: {\n        Ref: \"CognitoIdentityPool\"\n      },\n      RoleArn: {\n        \"Fn::GetAtt\": [\n          \"CognitoKibanaConfigureRole62CCE76A\",\n          \"Arn\"\n        ]\n      },\n      UserPoolId: {\n        Ref: \"CognitoUserPool53E37E69\"\n      }\n    },\n    DomainEndpointOptions: {\n      EnforceHTTPS: true,\n      TLSSecurityPolicy: 'Policy-Min-TLS-1-2-2019-07',\n    },\n    DomainName: \"test-domain\",\n    EBSOptions: {\n      EBSEnabled: true,\n      VolumeSize: 10\n    },\n    ElasticsearchClusterConfig: {\n      DedicatedMasterCount: 3,\n      DedicatedMasterEnabled: true,\n      InstanceCount: 3,\n      ZoneAwarenessConfig: {\n        AvailabilityZoneCount: 3\n      },\n      ZoneAwarenessEnabled: true\n    },\n    ElasticsearchVersion: \"6.3\",\n    EncryptionAtRestOptions: {\n      Enabled: true\n    },\n    NodeToNodeEncryptionOptions: {\n      Enabled: true\n    },\n    SnapshotOptions: {\n      AutomatedSnapshotStartHour: 5\n    }\n  });\n});\n\ntest('Test VPC with 1 AZ, Zone Awareness Disabled', () => {\n  const stack = new Stack(undefined, undefined, {\n    env: { account: \"123456789012\", region: 'us-east-1' },\n  });\n\n  const vpc = defaults.getTestVpc(stack, false);\n\n  const buildElasticSearchResponse = deployES(stack, 'test-domain', {\n    elasticsearchClusterConfig: {\n      dedicatedMasterEnabled: true,\n      dedicatedMasterCount: 3,\n      instanceCount: 3,\n      zoneAwarenessEnabled: false\n    }\n  }, undefined, vpc);\n\n  expect(buildElasticSearchResponse.domain).toBeDefined();\n  expect(buildElasticSearchResponse.role).toBeDefined();\n\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties('AWS::Elasticsearch::Domain', {\n    DomainName: \"test-domain\",\n    ElasticsearchClusterConfig: {\n      DedicatedMasterCount: 3,\n      DedicatedMasterEnabled: true,\n      InstanceCount: 3,\n      ZoneAwarenessEnabled: false\n    }\n  });\n});\n\ntest('Test VPC with 2 AZ, Zone Awareness Enabled', () => {\n  // If no environment is specified, a VPC will use 2 AZs by default.\n  // If an environment is specified, a VPC will use 3 AZs by default.\n  const stack = new Stack(undefined, undefined, {});\n\n  const vpc: ec2.IVpc = defaults.getTestVpc(stack, false);\n\n  const buildElasticSearchResponse = deployES(stack, 'test-domain', {}, undefined, vpc);\n\n  expect(buildElasticSearchResponse.domain).toBeDefined();\n  expect(buildElasticSearchResponse.role).toBeDefined();\n\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties('AWS::Elasticsearch::Domain', {\n    DomainName: \"test-domain\",\n    ElasticsearchClusterConfig: {\n      DedicatedMasterCount: 3,\n      DedicatedMasterEnabled: true,\n      InstanceCount: 2,\n      ZoneAwarenessEnabled: true\n    }\n  });\n});\n\ntest('Test VPC with 3 AZ, Zone Awareness Enabled', () => {\n  // If no environment is specified, a VPC will use 2 AZs by default.\n  // If an environment is specified, a VPC will use 3 AZs by default.\n  const stack = new Stack(undefined, undefined, {\n    env: { account: \"123456789012\", region: 'us-east-1' },\n  });\n\n  const vpc: ec2.IVpc = defaults.getTestVpc(stack);\n\n  const buildElasticSearchResponse = deployES(stack, 'test-domain', {}, undefined, vpc);\n\n  expect(buildElasticSearchResponse.domain).toBeDefined();\n  expect(buildElasticSearchResponse.role).toBeDefined();\n\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties('AWS::Elasticsearch::Domain', {\n    DomainName: \"test-domain\",\n    ElasticsearchClusterConfig: {\n      DedicatedMasterCount: 3,\n      DedicatedMasterEnabled: true,\n      InstanceCount: 3,\n      ZoneAwarenessEnabled: true\n    }\n  });\n});\n\ntest('Test deployment with an existing private VPC', () => {\n  const stack = new Stack(undefined, undefined, {\n    env: { account: \"123456789012\", region: 'us-east-1' },\n  });\n\n  const vpc = new ec2.Vpc(stack, 'existing-private-vpc-test', {\n    natGateways: 1,\n    subnetConfiguration: [\n      {\n        cidrMask: 24,\n        name: 'application',\n        subnetType: ec2.SubnetType.PRIVATE_WITH_EGRESS,\n      },\n      {\n        cidrMask: 24,\n        name: \"public\",\n        subnetType: ec2.SubnetType.PUBLIC,\n      }\n    ]\n  });\n\n  const buildElasticSearchResponse = deployES(stack, 'test-domain', {}, undefined, vpc);\n\n  expect(buildElasticSearchResponse.domain).toBeDefined();\n  expect(buildElasticSearchResponse.role).toBeDefined();\n\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties('AWS::Elasticsearch::Domain', {\n    DomainName: \"test-domain\",\n    ElasticsearchClusterConfig: {\n      DedicatedMasterCount: 3,\n      DedicatedMasterEnabled: true,\n      InstanceCount: 3,\n      ZoneAwarenessEnabled: true\n    }\n  });\n});\n\ntest('Test error thrown with no private subnet configurations', () => {\n  const stack = new Stack(undefined, undefined, {\n    env: { account: \"123456789012\", region: 'us-east-1' },\n  });\n\n  const vpc = defaults.buildVpc(stack, {\n    defaultVpcProps: {\n      subnetConfiguration: [\n        {\n          cidrMask: 18,\n          name: \"public\",\n          subnetType: ec2.SubnetType.PUBLIC,\n        }\n      ]\n    }\n  });\n\n  const app = () => {\n    deployES(stack, 'test-domain', {}, undefined, vpc);\n  };\n\n  expect(app).toThrowError('Error - No isolated or private subnets available in VPC');\n});\n\ntest('Test override ES version for buildElasticSearch', () => {\n  const stack = new Stack(undefined, undefined, {\n    env: { account: \"123456789012\", region: 'us-east-1' },\n  });\n\n  const response = deployES(stack, 'test-domain', {\n    elasticsearchVersion: '7.0'\n  });\n\n  expect(response.domain).toBeDefined();\n  expect(response.role).toBeDefined();\n\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties('AWS::Elasticsearch::Domain', {\n    AccessPolicies: {\n      Statement: [\n        {\n          Action: \"es:ESHttp*\",\n          Effect: \"Allow\",\n          Principal: {\n            AWS: {\n              \"Fn::GetAtt\": [\n                \"CognitoAuthorizedRole14E74FE0\",\n                \"Arn\"\n              ]\n            }\n          },\n          Resource: {\n            \"Fn::Join\": [\n              \"\",\n              [\n                \"arn:\",\n                {\n                  Ref: \"AWS::Partition\"\n                },\n                \":es:\",\n                {\n                  Ref: \"AWS::Region\"\n                },\n                \":\",\n                {\n                  Ref: \"AWS::AccountId\"\n                },\n                \":domain/test-domain/*\"\n              ]\n            ]\n          }\n        }\n      ],\n      Version: \"2012-10-17\"\n    },\n    CognitoOptions: {\n      Enabled: true,\n      IdentityPoolId: {\n        Ref: \"CognitoIdentityPool\"\n      },\n      RoleArn: {\n        \"Fn::GetAtt\": [\n          \"CognitoKibanaConfigureRole62CCE76A\",\n          \"Arn\"\n        ]\n      },\n      UserPoolId: {\n        Ref: \"CognitoUserPool53E37E69\"\n      }\n    },\n    DomainName: \"test-domain\",\n    EBSOptions: {\n      EBSEnabled: true,\n      VolumeSize: 10\n    },\n    ElasticsearchClusterConfig: {\n      DedicatedMasterCount: 3,\n      DedicatedMasterEnabled: true,\n      InstanceCount: 3,\n      ZoneAwarenessConfig: {\n        AvailabilityZoneCount: 3\n      },\n      ZoneAwarenessEnabled: true\n    },\n    ElasticsearchVersion: \"7.0\",\n    EncryptionAtRestOptions: {\n      Enabled: true\n    },\n    NodeToNodeEncryptionOptions: {\n      Enabled: true\n    },\n    SnapshotOptions: {\n      AutomatedSnapshotStartHour: 1\n    }\n  });\n\n});\n\ntest('Test ES with lambdaRoleARN', () => {\n  const stack = new Stack(undefined, undefined, {\n    env: { account: \"123456789012\", region: 'us-east-1' },\n  });\n\n  const buildElasticSearchResponse = deployES(stack, 'test-domain', {}, 'arn:aws:us-east-1:mylambdaRoleARN');\n\n  expect(buildElasticSearchResponse.domain).toBeDefined();\n  expect(buildElasticSearchResponse.role).toBeDefined();\n\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties('AWS::Elasticsearch::Domain', {\n    AccessPolicies: {\n      Statement: [\n        {\n          Action: \"es:ESHttp*\",\n          Effect: \"Allow\",\n          Principal: {\n            AWS: [\n              {\n                \"Fn::GetAtt\": [\n                  \"CognitoAuthorizedRole14E74FE0\",\n                  \"Arn\"\n                ]\n              },\n              \"arn:aws:us-east-1:mylambdaRoleARN\"\n            ]\n          },\n          Resource: {\n            \"Fn::Join\": [\n              \"\",\n              [\n                \"arn:\",\n                {\n                  Ref: \"AWS::Partition\"\n                },\n                \":es:\",\n                {\n                  Ref: \"AWS::Region\"\n                },\n                \":\",\n                {\n                  Ref: \"AWS::AccountId\"\n                },\n                \":domain/test-domain/*\"\n              ]\n            ]\n          }\n        }\n      ],\n      Version: \"2012-10-17\"\n    },\n    CognitoOptions: {\n      Enabled: true,\n      IdentityPoolId: {\n        Ref: \"CognitoIdentityPool\"\n      },\n      RoleArn: {\n        \"Fn::GetAtt\": [\n          \"CognitoKibanaConfigureRole62CCE76A\",\n          \"Arn\"\n        ]\n      },\n      UserPoolId: {\n        Ref: \"CognitoUserPool53E37E69\"\n      }\n    },\n    DomainName: \"test-domain\",\n    EBSOptions: {\n      EBSEnabled: true,\n      VolumeSize: 10\n    },\n    ElasticsearchClusterConfig: {\n      DedicatedMasterCount: 3,\n      DedicatedMasterEnabled: true,\n      InstanceCount: 3,\n      ZoneAwarenessConfig: {\n        AvailabilityZoneCount: 3\n      },\n      ZoneAwarenessEnabled: true\n    },\n    ElasticsearchVersion: \"6.3\",\n    EncryptionAtRestOptions: {\n      Enabled: true\n    },\n    NodeToNodeEncryptionOptions: {\n      Enabled: true\n    },\n    SnapshotOptions: {\n      AutomatedSnapshotStartHour: 1\n    }\n  });\n\n});\n\ntest('Count ES CW Alarms', () => {\n  const stack = new Stack();\n  const buildElasticSearchResponse = deployES(stack, 'test-domain');\n  expect(buildElasticSearchResponse.domain).toBeDefined();\n  expect(buildElasticSearchResponse.role).toBeDefined();\n\n  const cwList = defaults.buildElasticSearchCWAlarms(stack);\n\n  expect(cwList.length).toEqual(9);\n});\n"]}