Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tool-belt/interface-forge
Graceful mock-data generation using TypeScript
https://github.com/tool-belt/interface-forge
factories faker fakerjs testing tests typescript
Last synced: 2 months ago
JSON representation
Graceful mock-data generation using TypeScript
- Host: GitHub
- URL: https://github.com/tool-belt/interface-forge
- Owner: tool-belt
- License: mit
- Created: 2021-05-11T15:49:16.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2024-08-22T10:42:12.000Z (5 months ago)
- Last Synced: 2024-09-22T12:46:36.997Z (4 months ago)
- Topics: factories, faker, fakerjs, testing, tests, typescript
- Language: TypeScript
- Homepage: https://www.npmjs.com/package/interface-forge
- Size: 1.5 MB
- Stars: 70
- Watchers: 4
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
- awesome-faker - interface-forge - A library for mock data generation using factories. This library extends Faker.js directly. (Projects using `@faker-js/faker`)
README
# Interface-Forge
Interface-Forge is a TypeScript library for creating strongly typed mock data factories. This library builds upon [Faker.js](https://fakerjs.dev/) by providing a simple and intuitive `Factory` class that extends the `Faker` class from [Faker.js](https://fakerjs.dev/).
## Installation
```shell
npm install --save-dev interface-forge
```## Basic Example
To create a factory, you need a TypeScript type:
```typescript
// types.tsinterface User {
firstName: string;
lastName: string;
email: string;
profile: {
profession: string;
gender: string;
age: number;
};
}
```Pass the desired type as a generic argument when instantiating the `Factory` class, alongside default values for the factory:
```typescript
// factories.ts
import { Factory } from 'interface-forge';
import { User } from './types';const UserFactory = new Factory((factory, iteration) => ({
firstName: factory.person.firstName(),
lastName: factory.person.lastName(),
email: factory.internet.email(),
profile: {
profession: factory.person.jobType(),
gender: factory.person.gender(),
age: 27 + iteration,
},
}));
```Then use the factory to create an object of the desired type in a test file:
```typescript
// User.spec.tsdescribe('User', () => {
const user = UserFactory.build();
// user == {
// firstName: "Johanne",
// lastName: "Smith",
// email: "[email protected]",
// profile: {
// profession: "Journalist",
// gender: "Female",
// age: 27
// },
// }
// ...
});
```## Factory Class Methods
### `build`
Builds a single object based on the factory's schema. Optionally, you can pass an object to override specific properties.
**Usage:**
```typescript
const user = UserFactory.build();
// user == {
// firstName: "Johanne",
// lastName: "Smith",
// email: "[email protected]",
// profile: {
// profession: "Journalist",
// gender: "Female",
// age: 27
// },
// }const customUser = UserFactory.build({ age: 35 });
// customUser.age == 35
```### `batch`
Generates a batch of objects based on the factory's schema. Optionally, you can pass an object or an array of objects to override specific properties for each instance.
**Usage:**
```typescript
const users = UserFactory.batch(3);
// users == [
// { ... },
// { ... },
// { ... }
// ]const customUsers = UserFactory.batch(3, { age: 35 });
// customUsers == [
// { ..., age: 35 },
// { ..., age: 35 },
// { ..., age: 35 }
// ]const variedUsers = UserFactory.batch(3, [
{ age: 30 },
{ age: 25 },
{ age: 40 },
]);
// variedUsers == [
// { ..., age: 30 },
// { ..., age: 25 },
// { ..., age: 40 }
// ]
```### `use`
Creates a reference to a function that can be used within the factory. This method allows for the encapsulation of a function and its arguments, enabling deferred execution.
**Usage:**
```typescript
const complexFactory = new Factory((factory) => ({
name: factory.person.firstName(),
value: factory.number.int({ min: 1, max: 3 }),
options: {
type: '1',
},
}));const factoryWithOptions = new Factory((factory) => ({
...defaults,
options: {
type: '1',
children: factory.use(complexFactory.batch, 2),
},
}));const result = factoryWithOptions.build();
// result.options.children == [
// { ... },
// { ... }
// ]
```### `iterate`
Cycles through the values of an iterable indefinitely.
**Usage:**
```typescript
const values = ['Value 1', 'Value 2', 'Value 3'];
const generator = UserFactory.iterate(values);console.log(generator.next().value); // 'Value 1'
console.log(generator.next().value); // 'Value 2'
console.log(generator.next().value); // 'Value 3'
console.log(generator.next().value); // 'Value 1'
```### `sample`
Samples values randomly from an iterable, ensuring no immediate repetitions.
**Usage:**
```typescript
const values = [1, 2, 3];
const generator = UserFactory.sample(values);console.log(generator.next().value); // 1 (or 2, or 3)
console.log(generator.next().value); // (different from the previous value)
```## Contributing
Contributions of any kind are welcome! Please see the [contributing guide](CONTRIBUTING.md).