Run your tests using Jest & Apache Tinkerpop Docker container
npm install @shelf/jest-gremlin> Jest preset to run Gremlin server before tests
```
$ yarn add @shelf/jest-gremlin --dev
`js`
module.exports = {
preset: '@shelf/jest-gremlin',
};
If you have a custom jest.config.js make sure you remove testEnvironment property, otherwise it will conflict with the preset.
`js
import cwd from 'cwd';
module.exports = {
port: 8182,
protocol: 'ws',
imageName: 'tinkerpop/gremlin-server', // or your custom prebuilt image
imagePort: 8182, // port on which gremlin server is running inside the container
containerName: 'gremlin-server', // or your custom container name that would be spin up
maxTries: 10, // how many times to try to connect to gremlin server ()
triesInterval: 1000, // interval between tries
containerEngine: 'docker', // or 'podman' if you use podman - used in cli commands to start/stop container
};
`
`js`
it();
By default the jest-gremlin-config.js is read from cwd directory, but this might not bejest.config.*
suitable for monorepos with nested jest projects
with nested files nested in subdirectories.
If your jest-gremlin-config.js file is not located at {cwd}/jest-gremlin-config.js or youjest projects
are using nested , you can define the environment variable JEST_GREMLIN_CONFIGjest-gremlin-config.js
with the absolute path of the respective file.
`js
// src/nested/project/jest.config.js
const path = require('path');
// Define path of project level config - extension not required as file will be imported
// via require(process.env.JEST_GREMLIN_CONFIG)
process.env.JEST_GREMLIN_CONFIG = path.resolve(__dirname, './jest-gremlin-config');
module.exports = {
preset: '@shelf/jest-gremlin',
displayName: 'nested-project',
};
`
- postgres-local
- jest-elasticsearch
- jest-dynamodb
`sh``
$ git checkout master
$ yarn version
$ yarn publish
$ git push origin master --tags
MIT © Shelf