An open API service indexing awesome lists of open source software.

https://github.com/gedaiu/trial

The extensible test runner for DLang moved to
https://github.com/gedaiu/trial

dlang dub extensible test-runner

Last synced: 15 days ago
JSON representation

The extensible test runner for DLang moved to

Awesome Lists containing this project

README

          

[![Build Status](https://gitlab.com/szabobogdan3/trial/badges/master/build.svg)](https://gitlab.com/szabobogdan3/trial)
[![Line Coverage](http://trial.szabobogdan.com/artifacts/coverage/html/coverage-shield.svg)](http://trial.szabobogdan.com/artifacts/coverage/html/index.html)
[![DUB Version](https://img.shields.io/dub/v/trial.svg)](https://code.dlang.org/packages/trial)

[Writing unit tests is easy with Dlang](https://dlang.org/spec/unittest.html). Unfortunately
when you have a big collection of unit tests, it get's hard to maintain and debug them. In order
to avoid these problems, you can use this flexible test runner for D programing language.

## Motivation

There are many test runners for DLang and there are a few of them that have a lot of useful features
that helps you to be more productive. Sometimes you need to use a custom feature that is not embedded
with those libraries. Maybe it's about a custom test report, a new discovery mode or an integration with
a third party app like an IDE or Jenkins. In each of these cases you need to dig in a project that is
not maintained or you need features that does not match the creators view about this subject.

In order to be able to extend your test runs without depending on other people, I propose a simple
idea, inspired from well known projects like [TestNg](http://testng.org/doc/),
[NUnit](https://github.com/nunit/docs/wiki) and [mocha](https://mochajs.org/), that exposes a simple
interface that allows you to add what you want, when you want.

## How it works

The `trial` executable creates a custom main that will be embedded with your code. The build is created
using `dub` embeded as a library, so you don't need to install dub to use this runner. All the parameters that you
provide to trial will be passed directly to `dub`. Right now trial provides only the `--test` or `-t` option that will
filter the discovered tests. For example `trial -t "The user should see a nice message when one test is run"` will run
only the tests that contain that string in the name.

## Features

This library intends to provide a rich set of features that helps you to customize your test runs:
- [Test discoveries](doc/test-discovery.md)
- [Executors](doc/executors.md)
- [Reporters](doc/reporters.md)
- [Steps](doc/steps.md)
- [Attributes](doc/attributes.md)
- [Attachments](doc/attachments.md)
- [Plugins](doc/plugins.md)

## Configurable

The trial command can be configured through the `trial.json` file. This file will be created when you run `trial`
For the first time. All the root properties are optional. For more details about this file look at the
[Settings](http://trial.szabobogdan.com/api/trial/settings/Settings.html) structure.

By default `trial` will use the `unittest` configuration. If you need to use test dependencies or other special
setup for the test build, you can add a `trial` configuration inside your package file:

```json
...
"configurations": [ {
"name": "trial",
"dependencies": {
"trial:lifecycle": "~>0.7.11",
"fluent-asserts": "0.14.0-alpha.11"
}
}
]
...
```

Read [more](https://code.dlang.org/package-format?lang=json#configurations) about dub configurations.

## Hacking

Please have a look at [trial.interfaces](http://trial.szabobogdan.com/api/trial/interfaces.html)

## Building

Clone the repository and run `dub build :runner` to create the app.

## Structure

There are two packages inside this project. The `runner` packages contains the command line interface
to run your tests. `lifecycle` provides the functionality like test discovery and reporters.

## Fluent Asserts

Since DLang does not have a rich assert library, you can use [Fluent Asserts](http://fluentasserts.szabobogdan.com/), a library
that improves your experience of writing tests.