Skip to content

Manage data definitions, mock data and build APIs from validators

Notifications You must be signed in to change notification settings

dbebawy-modus/perigress

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

23 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Perigress

A medium for contract based development.

Data maintenance, contract testing and data generation without boilerplate using a series of either joi validators(.spec.js), JSON Schema(.spec.schema.js), or example JSON(.spec.json) files to represent the structure of the API URLs(which you are probably already writing).

The ultimate goal of this library is to generate fully functional and tested backends, mocks, seeds and migrations from nothing more than a set of schema.

1. Setup the directory layout

Only a single file is required to generate a test api, and that's the schema of the object you want to generate. That might be as simple as:

mkdir verifiers
mkdir verifiers/api
cp ../joi_user_definition.js verifiers/api/user.spec.js # OR
# cp ../json-schema_user.js verifiers/api/user.spec.schema.js

More complex options are described in the detailed setup document.

2. Use the mock in testing

You can launch the mock on the command line:

# use ./node_modules/perigress/bin/peri if you don't have a global `peri`
peri serve ./verifiers --port 8080
#in another terminal:
open "http://localhost:8080/api/user/list"

You can also launch the server within your code:

const { API } = require('@perigress/perigress');
const Mongonian = require('@perigress/mongonian');

const api = new API({
    subpath : 'verifiers',
    dir: __dirname
}, new Mongonian());
api.attach(expressInstance);

3. Generate data definitions

You can generate data definitions(SQL, Data Model) based on your endpoint contract.

4. Generate DB seed files

You can generate consistent fake data to load into your database without having to be paranoid about sanitizing the dev DB (or having to update seed scripts by hand every single time the DB structure is altered).

5. Generate migrations

Finally, because you can compute the difference between schema, you can also generate migrations for sets of changes of your data definitions.

6. Documentation

At any time the current spec is available at /spec with it's corresponding data at /openapi.json.

Roadmap

  • - list output
  • - primary key support
  • - audit columns
  • - edit support (ephemeral)
  • - example json support
  • - url mapping
  • - seed scripts
  • - documentation via OpenAPI
  • - error output
  • - selector support query filter documents
  • - foreign key support
  • - document assembly
  • - generate + persist requested filter values
  • - internal requests
  • - option to include saved objects in listing
  • - verbose mode
  • - save endpoint with symmetric object disassembly
  • - external express instances in mock
  • - pluggable transports
  • - Mongoish output format
  • - expose sift for extension
  • - passable page config
  • - query params passed to subqueries
  • - lifecycle hooks
  • - validator assembly
  • - db test suites
  • - better error handling
  • - better documentation
  • - deep object support (allow subobjects and arrays in schema)
  • - mongosh + mongojs support
  • - yup support
  • - Resty output format (json/form/xml)
  • - prisma support
  • - mongoose support
  • - persistent queries (returns for subsequent pages, without needing params)
  • - api generation

Testing

    mocha
    #or
    ./node_modules/mocha/bin/mocha

About

Manage data definitions, mock data and build APIs from validators

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 100.0%