UNPKG

quoad

Version:

Serenity/JS: Next generation acceptance testing library for modern web applications.

86 lines (72 loc) 4.03 kB
import { expect, ifExitCodeIsOtherThan, logOutput, PickEvent } from '@integration/testing-tools'; import { Timestamp } from '@serenity-js/core'; import { SceneFinished, SceneFinishes, SceneStarts, SceneTagged, TestRunFinished, TestRunFinishes, TestRunnerDetected, TestRunStarts, TestSuiteFinished, TestSuiteStarts, } from '@serenity-js/core/lib/events'; import { CorrelationId, ExecutionFailedWithAssertionError, ExecutionSuccessful, FeatureTag, Name } from '@serenity-js/core/lib/model'; import { describe, it } from 'mocha'; import { mocha } from '../src/mocha'; describe('@serenity-js/mocha', function () { this.timeout(30000); it('recognises nested suites', () => mocha('examples/suites.spec.js') .then(ifExitCodeIsOtherThan(1, logOutput)) .then(result => { expect(result.exitCode).to.equal(1); let currentSceneId: CorrelationId; PickEvent.from(result.events) .next(TestRunStarts, event => expect(event.timestamp).to.be.instanceof(Timestamp)) .next(TestSuiteStarts, event => expect(event.details.name).to.equal(new Name('Mocha reporting'))) .next(TestSuiteStarts, event => expect(event.details.name).to.equal(new Name('level 1 suite'))) .next(SceneStarts, event => { expect(event.details.name).to.equal(new Name('level 1 suite fails with an assertion error')); currentSceneId = event.sceneId; }) .next(SceneTagged, event => expect(event.tag).to.equal(new FeatureTag('Mocha reporting'))) .next(TestRunnerDetected, event => expect(event.name).to.equal(new Name('Mocha'))) .next(SceneFinishes, event => { expect(event.sceneId).to.equal(currentSceneId); }) .next(SceneFinished, event => { expect(event.sceneId).to.equal(currentSceneId); expect(event.outcome).to.be.instanceof(ExecutionFailedWithAssertionError); }) .next(TestSuiteStarts, event => expect(event.details.name).to.equal(new Name('level 2 suite'))) .next(SceneStarts, event => { expect(event.details.name).to.equal(new Name('level 1 suite level 2 suite passes')); currentSceneId = event.sceneId; }) .next(SceneTagged, event => expect(event.tag).to.equal(new FeatureTag('Mocha reporting'))) .next(TestRunnerDetected, event => expect(event.name).to.equal(new Name('Mocha'))) .next(SceneFinishes, event => { expect(event.sceneId).to.equal(currentSceneId); }) .next(SceneFinished, event => { expect(event.sceneId).to.equal(currentSceneId); expect(event.outcome).to.equal(new ExecutionSuccessful()); }) .next(TestSuiteFinished, event => { expect(event.details.name).to.equal(new Name('level 2 suite')) expect(event.outcome).to.be.instanceof(ExecutionSuccessful) }) .next(TestSuiteFinished, event => { expect(event.details.name).to.equal(new Name('level 1 suite')) expect(event.outcome).to.be.instanceof(ExecutionFailedWithAssertionError) }) .next(TestSuiteFinished, event => { expect(event.details.name).to.equal(new Name('Mocha reporting')) expect(event.outcome).to.be.instanceof(ExecutionSuccessful) }) .next(TestRunFinishes, event => expect(event.timestamp).to.be.instanceof(Timestamp)) .next(TestRunFinished, event => expect(event.timestamp).to.be.instanceof(Timestamp)) ; })); });