2020-03-24 15:00:46 +00:00
# Contribution Guidelines
2020-06-13 15:33:06 +05:30
2022-03-24 10:42:00 +03:00
Before publishing a PR, please test builds locally.
2020-03-24 15:00:46 +00:00
2021-12-03 02:36:58 +03:00
On each PR that contains changes relevant to Docker builds, images are being built and tested in our CI (GitHub Actions).
2020-03-24 15:00:46 +00:00
2021-12-10 11:53:43 +03:00
> :evergreen_tree: Please be considerate when pushing commits and opening PR for multiple branches, as the process of building images uses energy and contributes to global warming.
2021-12-10 11:48:00 +03:00
2021-12-03 02:36:58 +03:00
## Lint
2020-03-24 15:00:46 +00:00
2021-12-10 11:48:00 +03:00
We use `pre-commit` framework to lint the codebase before committing.
First, you need to install pre-commit with pip:
```shell
pip install pre-commit
```
Also you can use brew if you're on Mac:
2021-12-03 02:36:58 +03:00
```shell
2021-12-10 11:48:00 +03:00
brew install pre-commit
2021-12-03 02:36:58 +03:00
```
2020-03-24 15:00:46 +00:00
2021-12-10 11:48:00 +03:00
To setup _pre-commit_ hook, run:
```shell
pre-commit install
```
To run all the files in repository, run:
```shell
pre-commit run --all-files
```
2021-12-03 02:36:58 +03:00
## Build
2020-06-13 15:33:06 +05:30
2022-03-24 10:42:00 +03:00
We use [Docker Buildx Bake ](https://docs.docker.com/engine/reference/commandline/buildx_bake/ ). To build the images, run command below:
2021-12-03 02:36:58 +03:00
```shell
2022-03-24 10:42:00 +03:00
FRAPPE_VERSION=... ERPNEXT_VERSION=... docker buildx bake < targets >
2021-12-03 02:36:58 +03:00
```
2020-06-13 15:33:06 +05:30
2022-03-24 10:42:00 +03:00
Available targets can be found in `docker-bake.hcl` .
2020-06-13 15:33:06 +05:30
2022-03-24 10:42:00 +03:00
## Test
2021-12-10 11:53:43 +03:00
2022-03-24 10:42:00 +03:00
We use [pytest ](https://pytest.org ) for our integration tests.
2020-06-13 15:33:06 +05:30
2022-03-24 10:42:00 +03:00
Install Python test requirements:
2021-12-10 11:53:43 +03:00
2021-12-03 02:36:58 +03:00
```shell
2022-03-24 10:42:00 +03:00
python3 -m venv venv
source venv/bin/activate
pip install -r requirements-test.txt
2021-12-03 02:36:58 +03:00
```
2020-03-24 15:00:46 +00:00
2022-03-24 10:42:00 +03:00
Run pytest:
2021-12-10 11:53:43 +03:00
2021-12-03 02:36:58 +03:00
```shell
2022-03-24 10:42:00 +03:00
pytest
2021-12-03 02:36:58 +03:00
```
2020-03-24 15:00:46 +00:00
2022-03-24 10:42:00 +03:00
> We also have `requirements-dev.txt` file that contains development requirements for backend image (you can find it in `images/worker/` directory).
2020-03-24 15:00:46 +00:00
2020-06-13 15:33:06 +05:30
# Documentation
2020-03-24 15:00:46 +00:00
2022-03-24 10:42:00 +03:00
Place relevant markdown files in the `docs` directory and index them in README.md located at the root of repo.
2021-02-25 15:29:54 +05:30
# Wiki
Add alternatives that can be used optionally along with frappe_docker. Add articles to list on home page as well.
2021-06-24 16:54:17 +05:30
2021-12-03 02:36:58 +03:00
# Frappe and ERPNext updates
2021-06-24 16:54:17 +05:30
2021-12-03 02:36:58 +03:00
Each Frappe/ERPNext release triggers new stable images builds as well as bump to helm chart.