Fable bindings for Mocha.js.
Stable | Prerelease |
---|---|
See https://harry.vangberg.name/unit-testing-fable-with-mocha
module Test.Example
open Fable.Import.MochaJS
/// Assert that the expected and actual values are equal
let assertEqual expected actual: unit =
Assert.AreEqual(actual, expected)
/// Assert that the expected and actual values are not equal
let assertNotEqual expected actual: unit =
Assert.NotEqual(actual, expected)
describe "test suite" <| fun _ ->
it "should do something poorly" <| fun _ ->
assertEqual 1 2
it "should do something well" <| fun _ ->
assertEqual 2 2
)
it "should do something else well" <| fun _ ->
assertNotEqual 23 65
|> ignore
You will also need to import side effects from every test suite in a main test runner, otherwise test suites won't be detected by Mocha.
module Test.Main
open Fable.Core.JsInterop
importSideEffects "./TestSuiteA.fs"
importSideEffects "./TestSuiteB.fs"
// etc
Make sure the following requirements are installed in your system:
- dotnet SDK 2.0 or higher
- node.js 6.11 or higher
- yarn
- Mono if you're on Linux or macOS.
Then you just need to type ./build.cmd
or ./build.sh
In order to push the package to nuget.org you need to add your API keys to NUGET_KEY
environmental variable.
You can create a key here.
- Update RELEASE_NOTES with a new version, data and release notes ReleaseNotesHelper. Ex:
#### 0.2.0 - 30.04.2017
* FEATURE: Does cool stuff!
* BUGFIX: Fixes that silly oversight
- You can then use the Release target. This will:
- make a commit bumping the version: Bump version to 0.2.0
- publish the package to nuget
- push a git tag
./build.sh Release