This is a collection of common scripts that abstract away general configuration for applications, such as linting, code style formatting, testing etc. In addition, you as a developer can override or extend all configs 👏.
Projects typically have the same set of duplicated configs for testing/linting etc or worse yet different configs and rules.
This package has been created for two reasons:
- Standardise configs so each application uses the same set of rules, ensuring code consistency.
- Abstract the process of testing/linting etc into one package so you as a developer no longer need to setup everything manually.
This package includes the following 4 scripts for use in applications:
- Prettier - Auto format your code style
- Husky & Lint Staged - Automatically execute Prettier when running Git commit
- Jest - Unit test your code
- ESLint - A curated set of rules and guides
Using Yarn
yarn add --dev mango-scripts
or NPM
npm install --save-dev mango-scripts
Setup your package.json file with the following:
{
"scripts": {
"format": "mango-scripts format",
"precommit": "app-scripts precommit",
"test": "mango-scripts test",
"lint": "mango-scripts lint"
}
}
And execute a script, e.g.
yarn run format
Running yarn run format
will execute Prettier which will auto format your code and ensures it conforms to a consistent style (meaning no more code style discussions 👍).
See customising section for advanced usage.
While manually formatting code is okay, it can become a pain to do this yourself repeatedly. This script adds the ability to automatically run Prettier whenever you commit code. All you need to do is to add the following to your package.json:
"precommit": "mango-scripts precommit"
Internally it uses a Git Hook (via the packages Husky and Lint Staged) to check for staged files only and runs the format script on those files.
See customising section for advanced usage.
Running yarn run test
will execute Jest.
This means you can test React components using something like:
import React from 'react';
const Input = props => <input {...props} />;
describe('My Component', () => {
it('should render an input', () => {
const wrapper = shallow(<Input type="text" />);
expect(wrapper).toMatchSnapshot();
expect(wrapper).toHaveProp('type', 'text');
});
});
Running yarn run lint
will execute ESLint. The config provided extends from Mango.
Note the config includes an override section for Jest that only applies to files in the format
**/__tests__/*.js
, however because the config is not in the root directory the ESLint parser does not pick this up. Therefore it is recommended to extend the config and place it in your root directory. See customising section for usage.
All scripts have the ability for the config used to be modified, you can either specify your own config or extend the provided config. You can also pass any cli arguments and these will be passed onto the relevant script.
To supply your own config file the format
script will automatically look for any one of the following and use them in place of the built-in config:
- Using the
'--config'
argument, e.g.yarn run format --config ./file-to-config
- .prettierrc in your project root
- .prettierrc.js in your project root
- .prettier.config.js in your project root
- The prettier key in your package.json
To extend the config file simply import it and modify it, e.g. create a .prettierrc.js file with:
module.exports = {
...require('mango-scripts/configs/prettier'),
singleQuote: false,
};
In addition you can also supply your own ignore file. The format
script will automatically look for any one of the following:
- The
'--ignore-path'
argument, e.g.yarn run format --ignore-path ./file-to-ignore-config
- .prettierignore in your project root
To supply your own config file the precommit
script will automatically look for any one of the following and use them in place of the built-in config:
- Using the
'--config'
argument, e.g.
"precommit": "mango-scripts precommit --config ./file-to-config"
- .lintstagedrc in your project root
- .lint-staged.config.js in your project root
- The lint-staged key in your package.json
To extend the config file simply import it and modify it, e.g. create a .lint-staged.config.js file with:
module.exports = {
...require('mango-scripts/configs/prettier'),
};
To supply your own config file the test
script will automatically look for any one of the following and use them in place of the built-in config:
- Using the
'--config'
argument, e.g.yarn run test --config ./file-to-config
- jest.config.js in your project root
- The jest key in your package.json
To extend the config file simply import it and modify it, e.g. create a jest.config.js file with:
module.exports = {
...require('mango-scripts/configs/jest'),
moduleNameMapper: {
// Webpack aliases
},
};
In addition the test
script will use the built-in Babel config. To override this, it will automatically look for and use any one of the following:
- A
.babelrc
in your project root - The
babel
key in your package.json
You will have to then configure the Babel test setup yourself. The test
script sets the NODE_ENV to test
which will be of use to you. (See the Babel config used in src/configs/babel/config.js
to get an idea).
To supply your own config file the lint
script will automatically look for any one of the following and use them in place of the built-in config:
- Using the
'--config'
argument, e.g.yarn run lint --config ./file-to-config
- .eslintrc in your project root
- .eslintrc.js in your project root
- The eslintConfig key in your package.json
To extend the config file simply import it and modify it, e.g. create a .eslintrc.js file with:
module.exports = {
extends: [require.resolve('mango-scripts/configs/eslint')],
rules: {
'no-unused-vars': ['warn'],
},
};
In addition you can also supply your own ignore file. The lint
script will automatically look for any one of the following:
- The
'--ignore-path'
argument, e.g.yarn run lint --ignore-path ./file-to-ignore-config
- .eslintignore in your project root
- The eslintIgnore key in your package.json
module.exports = {
extends: [require.resolve('mango-scripts/configs/eslint')],
};