Skip to content

Commit 7cbc265

Browse files
authored
docs: Update CONTRIBUTING.md and add one for kedro-datasets (kedro-org#379)
Update CONTRIBUTING.md + add one for kedro-datasets Signed-off-by: Ankita Katiyar <ankitakatiyar2401@gmail.com>
1 parent 080c73a commit 7cbc265

File tree

5 files changed

+135
-28
lines changed

5 files changed

+135
-28
lines changed

CONTRIBUTING.md

+3-4
Original file line numberDiff line numberDiff line change
@@ -15,20 +15,19 @@ We also curate a [GitHub repo that lists content created by the Kedro community]
1515
## Contribute to the project
1616

1717
There are quite a few ways to contribute to Kedro, such as answering questions about Kedro to help others, fixing a typo on the documentation, reporting a bug, reviewing pull requests or adding a feature.
18-
ls
1918
Take a look at some of our [contribution suggestions on the Kedro GitHub Wiki](https://github.com/kedro-org/kedro/wiki/Contribute-to-Kedro)!
2019

2120
## Which plugin contributions are likely to be accepted?
2221

2322
Dataset contributions to the [Kedro-Datasets](https://github.com/kedro-org/kedro-plugins/tree/main/kedro-datasets) plugin are the most frequently accepted, since they do not require any changes to the framework itself.
2423

25-
However, we accept contributions to any of the other [Kedro-Plugins](https://github.com/kedro-org/kedro-plugins) or the framework or `Kedro-Viz`. As a guide, contributions based on existing issues from the Kedro team, or issues that the team has deemed useful, are most likely to be accepted. Any contributions that affect fundamental changes to the Kedro Framework would require discussion first. In this case, we recommend opening an issue instead of a pull request.
24+
However, we accept contributions to any of the other [Kedro-Plugins](https://github.com/kedro-org/kedro-plugins) or the framework or [`Kedro-Viz`](https://github.com/kedro-org/kedro-viz). As a guide, contributions based on existing issues from the Kedro team, or issues that the team has deemed useful, are most likely to be accepted. Any contributions that affect fundamental changes to the Kedro Framework would require discussion first. In this case, we recommend opening an issue instead of a pull request.
2625

27-
Make sure to check out the contributing guides for [Kedro-Docker](https://github.com/kedro-org/kedro-plugins/blob/main/kedro-docker/CONTRIBUTING.md) and [Kedro-Airflow](https://github.com/kedro-org/kedro-plugins/blob/main/kedro-airflow/CONTRIBUTING.md) if you intend to contribute to those specific plugins.
26+
Make sure to check out the contributing guides for [Kedro-Docker](https://github.com/kedro-org/kedro-plugins/blob/main/kedro-docker/CONTRIBUTING.md), [Kedro-Datasets](https://github.com/kedro-org/kedro-plugins/blob/main/kedro-datasets/CONTRIBUTING.md) and [Kedro-Airflow](https://github.com/kedro-org/kedro-plugins/blob/main/kedro-airflow/CONTRIBUTING.md) if you intend to contribute to those specific plugins.
2827

2928
## Join the Technical Steering Committee
3029
Kedro is an incubating project in [LF AI & Data](https://lfaidata.foundation/), a sub-organisation within the Linux Foundation that focuses on open innovation within the data and AI space.
3130

32-
The project is governed by a group of maintainers, known as the Technical Steering Committee (TSC); read more about the structure of our TSC in our [Technical Charter](./kedro_technical_charter.pdf).
31+
The project is governed by a group of maintainers, known as the Technical Steering Committee (TSC); read more about the structure of our TSC in our [Technical Charter](https://github.com/kedro-org/kedro/blob/main/kedro_technical_charter.pdf).
3332

3433
We regularly invite community members to join the TSC and help define the future of the Kedro project. Read the [guidance on becoming a Kedro maintainer](https://docs.kedro.org/en/stable/contribution/technical_steering_committee.html) to understand the process of joining the TSC.

Makefile

+1-1
Original file line numberDiff line numberDiff line change
@@ -37,7 +37,7 @@ clean:
3737
install-test-requirements:
3838
cd $(plugin) && pip install ".[test]"
3939

40-
install-pre-commit: install-test-requirements
40+
install-pre-commit:
4141
pre-commit install --install-hooks
4242

4343
uninstall-pre-commit:

kedro-airflow/CONTRIBUTING.md

+12-11
Original file line numberDiff line numberDiff line change
@@ -6,29 +6,27 @@ The following sections describe our vision and the contribution process.
66

77
## Code of conduct
88

9-
The Kedro team pledges to foster and maintain a welcoming and friendly community in all of our spaces. All members of our community are expected to follow our [Code of Conduct](CODE_OF_CONDUCT.md) and we will do our best to enforce those principles and build a happy environment where everyone is treated with respect and dignity.
9+
The Kedro team pledges to foster and maintain a welcoming and friendly community in all of our spaces. All members of our community are expected to follow our [Code of Conduct](CODE_OF_CONDUCT.md), and we will do our best to enforce those principles and build a happy environment where everyone is treated with respect and dignity.
1010

1111
# Get started
1212

1313
We use [GitHub Issues](https://github.com/kedro-org/kedro-plugins/issues) to keep track of known bugs. We keep a close eye on them and try to make it clear when we have an internal fix in progress. Before reporting a new issue, please do your best to ensure your problem hasn't already been reported. If so, it's often better to just leave a comment on an existing issue, rather than create a new one. Old issues also can often include helpful tips and solutions to common problems.
1414

15-
If you are looking for help with your code, please consider posting a question on [Stack Overflow](https://stackoverflow.com/questions/tagged/kedro-airflow). If you tag it `kedro-airflow`, `kedro` and `python`, more people will see it and may be able to help. We are unable to provide individual support via email. In the interest of community engagement we also believe that help is much more valuable if it's shared publicly, so that more people can benefit from it.
16-
17-
If you're over on Stack Overflow and want to boost your points, take a look at the `kedro-airflow` tag and see if you can help others out by sharing your knowledge. It's another great way to contribute.
15+
If you are looking for help with your code, please consider posting a question on [our Slack organisation](https://slack.kedro.org/). You can post your questions to the `#questions` or the `#plugins-integrations` channel. Past questions and discussions from our Slack organisation are accessible on [Linen](https://linen-slack.kedro.org/). In the interest of community engagement we also believe that help is much more valuable if it's shared publicly, so that more people can benefit from it.
1816

1917
If you have already checked the [existing issues](https://github.com/kedro-org/kedro-plugins/issues) on GitHub and are still convinced that you have found odd or erroneous behaviour then please file a [new issue](https://github.com/kedro-org/kedro-plugins/issues/new/choose). We have a template that helps you provide the necessary information we'll need in order to address your query.
2018

2119
## Feature requests
2220

2321
### Suggest a new feature
2422

25-
If you have new ideas for Kedro-Airflow functionality then please open a [GitHub issue](https://github.com/kedro-org/kedro-plugins/issues) with the label `Type: Enhancement`. Please describe in your own words the feature you would like to see, why you need it, and how it should work.
23+
If you have new ideas for Kedro-Airflow functionality then please open a [GitHub issue](https://github.com/kedro-org/kedro-plugins/issues) with the label `enhancement`. Please describe in your own words the feature you would like to see, why you need it, and how it should work.
2624

2725
### Contribute a new feature
2826

29-
If you're unsure where to begin contributing to Kedro-Airflow, please start by looking through the `good first issues` and `Request: Help Wanted` on [GitHub](https://github.com/kedro-org/kedro-plugins/issues).
27+
If you're unsure where to begin contributing to Kedro-Airflow, please start by looking through the `good first issue` and `help wanted` on [GitHub](https://github.com/kedro-org/kedro-plugins/issues).
3028

31-
Typically, small contributions to Kedro-Airflow are more preferable due to an easier review process, but we accept any new features if they prove to be essential for the functioning of the plugin or if we believe that they are used by most projects.
29+
Typically, small contributions to `kedro-airflow` are more preferable due to an easier review process, but we accept any new features if they prove to be essential for the functioning of the plugin or if we believe that they are used by most projects.
3230

3331
## Your first contribution
3432

@@ -69,15 +67,18 @@ We use a branching model that helps us keep track of branches in a logical, cons
6967
## Plugin contribution process
7068

7169
1. Fork the project
72-
2. Develop your contribution in a new branch and open a PR against the `master` branch
73-
3. Make sure the CI builds are green (have a look at the section [Running checks locally](#running-checks-locally) below)
74-
4. Update the PR according to the reviewer's comments
70+
2. Develop your contribution in a new branch.
71+
3. Make sure all your commits are signed off by using `-s` flag with `git commit`.
72+
4. Open a PR against the `main` branch and sure that the PR title follows the [Conventional Commits specs](https://www.conventionalcommits.org/en/v1.0.0/) with the scope `(airflow)`.
73+
5. Make sure the CI builds are green (have a look at the section [Running checks locally](#running-checks-locally) below)
74+
6. Update the PR according to the reviewer's comments
7575

7676
## CI / CD and running checks locally
7777
To run E2E tests you need to install the test requirements which includes `behave`, do this using the following command:
7878

7979
```bash
80-
pip install ".[test]"
80+
make plugin=kedro-airflow install-test-requirements
81+
make install-pre-commit
8182
```
8283

8384
### Running checks locally

kedro-datasets/CONTRIBUTING.md

+106
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,106 @@
1+
# Introduction
2+
3+
4+
Thank you for considering contributing to Kedro-Datasets! Kedro-Datasets is a collection of [Kedro's](https://github.com/kedro-org/kedro) data connectors. We welcome contributions in the form of pull requests, issues or code reviews. You can contribute new datasets, fix bugs in existing datasets, or simply send us spelling and grammar fixes or extra tests. Contribute anything that you think improves the community for us all!
5+
6+
The following sections describe our vision and the contribution process.
7+
8+
## Code of conduct
9+
10+
The Kedro team pledges to foster and maintain a welcoming and friendly community in all of our spaces. All members of our community are expected to follow our [Code of Conduct](CODE_OF_CONDUCT.md), and we will do our best to enforce those principles and build a happy environment where everyone is treated with respect and dignity.
11+
12+
# Get started
13+
14+
We use [GitHub Issues](https://github.com/kedro-org/kedro-plugins/issues) to keep track of known bugs. We keep a close eye on them and try to make it clear when we have an internal fix in progress. Before reporting a new issue, please do your best to ensure your problem hasn't already been reported. If so, it's often better to just leave a comment on an existing issue, rather than create a new one. Old issues also can often include helpful tips and solutions to common problems.
15+
16+
If you are looking for help with your code, please consider posting a question on [our Slack organisation](https://slack.kedro.org/). You can post your questions to the `#questions` channel. Past questions and discussions from our Slack organisation are accessible on [Linen](https://linen-slack.kedro.org/). In the interest of community engagement we also believe that help is much more valuable if it's shared publicly, so that more people can benefit from it.
17+
18+
If you have already checked the [existing issues](https://github.com/kedro-org/kedro-plugins/issues) on GitHub and are still convinced that you have found odd or erroneous behaviour then please file a [new issue](https://github.com/kedro-org/kedro-plugins/issues/new/choose). We have a template that helps you provide the necessary information we'll need in order to address your query.
19+
20+
## Feature requests
21+
22+
### Suggest a new feature
23+
24+
If you have new ideas for Kedro-Datasets then please open a [GitHub issue](https://github.com/kedro-org/kedro-plugins/issues) with the label `enhancement`. Please describe in your own words the feature you would like to see, why you need it, and how it should work.
25+
26+
### Contribute a new dataset
27+
28+
If you're unsure where to begin contributing to Kedro-Datasets, please start by looking through the `good first issue` and `help wanted` on [GitHub](https://github.com/kedro-org/kedro-plugins/issues).
29+
If you want to contribute a new dataset, read the [tutorial to create and contribute a custom dataset](https://docs.kedro.org/en/stable/data/how_to_create_a_custom_dataset.html) in the Kedro documentation.
30+
Make sure to add the new dataset to `kedro_datasets.rst` so that it shows up in the API documentation and to `static/jsonschema/kedro-catalog-X.json` for IDE validation.
31+
32+
33+
## Your first contribution
34+
35+
Working on your first pull request? You can learn how from these resources:
36+
* [First timers only](https://www.firsttimersonly.com/)
37+
* [How to contribute to an open source project on GitHub](https://egghead.io/courses/how-to-contribute-to-an-open-source-project-on-github)
38+
39+
### Guidelines
40+
41+
- Aim for cross-platform compatibility on Windows, macOS and Linux
42+
- We use [Anaconda](https://www.anaconda.com/distribution/) as a preferred virtual environment
43+
- We use [SemVer](https://semver.org/) for versioning
44+
45+
Our code is designed to be compatible with Python 3.6 onwards and our style guidelines are (in cascading order):
46+
47+
* [PEP 8 conventions](https://www.python.org/dev/peps/pep-0008/) for all Python code
48+
* [Google docstrings](https://google.github.io/styleguide/pyguide.html#38-comments-and-docstrings) for code comments
49+
* [PEP 484 type hints](https://www.python.org/dev/peps/pep-0484/) for all user-facing functions / class methods e.g.
50+
51+
```
52+
def count_truthy(elements: List[Any]) -> int:
53+
return sum(1 for elem in elements if elem)
54+
```
55+
56+
> *Note:* We only accept contributions under the [Apache 2.0](https://opensource.org/licenses/Apache-2.0) license, and you should have permission to share the submitted code.
57+
58+
### Branching conventions
59+
60+
We use a branching model that helps us keep track of branches in a logical, consistent way. All branches should have the hyphen-separated convention of: `<type-of-change>/<short-description-of-change>` e.g. `feature/awesome-new-feature`
61+
62+
| Types of changes | Description |
63+
| ---------------- | --------------------------------------------------------------------------- |
64+
| `docs` | Changes to the documentation of the plugin |
65+
| `feature` | Non-breaking change which adds functionality |
66+
| `fix` | Non-breaking change which fixes an issue |
67+
| `tests` | Changes to project unit (`tests/`) and / or integration (`features/`) tests |
68+
69+
## Plugin contribution process
70+
71+
1. Fork the project
72+
2. Develop your contribution in a new branch.
73+
3. Make sure all your commits are signed off by using `-s` flag with `git commit`.
74+
4. Open a PR against the `main` branch and sure that the PR title follows the [Conventional Commits specs](https://www.conventionalcommits.org/en/v1.0.0/) with the scope `(datasets)`.
75+
5. Make sure the CI builds are green (have a look at the section [Running checks locally](#running-checks-locally) below)
76+
6. Update the PR according to the reviewer's comments
77+
78+
## CI / CD and running checks locally
79+
To run tests you need to install the test requirements, do this using the following command:
80+
81+
```bash
82+
make plugin=kedro-datasets install-test-requirements
83+
make install-pre-commit
84+
```
85+
86+
87+
### Running checks locally
88+
89+
All checks run by our CI / CD pipeline can be run locally on your computer.
90+
91+
#### Linting (`ruff` and `black`)
92+
93+
```bash
94+
make plugin=kedro-datasets lint
95+
```
96+
97+
#### Unit tests, 100% coverage (`pytest`, `pytest-cov`)
98+
99+
```bash
100+
make plugin=kedro-datasets test
101+
```
102+
103+
If the tests in `kedro-datasets/kedro_datasets/spark` are failing, and you are not planning to work on Spark related features, then you can run the reduced test suite that excludes them with this command:
104+
```bash
105+
make test-no-spark
106+
```

0 commit comments

Comments
 (0)