Skip to content

Commit

Permalink
docs: add CONTRIBUTING guide, update README
Browse files Browse the repository at this point in the history
  • Loading branch information
tomassebestik committed Feb 13, 2024
1 parent ee5a61f commit d3b81da
Show file tree
Hide file tree
Showing 4 changed files with 215 additions and 121 deletions.
2 changes: 1 addition & 1 deletion .github/workflows/python-test.yml
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
name: Python Tests
name: Tests

on:
pull_request:
Expand Down
76 changes: 76 additions & 0 deletions CONTRIBUTING.md
Original file line number Diff line number Diff line change
@@ -1 +1,77 @@
We welcome contributions! To contribute to this repository, please read these instructions:

- [Project Organization](#project-organization)
- [Code and Testing](#code-and-testing)
- [Documentation and Maintenance](#documentation-and-maintenance)
- [Development and local testing](#development-and-local-testing)

---

## Project Organization

- **Project Configuration:** The setup for both production and development dependencies is outlined in the `pyproject.toml` file. This centralized approach simplifies dependency management.

- **Automatic `requirements.txt`:** Changes to dependencies are automatically reflected in the `requirements.txt` file, derived from `pyproject.toml`. Direct modifications should be avoided; instead, update `pyproject.toml`.

- **Commit Standard:** Adherence to the Espressif standard for Conventional Commits ensures consistency in commit messages. Tools like pre-commit hooks and the integrated PR linter DangerJS assist in formatting commit messages appropriately, a key factor for `commitizen` to auto-generate the changelog.

## Code and Testing

- **Code Style and Structure:**

- **Pre-Commit Hooks:** Install pre-commit hooks in this repository using the `pre-commit install` command.

- **Readable Code Structure:** Structure your code in a readable manner. The main logic should be in the default rule function, with implementation details in helper functions. Avoid nested `if` statements and unnecessary `else` statements to maintain code clarity and simplicity.

- **Remove Debug Statements:** Remove any development debug statements from your files.

- **Automated Tests:** The tests should cover all typical usage scenarios as well as edge cases to ensure robustness.

- **Testing Tool:** It is recommended to run `pytest` frequently during development to ensure that all aspects of your code are functioning as expected.

## Documentation and Maintenance

- **Changelog:** `CHANGELOG.md` is generated automatically by `commitizen` from commit messages. Not need to update `CHANGELOG.md` manually. Focus on informative and clear commit messages which end in the release notes.

- **Documentation:** Regularly check and update the documentation to keep it current.

- **PR Descriptions and Documentation:** When contributing, describe all changes or new features in the PR (Pull Request) description as well as in the documentation. When changing the style to the output style, attach a thumbnail after the change.

## Development and local testing

1. **Clone the Project**: Clone the repository to your local machine using:

```sh
git clone <project_clone_url>
```

2. **Set Up Development Environment:**

- Create and activate a virtual environment:

```sh
python -m venv venv && source ./venv/bin/activate
```

or:

```sh
virtualenv venv && source ./venv/bin/activate
```

- Install the project and development dependencies:
```sh
pip install -e '.[dev]'
```

3. **Testing Your Changes:**

Before submitting a pull request, ensure your changes pass all the tests. You can run the test suite with the following command:

```sh
pytest
```

---

👏**Thank you for your contributions.**
Loading

0 comments on commit d3b81da

Please sign in to comment.