@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.
Files changed (90) hide show
  1. package/.jsii +38 -28
  2. package/README.md +5 -0
  3. package/lib/dataops-job-l3-construct.d.ts +8 -1
  4. package/lib/dataops-job-l3-construct.js +40 -13
  5. package/node_modules/@aws-mdaa/config/README.md +3 -0
  6. package/node_modules/@aws-mdaa/config/lib/blueprint-value-transformer.d.ts +20 -0
  7. package/node_modules/@aws-mdaa/config/lib/blueprint-value-transformer.js +70 -0
  8. package/node_modules/@aws-mdaa/config/lib/blueprint-value-transformer.ts +88 -0
  9. package/node_modules/@aws-mdaa/config/lib/config.d.ts +87 -0
  10. package/node_modules/@aws-mdaa/config/lib/config.js +7 -0
  11. package/node_modules/@aws-mdaa/config/lib/config.ts +92 -0
  12. package/node_modules/@aws-mdaa/config/lib/index.d.ts +11 -0
  13. package/node_modules/@aws-mdaa/config/lib/index.js +28 -0
  14. package/node_modules/@aws-mdaa/config/lib/index.ts +12 -0
  15. package/node_modules/@aws-mdaa/config/lib/param-transformer.d.ts +49 -0
  16. package/node_modules/@aws-mdaa/config/lib/param-transformer.js +160 -0
  17. package/node_modules/@aws-mdaa/config/lib/param-transformer.ts +159 -0
  18. package/node_modules/@aws-mdaa/config/lib/path-value-transformer.d.ts +10 -0
  19. package/node_modules/@aws-mdaa/config/lib/path-value-transformer.js +30 -0
  20. package/node_modules/@aws-mdaa/config/lib/path-value-transformer.ts +27 -0
  21. package/node_modules/@aws-mdaa/config/lib/ref-value-transformer.d.ts +44 -0
  22. package/node_modules/@aws-mdaa/config/lib/ref-value-transformer.js +243 -0
  23. package/node_modules/@aws-mdaa/config/lib/ref-value-transformer.ts +302 -0
  24. package/node_modules/@aws-mdaa/config/lib/ssm-ref-transformer.d.ts +8 -0
  25. package/node_modules/@aws-mdaa/config/lib/ssm-ref-transformer.js +22 -0
  26. package/node_modules/@aws-mdaa/config/lib/ssm-ref-transformer.ts +21 -0
  27. package/node_modules/@aws-mdaa/config/lib/transformer.d.ts +35 -0
  28. package/node_modules/@aws-mdaa/config/lib/transformer.js +66 -0
  29. package/node_modules/@aws-mdaa/config/lib/transformer.ts +74 -0
  30. package/node_modules/@aws-mdaa/config/package.json +42 -0
  31. package/node_modules/@aws-mdaa/config/test/blueprint-value-transformer.test.js +224 -0
  32. package/node_modules/@aws-mdaa/config/test/blueprint-value-transformer.test.ts +259 -0
  33. package/node_modules/@aws-mdaa/config/test/config-nt.test.d.ts +5 -0
  34. package/node_modules/@aws-mdaa/config/test/config-nt.test.js +129 -0
  35. package/node_modules/@aws-mdaa/config/test/config-nt.test.ts +163 -0
  36. package/node_modules/@aws-mdaa/config/test/config.test.d.ts +5 -0
  37. package/node_modules/@aws-mdaa/config/test/config.test.js +409 -0
  38. package/node_modules/@aws-mdaa/config/test/config.test.ts +517 -0
  39. package/node_modules/@aws-mdaa/config/test/param-transformer.test.d.ts +5 -0
  40. package/node_modules/@aws-mdaa/config/test/param-transformer.test.js +216 -0
  41. package/node_modules/@aws-mdaa/config/test/param-transformer.test.ts +234 -0
  42. package/node_modules/@aws-mdaa/config/test/path-value-transformer.test.d.ts +5 -0
  43. package/node_modules/@aws-mdaa/config/test/path-value-transformer.test.js +59 -0
  44. package/node_modules/@aws-mdaa/config/test/path-value-transformer.test.ts +68 -0
  45. package/node_modules/@aws-mdaa/config/test/ref-value-transformer.test.d.ts +5 -0
  46. package/node_modules/@aws-mdaa/config/test/ref-value-transformer.test.js +254 -0
  47. package/node_modules/@aws-mdaa/config/test/ref-value-transformer.test.ts +304 -0
  48. package/node_modules/@aws-mdaa/config/test/ssm-ref-transformer.test.d.ts +5 -0
  49. package/node_modules/@aws-mdaa/config/test/ssm-ref-transformer.test.js +66 -0
  50. package/node_modules/@aws-mdaa/config/test/ssm-ref-transformer.test.ts +79 -0
  51. package/node_modules/@aws-mdaa/config/tsconfig.tsbuildinfo +1 -0
  52. package/node_modules/lodash/README.md +2 -2
  53. package/node_modules/lodash/_baseOrderBy.js +1 -1
  54. package/node_modules/lodash/_baseUnset.js +7 -20
  55. package/node_modules/lodash/_setCacheHas.js +1 -1
  56. package/node_modules/lodash/compact.js +1 -1
  57. package/node_modules/lodash/core.js +3 -3
  58. package/node_modules/lodash/core.min.js +26 -25
  59. package/node_modules/lodash/fromPairs.js +3 -1
  60. package/node_modules/lodash/lodash.js +38 -27
  61. package/node_modules/lodash/lodash.min.js +125 -129
  62. package/node_modules/lodash/package.json +4 -2
  63. package/node_modules/lodash/random.js +9 -0
  64. package/node_modules/lodash/template.js +16 -4
  65. package/node_modules/lodash/templateSettings.js +4 -0
  66. package/package.json +27 -32
  67. package/node_modules/@aws-mdaa/s3-bucketpolicy-helper/README.md +0 -185
  68. package/node_modules/@aws-mdaa/s3-bucketpolicy-helper/lib/index.d.ts +0 -57
  69. package/node_modules/@aws-mdaa/s3-bucketpolicy-helper/lib/index.js +0 -198
  70. package/node_modules/@aws-mdaa/s3-bucketpolicy-helper/lib/index.ts +0 -241
  71. package/node_modules/@aws-mdaa/s3-bucketpolicy-helper/package.json +0 -44
  72. package/node_modules/@aws-mdaa/s3-bucketpolicy-helper/test/bucketpolicy-helper.test.js +0 -200
  73. package/node_modules/@aws-mdaa/s3-bucketpolicy-helper/test/bucketpolicy-helper.test.ts +0 -215
  74. package/node_modules/@aws-mdaa/s3-bucketpolicy-helper/tsconfig.tsbuildinfo +0 -1
  75. package/node_modules/@aws-mdaa/s3-inventory-helper/.npmignore +0 -34
  76. package/node_modules/@aws-mdaa/s3-inventory-helper/README.md +0 -3
  77. package/node_modules/@aws-mdaa/s3-inventory-helper/jest.config.js +0 -5
  78. package/node_modules/@aws-mdaa/s3-inventory-helper/lib/index.d.ts +0 -48
  79. package/node_modules/@aws-mdaa/s3-inventory-helper/lib/index.js +0 -213
  80. package/node_modules/@aws-mdaa/s3-inventory-helper/lib/index.ts +0 -241
  81. package/node_modules/@aws-mdaa/s3-inventory-helper/package.json +0 -44
  82. package/node_modules/@aws-mdaa/s3-inventory-helper/test/TODO +0 -0
  83. package/node_modules/@aws-mdaa/s3-inventory-helper/tsconfig.json +0 -40
  84. package/node_modules/@aws-mdaa/s3-inventory-helper/tsconfig.tsbuildinfo +0 -1
  85. package/node_modules/@aws-mdaa/s3-inventory-helper/typedoc.json +0 -7
  86. /package/node_modules/@aws-mdaa/{s3-bucketpolicy-helper → config}/.npmignore +0 -0
  87. /package/node_modules/@aws-mdaa/{s3-bucketpolicy-helper → config}/jest.config.js +0 -0
  88. /package/node_modules/@aws-mdaa/{s3-bucketpolicy-helper/test/bucketpolicy-helper.test.d.ts → config/test/blueprint-value-transformer.test.d.ts} +0 -0
  89. /package/node_modules/@aws-mdaa/{s3-bucketpolicy-helper → config}/tsconfig.json +0 -0
  90. /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
+ });
@@ -0,0 +1,5 @@
1
+ /*!
2
+ * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
3
+ * SPDX-License-Identifier: Apache-2.0
4
+ */
5
+ export {};