UNPKG

@aws-solutions-constructs/core

Version:
285 lines 26.4 kB
"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"]}