Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/kseo/render_tests
A regression test framework for Dart.
https://github.com/kseo/render_tests
Last synced: about 2 months ago
JSON representation
A regression test framework for Dart.
- Host: GitHub
- URL: https://github.com/kseo/render_tests
- Owner: kseo
- License: bsd-3-clause
- Created: 2015-12-15T04:59:18.000Z (about 9 years ago)
- Default Branch: master
- Last Pushed: 2015-12-15T12:42:27.000Z (about 9 years ago)
- Last Synced: 2024-10-11T23:22:17.777Z (3 months ago)
- Language: Dart
- Homepage: https://pub.dartlang.org/packages/render_tests
- Size: 9.77 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# render_tests
A regression test framework for Dart.
render_tests performs regression tests by comparing the rendered output against an expected output file. It also provides an easy way to create expected output files (called rebaselining).
## Usage
Let's create regression tests for `markdownToHtml` function from [markdown][markdown] package.
The first thing you need to do is to implement `Renderer` instance. render_tests uses it to generate an output from the given file. You can implement `Renderer` by overriding `render` method with a call to `markdownToHtml`. Here, StringRenderer is a synonym for `Renderer`.
```dart
class MarkdownRenderer implements StringRenderer {
String render(String input) => markdownToHtml(input);
}
```Once you have a `Renderer`, you can construct a `RendererTests` instance from it. The second argument of the `RendererTests` is a [glob][glob] pattern which specifies the input files. Let's grab every file with `markdown` extension.
```dart
Renderer renderer = new MarkdownRenderer();
RendererTests tests = new RendererTests(renderer, '**.markdown');
```
If you run the test for the first time, you don't yet have the expected outputs to compare. You can create the expected outputs using `rebaseline` or `rebaselineAll`. If glob pattern matches `foo.markdown`, rebaselining will generate `foo.markdown.expected` file in the same directory as `foo.markdown`. Later, render_tests will use these expected outputs to find regression bugs. Don't forget to add these files to your VCS.NOTE: render_tests does not provide a script to perform rebaselining because you need to create your own `RendererTests` instance with your custom `Renderer`. I recommend you to create a small script which helps you perform rebaselining easily.
```dart
tests.rebaselineAll();
```Now you are ready to perform regression tests. Let's assume you made a few changes to `markdownToHtml` function and want to make sure that it didn't introduce any regression bug. You can register tests using `runTests` functions. Just create a test group and call `runTests` in it. render_tests compares the rendered result with the expected output and check if they are still the same.
```dart
group('markdownToHtml tests', () {
tests.runTests();
});
````example/base64encoder_tests.dart` is another example you can reference. The script provides commands to run tests and perform rebaselining.
```
base64encoder testsUsage: base64encoder_tests [arguments]
Global options:
-h, --help Print this usage information.Available commands:
help Display help information for base64encoder_tests.
rebaseline rebaseline the tests
run run the testsRun "base64encoder_tests help " for more information about a command.
```[markdown]: https://pub.dartlang.org/packages/markdown
[glob]: https://pub.dartlang.org/packages/glob## Features and bugs
Please file feature requests and bugs at the [issue tracker][tracker].
[tracker]: https://github.com/kseo/render_tests/issues