2016-10-16 20:02:21 +00:00
|
|
|
# angel_test
|
2017-05-27 13:26:05 +00:00
|
|
|
[![version 1.0.5+1](https://img.shields.io/badge/pub-1.0.5+1-brightgreen.svg)](https://pub.dartlang.org/packages/angel_test)
|
2017-03-25 15:26:00 +00:00
|
|
|
[![build status](https://travis-ci.org/angel-dart/test.svg)](https://travis-ci.org/angel-dart/test)
|
2016-12-10 18:15:02 +00:00
|
|
|
|
2016-10-16 20:02:21 +00:00
|
|
|
Testing utility library for the Angel framework.
|
|
|
|
|
2017-03-25 15:26:00 +00:00
|
|
|
# TestClient
|
|
|
|
The `TestClient` class is a custom `angel_client` that sends mock requests to your server.
|
|
|
|
This means that you will not have to bind your server to HTTP to run.
|
|
|
|
Plus, it is an `angel_client`, and thus supports services and other goodies.
|
|
|
|
|
|
|
|
The `TestClient` also supports WebSockets. WebSockets cannot be mocked (yet!) within this library,
|
|
|
|
so calling the `websocket()` function will also bind your server to HTTP, if it is not already listening.
|
|
|
|
|
|
|
|
The return value is a `WebSockets` client instance
|
|
|
|
(from [`package:angel_websocket`](https://github.com/angel-dart/websocket));
|
|
|
|
|
|
|
|
```dart
|
|
|
|
var ws = await client.websocket('/ws');
|
|
|
|
ws.service('api/users').onCreated.listen(...);
|
|
|
|
|
|
|
|
// To receive all blobs of data sent on the WebSocket:
|
|
|
|
ws.onData.listen(...);
|
|
|
|
```
|
|
|
|
|
|
|
|
# Matchers
|
|
|
|
Several `Matcher`s are bundled with this package, and run on any `package:http` `Response`,
|
|
|
|
not just those returned by Angel.
|
|
|
|
|
|
|
|
```dart
|
|
|
|
test('foo', () async {
|
|
|
|
var res = await client.get('/foo');
|
|
|
|
expect(res, allOf([
|
|
|
|
isJson({'foo': 'bar'}),
|
|
|
|
hasStatus(200),
|
|
|
|
hasContentType(ContentType.JSON),
|
|
|
|
hasContentType('application/json'),
|
|
|
|
hasHeader('server'), // Assert header present
|
|
|
|
hasHeader('server', 'angel'), // Assert header present with value
|
|
|
|
hasHeader('foo', ['bar', 'baz']), // ... Or multiple values
|
|
|
|
hasBody(), // Assert non-empty body
|
|
|
|
hasBody('{"foo":"bar"}') // Assert specific body
|
|
|
|
]));
|
|
|
|
});
|
|
|
|
|
|
|
|
test('error', () async {
|
|
|
|
var res = await client.get('/error');
|
|
|
|
expect(res, isAngelHttpException());
|
|
|
|
expect(res, isAngelHttpException(statusCode: 404, message: ..., errors: [...])) // Optional
|
|
|
|
});
|
|
|
|
```
|
|
|
|
|
|
|
|
`hasValidBody` is one of the most powerful `Matcher`s in this library,
|
|
|
|
because it allows you to validate a JSON body against a
|
|
|
|
[validation schema](https://github.com/angel-dart/validate).
|
|
|
|
|
|
|
|
Angel provides a comprehensive validation library that integrates tightly
|
|
|
|
with the very `matcher` package that you already use for testing. :)
|
|
|
|
|
|
|
|
[https://github.com/angel-dart/validate](https://github.com/angel-dart/validate)
|
|
|
|
|
|
|
|
```dart
|
|
|
|
test('validate response', () async {
|
|
|
|
var res = await client.get('/bar');
|
|
|
|
expect(res, hasValidBody(new Validator({
|
|
|
|
'foo': isBoolean,
|
|
|
|
'bar': [isString, equals('baz')],
|
|
|
|
'age*': [],
|
|
|
|
'nested': someNestedValidator
|
|
|
|
})));
|
|
|
|
});
|
|
|
|
```
|