diff --git a/pages/guide/setup.md b/pages/guide/setup.md index 40ccf5a..3ce739c 100644 --- a/pages/guide/setup.md +++ b/pages/guide/setup.md @@ -16,12 +16,14 @@ First, you need to choose which test framework you are going to use. Testdeck supports Mocha, Jasmine and Jest. -With some limitations, you can always change the test framework later on. (limitations: assertion/expectation framework.) +With some limitations, you can always change the test framework later on. + +Current limitations are the mocking framework and the assertion/expectation framework that you will use. ### Mocha {% highlight shell %} -npm install @testdeck/mocha mocha @types/mocha +npm install --save-dev @testdeck/mocha mocha @types/mocha {% endhighlight %} Alternatively, you can clone the existing mocha-seed and start from there. @@ -29,7 +31,7 @@ Alternatively, you can clone the existing jasmine-seed and start from there. @@ -37,7 +39,7 @@ Alternatively, you can clone the existing jest-seed and start from there. @@ -63,17 +65,64 @@ npm install --save-dev chai @types/chai #### Example Code {% highlight TypeScript linenos %} -import { suite, test } from '@testdeck/mocha'; +import { suite, test } from '@testdeck/mocha'; // might as well use jasmine/jest here import * as chai from 'chai'; +// let's have chai's should augmentations +chai.should(); + @suite class TestSuite { @test - someTest() { + assertTest() { chai.assert.isOk(false); } + + @test + expectTest() { + + chai.expect(false).to.be.true; + } + + @test + shouldTest() { + + const val = false; + + val.should.be.true; + } +} +{% endhighlight %} + + +### Should.js + +Should.js is a well established expectation framework. + +#### Setup + +{% highlight script %} +npm install --save-dev should +{% endhighlight %} + +#### Example Code + +{% highlight TypeScript linenos %} +import { suite, test } from '@testdeck/mocha'; // might as well use jasmine/jest here +import * as should from 'should'; + +@suite +class TestSuite { + + @test + someTest() { + + const var = false; + + var.should.be.true(); + } } {% endhighlight %} @@ -82,14 +131,48 @@ class TestSuite { #### Setup +{% highlight script %} +npm install --save-dev expect.js @types/expect.js +{% endhighlight %} + +#### Example Code + +{% highlight TypeScript linenos %} +TODO +{% endhighlight %} + + +### Expect + +While this is an integral part of the Jest test framework, it can be used as a stand alone package, too. + +#### Setup + +{% highlight script %} +npm install --save-dev expect @types/expect +{% endhighlight %} + #### Example Code {% highlight TypeScript linenos %} +import { suite, test } from '@testdeck/mocha'; // might as well use jasmine/jest here +import * as expect from 'expect'; + +@suite +class TestSuite { + + @test + someTest() { + + expect(false).toBe(true); + } +} {% endhighlight %} + ### NodeJS assert -A simple assertion framework that is included with the standard NodeJS library. +A simple, no fuss, assertion framework that is included with the standard NodeJS library. #### Setup @@ -98,7 +181,7 @@ This is part of the standard NodeJS library. #### Example Code {% highlight TypeScript linenos %} -import { suite, test } from '@testdeck/mocha'; +import { suite, test } from '@testdeck/mocha'; // might as well use jasmine/jest here import * as assert from 'assert'; @suite @@ -115,32 +198,127 @@ class TestSuite { ### Jasmine built-in +For Jasmine, we recommend the built-in expectation framework. + +#### Setup + +This is an integral part of Jasmine. + +#### Example Code + +{% highlight TypeScript linenos %} +import { suite, test } from '@testdeck/jasmine'; + +@suite +class TestSuite { + + @test + someTest() { + + expect(false).toBe(true); + } +} +{% endhighlight %} + ### Jest built-in +For Jest, we recommend the built-in expectation framework. -
assert
+#### Setup -
Jasmine built-in
-
For Jasmine, we recommend the built-in expectation framework.
+This is an integral part of Jest. -
Jest built-in
-
For Jest, we recommend the built-in expectation framework.
- +#### Example Code + +{% highlight TypeScript linenos %} +import { suite, test } from '@testdeck/jest'; + +@suite +class TestSuite { + + @test + someTest() { + + expect(false).toBe(true); + } +} +{% endhighlight %} ## Mocking Frameworks -
-
Sinon
-
For mocha, we recommend Sinon.
-
Jasmine built-in
-
For Jasmine, we recommend using the built-in mocking facility.
+### Sinon -
Jest built-in
-
For Jest, we recommend using the built-in mocking facility.
-
+#### Setup + +#### Example Code + + +### Jasmine built-in + +Jasmine provides you with a built-in mocking facility. + +#### Setup + +This is an integral part of Jasmine. + +#### Example Code + +{% highlight TypeScript linenos %} +import { suite, test } from '@testdeck/jasmine'; + +class SUT { + + private flags: {}; + + public setFlag(flag: string, value: boolean): void { + + this.flags[flag] = value; + } + + public getFlag(flag: string): boolean { + + return this.flags[flag] || false; + } +} + +@suite +class TestSuite { + + private sut: SUT; + + before() { + + this.sut = new SUT(); + } + + @test + someTest() { + + spyOn(this.sut, 'getFlag').and.returnValue(false); + expect(this.sut.getFlag('foo')).toBe(true); + } +} +{% endhighlight %} + + +### Jest built-in + +Jest, similarly to Jasmine, provides you with a built-in mocking facility. + +And we will not go into length here on how that works. + +See the official documentation [here](https://jestjs.io/docs/en/jest-object.html) and [here](https://jestjs.io/docs/en/mock-function-api). + +#### Setup + +This is an integral part of Jest. + +#### Example Code + +Since Jest is highly opinionated about its mocks, we refrain from providing you with an example here. YMMV. ## Dependency Injection