Documents configuration tasks managed by robo-config.
- 📂
assorted/@npm-opensource
Manage various configuration files for an open source npm package on github.
Targets | Requires | Variables |
---|---|---|
project ├─ .circleci │ └─ config.yml ├─ .dependabot │ └─ config.yml ├─ .idea │ └─ ${projectName}.iml ├─ .c8rc.json ├─ .editorconfig ├─ eslint.config.js ├─ .eslintrc.json ├─ .gally.json ├─ ├─ .gitignore ├─ LICENSE ├─ .mocharc.yml ├─ .npmignore ├─ package.json ├─ README.md ├─ .releaserc.json ├─ src │ └─ index.js └─ test ├─ hot.js └─ index.spec.js |
Manage basic project structure for npm package on github.
Targets | Requires | Variables |
---|---|---|
project ├─ eslint.config.js ├─ .eslintrc.json ├─ ├─ .mocharc.yml ├─ README.md ├─ src │ └─ index.js └─ test ├─ hot.js └─ index.spec.js |
Updating gardener.js using overwrite.
- Manage gardener.js file for js-gardener.
Targets | Requires |
---|---|
project └─ |
Manage basic project structure for npm package on github.
Targets | Requires | Variables |
---|---|---|
project ├─ eslint.config.js ├─ .eslintrc.json ├─ .mocharc.yml ├─ README.md ├─ src │ └─ index.js └─ test ├─ hot.js └─ index.spec.js |
📋 struct/test-hot (index
)
Updating test/hot.js using overwrite.
- Create custom loader file.
Targets | Requires |
---|---|
project └─ test └─ hot.js |
Updating README.md using create-only.
- Create README.md template file.
Targets | Variables |
---|---|
project └─ README.md |
Updating .mocharc.yml using create-only.
- Create options file for mocha tests.
Targets | Requires |
---|---|
project └─ .mocharc.yml |
Updating test/index.spec.js using create-only.
- Create package template index.spec.js test file.
Targets | Requires |
---|---|
project └─ test └─ index.spec.js |
Updating src/index.js using create-only.
- Create package template index.js file.
Targets | Requires |
---|---|
project └─ src └─ index.js |
Updating .eslintrc.json using overwrite.
- Create configuration file for eslint enforcing opinionated, best practices.
Targets | Requires |
---|---|
project └─ .eslintrc.json |
Updating eslint.config.js using overwrite.
- Create configuration file for eslint enforcing opinionated, best practices.
Targets | Requires |
---|---|
project └─ eslint.config.js |
Manage semantic-release configuration for npm package on github.
Targets | Requires |
---|---|
project └─ .releaserc.json |
Updating .releaserc.json using overwrite.
- Slightly extended release commit convention for semantic-release.
Targets | Requires |
---|---|
project └─ .releaserc.json |
Manage package.json for npm package on github.
Targets | Requires | Variables |
---|---|---|
project └─ package.json |
Updating package.json using merge-shallow.
- Set various entries.
Targets | Requires | Variables |
---|---|---|
project └─ package.json |
Updating package.json using merge-deep.
- Set various entries.
Targets | Requires | Variables |
---|---|---|
project └─ package.json |
Updating package.json using default-shallow.
- Set defaults for various entries.
Targets | Requires |
---|---|
project └─ package.json |
Updating package.json using default-deep.
- Set defaults for various entries.
Targets | Requires |
---|---|
project └─ package.json |
Manage npm configuration for npm package on github.
Targets | Requires |
---|---|
project └─ .npmignore |
📋 npm/npmignore (index
)
Updating .npmignore using unique-top.
- Inject comment into .npmignore explaining when to use it.
Targets | Requires |
---|---|
project └─ .npmignore |
Manage license configuration for open source project.
Targets | Requires | Variables |
---|---|---|
project ├─ LICENSE └─ package.json |
Updating package.json using merge-shallow.
- Link MIT license file into npm configuration.
Targets | Requires | Variables |
---|---|---|
project └─ package.json |
Updating LICENSE using overwrite.
- Generate MIT license file.
Targets | Variables |
---|---|
project └─ LICENSE |
Manage WebStorm configuration.
Targets | Requires | Variables |
---|---|---|
project └─ .idea └─ ${projectName}.iml |
Updating .idea/${projectName}.iml (if exists) using xml-merge.
- Mark
coverage
Folder as excluded in Jetbrains.
Targets | Requires | Variables |
---|---|---|
project └─ .idea └─ ${projectName}.iml |
Manage gitignore configuration for npm package on github.
Targets | Requires |
---|---|
project └─ .gitignore |
Updating .gitignore using unique-top.
- Inject recommended entries into gitignore file.
- Default ignores for JetBrains IDE.
- Default ignores for OSX
- Default ignores for NodeJs
Targets | Requires |
---|---|
project └─ .gitignore |
Manage gally configuration for npm package on github.
Targets | Requires | Variables |
---|---|---|
project └─ .gally.json |
Updating .gally.json using overwrite.
- Restrictive two-branch config.
Targets | Requires | Variables |
---|---|---|
project └─ .gally.json |
📂 editor/#default (index
)
Manage editor configuration for project.
Targets |
---|
project └─ .editorconfig |
Updating .editorconfig using overwrite.
- Two space line indentation.
- Set
lf
line endings. - Set
utf8
encoding. - Remove unnecessary whitespaces.
Targets |
---|
project └─ .editorconfig |
Manage dependabot configuration for npm package on github.
Targets | Requires |
---|---|
project └─ .dependabot └─ config.yml |
Updating .dependabot/config.yml using overwrite.
- Configure dependabot to instantly merge javascript dependency updates into the
dev
branch.
Targets | Requires |
---|---|
project └─ .dependabot └─ config.yml |
Manage circleci configuration for npm package on github.
Targets | Requires |
---|---|
project └─ .circleci └─ config.yml |
Updating .circleci/config.yml using overwrite.
- Restrictive two-branch circleci config.
Targets | Requires |
---|---|
project └─ .circleci └─ config.yml |
📂 c8/#default (index
)
Manage .c8rc.json for c8 coverage testing.
Targets | Requires |
---|---|
project └─ .c8rc.json |
Updating .c8rc.json using merge-shallow.
- Set various entries.
Targets | Requires |
---|---|
project └─ .c8rc.json |
Updating .c8rc.json using merge-deep.
- Set various entries.
Targets | Requires |
---|---|
project └─ .c8rc.json |
Updating .c8rc.json using default-shallow.
- Set defaults for various entries.
Targets | Requires |
---|---|
project └─ .c8rc.json |
Updating .c8rc.json using default-deep.
- Set defaults for various entries.
Targets | Requires |
---|---|
project └─ .c8rc.json |
Add badged for npm open source package on github.
Targets | Requires | Variables |
---|---|---|
project └─ README.md |
Updating README.md using merge-below-title.
- Display npm status badge in README.
Targets | Requires | Variables |
---|---|---|
project └─ README.md |
Updating README.md using merge-below-title.
- Display npm downloads badge in README.
Targets | Requires | Variables |
---|---|---|
project └─ README.md |
📋 badges/circleci (index
)
Updating README.md using merge-below-title.
- Display circleci badge in README.
Targets | Requires | Variables |
---|---|---|
project └─ README.md |
Programming Language.
JavaScript, often abbreviated as JS, is a high-level, interpreted programming language that conforms to the ECMAScript specification. It is characterized as dynamic, weakly typed, prototype-based and multi-paradigm.
NodeJs Project Management.
Enforces and helps setting up best practices around NodeJs projects. 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.
JavaScript test framework.
Mocha is a JavaScript test framework for Node.js programs, featuring browser support, asynchronous testing, test coverage reports, and use of any assertion library.
JavaScript assertion library.
Chai is a BDD / TDD assertion library for node and the browser that can be paired with any javascript testing framework.
Linting for JavaScript.
JSLint is a static code analysis tool used in software development for checking if JavaScript source code complies with coding rules.
Automates npm package release workflow.
Automates the package release workflow including:
- determining the next version number
- generating the release notes
- publishing the package
Javascript package repository.
Requires the project to be conform with the npm standard, i.e. contain a package.json file. Does not require the project to be published to npm.
Javascript package repository published.
Requires the project to be published to npm either as a private or public package.
Collection of various IDEs.
Collection of various IDEs. There exists one for every major programming language and they are all very similar (i.e. shortcuts, layout), which makes them great when switching languages.
Coverage testing for javascript projects.
A major coverage testing framework for javascript. Comes with all the bells and whistles.
Version control system.
The most used version control system. Not to be confused with github (which uses git).
Run automated jobs using docker containers.
Allows set up for ci/cd using docker containers. Automates development process quickly, safely, and at scale.
Automation around github.com Repository Management
Allows management of github.com repositories through configuration. Very powerful when you need to synchronize settings across multiple repositories.
Major development platform powered by git.
GitHub is a code hosting platform for collaboration and version control. Lets you and others work together on projects.
Automatic dependency updates.
Makes dependency updates very easy by automatically creating pull requests in your repo. All major programming languages are supported or work is done towards supporting them.
Dependency management similar to npm.
Very similar functionality to npm cli.
packageName : string
Name of the package on npm.
The name of the project as published to npm. Note that for scoped packages the name can differ significantly from the repo name.
nccExclude : array
Default: ``
Exclude packages from ncc compilation.
nccEnabled : boolean
Enable ncc for service.
Uses NCC to compile service. Please ensure that the service still works after ncc compilation.
nodeVersion : string
The minimum node version targeted.
The minimum nodejs version that the project targets.
repoKey : string
Repository key.
The repository key contains the owner or organization of the project and the repository name itself, separated by a slash.
ownerName : string
Name of the owner of this project.
The owner name of the project is the name of the person or organization publishing the project under their license.
projectName : string
Name of the project.
The project name is in most cases identical to the repository name.
owner : string
The owner of the code on github.
The code owner is the gatekeeper of the project, ultimately responsible for all changes.
mergeBot : string
The github name of the bot used for automatic merging.
🔹 other
Runner for js-gardener.
Execute all configured js-gardener tasks.
🔹 other
Custom loader to allow hot reloading of files for testing.
🔹 nostruct
Project readme file.
Contains lots of information about the project itself.
🔺 mocha, javascript
🔹 list
Mocha test configuration file.
🔹 other
Main project test file.
Main test file for the project. At the very least tests signature of what is exposed.
🔹 other
Main project file.
Main file for the project. Exposes functionality for libraries.
🔺 eslint
🔹 json
Configuration file for eslint.
🔺 eslint
🔹 nostruct
Configuration file for eslint.
🔹 json
Configuration for semantic-release.
Configuration file for semantic-release and plugins
🔺 npm
🔹 json
Configuration for npm package.
🔺 npm, npm-published
🔹 list
Config to exclude files from npm package.
Note that this file is mostly not required. Use whitelisting instead. See here for more information.
🔹 nostruct
Project License file.
Specify the license the project is published under. Can be set to unlicensed as well.
🔹 xml
Module Library configuration file for JetBrains IDE.
🔺 git
🔹 list
Exclude files from being tracked.
Specifies files intentionally untracked by git.
🔹 json
Configuration file for gally.
Includes detailed configuration for github project structure.
🔹 other
Defines file formatting.
Defines file formatting that an IDE can pick up and use to format project files.
🔹 yml
Configuration file for dependabot.
🔺 circleci
🔹 yml
Configuration file for circleci.
🔺 c8
🔹 json
Configuration for c8 package.
🔹 any
Simply replace the old with the new content.
🔹 any
Does nothing when the file is already present, otherwise creates it.
🔹 json
, yml
Does a shallow merge aka Object.assign()
.
Useful when specific keys of the target need to be overwritten.
🔹 json
, yml
Does a "smart" deep merge.
This will not work as desired for all object deep merging, but should for many cases.
🔹 json
, yml
Similar to merge-shallow
, but keeps existing values instead of overwriting.
Useful to ensure specific keys of the target are present without overwriting existing content.
🔹 json
, yml
Similar to merge-deep
, but keeps existing values instead of overwriting.
Useful to ensure specific keys of the target are present without overwriting existing content.
🔹 list
Merges content at the top of the file and removes existing, duplicate lines.
Useful for managing e.g. .gitignore
when the original content should be kept.
🔹 xml
Does a "smart" deep merge.
This will not work as desired for all xml merging, but should for many cases.
🔹 list
, nostruct
Merges content below title.