@aws-solutions-constructs/core
Version:
Core CDK Construct for patterns library
285 lines • 26.4 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 process = require("process");
const override_warning_service_1 = require("../lib/override-warning-service");
const __1 = require("../");
// Mock setup
beforeEach(() => {
jest.resetModules();
jest.clearAllMocks();
delete process.env.overrideWarningsEnabled;
});
test('Test override detection: positive, not-nested', () => {
// Arrange
const a = {
keyA: 'valueA',
keyB: 'valueB',
keyC: 'valueC'
};
const b = {
keyA: 'new-valueA',
keyD: 'valueD'
};
// Act
const consoleLogSpy = jest.spyOn(console, 'log');
(0, override_warning_service_1.flagOverriddenDefaults)(a, b);
// Assert
expect(consoleLogSpy).toBeCalledTimes(1);
});
test('Test override detection: negative, not-nested', () => {
// Arrange
const a = {
keyA: 'valueA',
keyB: 'valueB',
keyC: 'valueC'
};
const b = {
keyD: 'valueD'
};
// Act
const consoleLogSpy = jest.spyOn(console, 'log');
(0, override_warning_service_1.flagOverriddenDefaults)(a, b);
// Assert
expect(consoleLogSpy).toBeCalledTimes(0);
});
test('Test override detection: positive, nested', () => {
// Arrange
const a = {
keyA: 'valueA',
keyB: 'valueB',
keyC: 'valueC',
keyD: {
keyDA: 'valueDA',
keyDB: 'valueDB'
}
};
const b = {
keyC: 'valueCAnew',
keyD: {
keyDA: 'valueDAnew'
}
};
// Act
const consoleLogSpy = jest.spyOn(console, 'log');
(0, override_warning_service_1.flagOverriddenDefaults)(a, b);
// Assert
expect(consoleLogSpy).toBeCalledTimes(2);
});
test('Test override detection: negative, nested', () => {
// Arrange
const a = {
keyA: 'valueA',
keyB: 'valueB',
keyC: 'valueC',
keyD: {
keyDA: 'valueDA',
keyDB: 'valueDB'
}
};
const b = {
keyD: {
keyDA: 'valueDA'
}
};
// Act
const consoleLogSpy = jest.spyOn(console, 'log');
(0, override_warning_service_1.flagOverriddenDefaults)(a, b);
// Assert
expect(consoleLogSpy).toBeCalledTimes(0);
});
test('Test override warning on/off: default on', () => {
// Arrange
const a = {
keyA: 'valueA',
keyB: 'valueB',
keyC: 'valueC'
};
const b = {
keyA: 'new-valueA',
keyD: 'valueD'
};
// Act
const consoleLogSpy = jest.spyOn(console, 'log');
(0, __1.overrideProps)(a, b);
// Assert
expect(consoleLogSpy).toBeCalledTimes(1);
});
test('Test override warning on/off: explicit on', () => {
// Arrange
const a = {
keyA: 'valueA',
keyB: 'valueB',
keyC: 'valueC'
};
const b = {
keyA: 'new-valueA',
keyD: 'valueD'
};
process.env.overrideWarningsEnabled = 'true';
// Act
const consoleLogSpy = jest.spyOn(console, 'log');
(0, __1.overrideProps)(a, b);
// Assert
expect(consoleLogSpy).toBeCalledTimes(1);
});
test('Test override warning on/off: explicit off', () => {
// Arrange
const a = {
keyA: 'valueA',
keyB: 'valueB',
keyC: 'valueC'
};
const b = {
keyA: 'new-valueA',
keyD: 'valueD'
};
// Act
const consoleLogSpy = jest.spyOn(console, 'log');
process.env.overrideWarningsEnabled = 'false';
const result = (0, __1.overrideProps)(a, b);
// Assert
expect(consoleLogSpy).toBeCalledTimes(0);
expect(result).toEqual({
keyA: 'new-valueA',
keyB: 'valueB',
keyC: 'valueC',
keyD: 'valueD'
});
});
test('Test override warning on/off: undefined on', () => {
// Arrange
const a = {
keyA: 'valueA',
keyB: 'valueB',
keyC: 'valueC'
};
const b = {
keyA: 'new-valueA',
keyD: 'valueD'
};
// Act
const consoleLogSpy = jest.spyOn(console, 'log');
process.env.overrideWarningsEnabled = undefined;
const result = (0, __1.overrideProps)(a, b);
// Assert
expect(consoleLogSpy).toBeCalledTimes(1);
expect(result).toEqual({
keyA: 'new-valueA',
keyB: 'valueB',
keyC: 'valueC',
keyD: 'valueD'
});
});
test('Test current prefilters', () => {
// Arrange
const a = {
destination: 'sampleDestinationValueA',
maxRecordAge: 'sampleMaxRecordAgeValueA',
expiration: 'sampleExpirationValueA',
transitionAfter: 'sampleTransitionValueA',
timeout: 'sampleTimeoutValueA',
period: 'samplePeriodValueA',
node: 'sampleNodeA'
};
const b = {
destination: 'sampleDestinationValueB',
maxRecordAge: 'sampleMaxRecordAgeValueB',
expiration: 'sampleExpirationValueB',
transitionAfter: 'sampleTransitionValueB',
timeout: 'sampleTimeoutValueB',
period: 'samplePeriodValueA',
node: 'sampleNodeA'
};
// Act
const consoleLogSpy = jest.spyOn(console, 'log');
process.env.overrideWarningsEnabled = undefined;
const result = (0, __1.overrideProps)(a, b);
// Assert
expect(consoleLogSpy).toBeCalledTimes(6);
expect(result).toEqual({
destination: 'sampleDestinationValueB',
maxRecordAge: 'sampleMaxRecordAgeValueB',
expiration: 'sampleExpirationValueB',
transitionAfter: 'sampleTransitionValueB',
timeout: 'sampleTimeoutValueB',
period: 'samplePeriodValueA',
node: 'sampleNodeA'
});
});
test('Test overrideProps with warnings disabled in argument', () => {
process.env.overrideWarningsEnabled = 'true';
const a = {
keyA: 'valueA',
keyB: 'valueB',
keyC: 'valueC'
};
const b = {
keyA: 'new-valueA',
keyD: 'valueD'
};
// Act
const consoleLogSpy = jest.spyOn(console, 'log');
(0, __1.overrideProps)(a, b, undefined, true);
// Assert
expect(consoleLogSpy).toBeCalledTimes(0);
});
test('Test overrideProps with deep arguments', () => {
const a = {
keyA: 'valueA',
keyB: 'valueB',
keyC: {
keyCA: 'valueCA',
keyCB: 'valueCB'
},
keyD: 'valueD'
};
const b = {
keyA: 'new-valueA',
keyB: 'valueB',
keyC: {
keyCA: 'valueCANew',
},
keyD: {
keyDA: 'valueDANew',
keyDB: 'valueDBNew'
}
};
// Act
const consoleLogSpy = jest.spyOn(console, 'log');
(0, __1.overrideProps)(a, b);
// Assert
expect(consoleLogSpy).toBeCalledTimes(3);
});
test('Confirm node stops circular reference traversal', () => {
// Arrange
const a = {
keyA: 'valueA',
keyB: 'valueB',
keyC: 'valueC'
};
const b = {
keyA: 'new-valueA',
keyD: 'valueD',
keyE: {
node: {}
}
};
b.keyE.node = b;
const consoleLogSpy = jest.spyOn(console, 'log');
(0, override_warning_service_1.flagOverriddenDefaults)(a, b);
// Assert
expect(consoleLogSpy).toBeCalledTimes(1);
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"override-warning-service.test.js","sourceRoot":"","sources":["override-warning-service.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 * as process from 'process';\nimport { flagOverriddenDefaults } from '../lib/override-warning-service';\nimport { overrideProps } from '../';\n\n// Mock setup\nbeforeEach(() => {\n  jest.resetModules();\n  jest.clearAllMocks();\n  delete process.env.overrideWarningsEnabled;\n});\n\ntest('Test override detection: positive, not-nested', () => {\n  // Arrange\n  const a = {\n    keyA: 'valueA',\n    keyB: 'valueB',\n    keyC: 'valueC'\n  };\n  const b = {\n    keyA: 'new-valueA',\n    keyD: 'valueD'\n  };\n  // Act\n  const consoleLogSpy = jest.spyOn(console, 'log');\n  flagOverriddenDefaults(a, b);\n  // Assert\n  expect(consoleLogSpy).toBeCalledTimes(1);\n});\n\ntest('Test override detection: negative, not-nested', () => {\n  // Arrange\n  const a = {\n    keyA: 'valueA',\n    keyB: 'valueB',\n    keyC: 'valueC'\n  };\n  const b = {\n    keyD: 'valueD'\n  };\n  // Act\n  const consoleLogSpy = jest.spyOn(console, 'log');\n  flagOverriddenDefaults(a, b);\n  // Assert\n  expect(consoleLogSpy).toBeCalledTimes(0);\n});\n\ntest('Test override detection: positive, nested', () => {\n  // Arrange\n  const a = {\n    keyA: 'valueA',\n    keyB: 'valueB',\n    keyC: 'valueC',\n    keyD: {\n      keyDA: 'valueDA',\n      keyDB: 'valueDB'\n    }\n  };\n  const b = {\n    keyC: 'valueCAnew',\n    keyD: {\n      keyDA: 'valueDAnew'\n    }\n  };\n  // Act\n  const consoleLogSpy = jest.spyOn(console, 'log');\n  flagOverriddenDefaults(a, b);\n  // Assert\n  expect(consoleLogSpy).toBeCalledTimes(2);\n});\n\ntest('Test override detection: negative, nested', () => {\n  // Arrange\n  const a = {\n    keyA: 'valueA',\n    keyB: 'valueB',\n    keyC: 'valueC',\n    keyD: {\n      keyDA: 'valueDA',\n      keyDB: 'valueDB'\n    }\n  };\n  const b = {\n    keyD: {\n      keyDA: 'valueDA'\n    }\n  };\n  // Act\n  const consoleLogSpy = jest.spyOn(console, 'log');\n  flagOverriddenDefaults(a, b);\n  // Assert\n  expect(consoleLogSpy).toBeCalledTimes(0);\n});\n\ntest('Test override warning on/off: default on', () => {\n  // Arrange\n  const a = {\n    keyA: 'valueA',\n    keyB: 'valueB',\n    keyC: 'valueC'\n  };\n  const b = {\n    keyA: 'new-valueA',\n    keyD: 'valueD'\n  };\n  // Act\n  const consoleLogSpy = jest.spyOn(console, 'log');\n  overrideProps(a, b);\n  // Assert\n  expect(consoleLogSpy).toBeCalledTimes(1);\n});\n\ntest('Test override warning on/off: explicit on', () => {\n  // Arrange\n  const a = {\n    keyA: 'valueA',\n    keyB: 'valueB',\n    keyC: 'valueC'\n  };\n  const b = {\n    keyA: 'new-valueA',\n    keyD: 'valueD'\n  };\n  process.env.overrideWarningsEnabled = 'true';\n  // Act\n  const consoleLogSpy = jest.spyOn(console, 'log');\n  overrideProps(a, b);\n  // Assert\n  expect(consoleLogSpy).toBeCalledTimes(1);\n});\n\ntest('Test override warning on/off: explicit off', () => {\n  // Arrange\n  const a = {\n    keyA: 'valueA',\n    keyB: 'valueB',\n    keyC: 'valueC'\n  };\n  const b = {\n    keyA: 'new-valueA',\n    keyD: 'valueD'\n  };\n  // Act\n  const consoleLogSpy = jest.spyOn(console, 'log');\n  process.env.overrideWarningsEnabled = 'false';\n  const result = overrideProps(a, b);\n  // Assert\n  expect(consoleLogSpy).toBeCalledTimes(0);\n\n  expect(result).toEqual({\n    keyA: 'new-valueA',\n    keyB: 'valueB',\n    keyC: 'valueC',\n    keyD: 'valueD'\n  });\n\n});\n\ntest('Test override warning on/off: undefined on', () => {\n  // Arrange\n  const a = {\n    keyA: 'valueA',\n    keyB: 'valueB',\n    keyC: 'valueC'\n  };\n  const b = {\n    keyA: 'new-valueA',\n    keyD: 'valueD'\n  };\n  // Act\n  const consoleLogSpy = jest.spyOn(console, 'log');\n  process.env.overrideWarningsEnabled = undefined;\n  const result = overrideProps(a, b);\n  // Assert\n  expect(consoleLogSpy).toBeCalledTimes(1);\n\n  expect(result).toEqual({\n    keyA: 'new-valueA',\n    keyB: 'valueB',\n    keyC: 'valueC',\n    keyD: 'valueD'\n  });\n\n});\n\ntest('Test current prefilters', () => {\n  // Arrange\n  const a = {\n    destination: 'sampleDestinationValueA',\n    maxRecordAge: 'sampleMaxRecordAgeValueA',\n    expiration: 'sampleExpirationValueA',\n    transitionAfter: 'sampleTransitionValueA',\n    timeout: 'sampleTimeoutValueA',\n    period: 'samplePeriodValueA',\n    node: 'sampleNodeA'\n  };\n  const b = {\n    destination: 'sampleDestinationValueB',\n    maxRecordAge: 'sampleMaxRecordAgeValueB',\n    expiration: 'sampleExpirationValueB',\n    transitionAfter: 'sampleTransitionValueB',\n    timeout: 'sampleTimeoutValueB',\n    period: 'samplePeriodValueA',\n    node: 'sampleNodeA'\n  };\n  // Act\n  const consoleLogSpy = jest.spyOn(console, 'log');\n  process.env.overrideWarningsEnabled = undefined;\n  const result = overrideProps(a, b);\n  // Assert\n  expect(consoleLogSpy).toBeCalledTimes(6);\n  expect(result).toEqual({\n    destination: 'sampleDestinationValueB',\n    maxRecordAge: 'sampleMaxRecordAgeValueB',\n    expiration: 'sampleExpirationValueB',\n    transitionAfter: 'sampleTransitionValueB',\n    timeout: 'sampleTimeoutValueB',\n    period: 'samplePeriodValueA',\n    node: 'sampleNodeA'\n  });\n});\n\ntest('Test overrideProps with warnings disabled in argument', () => {\n  process.env.overrideWarningsEnabled = 'true';\n  const a = {\n    keyA: 'valueA',\n    keyB: 'valueB',\n    keyC: 'valueC'\n  };\n  const b = {\n    keyA: 'new-valueA',\n    keyD: 'valueD'\n  };\n  // Act\n  const consoleLogSpy = jest.spyOn(console, 'log');\n  overrideProps(a, b, undefined, true);\n  // Assert\n  expect(consoleLogSpy).toBeCalledTimes(0);\n\n});\n\ntest('Test overrideProps with deep arguments', () => {\n  const a = {\n    keyA: 'valueA',\n    keyB: 'valueB',\n    keyC: {\n      keyCA: 'valueCA',\n      keyCB: 'valueCB'\n    },\n    keyD: 'valueD'\n  };\n  const b = {\n    keyA: 'new-valueA',\n    keyB: 'valueB',\n    keyC: {\n      keyCA: 'valueCANew',\n    },\n    keyD: {\n      keyDA: 'valueDANew',\n      keyDB: 'valueDBNew'\n    }\n  };\n  // Act\n  const consoleLogSpy = jest.spyOn(console, 'log');\n  overrideProps(a, b);\n  // Assert\n  expect(consoleLogSpy).toBeCalledTimes(3);\n});\n\ntest('Confirm node stops circular reference traversal', () => {\n  // Arrange\n  const a = {\n    keyA: 'valueA',\n    keyB: 'valueB',\n    keyC: 'valueC'\n  };\n  const b = {\n    keyA: 'new-valueA',\n    keyD: 'valueD',\n    keyE: {\n      node: {}\n    }\n  };\n  b.keyE.node = b;\n\n  const consoleLogSpy = jest.spyOn(console, 'log');\n  flagOverriddenDefaults(a, b);\n  // Assert\n  expect(consoleLogSpy).toBeCalledTimes(1);\n});\n"]}