Skip to content
This repository has been archived by the owner on Jan 10, 2025. It is now read-only.

Re-export faker from graphql-fixtures #2155

Merged
merged 2 commits into from
Feb 2, 2022
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 5 additions & 1 deletion packages/graphql-fixtures/CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,11 @@ All notable changes to this project will be documented in this file.
The format is based on [Keep a Changelog](http://keepachangelog.com/en/1.0.0/)
and adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0.html).

<!-- ## Unreleased -->
## Unreleased

### Changed

- Re-export the instance of faker used in graphql-fixtures so that it can be leveraged easily by consumers [[#2155]](https://github.com/Shopify/quilt/pull/2155)

## 1.3.0 - 2022-02-01

Expand Down
26 changes: 25 additions & 1 deletion packages/graphql-fixtures/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -57,6 +57,20 @@ If you need to have the filled object immediately, you can invoke `fill` as foll
const data = fill(myQuery, data)({query: myQuery});
```

#### Using faker

When using `faker` to provide fake data within your filler function, you should use the `faker` instance that is exported by this library in order to avoid data mismatches. Rather than `import faker from '@faker-js/faker'` instead use:

```ts
import {createFiller, faker} from 'graphql-fixtures';

const fill = createFiller(schema, {
resolvers: {
ID: (_, {parent}) => `gid://${parent.name}/${faker.datatype.number()}`,
},
});
```

#### Interfaces and Unions

When attempting to fill data for a union or interface type, the filler will default to selecting a random type that implements the interface/ is a member of the union. If you would like to ensure a particular type is selected, but leave all the other fields to be filled by resolvers, you can provide a `__typename` field in the `data` argument for that field that selects the type you wish to be filled.
Expand Down Expand Up @@ -89,7 +103,7 @@ query MyQuery {
We can create a simpler filler globally, and use it every time we wish to generate a fixture:

```ts
import {createFiller} from 'graphql-fixtures';
import {createFiller, faker} from 'graphql-fixtures';
import schema from './schema';
import myQuery from './MyQuery.graphql';

Expand All @@ -101,6 +115,11 @@ const fillMyQueryOne = fill(myQuery);
// will result in {self: {__typename: 'Person', name: 'Chris'}}
const fillMyQueryTwo = fill(myQuery, {self: {name: 'Chris'}});
const fillMyQueryThree = fill(myQuery, {self: () => ({name: 'Chris'})});

// will result in an object with a random name
const fillMyQueryThree = fill(myQuery, {
self: () => ({name: faker.name.firstName()}),
});
```

As noted above, individual fields can be a function that takes the current GraphQL request and details about the field, and returns the partial data. You can even do this for the entire partial object, allowing you to completely switch out what partial data is used for an invocation based on things like the variables to the current query:
Expand Down Expand Up @@ -128,6 +147,11 @@ When a single number is provided as the first argument, an array of that size wi

```ts
// assuming `widgets` in a list of Widget objects
import {createFiller, faker} from 'graphql-fixtures';
import schema from './schema';
import widgetQuery from './WidgetQuery.graphql';

const fill = createFiller(schema);

const fixture = fill(widgetQuery, {
widgets: list([2, 4], {id: () => faker.datatype.uuid()}),
Expand Down
2 changes: 2 additions & 0 deletions packages/graphql-fixtures/src/fill.ts
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,8 @@ import {

import {randomFromArray, chooseNull} from './utilities';

// Re-export faker so that the exact version can be used by consumers
export {faker};
export interface FieldMetadata {
fieldIndex?: number;
fieldName: string;
Expand Down
10 changes: 8 additions & 2 deletions packages/graphql-fixtures/src/tests/fill.test.ts
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
import faker from '@faker-js/faker/locale/en';
// eslint-disable-next-line @shopify/typescript/prefer-build-client-schema
import {buildSchema} from 'graphql';
import {parse, DocumentNode} from 'graphql-typed';
import originalFaker from '@faker-js/faker/locale/en';

import {createFiller, list, Options} from '../fill';
import {createFiller, list, Options, faker} from '../fill';

jest.mock('../utilities', () => {
const utilities = jest.requireActual('../utilities');
Expand Down Expand Up @@ -1327,6 +1327,12 @@ describe('createFiller()', () => {
});
});

describe('faker', () => {
it('re-exports faker for use by consumers', () => {
expect(faker).toStrictEqual(originalFaker);
});
});

function createFillerForSchema(schema: string, options?: Options) {
const filler = createFiller(buildSchema(schema), options);
return <Data, PartialData>(
Expand Down