Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Docs #77

Open
wants to merge 7 commits into
base: main
Choose a base branch
from
Open

Docs #77

Show file tree
Hide file tree
Changes from 6 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
241 changes: 241 additions & 0 deletions CONTRIBUTING.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,241 @@
# Contributing to the cinder operator

Thank you for taking the time to contribute!

The following is a set of guidelines for contributing to the [cinder-operator
hosted in GitHub](https://github.com/openstack-k8s-operators/cinder-operator).
Feel free to propose changes to this document or any other in a pull request.

## What should I know before I get started?

The cinder-operator is not a large open source project, but it's part of the
[OpenStack podification effort](https://github.com/openstack-k8s-operators)
which is of some size.

There are some requirements to deploy a working Cinder control plane within
OpenShift using the cinder-operator. For simplicity's sake all the
documentation will assume that the
[openstack-operator](https://github.com/openstack-k8s-operators/openstack-operator)
will be used to deploy necessary services, though this doesn't mean that there
are no other ways to do it.

Before working on your first code contribution it would be a good idea to
complete the [getting started](README.md#getting-started) section first to get
familiar with the deploying of the services and to get a feeling of the
behavior of a working OpenStack deployment.

Please refer to the [OpenStack documentation](https://docs.openstack.org) to
learn about OpenStack itself.

### Design decisions

There is some [global podification
documentation](https://github.com/openstack-k8s-operators/docs) relevant for
all the operators, but there are also some global design decisions that have
not been spelled out yet anywhere else, so they are included in the
[cinder-operator design decisions document](docs/dev/design-decisions.md).

## How to contribute?

This project is [using pull
request](https://docs.github.com/en/pull-requests/collaborating-with-pull-requests/proposing-changes-to-your-work-with-pull-requests/about-pull-requests)
to submit changes, but it is not currently using the [issues
section](https://github.com/openstack-k8s-operators/cinder-operator/issues) or
any other GitHub feature to track the project's bugs or features and instead it
is expected that whoever finds an issue will fix it or will find someone else
to work on it.

### Testing changes

Developers submitting PRs are expected to have run the code and manually
verified the functionality before submitting the PR, with the exception
of documentation only and CI only PRs.

There are multiple ways to test code changes, but in general terms they can be
split into 2 categories: running things locally or in a container in the
OpenShift cluster.

Running things locally is considerably faster but it doesn't use the real ACLs
(RBACs) the cinder-operator would use on a normal deployment. On the other hand
running things in OpenShift is slower (because we have to build a new
container) but runs as close as a real deployment as we can.

Each of the approaches has its own advantages and disadvantages, so different
variants of both approaches will be covered for readers to choose the one they
prefer.

The following list of articles assumes that podified OpenStack has been
deployed using the openstack-operator as described in the [Getting started
section](README.md#getting-started):

- [Run operator locally](docs/dev/local.md)
- [Run operator in OpenShift using a custom image](docs/dev/custom-image.md)
- [Running locally with external dependencies](docs/dev/local-dependencies.md)
- [Running in OpenShift with external
dependencies](docs/dev/custom-image-dependencies.md)

There is a script called `hack/checkout_pr.sh` that is helpful when we want to
test an existing PR that has dependencies. Check the [Testing PR section in the
hack documentation](hack/README.md#testing-prs) for additional information.

### Debugging

When working on the cinder-operator there will be times where things won't work
as expected and we'll need to debug things.

In the [debugging article](docs/dev/debug.md) we present some ideas to help you
figure things out.

### Pull Requests

While the pull request flow is used for submitting new issues and for
reviewing, the git repository should **always** be the source of truth, so all
decisions made through the reviewing and design phases should be properly
reflected in the final code, code comments, documentation, and git commit
message that is merged. It should not be necessary to go to a PR in GitHub and
go through the comments to know what a commit is meant to do or why it is doing
it.

*One-liner* commit messages should be avoided like the plague. Please refer to
the [commit messages guide line](#commit-messages) for good practices on commit
messages.

The cinder-operator project will not squash all pull request commits into a
single commit but will look to preserve all submitted individual commits
instead using a merge strategy instead. This means that we can have both
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please remove one of the 'instead'.

single commit and as multi-commit PRs, and both have their places. It's all
about how and when to split changes.

#### Dependency Management

When submitting a PR that has dependencies in other repositories these
dependencies should be stated in the PR or the commits using the `Depends-On:`
tag.

There are 4 ways to state a dependency with another projects PR:
- `Depends-On: lib-common=88`
- `Depends-On: lib-common#88`
- `Depends-On: openstack-k8s-operators/lib-common#88`
- `Depends-On: https://github.com/openstack-k8s-operators/lib-common/88`

Multiple `Depends-On:` tags are supported.

For the time being these tags are only useful when using the
`hack/checkout_pr.sh` or `hack/showdeps.py` scripts.

A good example of using these tags is the `extraVol` series of PRs. There are
PRs in 4 projects: lib-common, cinder-operator, glance-operator, and the
openstack-operator.

The operators all require the lib-common PR, but then there are 2 circular
requirements. One is between the cinder-operator and the openstack-operator,
and the other is between the glance-operator and the openstack-operator.

These are the PRs for reference:

- https://github.com/openstack-k8s-operators/lib-common/pull/88
- https://github.com/openstack-k8s-operators/cinder-operator/pull/65
- https://github.com/openstack-k8s-operators/glance-operator/pull/75
- https://github.com/openstack-k8s-operators/openstack-operator/pull/38

#### Structural split of changes

The general rule for how to split code changes into commits is that we should
aim to have a single "logical change" per commit.

As the [OpenStack Git Commit Good
Practice](https://wiki.openstack.org/wiki/GitCommitMessages) explains, there
are multiple reasons why this rule is important:

- The smaller the amount of code being changed in a commit, the quicker &
easier it is to review & identify potential flaws in that specific code
change.
- If a change is found to be flawed later, it may be necessary to revert the
broken commit. This is much easier to do if there are not other unrelated
code changes entangled with the original commit.
- When troubleshooting problems using Git's bisect capability, small well
defined changes will aid in isolating exactly where the code problem was
introduced.
- When browsing history using Git annotate/blame, small well defined changes
also aid in isolating exactly where & why a piece of code came from.

In the [OpenStack Git Commit Good Practice
page](https://wiki.openstack.org/wiki/GitCommitMessages) we can also find two
great sections explaining [things to avoid when creating
commits](https://wiki.openstack.org/wiki/GitCommitMessages#Things_to_avoid_when_creating_commits)
and [examples of bad
practice](https://wiki.openstack.org/wiki/GitCommitMessages#Examples_of_bad_practice)
that contributors to this repository should take into consideration.

#### PR Images

Once a PR merges it will trigger an image rebuild and publish, so how can we
fultonj marked this conversation as resolved.
Show resolved Hide resolved
tell when the new image is ready?

For that we'll go to the [project's
actions](https://github.com/openstack-k8s-operators/cinder-operator/actions)
and in there [we select the `Cinder Operator image builder`
job](https://github.com/openstack-k8s-operators/cinder-operator/actions/workflows/build-cinder-operator.yaml)
where we'll see the job that is building the new operator container image.

In there how the job is building 3 images: Operator, Bundle, and Index, and if
you go into each one of them and expand the `Push **** To quay.io` step you can
find the actual image location.

For example:

```
Successfully pushed "cinder-operator-index:9f3d1ec26ba8939710f146f3e6a1d81f5077be8a" to "quay.io/***/cinder-operator-index:9f3d1ec26ba8939710f146f3e6a1d81f5077be8a"
```

## Style Guides

### Go Style Guide

While the project has not formally defined a Go Style Guide for the project it
uses [Gofmt](https://pkg.go.dev/cmd/gofmt) for automated code formatting.

This tool is automatically called when building the cinder-operator binary
using the `Makefile` or when it is manually invoked with:

```sh
make fmt
```

Pull Requests are expected to have passed the formatting tool before committing
the code and submitting the PR.

### Commit Messages

As mentioned before, commit messages are a very important part of a pull
request, and their contents must be carefully crafted.

Commit messages should:

- Provide a brief description of the change in the first line.
- Insert a single blank line after the first line.
- Provide a detailed description of the change in the following lines, breaking
paragraphs where needed.
- Lines should be wrapped at 72 characters.

Once again the OpenStack documentation goes over the [important things to
consider when writing the commit
message](https://wiki.openstack.org/wiki/GitCommitMessages#Information_in_commit_messages),
so please take a good look. The short version is:

- Do not assume the reviewer understands what the original problem was.
- Do not assume the reviewer has access to external web services/site.
- Do not assume the code is self-evident/self-documenting.
- Describe why a change is being made.
- Read the commit message to see if it hints at improved code structure.
- The first commit line is the most important.
- Describe any limitations of the current code.
- Do not assume the reviewer has knowledge of the tests executed on the change
- Do not include patch set-specific comments.

## Helpful scripts

Under the `hack` directory we'll find scripts that can help us in the
development of the cinder-operator as well as some tips and tricks.

Refer to its `README.md` file for additional information.
Loading