-
Notifications
You must be signed in to change notification settings - Fork 1.6k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #2977 from tejal29/small_prs
Add small pr guidelines
- Loading branch information
Showing
2 changed files
with
87 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,86 @@ | ||
# Pull Request Guidelines | ||
|
||
Writing good pull requests increases development velocity and minimizes frustration. | ||
|
||
Small pull request will be merged quicker. | ||
|
||
Having big pull requests that bounce back and forth between developers | ||
and reviewers can slow progress down significantly, causing developers to waste a | ||
lot of time dealing with merge conflicts. | ||
|
||
Big pull requests also increase the risk of breaking things; since changes are so big, | ||
- it’s hard to truly understand all the changes and | ||
- test them for regressions. | ||
|
||
In order to promote good PR quality, the skaffold team will push back | ||
against big PRs. See [0](https://github.com/GoogleContainerTools/skaffold/pull/2750#pullrequestreview-283621241), [1](https://github.com/GoogleContainerTools/skaffold/pull/2917#pullrequestreview-291415741) | ||
|
||
## Breaking down Pull Requests | ||
|
||
### Feature development. | ||
When proposing a new feature, please review our [Design Document Proposal](../design_proposals) to see if you should first create a `Design Proposal`. | ||
|
||
Adding a new command or skaffold config results in large number of changes due to | ||
all the boilerplate code required for adding a new command, generating docs etc. | ||
|
||
It makes sense to break down these changes into 2 categories: | ||
1. "Invisible changes": Incremental, small code changes | ||
1. refactoring: either keep the functionality the same but refactoring the design or | ||
1. partial implementations: unit tested, new behavior, that is not yet accessible by the main control flow. | ||
2. "Visible changes": User affecting changes, for example | ||
1. Adding a new command which exercises the above code changes | ||
1. Adding config change and generating docs. | ||
|
||
#### Config Change Example | ||
Below is an example of how you can break a config change into small individual PRs. | ||
|
||
A contributor wanted to support [custom build args to `kustomize` deployer](https://github.com/GoogleContainerTools/skaffold/issues/2488). | ||
This required skaffold to add the `deploy.kustomize.buildArgs` field and then plumb the arguments to the `kustomize` command. | ||
|
||
This small 10 line change results into 100+ lines of code along with test code. | ||
It would greatly simplify code review process if we break this change into | ||
1. Coding logic and test coverage. | ||
2. User facing documentation. | ||
|
||
In this case, the contributor split this PR in 2 small changes | ||
1. Introduce a [place holder for a new config](https://github.com/GoogleContainerTools/skaffold/pull/2870). | ||
|
||
This PR highlights the logic changes and makes it easier for reviewers to review code logic and tests. | ||
|
||
Note: The code added in this PR does not get exercised other than in tests. | ||
2. [Add a field to skaffold config](https://github.com/GoogleContainerTools/skaffold/pull/2871) and pass it to the place holder. | ||
This PR makes it easier for reviewers to review the user facing config changes and make sure all the precautions like | ||
- good user documentation | ||
- deprecation policy if applicable | ||
- upgrade policy etc were followed. | ||
|
||
#### Adding new functionality | ||
Below is an example on how you can introduce a new functionality to skaffold in smaller incremental PRs. | ||
|
||
To add ability to [render templated k8 manifests without deploying](https://github.com/GoogleContainerTools/skaffold/issues/1187), required us to make a bunch of changes in skaffold | ||
1. Add this feature to `kubectl`, `helm` and `kustomize` deployers supported by skaffold. | ||
2. support a new flag for `skaffold deploy` and `skaffold run` command | ||
3. may be add a new command to only render k8 manifests. | ||
|
||
Item 2 and 3 in the above list of changes, are user facing features and could be abstracted out. | ||
Item 1 can further be implemented incrementally by supporting this new feature for each of the deployer. | ||
|
||
To implement this feature, we | ||
1. First added an [method to interface `deployer` with empty stub](https://github.com/GoogleContainerTools/skaffold/pull/2834). | ||
|
||
Note: The code added in this PR does not get exercised other than in tests. | ||
2. Then add render implementation for each [kubectl deployer](https://github.com/GoogleContainerTools/skaffold/pull/2943), kustomize and helm. | ||
3. Add a [render command](https://github.com/GoogleContainerTools/skaffold/pull/2942) | ||
|
||
Remember, its ok to land code which is not exercised. However please mention the follow up work | ||
in **Next PRs** section when creating a Pull Request [e.g. here.](https://github.com/GoogleContainerTools/skaffold/pull/2811) | ||
|
||
Implementing the full functionality sometimes might makes a lot of sense, | ||
- so that you can get feedback regarding the code while implementing it also | ||
- the maintainers can try it out and test it, get a feel for it. | ||
|
||
If you are opening a big PR, we can mark these as `Draft PR` that will broken down into smaller PRs that can refer back to this `Draft PR`. | ||
You can either rebase the `Draft PR` as the smaller pieces get merged, and then finally merge `Draft PR` or close it without merging once all functionality is implemented. | ||
See for example [#2917](https://github.com/GoogleContainerTools/skaffold/pull/2917). | ||
|
||
Finally, please use your best judgement when submitting pull requests, these rules might not always work for you - we would love to hear that! |