Gardener
Enforces highest code quality and minimizes package setup and maintenance complexity - so you can focus on writing code. Highly recommended if you are getting started with a new package and extremely useful if you are maintaining multiple packages.
What it does
Getting Started
Preparation
- Create New Project (e.g. using Webstorm)
- Create New Repository on Github
- Run
git init
, git remote add origin URL
, git checkout -b master
- Run
npm init
and fill in details
Install Gardener
$ npm install --save-dev js-gardener
Run Basic Setup
Create gruntfile.js
in the root folder with the following contents
module.exports = (grunt) => {
grunt.initConfig({
pkg: grunt.file.readJSON('package.json'),
gardener: {
this: {
options: {}
}
}
});
grunt.loadNpmTasks('js-gardener');
};
Then run
$ grunt gardener
This will generate some files and alter your existing package.json file.
Create your files in the lib
folder and corresponding tests in the test
folder (Mocha and Chai work great), and ensure everything works fine by running npm test
. Finalize your README.md and package.json and commit and push to GitHub.
Now configure your Badges.
Run Tests Locally
To run all tests locally
$ npm test
and in debug mode with
$ npm test -- --debug
Structure
Folders - Write your tests in the test
and your code in the lib
folder. Only test files of the format test_*.js
are picked up.
Branches - You release branch is master
. Develop against develop
or feature branches. When you are ready for a release, merge your changes into master
.
Badges
Badges represent external services that integrate with your repository. The Badges are auto generated, but the services need to be enabled manually. This section will instruct you on how to set up and utilize each service. When completed, verify each service by clicking the corresponding badge.
Before configuring external services, ensure npm test
runs locally without errors and all changes are pushed.
Configure Badges
Note: If you username is different between github and a service, you will need to adjust the badge url.
Options
skip
Type: array
Default: []
Array of tasks to skip. Should not be necessary to use unless you really need to. Available tasks are:
gardener_copy
: Copy template files and create foldersgardener_package
: Alter package.jsongardener_configure
: Alter other configuration filesgardener_badges
: Insert Badgesgardener_structure
: Enforce that test file structure matches lib contentgardener_eslint
: Ensure code is according to best eslint practisesgardener_flow
: Execute flow validation for enabled files.yamllint
: Ensure yaml files are passing lintgardener_depcheck
: Ensure dependencies are installed as specified in package.jsongardener_depused
: Ensure all installed dependencies are usedmocha_istanbul
: Run tests in test
folder and force 100% coverage
cwd
Type: string
Default: process.cwd()
Specify the directory to run the tests against. Useful if you have multiple packages that you manage centralized from a parent folder.
Ignore Files
.coverignore
Define files which should be excluded from coverage. Always excluded files can be found here.
.eslintignore
Define files which should be excluded for eslint. Always excluded files can be found here.
.depunusedignore
Define packages that should be excluded from usage check. Useful when a false negative is detected, e.g. for plugins where usage is defined in configuration. Always excluded packages can be found here.
.structignore
Define test files that should not be checked for structure. Usually not necessary. Always excluded test files can be found here.
Example Projects
While this project utilizes itself for testing - how cool is that? - a cleaner example (without the grunt file) can be found here.
Example project using js-gardener and lambda-tdd can be found here.
All my npm packages also utilize Gardener.
How to Contribute
When you contribute to any Gardener repositories, always run npm test
locally before opening a PR.
Desired Changes
- Move all grunt tasks into separate function
- Use something more suitable than grunt
- Add more configuration options