Working on your first Pull Request? You can learn how from this free series, How to Contribute to an Open Source Project on GitHub.
All contributions must be submitted as a Pull Request (PR) so you need to fork this repo on your GitHub account.
The main branch aka mainline is master
, it contains the latest code, and it is undergoing major development. Any other branch is temporary and could be deleted. You can read more about the Trank-based development to get a deep understanding of how it works.
⚡ All PRs must be against the
master
branch to be considered.
A valid PR must follow these points:
- Unit test is correctly implemented and covers the new scenario.
- If the code introduces a new feature, please add documentation or describe the feature in the PR description.
- The commit message follows the conventional commit.
- The reviewer is assigned from the developers of the same project or code owners, possibly related to the task designed or a component affected.
- If you are going to work on new features or fix bugs or make significant architecture changes, create an issue before sending a PR, use close keywords to link an issue, and PR.
The PR, which is NOT planned to be merged, has to be converted to draft PR.
To release a new version, you should issue the following commands:
git fetch origin
git checkout master
git merge --squash branch-name
git commit -m 'message'
Use --squash
, to leave the history of commits in feature-branch and prevents the Git merge command from creating a merge commit.
To create a feature branch you should issue the following commands:
git fetch
git checkout --no-track -b branch-name origin/master
Each branch name consists of a type, ref, and subject.
<type>[<DELIMITER>#<ref>]/<subject>
Where type
- can accept one of the values are described below, ref
- reference GitHub issues, Jira tickets, or other PRs.
e.g. fix-#184/multiple-hosts-are-duplicated
or fix/multiple-hosts-are-duplicated
The type
and subject
are mandatory, the ref
is optional.
The commits must follow the https://www.conventionalcommits.org/en/v1.0.0/ naming convention. Please make sure to read the full guideline.
Each commit message consists of a header, a body, and a footer.
<header>
<BLANK LINE>
<body>
<BLANK LINE>
<footer>
The header
is mandatory and must conform to the following format:
<type>(<scope>): <short summary>
│ │ │
│ │ └─⫸ Summary in present tense. Not capitalized. No period at the end.
│ │
│ └─⫸ Commit Scope depends on ubiquitous language, e.g. scan, request-executor, identity, dast, auth-object, etc.
│
└─⫸ Commit Type: build|ci|docs|feat|fix|perf|refactor|test
The header
should be limited to 100 symbols, make sure the first letter is not capitalized.
The type
must be one of the following:
-
feat: A new feature
-
fix: A bug fix
-
docs: Documentation only changes
-
style: Changes that do not affect the meaning of the code (white-space, formatting, missing semi-colons, etc)
-
refactor: A code change that neither fixes a bug nor adds a feature
-
perf: A code change that improves performance
-
test: Adding missing or correcting existing tests
-
build: Changes to the build process or auxiliary tools and libraries such as documentation generation
-
ci: Changes to the CI/CD process
The header
and body
must use the imperative, present tense: "change" not "changed" nor "changes".
The body
should include the motivation for the change and contrast this with previous behavior.
The footer
can contain information about breaking changes and is also the place to reference GitHub issues (see details in Linking a pull request to an issue), Jira tickets (see details in Smart Commits guideline), and other PRs that this commit closes or is related to, i.e.:
feat(dast): add entry point statistics
add the amount of requests dispatched per entry point
closes #666
The full description should not repeat the short description. If the short description is self-explanatory, leave only the footer
:
feat(dast): add the amount of requests per dispatched entry point
NLJ-480 #close
If the commit reverts a previous commit, it should begin with revert:
, followed by the header of the reverted commit. In the body, it should say: Reverts commit <hash>.
, where the hash is the SHA of the commit being reverted.
revert: add the amount of requests per dispatched entry point
Reverts commit 0000000
To ensure consistency throughout the source code, keep these rules in mind as you are working:
- Inspect the format, syntax errors, deviations before pushing to the branch.
- Don't use transpilation mode of the compiler. You can use it only to debug.
- We love OOP and, whenever possible, prefer them over closures and functions.
⚡ We use husky, commitlint and lint-staged, they will help you to follow these rules.
To install all dependencies used by this project, issue this command in your terminal:
$ npm ci
The project can be built manually by issuing the following command:
npm run build -- ${lib}
The build artifacts will be stored in the dist
folder.
Run this command in terminal to execute the unit tests via Jest:
$ npm t
Run his command in terminal to execute the end-to-end tests:
$ npm run e2e
Set NODE_ENV
variable to test
if you want to use test mock and stubs, to reduce overhead.
This project uses ESLint for code linting.
⚡ ESLint can be configured via
.eslintrc.json
file in the project root folder.
To lint all the apps and modules by running:
$ npm run nx run-many --all --target lint
To lint single module, run this command in terminal:
$ npm run lint -- ${lib}
To lint multiple modules at once:
$ npm run nx run-many -- --target=lint --projects=${lib},${lib1}
This project uses Prettier for code formatting.
⚡ ESLint can be configured via
.prettierrc
file in the project root folder.
To format all the apps and modules by running:
$ npm run format
To format single module, run this command in terminal:
$ npm run format -- ${lib}
To format multiple modules at once:
$ npm run format -- --projects=${lib},${lib1}
Issue the following command to generate a new package:
$ nx generate @nx/node:lib ${lib} --importPath=@sectester/${lib}
⚡ It is important to have a clean git working directory before invoking a generator so that you can easily revert changes and re-invoke the generator with different inputs.
This will create a new library inside the working directory according to the schematic.
To generate the publish
executor to release a package, you just need to issue the following command:
nx workspace-generator publish ${lib} --buildTarget ${lib}:build