123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236 |
- 'use strict';
- Object.defineProperty(exports, '__esModule', {
- value: true
- });
- exports.default = void 0;
- var _state = require('./state');
- var _types = require('./types');
- var _utils = require('./utils');
- /**
- * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved.
- *
- * This source code is licensed under the MIT license found in the
- * LICENSE file in the root directory of this source tree.
- */
- const run = async () => {
- const {rootDescribeBlock} = (0, _state.getState)();
- await (0, _state.dispatch)({
- name: 'run_start'
- });
- await _runTestsForDescribeBlock(rootDescribeBlock);
- await (0, _state.dispatch)({
- name: 'run_finish'
- });
- return (0, _utils.makeRunResult)(
- (0, _state.getState)().rootDescribeBlock,
- (0, _state.getState)().unhandledErrors
- );
- };
- const _runTestsForDescribeBlock = async describeBlock => {
- await (0, _state.dispatch)({
- describeBlock,
- name: 'run_describe_start'
- });
- const {beforeAll, afterAll} = (0, _utils.getAllHooksForDescribe)(
- describeBlock
- );
- const isSkipped = describeBlock.mode === 'skip';
- if (!isSkipped) {
- for (const hook of beforeAll) {
- await _callCircusHook({
- describeBlock,
- hook
- });
- }
- } // Tests that fail and are retried we run after other tests
- const retryTimes = parseInt(global[_types.RETRY_TIMES], 10) || 0;
- const deferredRetryTests = [];
- for (const child of describeBlock.children) {
- switch (child.type) {
- case 'describeBlock': {
- await _runTestsForDescribeBlock(child);
- break;
- }
- case 'test': {
- const hasErrorsBeforeTestRun = child.errors.length > 0;
- await _runTest(child, isSkipped);
- if (
- hasErrorsBeforeTestRun === false &&
- retryTimes > 0 &&
- child.errors.length > 0
- ) {
- deferredRetryTests.push(child);
- }
- break;
- }
- }
- } // Re-run failed tests n-times if configured
- for (const test of deferredRetryTests) {
- let numRetriesAvailable = retryTimes;
- while (numRetriesAvailable > 0 && test.errors.length > 0) {
- // Clear errors so retries occur
- await (0, _state.dispatch)({
- name: 'test_retry',
- test
- });
- await _runTest(test, isSkipped);
- numRetriesAvailable--;
- }
- }
- if (!isSkipped) {
- for (const hook of afterAll) {
- await _callCircusHook({
- describeBlock,
- hook
- });
- }
- }
- await (0, _state.dispatch)({
- describeBlock,
- name: 'run_describe_finish'
- });
- };
- const _runTest = async (test, parentSkipped) => {
- await (0, _state.dispatch)({
- name: 'test_start',
- test
- });
- const testContext = Object.create(null);
- const {hasFocusedTests, testNamePattern} = (0, _state.getState)();
- const isSkipped =
- parentSkipped ||
- test.mode === 'skip' ||
- (hasFocusedTests && test.mode !== 'only') ||
- (testNamePattern && !testNamePattern.test((0, _utils.getTestID)(test)));
- if (isSkipped) {
- await (0, _state.dispatch)({
- name: 'test_skip',
- test
- });
- return;
- }
- if (test.mode === 'todo') {
- await (0, _state.dispatch)({
- name: 'test_todo',
- test
- });
- return;
- }
- const {afterEach, beforeEach} = (0, _utils.getEachHooksForTest)(test);
- for (const hook of beforeEach) {
- if (test.errors.length) {
- // If any of the before hooks failed already, we don't run any
- // hooks after that.
- break;
- }
- await _callCircusHook({
- hook,
- test,
- testContext
- });
- }
- await _callCircusTest(test, testContext);
- for (const hook of afterEach) {
- await _callCircusHook({
- hook,
- test,
- testContext
- });
- } // `afterAll` hooks should not affect test status (pass or fail), because if
- // we had a global `afterAll` hook it would block all existing tests until
- // this hook is executed. So we dispatch `test_done` right away.
- await (0, _state.dispatch)({
- name: 'test_done',
- test
- });
- };
- const _callCircusHook = async ({hook, test, describeBlock, testContext}) => {
- await (0, _state.dispatch)({
- hook,
- name: 'hook_start'
- });
- const timeout = hook.timeout || (0, _state.getState)().testTimeout;
- try {
- await (0, _utils.callAsyncCircusFn)(hook, testContext, {
- isHook: true,
- timeout
- });
- await (0, _state.dispatch)({
- describeBlock,
- hook,
- name: 'hook_success',
- test
- });
- } catch (error) {
- await (0, _state.dispatch)({
- describeBlock,
- error,
- hook,
- name: 'hook_failure',
- test
- });
- }
- };
- const _callCircusTest = async (test, testContext) => {
- await (0, _state.dispatch)({
- name: 'test_fn_start',
- test
- });
- const timeout = test.timeout || (0, _state.getState)().testTimeout;
- (0, _utils.invariant)(
- test.fn,
- "Tests with no 'fn' should have 'mode' set to 'skipped'"
- );
- if (test.errors.length) {
- return; // We don't run the test if there's already an error in before hooks.
- }
- try {
- await (0, _utils.callAsyncCircusFn)(test, testContext, {
- isHook: false,
- timeout
- });
- await (0, _state.dispatch)({
- name: 'test_fn_success',
- test
- });
- } catch (error) {
- await (0, _state.dispatch)({
- error,
- name: 'test_fn_failure',
- test
- });
- }
- };
- var _default = run;
- exports.default = _default;
|