Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/vlucas/frisby
Frisby is a REST API testing framework built on Jest that makes testing API endpoints easy, fast, and fun.
https://github.com/vlucas/frisby
hacktoberfest integration-testing jasmine jest rest-api testing testing-framework
Last synced: 4 days ago
JSON representation
Frisby is a REST API testing framework built on Jest that makes testing API endpoints easy, fast, and fun.
- Host: GitHub
- URL: https://github.com/vlucas/frisby
- Owner: vlucas
- Created: 2012-02-23T23:10:20.000Z (almost 13 years ago)
- Default Branch: master
- Last Pushed: 2023-10-23T19:22:49.000Z (about 1 year ago)
- Last Synced: 2024-10-29T14:55:24.923Z (3 months ago)
- Topics: hacktoberfest, integration-testing, jasmine, jest, rest-api, testing, testing-framework
- Language: JavaScript
- Homepage: http://frisbyjs.com
- Size: 681 KB
- Stars: 1,525
- Watchers: 43
- Forks: 201
- Open Issues: 28
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Frisby
[![NPM](https://nodei.co/npm/frisby.png)](https://nodei.co/npm/frisby/)
[![CI](https://github.com/vlucas/frisby/actions/workflows/ci.yml/badge.svg)](https://github.com/vlucas/frisby/actions/workflows/ci.yml)![Frisby.js](https://user-images.githubusercontent.com/5210420/193491809-ecfe1741-3931-4c32-8554-483294e91592.png)
## Introduction
Frisby.js an API testing tool built on top of
[Jest](https://facebook.github.io/jest/) that makes testing API endpoints easy,
fast and fun.## Installation
Install Frisby v2.x from NPM into your project:
npm install --save-dev frisby joi
## Creating Tests
### Simple Example
The minimum setup to run a single test expectation.
```javascript
const frisby = require('frisby');it('should be a teapot', function () {
// Return the Frisby.js Spec in the 'it()' (just like a promise)
return frisby.get('http://httpbin.org/status/418')
.expect('status', 418);
});
```### Nested Dependent HTTP Calls
A more complex example with nested dependent Frisby tests with Frisby's Promise-style `then` method.
```javascript
const frisby = require('frisby');
const Joi = require('joi');describe('Posts', function () {
it('should return all posts and first post should have comments', function () {
return frisby.get('http://jsonplaceholder.typicode.com/posts')
.expect('status', 200)
.expect('jsonTypes', '*', {
userId: Joi.number(),
id: Joi.number(),
title: Joi.string(),
body: Joi.string()
})
.then(function (res) { // res = FrisbyResponse object
let postId = res.json[0].id;// Get first post's comments
// RETURN the FrisbySpec object so function waits on it to finish - just like a Promise chain
return frisby.get('http://jsonplaceholder.typicode.com/posts/' + postId + '/comments')
.expect('status', 200)
.expect('json', '*', {
postId: postId
})
.expect('jsonTypes', '*', {
postId: Joi.number(),
id: Joi.number(),
name: Joi.string(),
email: Joi.string().email(),
body: Joi.string()
});
});
});
});
```## Built-In Expect Handlers
Frisby comes with many handy built-in expect handlers to help you test the HTTP
response of your API.* `status` - Check HTTP status
* `header` - Check HTTP header key + value
* `json` - Match JSON structure + values (RegExp can be used)
* `jsonStrict` - Match EXACT JSON structure + values (extra keys not tested for cause test failures)
* `jsonTypes` - Match JSON structure + value types
* `jsonTypesStrict` - Match EXACT JSON structure + value types (extra keys not tested for cause test failures)
* `bodyContains` - Match partial body content (string or regex)
* `responseTime` - Check if request completes within a specified duration (ms)## Define Custom Expect Handlers
When Frisby's built-in expect handlers are not enough, or if you find yourself
running the same expectations in multiple places in your tests, you can define
your own custom expect handler once, and then run it from anywhere in your
tests.```javascript
beforeAll(function () {
// Add our custom expect handler
frisby.addExpectHandler('isUser1', function (response) {
let json = response.body;// Run custom Jasmine matchers here
expect(json.id).toBe(1);
expect(json.email).toBe('[email protected]');
});
});// Use our new custom expect handler
it('should allow custom expect handlers to be registered and used', function () {
return frisby.get('https://api.example.com/users/1')
.expect('isUser1')
});afterAll(function () {
// Remove said custom handler (if needed)
frisby.removeExpectHandler('isUser1');
});
```### Expecting JSON types using Joi
With Frisby, you can use [Joi](https://github.com/hapijs/joi) to set the expectation that the JSON body response from the HTTP call meets a defined schema. Check out the [Joi API](https://github.com/hapijs/joi/blob/master/API.md) for more details.
## Using Jasmine Matchers Directly
Any of the [Jasmine matchers](http://jasmine.github.io/2.4/introduction.html)
can be used inside the `then` method to perform additional or custom tests on
the response data.```javascript
const frisby = require('frisby');it('should be user 1', function () {
return frisby.get('https://api.example.com/users/1')
.then(function (res) {
expect(res.json.id).toBe(1);
expect(res.json.email).toBe('[email protected]');
});
});
```## Running Tests
Frisby uses Jasmine style assertion syntax, and uses
[Jest](https://facebook.github.io/jest/) to run tests.Jest can run sandboxed tests in parallel, which fits the concept of HTTP
testing very nicely so your tests run much faster.### Install Jest
npm install --save-dev jest
### Create your tests
mkdir __tests__
touch __tests__/api.spec.js### Run your tests from the CLI
cd your/project
jest### Documentation
Documentation is hosted at [frisbyjs.com](http://frisbyjs.com/), the
documentation pages has separate
[repository](https://github.com/vlucas/frisby-site).## License
Licensed under the [BSD 3-Clause](http://opensource.org/licenses/BSD-3-Clause)
license.