@aws-mdaa/dataops-job-l3-construct 1.5.0 → 1.6.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.
- package/.jsii +38 -28
- package/README.md +5 -0
- package/lib/dataops-job-l3-construct.d.ts +8 -1
- package/lib/dataops-job-l3-construct.js +40 -13
- package/node_modules/@aws-mdaa/config/README.md +3 -0
- package/node_modules/@aws-mdaa/config/lib/blueprint-value-transformer.d.ts +20 -0
- package/node_modules/@aws-mdaa/config/lib/blueprint-value-transformer.js +70 -0
- package/node_modules/@aws-mdaa/config/lib/blueprint-value-transformer.ts +88 -0
- package/node_modules/@aws-mdaa/config/lib/config.d.ts +87 -0
- package/node_modules/@aws-mdaa/config/lib/config.js +7 -0
- package/node_modules/@aws-mdaa/config/lib/config.ts +92 -0
- package/node_modules/@aws-mdaa/config/lib/index.d.ts +11 -0
- package/node_modules/@aws-mdaa/config/lib/index.js +28 -0
- package/node_modules/@aws-mdaa/config/lib/index.ts +12 -0
- package/node_modules/@aws-mdaa/config/lib/param-transformer.d.ts +49 -0
- package/node_modules/@aws-mdaa/config/lib/param-transformer.js +160 -0
- package/node_modules/@aws-mdaa/config/lib/param-transformer.ts +159 -0
- package/node_modules/@aws-mdaa/config/lib/path-value-transformer.d.ts +10 -0
- package/node_modules/@aws-mdaa/config/lib/path-value-transformer.js +30 -0
- package/node_modules/@aws-mdaa/config/lib/path-value-transformer.ts +27 -0
- package/node_modules/@aws-mdaa/config/lib/ref-value-transformer.d.ts +44 -0
- package/node_modules/@aws-mdaa/config/lib/ref-value-transformer.js +243 -0
- package/node_modules/@aws-mdaa/config/lib/ref-value-transformer.ts +302 -0
- package/node_modules/@aws-mdaa/config/lib/ssm-ref-transformer.d.ts +8 -0
- package/node_modules/@aws-mdaa/config/lib/ssm-ref-transformer.js +22 -0
- package/node_modules/@aws-mdaa/config/lib/ssm-ref-transformer.ts +21 -0
- package/node_modules/@aws-mdaa/config/lib/transformer.d.ts +35 -0
- package/node_modules/@aws-mdaa/config/lib/transformer.js +66 -0
- package/node_modules/@aws-mdaa/config/lib/transformer.ts +74 -0
- package/node_modules/@aws-mdaa/config/package.json +42 -0
- package/node_modules/@aws-mdaa/config/test/blueprint-value-transformer.test.js +224 -0
- package/node_modules/@aws-mdaa/config/test/blueprint-value-transformer.test.ts +259 -0
- package/node_modules/@aws-mdaa/config/test/config-nt.test.d.ts +5 -0
- package/node_modules/@aws-mdaa/config/test/config-nt.test.js +129 -0
- package/node_modules/@aws-mdaa/config/test/config-nt.test.ts +163 -0
- package/node_modules/@aws-mdaa/config/test/config.test.d.ts +5 -0
- package/node_modules/@aws-mdaa/config/test/config.test.js +409 -0
- package/node_modules/@aws-mdaa/config/test/config.test.ts +517 -0
- package/node_modules/@aws-mdaa/config/test/param-transformer.test.d.ts +5 -0
- package/node_modules/@aws-mdaa/config/test/param-transformer.test.js +216 -0
- package/node_modules/@aws-mdaa/config/test/param-transformer.test.ts +234 -0
- package/node_modules/@aws-mdaa/config/test/path-value-transformer.test.d.ts +5 -0
- package/node_modules/@aws-mdaa/config/test/path-value-transformer.test.js +59 -0
- package/node_modules/@aws-mdaa/config/test/path-value-transformer.test.ts +68 -0
- package/node_modules/@aws-mdaa/config/test/ref-value-transformer.test.d.ts +5 -0
- package/node_modules/@aws-mdaa/config/test/ref-value-transformer.test.js +254 -0
- package/node_modules/@aws-mdaa/config/test/ref-value-transformer.test.ts +304 -0
- package/node_modules/@aws-mdaa/config/test/ssm-ref-transformer.test.d.ts +5 -0
- package/node_modules/@aws-mdaa/config/test/ssm-ref-transformer.test.js +66 -0
- package/node_modules/@aws-mdaa/config/test/ssm-ref-transformer.test.ts +79 -0
- package/node_modules/@aws-mdaa/config/tsconfig.tsbuildinfo +1 -0
- package/node_modules/lodash/README.md +2 -2
- package/node_modules/lodash/_baseOrderBy.js +1 -1
- package/node_modules/lodash/_baseUnset.js +7 -20
- package/node_modules/lodash/_setCacheHas.js +1 -1
- package/node_modules/lodash/compact.js +1 -1
- package/node_modules/lodash/core.js +3 -3
- package/node_modules/lodash/core.min.js +26 -25
- package/node_modules/lodash/fromPairs.js +3 -1
- package/node_modules/lodash/lodash.js +38 -27
- package/node_modules/lodash/lodash.min.js +125 -129
- package/node_modules/lodash/package.json +4 -2
- package/node_modules/lodash/random.js +9 -0
- package/node_modules/lodash/template.js +16 -4
- package/node_modules/lodash/templateSettings.js +4 -0
- package/package.json +27 -32
- package/node_modules/@aws-mdaa/s3-bucketpolicy-helper/README.md +0 -185
- package/node_modules/@aws-mdaa/s3-bucketpolicy-helper/lib/index.d.ts +0 -57
- package/node_modules/@aws-mdaa/s3-bucketpolicy-helper/lib/index.js +0 -198
- package/node_modules/@aws-mdaa/s3-bucketpolicy-helper/lib/index.ts +0 -241
- package/node_modules/@aws-mdaa/s3-bucketpolicy-helper/package.json +0 -44
- package/node_modules/@aws-mdaa/s3-bucketpolicy-helper/test/bucketpolicy-helper.test.js +0 -200
- package/node_modules/@aws-mdaa/s3-bucketpolicy-helper/test/bucketpolicy-helper.test.ts +0 -215
- package/node_modules/@aws-mdaa/s3-bucketpolicy-helper/tsconfig.tsbuildinfo +0 -1
- package/node_modules/@aws-mdaa/s3-inventory-helper/.npmignore +0 -34
- package/node_modules/@aws-mdaa/s3-inventory-helper/README.md +0 -3
- package/node_modules/@aws-mdaa/s3-inventory-helper/jest.config.js +0 -5
- package/node_modules/@aws-mdaa/s3-inventory-helper/lib/index.d.ts +0 -48
- package/node_modules/@aws-mdaa/s3-inventory-helper/lib/index.js +0 -213
- package/node_modules/@aws-mdaa/s3-inventory-helper/lib/index.ts +0 -241
- package/node_modules/@aws-mdaa/s3-inventory-helper/package.json +0 -44
- package/node_modules/@aws-mdaa/s3-inventory-helper/test/TODO +0 -0
- package/node_modules/@aws-mdaa/s3-inventory-helper/tsconfig.json +0 -40
- package/node_modules/@aws-mdaa/s3-inventory-helper/tsconfig.tsbuildinfo +0 -1
- package/node_modules/@aws-mdaa/s3-inventory-helper/typedoc.json +0 -7
- /package/node_modules/@aws-mdaa/{s3-bucketpolicy-helper → config}/.npmignore +0 -0
- /package/node_modules/@aws-mdaa/{s3-bucketpolicy-helper → config}/jest.config.js +0 -0
- /package/node_modules/@aws-mdaa/{s3-bucketpolicy-helper/test/bucketpolicy-helper.test.d.ts → config/test/blueprint-value-transformer.test.d.ts} +0 -0
- /package/node_modules/@aws-mdaa/{s3-bucketpolicy-helper → config}/tsconfig.json +0 -0
- /package/node_modules/@aws-mdaa/{s3-bucketpolicy-helper → config}/typedoc.json +0 -0
|
@@ -0,0 +1,129 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/*!
|
|
3
|
+
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
|
|
4
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
+
*/
|
|
6
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
+
const aws_cdk_lib_1 = require("aws-cdk-lib");
|
|
8
|
+
const lib_1 = require("../lib");
|
|
9
|
+
/**
|
|
10
|
+
* These tests cover all logic not directly related to the Transformers
|
|
11
|
+
*/
|
|
12
|
+
jest.mock('aws-cdk-lib', () => ({
|
|
13
|
+
CfnParameter: jest.fn().mockImplementation(() => ({
|
|
14
|
+
valueAsString: 'string-value',
|
|
15
|
+
valueAsNumber: 123,
|
|
16
|
+
valueAsList: ['item1', 'item2'],
|
|
17
|
+
})),
|
|
18
|
+
Stack: {
|
|
19
|
+
of: jest.fn().mockReturnValue({
|
|
20
|
+
partition: 'aws',
|
|
21
|
+
region: 'us-east-1',
|
|
22
|
+
account: '123456789012',
|
|
23
|
+
}),
|
|
24
|
+
},
|
|
25
|
+
}));
|
|
26
|
+
describe('Test createParamUsingTypeLabels', () => {
|
|
27
|
+
class TestConfigTransformer extends lib_1.MdaaConfigParamRefValueTransformer {
|
|
28
|
+
constructor(props) {
|
|
29
|
+
props =
|
|
30
|
+
props ||
|
|
31
|
+
{
|
|
32
|
+
scope: {
|
|
33
|
+
node: {},
|
|
34
|
+
},
|
|
35
|
+
};
|
|
36
|
+
super(props);
|
|
37
|
+
this.scope = props.scope;
|
|
38
|
+
}
|
|
39
|
+
testCreateParamUsingTypeLabels(paramBase, paramName, paramProps) {
|
|
40
|
+
return this.createParamUsingTypeLabels(paramBase, paramName, paramProps);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
beforeEach(() => {
|
|
44
|
+
jest.clearAllMocks();
|
|
45
|
+
});
|
|
46
|
+
test('throws error when scope is not defined', () => {
|
|
47
|
+
const testClass = new TestConfigTransformer({});
|
|
48
|
+
// Act & Assert
|
|
49
|
+
expect(() => {
|
|
50
|
+
testClass.testCreateParamUsingTypeLabels('string:test', 'TestParam', {});
|
|
51
|
+
}).toThrow('Unable to create params outside of a Construct');
|
|
52
|
+
});
|
|
53
|
+
test('creates string parameter when paramBase starts with "string:"', () => {
|
|
54
|
+
// Arrange
|
|
55
|
+
const paramProps = { default: 'default-value' };
|
|
56
|
+
const testClass = new TestConfigTransformer();
|
|
57
|
+
// Act
|
|
58
|
+
const result = testClass.testCreateParamUsingTypeLabels('string:test', 'TestParam', paramProps);
|
|
59
|
+
// Assert
|
|
60
|
+
expect(aws_cdk_lib_1.CfnParameter).toHaveBeenCalledWith(testClass.scope, 'TestParam', { ...paramProps, type: 'String' });
|
|
61
|
+
expect(result).toBe('string-value');
|
|
62
|
+
});
|
|
63
|
+
test('creates number parameter when paramBase starts with "number"', () => {
|
|
64
|
+
// Arrange
|
|
65
|
+
const paramProps = { default: 42 };
|
|
66
|
+
const testClass = new TestConfigTransformer();
|
|
67
|
+
// Act
|
|
68
|
+
const result = testClass.testCreateParamUsingTypeLabels('number:test', 'TestParam', paramProps);
|
|
69
|
+
// Assert
|
|
70
|
+
expect(aws_cdk_lib_1.CfnParameter).toHaveBeenCalledWith(testClass.scope, 'TestParam', { ...paramProps, type: 'Number' });
|
|
71
|
+
expect(result).toBe(123);
|
|
72
|
+
});
|
|
73
|
+
test('creates list parameter when paramBase starts with "list"', () => {
|
|
74
|
+
const mockScope = {
|
|
75
|
+
node: {},
|
|
76
|
+
};
|
|
77
|
+
const testClass = new TestConfigTransformer({ scope: mockScope });
|
|
78
|
+
// Arrange
|
|
79
|
+
const paramProps = { default: 'item1,item2' };
|
|
80
|
+
// Act
|
|
81
|
+
const result = testClass.testCreateParamUsingTypeLabels('list:test', 'TestParam', paramProps);
|
|
82
|
+
// Assert
|
|
83
|
+
expect(aws_cdk_lib_1.CfnParameter).toHaveBeenCalledWith(testClass.scope, 'TestParam', {
|
|
84
|
+
...paramProps,
|
|
85
|
+
type: 'CommaDelimitedList',
|
|
86
|
+
});
|
|
87
|
+
expect(result).toBe('item1,item2');
|
|
88
|
+
});
|
|
89
|
+
test('creates default string parameter when no type prefix is provided', () => {
|
|
90
|
+
const testClass = new TestConfigTransformer();
|
|
91
|
+
// Arrange
|
|
92
|
+
const paramProps = { default: 'default-value' };
|
|
93
|
+
// Act
|
|
94
|
+
const result = testClass.testCreateParamUsingTypeLabels('test', 'TestParam', paramProps);
|
|
95
|
+
// Assert
|
|
96
|
+
expect(aws_cdk_lib_1.CfnParameter).toHaveBeenCalledWith(testClass.scope, 'TestParam', paramProps);
|
|
97
|
+
expect(result).toBe('string-value');
|
|
98
|
+
});
|
|
99
|
+
test('handles undefined paramProps', () => {
|
|
100
|
+
const testClass = new TestConfigTransformer();
|
|
101
|
+
// Act
|
|
102
|
+
const result = testClass.testCreateParamUsingTypeLabels('string:test', 'TestParam', undefined);
|
|
103
|
+
// Assert
|
|
104
|
+
expect(aws_cdk_lib_1.CfnParameter).toHaveBeenCalledWith(testClass.scope, 'TestParam', { type: 'String' });
|
|
105
|
+
expect(result).toBe('string-value');
|
|
106
|
+
});
|
|
107
|
+
test('uses paramProps type when no prefix provided', () => {
|
|
108
|
+
const testClass = new TestConfigTransformer();
|
|
109
|
+
// Arrange - paramProps has type, but paramBase has no prefix
|
|
110
|
+
const paramProps = { type: 'Number', default: 42 };
|
|
111
|
+
// Act
|
|
112
|
+
const result = testClass.testCreateParamUsingTypeLabels('test', 'TestParam', paramProps);
|
|
113
|
+
// Assert - Should use paramProps as-is (including the type)
|
|
114
|
+
expect(aws_cdk_lib_1.CfnParameter).toHaveBeenCalledWith(testClass.scope, 'TestParam', paramProps);
|
|
115
|
+
// But returns valueAsString because no prefix means default string behavior
|
|
116
|
+
expect(result).toBe('string-value');
|
|
117
|
+
});
|
|
118
|
+
test('prefix overrides paramProps type', () => {
|
|
119
|
+
const testClass = new TestConfigTransformer();
|
|
120
|
+
// Arrange - paramProps has type String, but prefix says number
|
|
121
|
+
const paramProps = { type: 'String', default: 'will-be-overridden' };
|
|
122
|
+
// Act
|
|
123
|
+
const result = testClass.testCreateParamUsingTypeLabels('number:test', 'TestParam', paramProps);
|
|
124
|
+
// Assert - Prefix wins, type is overridden to Number
|
|
125
|
+
expect(aws_cdk_lib_1.CfnParameter).toHaveBeenCalledWith(testClass.scope, 'TestParam', { ...paramProps, type: 'Number' });
|
|
126
|
+
expect(result).toBe(123);
|
|
127
|
+
});
|
|
128
|
+
});
|
|
129
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"config-nt.test.js","sourceRoot":"","sources":["config-nt.test.ts"],"names":[],"mappings":"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","sourcesContent":["/*!\n * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport { CfnParameter, CfnParameterProps } from 'aws-cdk-lib';\nimport { MdaaConfigParamRefValueTransformer, MdaaConfigParamRefValueTransformerProps } from '../lib';\nimport { Construct, Node } from 'constructs';\n\n/**\n * These tests cover all logic not directly related to the Transformers\n */\njest.mock('aws-cdk-lib', () => ({\n  CfnParameter: jest.fn().mockImplementation(() => ({\n    valueAsString: 'string-value',\n    valueAsNumber: 123,\n    valueAsList: ['item1', 'item2'],\n  })),\n  Stack: {\n    of: jest.fn().mockReturnValue({\n      partition: 'aws',\n      region: 'us-east-1',\n      account: '123456789012',\n    }),\n  },\n}));\ndescribe('Test createParamUsingTypeLabels', () => {\n  class TestConfigTransformer extends MdaaConfigParamRefValueTransformer {\n    public scope: Construct | undefined;\n\n    constructor(props?: MdaaConfigParamRefValueTransformerProps) {\n      props =\n        props ||\n        ({\n          scope: {\n            node: {} as Node,\n          } as Construct,\n        } as MdaaConfigParamRefValueTransformerProps);\n      super(props);\n      this.scope = props.scope;\n    }\n\n    public testCreateParamUsingTypeLabels(\n      paramBase: string,\n      paramName: string,\n      paramProps: CfnParameterProps | undefined,\n    ) {\n      return this.createParamUsingTypeLabels(paramBase, paramName, paramProps);\n    }\n  }\n\n  beforeEach(() => {\n    jest.clearAllMocks();\n  });\n\n  test('throws error when scope is not defined', () => {\n    const testClass = new TestConfigTransformer({} as unknown as MdaaConfigParamRefValueTransformerProps);\n    // Act & Assert\n    expect(() => {\n      testClass.testCreateParamUsingTypeLabels('string:test', 'TestParam', {});\n    }).toThrow('Unable to create params outside of a Construct');\n  });\n\n  test('creates string parameter when paramBase starts with \"string:\"', () => {\n    // Arrange\n    const paramProps = { default: 'default-value' };\n    const testClass = new TestConfigTransformer();\n\n    // Act\n    const result = testClass.testCreateParamUsingTypeLabels('string:test', 'TestParam', paramProps);\n\n    // Assert\n    expect(CfnParameter).toHaveBeenCalledWith(testClass.scope, 'TestParam', { ...paramProps, type: 'String' });\n    expect(result).toBe('string-value');\n  });\n\n  test('creates number parameter when paramBase starts with \"number\"', () => {\n    // Arrange\n    const paramProps = { default: 42 };\n    const testClass = new TestConfigTransformer();\n\n    // Act\n    const result = testClass.testCreateParamUsingTypeLabels('number:test', 'TestParam', paramProps);\n\n    // Assert\n    expect(CfnParameter).toHaveBeenCalledWith(testClass.scope, 'TestParam', { ...paramProps, type: 'Number' });\n    expect(result).toBe(123);\n  });\n\n  test('creates list parameter when paramBase starts with \"list\"', () => {\n    const mockScope = {\n      node: {} as Node,\n    };\n    const testClass = new TestConfigTransformer({ scope: mockScope } as MdaaConfigParamRefValueTransformerProps);\n\n    // Arrange\n    const paramProps = { default: 'item1,item2' };\n\n    // Act\n    const result = testClass.testCreateParamUsingTypeLabels('list:test', 'TestParam', paramProps);\n\n    // Assert\n    expect(CfnParameter).toHaveBeenCalledWith(testClass.scope, 'TestParam', {\n      ...paramProps,\n      type: 'CommaDelimitedList',\n    });\n    expect(result).toBe('item1,item2');\n  });\n\n  test('creates default string parameter when no type prefix is provided', () => {\n    const testClass = new TestConfigTransformer();\n\n    // Arrange\n    const paramProps = { default: 'default-value' };\n\n    // Act\n    const result = testClass.testCreateParamUsingTypeLabels('test', 'TestParam', paramProps);\n\n    // Assert\n    expect(CfnParameter).toHaveBeenCalledWith(testClass.scope, 'TestParam', paramProps);\n    expect(result).toBe('string-value');\n  });\n\n  test('handles undefined paramProps', () => {\n    const testClass = new TestConfigTransformer();\n\n    // Act\n    const result = testClass.testCreateParamUsingTypeLabels('string:test', 'TestParam', undefined);\n\n    // Assert\n    expect(CfnParameter).toHaveBeenCalledWith(testClass.scope, 'TestParam', { type: 'String' });\n    expect(result).toBe('string-value');\n  });\n\n  test('uses paramProps type when no prefix provided', () => {\n    const testClass = new TestConfigTransformer();\n\n    // Arrange - paramProps has type, but paramBase has no prefix\n    const paramProps = { type: 'Number', default: 42 };\n\n    // Act\n    const result = testClass.testCreateParamUsingTypeLabels('test', 'TestParam', paramProps);\n\n    // Assert - Should use paramProps as-is (including the type)\n    expect(CfnParameter).toHaveBeenCalledWith(testClass.scope, 'TestParam', paramProps);\n    // But returns valueAsString because no prefix means default string behavior\n    expect(result).toBe('string-value');\n  });\n\n  test('prefix overrides paramProps type', () => {\n    const testClass = new TestConfigTransformer();\n\n    // Arrange - paramProps has type String, but prefix says number\n    const paramProps = { type: 'String', default: 'will-be-overridden' };\n\n    // Act\n    const result = testClass.testCreateParamUsingTypeLabels('number:test', 'TestParam', paramProps);\n\n    // Assert - Prefix wins, type is overridden to Number\n    expect(CfnParameter).toHaveBeenCalledWith(testClass.scope, 'TestParam', { ...paramProps, type: 'Number' });\n    expect(result).toBe(123);\n  });\n});\n"]}
|
|
@@ -0,0 +1,163 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
|
|
3
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
import { CfnParameter, CfnParameterProps } from 'aws-cdk-lib';
|
|
7
|
+
import { MdaaConfigParamRefValueTransformer, MdaaConfigParamRefValueTransformerProps } from '../lib';
|
|
8
|
+
import { Construct, Node } from 'constructs';
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* These tests cover all logic not directly related to the Transformers
|
|
12
|
+
*/
|
|
13
|
+
jest.mock('aws-cdk-lib', () => ({
|
|
14
|
+
CfnParameter: jest.fn().mockImplementation(() => ({
|
|
15
|
+
valueAsString: 'string-value',
|
|
16
|
+
valueAsNumber: 123,
|
|
17
|
+
valueAsList: ['item1', 'item2'],
|
|
18
|
+
})),
|
|
19
|
+
Stack: {
|
|
20
|
+
of: jest.fn().mockReturnValue({
|
|
21
|
+
partition: 'aws',
|
|
22
|
+
region: 'us-east-1',
|
|
23
|
+
account: '123456789012',
|
|
24
|
+
}),
|
|
25
|
+
},
|
|
26
|
+
}));
|
|
27
|
+
describe('Test createParamUsingTypeLabels', () => {
|
|
28
|
+
class TestConfigTransformer extends MdaaConfigParamRefValueTransformer {
|
|
29
|
+
public scope: Construct | undefined;
|
|
30
|
+
|
|
31
|
+
constructor(props?: MdaaConfigParamRefValueTransformerProps) {
|
|
32
|
+
props =
|
|
33
|
+
props ||
|
|
34
|
+
({
|
|
35
|
+
scope: {
|
|
36
|
+
node: {} as Node,
|
|
37
|
+
} as Construct,
|
|
38
|
+
} as MdaaConfigParamRefValueTransformerProps);
|
|
39
|
+
super(props);
|
|
40
|
+
this.scope = props.scope;
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
public testCreateParamUsingTypeLabels(
|
|
44
|
+
paramBase: string,
|
|
45
|
+
paramName: string,
|
|
46
|
+
paramProps: CfnParameterProps | undefined,
|
|
47
|
+
) {
|
|
48
|
+
return this.createParamUsingTypeLabels(paramBase, paramName, paramProps);
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
beforeEach(() => {
|
|
53
|
+
jest.clearAllMocks();
|
|
54
|
+
});
|
|
55
|
+
|
|
56
|
+
test('throws error when scope is not defined', () => {
|
|
57
|
+
const testClass = new TestConfigTransformer({} as unknown as MdaaConfigParamRefValueTransformerProps);
|
|
58
|
+
// Act & Assert
|
|
59
|
+
expect(() => {
|
|
60
|
+
testClass.testCreateParamUsingTypeLabels('string:test', 'TestParam', {});
|
|
61
|
+
}).toThrow('Unable to create params outside of a Construct');
|
|
62
|
+
});
|
|
63
|
+
|
|
64
|
+
test('creates string parameter when paramBase starts with "string:"', () => {
|
|
65
|
+
// Arrange
|
|
66
|
+
const paramProps = { default: 'default-value' };
|
|
67
|
+
const testClass = new TestConfigTransformer();
|
|
68
|
+
|
|
69
|
+
// Act
|
|
70
|
+
const result = testClass.testCreateParamUsingTypeLabels('string:test', 'TestParam', paramProps);
|
|
71
|
+
|
|
72
|
+
// Assert
|
|
73
|
+
expect(CfnParameter).toHaveBeenCalledWith(testClass.scope, 'TestParam', { ...paramProps, type: 'String' });
|
|
74
|
+
expect(result).toBe('string-value');
|
|
75
|
+
});
|
|
76
|
+
|
|
77
|
+
test('creates number parameter when paramBase starts with "number"', () => {
|
|
78
|
+
// Arrange
|
|
79
|
+
const paramProps = { default: 42 };
|
|
80
|
+
const testClass = new TestConfigTransformer();
|
|
81
|
+
|
|
82
|
+
// Act
|
|
83
|
+
const result = testClass.testCreateParamUsingTypeLabels('number:test', 'TestParam', paramProps);
|
|
84
|
+
|
|
85
|
+
// Assert
|
|
86
|
+
expect(CfnParameter).toHaveBeenCalledWith(testClass.scope, 'TestParam', { ...paramProps, type: 'Number' });
|
|
87
|
+
expect(result).toBe(123);
|
|
88
|
+
});
|
|
89
|
+
|
|
90
|
+
test('creates list parameter when paramBase starts with "list"', () => {
|
|
91
|
+
const mockScope = {
|
|
92
|
+
node: {} as Node,
|
|
93
|
+
};
|
|
94
|
+
const testClass = new TestConfigTransformer({ scope: mockScope } as MdaaConfigParamRefValueTransformerProps);
|
|
95
|
+
|
|
96
|
+
// Arrange
|
|
97
|
+
const paramProps = { default: 'item1,item2' };
|
|
98
|
+
|
|
99
|
+
// Act
|
|
100
|
+
const result = testClass.testCreateParamUsingTypeLabels('list:test', 'TestParam', paramProps);
|
|
101
|
+
|
|
102
|
+
// Assert
|
|
103
|
+
expect(CfnParameter).toHaveBeenCalledWith(testClass.scope, 'TestParam', {
|
|
104
|
+
...paramProps,
|
|
105
|
+
type: 'CommaDelimitedList',
|
|
106
|
+
});
|
|
107
|
+
expect(result).toBe('item1,item2');
|
|
108
|
+
});
|
|
109
|
+
|
|
110
|
+
test('creates default string parameter when no type prefix is provided', () => {
|
|
111
|
+
const testClass = new TestConfigTransformer();
|
|
112
|
+
|
|
113
|
+
// Arrange
|
|
114
|
+
const paramProps = { default: 'default-value' };
|
|
115
|
+
|
|
116
|
+
// Act
|
|
117
|
+
const result = testClass.testCreateParamUsingTypeLabels('test', 'TestParam', paramProps);
|
|
118
|
+
|
|
119
|
+
// Assert
|
|
120
|
+
expect(CfnParameter).toHaveBeenCalledWith(testClass.scope, 'TestParam', paramProps);
|
|
121
|
+
expect(result).toBe('string-value');
|
|
122
|
+
});
|
|
123
|
+
|
|
124
|
+
test('handles undefined paramProps', () => {
|
|
125
|
+
const testClass = new TestConfigTransformer();
|
|
126
|
+
|
|
127
|
+
// Act
|
|
128
|
+
const result = testClass.testCreateParamUsingTypeLabels('string:test', 'TestParam', undefined);
|
|
129
|
+
|
|
130
|
+
// Assert
|
|
131
|
+
expect(CfnParameter).toHaveBeenCalledWith(testClass.scope, 'TestParam', { type: 'String' });
|
|
132
|
+
expect(result).toBe('string-value');
|
|
133
|
+
});
|
|
134
|
+
|
|
135
|
+
test('uses paramProps type when no prefix provided', () => {
|
|
136
|
+
const testClass = new TestConfigTransformer();
|
|
137
|
+
|
|
138
|
+
// Arrange - paramProps has type, but paramBase has no prefix
|
|
139
|
+
const paramProps = { type: 'Number', default: 42 };
|
|
140
|
+
|
|
141
|
+
// Act
|
|
142
|
+
const result = testClass.testCreateParamUsingTypeLabels('test', 'TestParam', paramProps);
|
|
143
|
+
|
|
144
|
+
// Assert - Should use paramProps as-is (including the type)
|
|
145
|
+
expect(CfnParameter).toHaveBeenCalledWith(testClass.scope, 'TestParam', paramProps);
|
|
146
|
+
// But returns valueAsString because no prefix means default string behavior
|
|
147
|
+
expect(result).toBe('string-value');
|
|
148
|
+
});
|
|
149
|
+
|
|
150
|
+
test('prefix overrides paramProps type', () => {
|
|
151
|
+
const testClass = new TestConfigTransformer();
|
|
152
|
+
|
|
153
|
+
// Arrange - paramProps has type String, but prefix says number
|
|
154
|
+
const paramProps = { type: 'String', default: 'will-be-overridden' };
|
|
155
|
+
|
|
156
|
+
// Act
|
|
157
|
+
const result = testClass.testCreateParamUsingTypeLabels('number:test', 'TestParam', paramProps);
|
|
158
|
+
|
|
159
|
+
// Assert - Prefix wins, type is overridden to Number
|
|
160
|
+
expect(CfnParameter).toHaveBeenCalledWith(testClass.scope, 'TestParam', { ...paramProps, type: 'Number' });
|
|
161
|
+
expect(result).toBe(123);
|
|
162
|
+
});
|
|
163
|
+
});
|