@aws-cdk/integ-runner
Version:
CDK Integration Testing Tool
192 lines • 24.2 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", { value: true });
exports.integTestWorker = integTestWorker;
exports.watchTestWorker = watchTestWorker;
exports.snapshotTestWorker = snapshotTestWorker;
const workerpool = require("workerpool");
const runner_1 = require("../../runner");
const integration_tests_1 = require("../../runner/integration-tests");
const common_1 = require("../common");
/**
* Runs a single integration test batch request.
* If the test does not have an existing snapshot,
* this will first generate a snapshot and then execute
* the integration tests.
*
* If the tests succeed it will then save the snapshot
*/
async function integTestWorker(request) {
const failures = [];
const verbosity = request.verbosity ?? 0;
for (const testInfo of request.tests) {
const test = new integration_tests_1.IntegTest({
...testInfo,
watch: request.watch,
}); // Hydrate from data
const start = Date.now();
try {
const runner = new runner_1.IntegTestRunner({
test,
profile: request.profile,
region: request.region,
proxy: request.proxy,
caBundlePath: request.caBundlePath,
env: {
CDK_DOCKER: process.env.CDK_DOCKER ?? 'docker',
},
showOutput: verbosity >= 2,
}, testInfo.destructiveChanges);
const tests = await runner.actualTests();
if (!tests || Object.keys(tests).length === 0) {
throw new Error(`No tests defined for ${runner.testName}`);
}
for (const testCaseName of Object.keys(tests)) {
try {
const results = await runner.runIntegTestCase({
testCaseName,
clean: request.clean,
dryRun: request.dryRun,
updateWorkflow: request.updateWorkflow,
verbosity,
});
if (results && Object.values(results).some(result => result.status === 'fail')) {
failures.push(testInfo);
workerpool.workerEmit({
reason: common_1.DiagnosticReason.ASSERTION_FAILED,
testName: `${runner.testName}-${testCaseName} (${request.profile}/${request.region})`,
message: (0, common_1.formatAssertionResults)(results),
duration: (Date.now() - start) / 1000,
});
}
else {
workerpool.workerEmit({
reason: common_1.DiagnosticReason.TEST_SUCCESS,
testName: `${runner.testName}-${testCaseName}`,
message: results ? (0, common_1.formatAssertionResults)(results) : 'NO ASSERTIONS',
duration: (Date.now() - start) / 1000,
});
}
}
catch (e) {
failures.push(testInfo);
workerpool.workerEmit({
reason: common_1.DiagnosticReason.TEST_FAILED,
testName: `${runner.testName}-${testCaseName} (${request.profile}/${request.region})`,
message: `Integration test failed: ${(0, common_1.formatError)(e)}`,
duration: (Date.now() - start) / 1000,
});
}
}
}
catch (e) {
failures.push(testInfo);
workerpool.workerEmit({
reason: common_1.DiagnosticReason.TEST_ERROR,
testName: `${testInfo.fileName} (${request.profile}/${request.region})`,
message: `Error during integration test: ${(0, common_1.formatError)(e)}`,
duration: (Date.now() - start) / 1000,
});
}
}
return failures;
}
async function watchTestWorker(options) {
const verbosity = options.verbosity ?? 0;
const test = new integration_tests_1.IntegTest(options);
const runner = new runner_1.IntegTestRunner({
test,
profile: options.profile,
region: options.region,
proxy: options.proxy,
caBundlePath: options.caBundlePath,
env: {
CDK_DOCKER: process.env.CDK_DOCKER ?? 'docker',
},
showOutput: verbosity >= 2,
});
runner.createCdkContextJson();
const tests = await runner.actualTests();
if (!tests || Object.keys(tests).length === 0) {
throw new Error(`No tests defined for ${runner.testName}`);
}
for (const testCaseName of Object.keys(tests)) {
await runner.watchIntegTest({
testCaseName,
verbosity,
});
}
}
/**
* Runs a single snapshot test batch request.
* For each integration test this will check to see
* if there is an existing snapshot, and if there is will
* check if there are any changes
*/
async function snapshotTestWorker(testInfo, options = {}) {
const failedTests = new Array();
const start = Date.now();
const test = new integration_tests_1.IntegTest(testInfo); // Hydrate the data record again
const timer = setTimeout(() => {
workerpool.workerEmit({
reason: common_1.DiagnosticReason.TEST_WARNING,
testName: test.testName,
message: 'Test is taking a very long time',
duration: (Date.now() - start) / 1000,
});
}, 60_000);
try {
const runner = new runner_1.IntegSnapshotRunner({
test,
showOutput: options.verbose ?? false,
});
if (!runner.hasSnapshot()) {
workerpool.workerEmit({
reason: common_1.DiagnosticReason.NO_SNAPSHOT,
testName: test.testName,
message: 'No Snapshot',
duration: (Date.now() - start) / 1000,
});
failedTests.push(test.info);
}
else {
const { diagnostics, destructiveChanges } = await runner.testSnapshot(options);
if (diagnostics.length > 0) {
diagnostics.forEach(diagnostic => workerpool.workerEmit({
...diagnostic,
duration: (Date.now() - start) / 1000,
}));
failedTests.push({
...test.info,
destructiveChanges,
});
}
else {
workerpool.workerEmit({
reason: common_1.DiagnosticReason.SNAPSHOT_SUCCESS,
testName: test.testName,
message: 'Success',
duration: (Date.now() - start) / 1000,
});
}
}
}
catch (e) {
failedTests.push(test.info);
workerpool.workerEmit({
message: (0, common_1.formatError)(e),
testName: test.testName,
reason: common_1.DiagnosticReason.SNAPSHOT_ERROR,
duration: (Date.now() - start) / 1000,
});
}
finally {
clearTimeout(timer);
}
return failedTests;
}
workerpool.worker({
snapshotTestWorker,
integTestWorker,
watchTestWorker,
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"extract_worker.js","sourceRoot":"","sources":["extract_worker.ts"],"names":[],"mappings":"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","sourcesContent":["import * as workerpool from 'workerpool';\nimport { IntegSnapshotRunner, IntegTestRunner } from '../../runner';\nimport type { IntegTestInfo } from '../../runner/integration-tests';\nimport { IntegTest } from '../../runner/integration-tests';\nimport type { IntegTestWorkerConfig, SnapshotVerificationOptions, Diagnostic } from '../common';\nimport { DiagnosticReason, formatAssertionResults, formatError } from '../common';\nimport type { IntegTestBatchRequest } from '../integ-test-worker';\nimport type { IntegWatchOptions } from '../integ-watch-worker';\n\n/**\n * Runs a single integration test batch request.\n * If the test does not have an existing snapshot,\n * this will first generate a snapshot and then execute\n * the integration tests.\n *\n * If the tests succeed it will then save the snapshot\n */\nexport async function integTestWorker(request: IntegTestBatchRequest): Promise<IntegTestWorkerConfig[]> {\n  const failures: IntegTestInfo[] = [];\n  const verbosity = request.verbosity ?? 0;\n\n  for (const testInfo of request.tests) {\n    const test = new IntegTest({\n      ...testInfo,\n      watch: request.watch,\n    }); // Hydrate from data\n    const start = Date.now();\n\n    try {\n      const runner = new IntegTestRunner({\n        test,\n        profile: request.profile,\n        region: request.region,\n        proxy: request.proxy,\n        caBundlePath: request.caBundlePath,\n        env: {\n          CDK_DOCKER: process.env.CDK_DOCKER ?? 'docker',\n        },\n        showOutput: verbosity >= 2,\n      }, testInfo.destructiveChanges);\n\n      const tests = await runner.actualTests();\n\n      if (!tests || Object.keys(tests).length === 0) {\n        throw new Error(`No tests defined for ${runner.testName}`);\n      }\n      for (const testCaseName of Object.keys(tests)) {\n        try {\n          const results = await runner.runIntegTestCase({\n            testCaseName,\n            clean: request.clean,\n            dryRun: request.dryRun,\n            updateWorkflow: request.updateWorkflow,\n            verbosity,\n          });\n          if (results && Object.values(results).some(result => result.status === 'fail')) {\n            failures.push(testInfo);\n            workerpool.workerEmit({\n              reason: DiagnosticReason.ASSERTION_FAILED,\n              testName: `${runner.testName}-${testCaseName} (${request.profile}/${request.region})`,\n              message: formatAssertionResults(results),\n              duration: (Date.now() - start) / 1000,\n            });\n          } else {\n            workerpool.workerEmit({\n              reason: DiagnosticReason.TEST_SUCCESS,\n              testName: `${runner.testName}-${testCaseName}`,\n              message: results ? formatAssertionResults(results) : 'NO ASSERTIONS',\n              duration: (Date.now() - start) / 1000,\n            });\n          }\n        } catch (e) {\n          failures.push(testInfo);\n          workerpool.workerEmit({\n            reason: DiagnosticReason.TEST_FAILED,\n            testName: `${runner.testName}-${testCaseName} (${request.profile}/${request.region})`,\n            message: `Integration test failed: ${formatError(e)}`,\n            duration: (Date.now() - start) / 1000,\n          });\n        }\n      }\n    } catch (e) {\n      failures.push(testInfo);\n      workerpool.workerEmit({\n        reason: DiagnosticReason.TEST_ERROR,\n        testName: `${testInfo.fileName} (${request.profile}/${request.region})`,\n        message: `Error during integration test: ${formatError(e)}`,\n        duration: (Date.now() - start) / 1000,\n      });\n    }\n  }\n\n  return failures;\n}\n\nexport async function watchTestWorker(options: IntegWatchOptions): Promise<void> {\n  const verbosity = options.verbosity ?? 0;\n  const test = new IntegTest(options);\n  const runner = new IntegTestRunner({\n    test,\n    profile: options.profile,\n    region: options.region,\n    proxy: options.proxy,\n    caBundlePath: options.caBundlePath,\n    env: {\n      CDK_DOCKER: process.env.CDK_DOCKER ?? 'docker',\n    },\n    showOutput: verbosity >= 2,\n  });\n  runner.createCdkContextJson();\n  const tests = await runner.actualTests();\n\n  if (!tests || Object.keys(tests).length === 0) {\n    throw new Error(`No tests defined for ${runner.testName}`);\n  }\n  for (const testCaseName of Object.keys(tests)) {\n    await runner.watchIntegTest({\n      testCaseName,\n      verbosity,\n    });\n  }\n}\n\n/**\n * Runs a single snapshot test batch request.\n * For each integration test this will check to see\n * if there is an existing snapshot, and if there is will\n * check if there are any changes\n */\nexport async function snapshotTestWorker(testInfo: IntegTestInfo, options: SnapshotVerificationOptions = {}): Promise<IntegTestWorkerConfig[]> {\n  const failedTests = new Array<IntegTestWorkerConfig>();\n  const start = Date.now();\n  const test = new IntegTest(testInfo); // Hydrate the data record again\n\n  const timer = setTimeout(() => {\n    workerpool.workerEmit({\n      reason: DiagnosticReason.TEST_WARNING,\n      testName: test.testName,\n      message: 'Test is taking a very long time',\n      duration: (Date.now() - start) / 1000,\n    });\n  }, 60_000);\n\n  try {\n    const runner = new IntegSnapshotRunner({\n      test,\n      showOutput: options.verbose ?? false,\n    });\n    if (!runner.hasSnapshot()) {\n      workerpool.workerEmit({\n        reason: DiagnosticReason.NO_SNAPSHOT,\n        testName: test.testName,\n        message: 'No Snapshot',\n        duration: (Date.now() - start) / 1000,\n      });\n      failedTests.push(test.info);\n    } else {\n      const { diagnostics, destructiveChanges } = await runner.testSnapshot(options);\n      if (diagnostics.length > 0) {\n        diagnostics.forEach(diagnostic => workerpool.workerEmit({\n          ...diagnostic,\n          duration: (Date.now() - start) / 1000,\n        } as Diagnostic));\n        failedTests.push({\n          ...test.info,\n          destructiveChanges,\n        });\n      } else {\n        workerpool.workerEmit({\n          reason: DiagnosticReason.SNAPSHOT_SUCCESS,\n          testName: test.testName,\n          message: 'Success',\n          duration: (Date.now() - start) / 1000,\n        } as Diagnostic);\n      }\n    }\n  } catch (e: any) {\n    failedTests.push(test.info);\n    workerpool.workerEmit({\n      message: formatError(e),\n      testName: test.testName,\n      reason: DiagnosticReason.SNAPSHOT_ERROR,\n      duration: (Date.now() - start) / 1000,\n    } as Diagnostic);\n  } finally {\n    clearTimeout(timer);\n  }\n\n  return failedTests;\n}\n\nworkerpool.worker({\n  snapshotTestWorker,\n  integTestWorker,\n  watchTestWorker,\n});\n"]}