2021-07-10 02:51:07 +00:00
# Angel3 Testing Library
[data:image/s3,"s3://crabby-images/96a04/96a04776f66a45f2c555467d55d4200cfdb09447" alt="version "](https://pub.dartlang.org/packages/angel3_test)
2021-05-15 08:35:27 +00:00
[data:image/s3,"s3://crabby-images/fb323/fb32333d9edbb854cf31aef175a56bba8764eefc" alt="Null Safety "](https://dart.dev/null-safety)
[data:image/s3,"s3://crabby-images/ed53c/ed53ccc0d55f52cbdfd4b60248c5c6206a84c479" alt="Gitter "](https://gitter.im/angel_dart/discussion)
[data:image/s3,"s3://crabby-images/60424/60424a6f1f9e21cae5d8b2ca9203d16f2c867ac5" alt="License "](https://github.com/dukefirehawk/angel/tree/angel3/packages/test/LICENSE)
2016-12-10 18:15:02 +00:00
2021-07-10 02:51:07 +00:00
Testing utility library for the Angel3 framework.
## TestClient
2016-10-16 20:02:21 +00:00
2021-05-15 08:35:27 +00:00
The `TestClient` class is a custom `angel3_client` that sends mock requests to your server.
2017-03-25 15:26:00 +00:00
This means that you will not have to bind your server to HTTP to run.
2021-05-15 08:35:27 +00:00
Plus, it is an `angel3_client` , and thus supports services and other goodies.
2017-03-25 15:26:00 +00:00
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
2021-05-15 08:35:27 +00:00
(from [`package:angel3_websocket` ](https://github.com/dukefirehawk/angel/tree/angel3/packages/websocket ));
2017-03-25 15:26:00 +00:00
```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(...);
```
2021-07-10 02:51:07 +00:00
## Matchers
2017-03-25 15:26:00 +00:00
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
});
```
2021-07-10 02:51:07 +00:00
`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/dukefirehawk/angel/tree/angel3/packages/validate ).
2017-03-25 15:26:00 +00:00
2021-07-10 02:51:07 +00:00
Angel provides a comprehensive validation library that integrates tightly with the very `matcher` package that you already use for testing.
2017-03-25 15:26:00 +00:00
2021-05-15 08:35:27 +00:00
[`package:angel3_validate` ](https://github.com/dukefirehawk/angel/tree/angel3/packages//validate )
2017-03-25 15:26:00 +00:00
```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
})));
});
2021-07-10 02:51:07 +00:00
```