Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jamiebuilds/fixturez
Easily create and maintain test fixtures in the file system
https://github.com/jamiebuilds/fixturez
ava fixtures jest mocha test
Last synced: 13 days ago
JSON representation
Easily create and maintain test fixtures in the file system
- Host: GitHub
- URL: https://github.com/jamiebuilds/fixturez
- Owner: jamiebuilds
- License: mit
- Created: 2018-01-02T06:36:44.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2024-01-09T13:59:43.000Z (10 months ago)
- Last Synced: 2024-09-17T15:34:11.414Z (about 2 months ago)
- Topics: ava, fixtures, jest, mocha, test
- Language: JavaScript
- Size: 102 KB
- Stars: 56
- Watchers: 3
- Forks: 3
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# fixturez
> Easily create and maintain test fixtures in the file system
- Place fixtures in any parent directory
- Find them again in your tests by their name
- Searches up the file system to find a match
- Makes it easy to move fixtures around and share between tests
- Copy them into a temporary directory
- Automatically cleanup any temporary files created## Install
```sh
yarn add --dev fixturez
```## Example
```
/path/to/project/
/src/
/fixtures/
samples.txt
examples/...
/nested/
/fixtures/
data.json
test.js
``````js
// src/nested/test.js
const test = require('ava');
const fixtures = require('fixturez');
const f = fixtures(__dirname);test('finding a fixture', t => {
let filePath = f.find('samples.txt'); // "/path/to/project/src/fixtures/samples.txt"
// ...
});test('copying a file', t => {
let tmpPath = f.copy('data.json'); //
// "/private/var/folders/3x/jf5977fn79jbglr7rk0tq4d00000gn/T/a9fb0decd08179eb6cf4691568aa2018/data.json"
// (from /path/to/project/src/nested/fixtures/samples.txt)
});test('copying a directory', t => {
let tmpPath = f.copy('examples');
// "/private/var/folders/3x/jf5977fn79jbglr7rk0tq4d00000gn/T/4f504b9edb5ba0e89451617bf9f971dd/examples"
// (from /path/to/project/src/fixtures/examples)
});
```## API
```js
const fixtures = require('fixturez');
```### `fixtures(dirname, opts)`
Create fixture functions for the current file.
```js
const f = fixtures(__dirname);
```### `f.find(basename)`
Find and return the path to a fixture by its `basename` (directory or filename
including file extension).```js
let dirname = f.find('directory');
let filename = f.find('file.txt');
f.find('file'); // Error, not found!
```### `f.copy(basename)`
Copy a fixture into a temporary directory by its `basename`.
```js
let tempDir = f.copy('directory');
let tempFile = f.copy('file.txt');
```### `f.temp()`
Create an empty temporary directory.
```js
let tempDir = f.temp();
```### `f.cleanup()`
Deletes any temporary files you created. This will automatically be called when
the Node process closes.### `opts.glob`
Which files to match against when searching up the file system.
Default: `{fixtures,__fixtures__}/*`
```js
const f = fixtures(__dirname, { glob: 'mocks/*.json' });
```### `opts.cleanup`
Automatically cleanup temporary files created
Default: `true`
```js
const f = fixtures(__dirname, { cleanup: false });
```### `opts.root`
Set the parent directory to stop searching for fixtures.
Default: `"/"`
```js
const f = fixtures(__dirname, { root: 'path/to/project' });
```