@aws-solutions-constructs/core
Version:
Core CDK Construct for patterns library
416 lines • 42.3 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 buildTestOpenSearchDomain(stack, openSearchDomainName, 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
});
return defaults.buildOpenSearch(stack, {
userpool,
identitypool,
cognitoAuthorizedRoleARN: cognitoAuthorizedRole.roleArn,
serviceRoleARN: lambdaRoleARN ? lambdaRoleARN : undefined,
vpc,
openSearchDomainName,
clientDomainProps
});
}
function deployStack() {
return new aws_cdk_lib_1.Stack(undefined, undefined, {
env: { account: "123456789012", region: 'us-east-1' },
});
}
test('Test override SnapshotOptions for buildOpenSearch', () => {
const stack = deployStack();
const buildOpenSearchResponse = buildTestOpenSearchDomain(stack, 'test-domain', {
snapshotOptions: {
automatedSnapshotStartHour: 5
}
});
expect(buildOpenSearchResponse.domain).toBeDefined();
expect(buildOpenSearchResponse.role).toBeDefined();
assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::OpenSearchService::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": [
"CognitoDashboardConfigureRoleEC5F4809",
"Arn"
]
},
UserPoolId: {
Ref: "CognitoUserPool53E37E69"
}
},
DomainEndpointOptions: {
EnforceHTTPS: true,
TLSSecurityPolicy: 'Policy-Min-TLS-1-2-2019-07',
},
DomainName: "test-domain",
EBSOptions: {
EBSEnabled: true,
VolumeSize: 10
},
ClusterConfig: {
DedicatedMasterCount: 3,
DedicatedMasterEnabled: true,
InstanceCount: 3,
ZoneAwarenessConfig: {
AvailabilityZoneCount: 3
},
ZoneAwarenessEnabled: true
},
EngineVersion: "OpenSearch_1.3",
EncryptionAtRestOptions: {
Enabled: true
},
NodeToNodeEncryptionOptions: {
Enabled: true
},
SnapshotOptions: {
AutomatedSnapshotStartHour: 5
}
});
});
test('Test VPC with 1 AZ, Zone Awareness Disabled', () => {
const stack = deployStack();
const vpc = defaults.getTestVpc(stack, false);
buildTestOpenSearchDomain(stack, 'test-domain', {
clusterConfig: {
dedicatedMasterEnabled: true,
dedicatedMasterCount: 3,
instanceCount: 3,
zoneAwarenessEnabled: false
}
}, undefined, vpc);
assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::OpenSearchService::Domain', {
DomainName: "test-domain",
ClusterConfig: {
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 buildOpenSearchResponse = buildTestOpenSearchDomain(stack, 'test-domain', {}, undefined, vpc);
expect(buildOpenSearchResponse.domain).toBeDefined();
expect(buildOpenSearchResponse.role).toBeDefined();
assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::OpenSearchService::Domain', {
DomainName: "test-domain",
ClusterConfig: {
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 = deployStack();
const vpc = defaults.getTestVpc(stack);
buildTestOpenSearchDomain(stack, 'test-domain', {}, undefined, vpc);
assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::OpenSearchService::Domain', {
DomainName: "test-domain",
ClusterConfig: {
DedicatedMasterCount: 3,
DedicatedMasterEnabled: true,
InstanceCount: 3,
ZoneAwarenessEnabled: true
}
});
});
test('Test deployment with an existing private VPC', () => {
const stack = deployStack();
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,
}
]
});
buildTestOpenSearchDomain(stack, 'test-domain', {}, undefined, vpc);
assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::OpenSearchService::Domain', {
DomainName: "test-domain",
ClusterConfig: {
DedicatedMasterCount: 3,
DedicatedMasterEnabled: true,
InstanceCount: 3,
ZoneAwarenessEnabled: true
}
});
});
test('Test error thrown with no private subnet configurations', () => {
const stack = deployStack();
const vpc = defaults.buildVpc(stack, {
defaultVpcProps: {
subnetConfiguration: [
{
cidrMask: 18,
name: "public",
subnetType: ec2.SubnetType.PUBLIC,
}
]
}
});
const app = () => {
buildTestOpenSearchDomain(stack, 'test-domain', {}, undefined, vpc);
};
expect(app).toThrowError('Error - No isolated or private subnets available in VPC');
});
test('Test engine version override for buildOpenSearch', () => {
const stack = deployStack();
buildTestOpenSearchDomain(stack, 'test-domain', {
engineVersion: 'OpenSearch_1.0'
});
assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::OpenSearchService::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": [
"CognitoDashboardConfigureRoleEC5F4809",
"Arn"
]
},
UserPoolId: {
Ref: "CognitoUserPool53E37E69"
}
},
DomainName: "test-domain",
EBSOptions: {
EBSEnabled: true,
VolumeSize: 10
},
ClusterConfig: {
DedicatedMasterCount: 3,
DedicatedMasterEnabled: true,
InstanceCount: 3,
ZoneAwarenessConfig: {
AvailabilityZoneCount: 3
},
ZoneAwarenessEnabled: true
},
EngineVersion: "OpenSearch_1.0",
EncryptionAtRestOptions: {
Enabled: true
},
NodeToNodeEncryptionOptions: {
Enabled: true
},
SnapshotOptions: {
AutomatedSnapshotStartHour: 1
}
});
});
test('Test deployment with lambdaRoleARN', () => {
const stack = deployStack();
const buildOpenSearchResponse = buildTestOpenSearchDomain(stack, 'test-domain', {}, 'arn:aws:us-east-1:mylambdaRoleARN');
expect(buildOpenSearchResponse.domain).toBeDefined();
expect(buildOpenSearchResponse.role).toBeDefined();
assertions_1.Template.fromStack(stack).hasResourceProperties('AWS::OpenSearchService::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": [
"CognitoDashboardConfigureRoleEC5F4809",
"Arn"
]
},
UserPoolId: {
Ref: "CognitoUserPool53E37E69"
}
},
DomainName: "test-domain",
EBSOptions: {
EBSEnabled: true,
VolumeSize: 10
},
ClusterConfig: {
DedicatedMasterCount: 3,
DedicatedMasterEnabled: true,
InstanceCount: 3,
ZoneAwarenessConfig: {
AvailabilityZoneCount: 3
},
ZoneAwarenessEnabled: true
},
EngineVersion: "OpenSearch_1.3",
EncryptionAtRestOptions: {
Enabled: true
},
NodeToNodeEncryptionOptions: {
Enabled: true
},
SnapshotOptions: {
AutomatedSnapshotStartHour: 1
}
});
});
test('Count OpenSearch CloudWatch alarms', () => {
const stack = new aws_cdk_lib_1.Stack();
buildTestOpenSearchDomain(stack, 'test-domain');
const cwList = defaults.buildOpenSearchCWAlarms(stack);
expect(cwList.length).toEqual(9);
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"opensearch-helper.test.js","sourceRoot":"","sources":["opensearch-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 opensearch from 'aws-cdk-lib/aws-opensearchservice';\nimport * as defaults from '../index';\nimport { Template } from 'aws-cdk-lib/assertions';\nimport * as ec2 from 'aws-cdk-lib/aws-ec2';\nimport { BuildOpenSearchResponse } from '../index';\n\nfunction buildTestOpenSearchDomain(stack: Stack, openSearchDomainName: string, clientDomainProps?: opensearch.CfnDomainProps,\n  lambdaRoleARN?: string, vpc?: ec2.IVpc): BuildOpenSearchResponse {\n  const userpool = defaults.buildUserPool(stack);\n  const userpoolclient = defaults.buildUserPoolClient(stack, userpool, {\n    userPoolClientName: 'test',\n    userPool: userpool\n  });\n\n  const identitypool = defaults.buildIdentityPool(stack, userpool, userpoolclient);\n  const cognitoAuthorizedRole = defaults.setupCognitoForSearchService(stack, 'test-domain', {\n    userpool,\n    userpoolclient,\n    identitypool\n  });\n\n  return defaults.buildOpenSearch(stack, {\n    userpool,\n    identitypool,\n    cognitoAuthorizedRoleARN: cognitoAuthorizedRole.roleArn,\n    serviceRoleARN: lambdaRoleARN ? lambdaRoleARN : undefined,\n    vpc,\n    openSearchDomainName,\n    clientDomainProps\n  });\n}\n\nfunction deployStack() {\n  return new Stack(undefined, undefined, {\n    env: { account: \"123456789012\", region: 'us-east-1' },\n  });\n}\n\ntest('Test override SnapshotOptions for buildOpenSearch', () => {\n  const stack = deployStack();\n\n  const buildOpenSearchResponse = buildTestOpenSearchDomain(stack, 'test-domain', {\n    snapshotOptions: {\n      automatedSnapshotStartHour: 5\n    }\n  });\n\n  expect(buildOpenSearchResponse.domain).toBeDefined();\n  expect(buildOpenSearchResponse.role).toBeDefined();\n  Template.fromStack(stack).hasResourceProperties('AWS::OpenSearchService::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          \"CognitoDashboardConfigureRoleEC5F4809\",\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    ClusterConfig: {\n      DedicatedMasterCount: 3,\n      DedicatedMasterEnabled: true,\n      InstanceCount: 3,\n      ZoneAwarenessConfig: {\n        AvailabilityZoneCount: 3\n      },\n      ZoneAwarenessEnabled: true\n    },\n    EngineVersion: \"OpenSearch_1.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 = deployStack();\n\n  const vpc = defaults.getTestVpc(stack, false);\n\n  buildTestOpenSearchDomain(stack, 'test-domain', {\n    clusterConfig: {\n      dedicatedMasterEnabled: true,\n      dedicatedMasterCount: 3,\n      instanceCount: 3,\n      zoneAwarenessEnabled: false\n    }\n  }, undefined, vpc);\n\n  Template.fromStack(stack).hasResourceProperties('AWS::OpenSearchService::Domain', {\n    DomainName: \"test-domain\",\n    ClusterConfig: {\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 buildOpenSearchResponse = buildTestOpenSearchDomain(stack, 'test-domain', {}, undefined, vpc);\n\n  expect(buildOpenSearchResponse.domain).toBeDefined();\n  expect(buildOpenSearchResponse.role).toBeDefined();\n  Template.fromStack(stack).hasResourceProperties('AWS::OpenSearchService::Domain', {\n    DomainName: \"test-domain\",\n    ClusterConfig: {\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 = deployStack();\n\n  const vpc: ec2.IVpc = defaults.getTestVpc(stack);\n\n  buildTestOpenSearchDomain(stack, 'test-domain', {}, undefined, vpc);\n\n  Template.fromStack(stack).hasResourceProperties('AWS::OpenSearchService::Domain', {\n    DomainName: \"test-domain\",\n    ClusterConfig: {\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 = deployStack();\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  buildTestOpenSearchDomain(stack, 'test-domain', {}, undefined, vpc);\n\n  Template.fromStack(stack).hasResourceProperties('AWS::OpenSearchService::Domain', {\n    DomainName: \"test-domain\",\n    ClusterConfig: {\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 = deployStack();\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    buildTestOpenSearchDomain(stack, 'test-domain', {}, undefined, vpc);\n  };\n\n  expect(app).toThrowError('Error - No isolated or private subnets available in VPC');\n});\n\ntest('Test engine version override for buildOpenSearch', () => {\n  const stack = deployStack();\n\n  buildTestOpenSearchDomain(stack, 'test-domain', {\n    engineVersion: 'OpenSearch_1.0'\n  });\n\n  Template.fromStack(stack).hasResourceProperties('AWS::OpenSearchService::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          \"CognitoDashboardConfigureRoleEC5F4809\",\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    ClusterConfig: {\n      DedicatedMasterCount: 3,\n      DedicatedMasterEnabled: true,\n      InstanceCount: 3,\n      ZoneAwarenessConfig: {\n        AvailabilityZoneCount: 3\n      },\n      ZoneAwarenessEnabled: true\n    },\n    EngineVersion: \"OpenSearch_1.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 deployment with lambdaRoleARN', () => {\n  const stack = deployStack();\n\n  const buildOpenSearchResponse = buildTestOpenSearchDomain(stack, 'test-domain', {}, 'arn:aws:us-east-1:mylambdaRoleARN');\n\n  expect(buildOpenSearchResponse.domain).toBeDefined();\n  expect(buildOpenSearchResponse.role).toBeDefined();\n  Template.fromStack(stack).hasResourceProperties('AWS::OpenSearchService::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          \"CognitoDashboardConfigureRoleEC5F4809\",\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    ClusterConfig: {\n      DedicatedMasterCount: 3,\n      DedicatedMasterEnabled: true,\n      InstanceCount: 3,\n      ZoneAwarenessConfig: {\n        AvailabilityZoneCount: 3\n      },\n      ZoneAwarenessEnabled: true\n    },\n    EngineVersion: \"OpenSearch_1.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 OpenSearch CloudWatch alarms', () => {\n  const stack = new Stack();\n  buildTestOpenSearchDomain(stack, 'test-domain');\n  const cwList = defaults.buildOpenSearchCWAlarms(stack);\n\n  expect(cwList.length).toEqual(9);\n});\n"]}