'use strict'; Object.defineProperty(exports, '__esModule', { value: true }); exports.default = void 0; var _testResult = require('@jest/test-result'); var _jestMessageUtil = require('jest-message-util'); var Symbol = global['jest-symbol-do-not-touch'] || global.Symbol; function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function(sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function(key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function(key) { Object.defineProperty( target, key, Object.getOwnPropertyDescriptor(source, key) ); }); } } return target; } var Symbol = global['jest-symbol-do-not-touch'] || global.Symbol; var jestNow = global[Symbol.for('jest-native-now')] || global.Date.now; var Symbol = global['jest-symbol-do-not-touch'] || global.Symbol; var Promise = global[Symbol.for('jest-native-promise')] || global.Promise; function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } class Jasmine2Reporter { constructor(globalConfig, config, testPath) { _defineProperty(this, '_testResults', void 0); _defineProperty(this, '_globalConfig', void 0); _defineProperty(this, '_config', void 0); _defineProperty(this, '_currentSuites', void 0); _defineProperty(this, '_resolve', void 0); _defineProperty(this, '_resultsPromise', void 0); _defineProperty(this, '_startTimes', void 0); _defineProperty(this, '_testPath', void 0); this._globalConfig = globalConfig; this._config = config; this._testPath = testPath; this._testResults = []; this._currentSuites = []; this._resolve = null; this._resultsPromise = new Promise(resolve => (this._resolve = resolve)); this._startTimes = new Map(); } jasmineStarted(_runDetails) {} specStarted(spec) { this._startTimes.set(spec.id, jestNow()); } specDone(result) { this._testResults.push( this._extractSpecResults(result, this._currentSuites.slice(0)) ); } suiteStarted(suite) { this._currentSuites.push(suite.description); } suiteDone(_result) { this._currentSuites.pop(); } jasmineDone(_runDetails) { let numFailingTests = 0; let numPassingTests = 0; let numPendingTests = 0; let numTodoTests = 0; const testResults = this._testResults; testResults.forEach(testResult => { if (testResult.status === 'failed') { numFailingTests++; } else if (testResult.status === 'pending') { numPendingTests++; } else if (testResult.status === 'todo') { numTodoTests++; } else { numPassingTests++; } }); const testResult = _objectSpread( {}, (0, _testResult.createEmptyTestResult)(), { console: null, failureMessage: (0, _jestMessageUtil.formatResultsErrors)( testResults, this._config, this._globalConfig, this._testPath ), numFailingTests, numPassingTests, numPendingTests, numTodoTests, snapshot: { added: 0, fileDeleted: false, matched: 0, unchecked: 0, unmatched: 0, updated: 0 }, testFilePath: this._testPath, testResults } ); this._resolve(testResult); } getResults() { return this._resultsPromise; } _addMissingMessageToStack(stack, message) { // Some errors (e.g. Angular injection error) don't prepend error.message // to stack, instead the first line of the stack is just plain 'Error' const ERROR_REGEX = /^Error:?\s*\n/; if (stack && message && !stack.includes(message)) { return message + stack.replace(ERROR_REGEX, '\n'); } return stack; } _extractSpecResults(specResult, ancestorTitles) { const start = this._startTimes.get(specResult.id); const duration = start ? jestNow() - start : undefined; const status = specResult.status === 'disabled' ? 'pending' : specResult.status; const location = specResult.__callsite ? { column: specResult.__callsite.getColumnNumber(), line: specResult.__callsite.getLineNumber() } : null; const results = { ancestorTitles, duration, failureMessages: [], fullName: specResult.fullName, location, numPassingAsserts: 0, // Jasmine2 only returns an array of failed asserts. status, title: specResult.description }; specResult.failedExpectations.forEach(failed => { const message = !failed.matcherName && failed.stack ? this._addMissingMessageToStack(failed.stack, failed.message) : failed.message || ''; results.failureMessages.push(message); }); return results; } } exports.default = Jasmine2Reporter;