We'd love to accept your patches and contributions and help make this project even better than it is today!
As a contributor, here are the guidelines we would like you to follow:
- Clone this repository
git clone https://github.com/hdorgeval/playwright-fluent
cd playwright-fluent
- Install dependencies
Ensure your node version is >= 18.
npm install
- Install peer dependencies
npm run install-peers
- Run tests locally
npm test
Commit messages should follow the Semantic Commit Messages format:
label(namespace): title
description
footer
-
label is one of the following:
chore
- build-related work, a change in the package.json file, a change in a configuration file or a change to a script file.docs
- changes to docs, e.g.docs(api.md): ..
to change documentation.feat
- a new feature.fix
- a bug fix.refactor
- a code change that neither fixes a bug nor adds a featurestyle
- a change in the code style: spaces/alignment/wrapping etc.test
- adding missing tests or correcting existing tests.
-
namespace is put in parenthesis after label and is mandatory. Must be lowercase.
-
title is a brief summary of changes.
-
description is optional, new-line separated from title and is in present tense.
-
footer is optional, new-line separated from description and contains "fixes" / "references" attribution to github issues.
-
footer should also include "BREAKING CHANGE" if current API clients will break due to this change. It should explain what changed and how to get the old behavior.
Example:
fix(page): fix page.pizza method
This patch fixes page.pizza so that it works with iframes.
Fixes #123, Fixes #234
BREAKING CHANGE: page.pizza now delivers pizza at home by default.
To deliver to a different location, use "deliver" option:
`page.pizza({deliver: 'work'})`.
- You should follow this Github Guide on Markdown
-
Comments inside code should be generally avoided. If the code would not be understood without comments, consider re-writing the code to make it self-explanatory.
-
You should only comment public methods exposed by the API. Use JSDoc syntax and/or use the VSCode extension Document This
For all dependencies (both installation and development):
- Do not add a dependency if the desired functionality is easily implementable.
- If adding a dependency, it should be well-maintained and trustworthy.
A barrier for introducing new installation dependencies is especially high:
- Do not add a production dependency unless it's critical to project success.