-
Notifications
You must be signed in to change notification settings - Fork 186
Contributing
To know what piece of software is where, you can check https://www.uyuni-project.org/pages/source-code.html
If you change something relevant for the user, a changelog entry must be added to all affected packages. How to do that depends on where the packages are being developed (details below)
All changelog entries must follow https://en.opensuse.org/openSUSE:Creating_a_changes_file_(RPM).
In particular:
- You shall not modify any existing component (where component is a text enclosed between ----------).
- Small typo fixes are accepted, as is the addition of bug references, and trimming useless trailing whitespace.
- Limit your maximum line length to 67 characters.
- All entries must start with a dash (-). You can add second-level using asterisks (*). Third-level or deeper bullet points are not defined, but in any case do NOT use asterisks for it.
- If you add product names, use the right capitalization and format.
- Use the rigth indentation for each line.
Very important: the chagelogs must understandable for users, and relevant for them.
Some examples of wrong changelog entries:
- Fixed a crash
What crash?
- Port PR #1165 from upstream
What's that PR about?
- Enable OpenSuSE 15.3 as a supported client
Name is openSUSE
- cobbler20-setup was removed
Why?
- Enable support for the following products:
+ openSUSE 15.3
+ SLE Micro 5.2
Use *
instead of +
for the second level list.
- Enable support for the following products:
* openSUSE 15.3
* SLE Micro 5.2
Wrong indentation
We work with Pull Requests, so you need to be familiar with them and with the concept of forking.
-
If this is your first contribution: fork the git repository you want to change, and then clone it to your computer.
If this is not your first contribution: Go to your local clone and make sure your master branch is synced against
upstream
. -
Create an new branch from master.
-
Develop the feature or the bugfix on that branch: code, tests and changelogs (last two where applicable).
You can freely commit and push. Pushes will go to your forked repository at this stage.
Amend commits or squash them together when it makes sense.
IMPORTANT: In most cases, specially if you plan to submit to the uyuni-project/uyuni, you need to add a changelog to be used for the RPM/Deb packages.
-
Create a Pull Request. The base branch will always be
master
.For the uyuni-project/uyuni repository you will need to fill a template explaining the changes. Use the checkboxes and pay attention to the data requested (for example screenshots if it makes sense)
-
If you are developing a new feature (or changing an existing one) that is covered by the documentation, you need to prepare Pull Request for this.
Reference the Pull Requests for the documentation at the Pull Request for the code.
-
A reviewer should self-assign soon and will either merge the Pull Request or request clarifications or changes.
NOTE: We plan to add automation to assign reviewers automatically.
In general there should always be changelogs for all PRs, with some exceptions:
- You are fixing a test.
- You are changing something that doesn't affect a package.
Procedure:
- Check what packages your PR is changing. The easiest way is checking the folder
rel-eng/packages
. Each file there represent a package and contains the current version of the package, and the path for the package. Inside that path you will find a<packagename>.changes
file. If your PR affects any of the paths or children of such paths, you need a changelog entry. - For each package, open its
.changes
file. - If the first line on the changes file is a separator (
-------------------------------------------------------------------
) make sure there's add an empty line on top of it. - Add your new entry on top. For example
- Fix taskomatic to avoid crashes when using salt 3000
. Do not add a header with the date, your name and your email. - Make sure you commit the changes to the changelogs.
Check their contributing guides for details.
There are some packages that we do not maintain in git repositories, but directly on OBS.
Some examples are the patterns or the product definitions.
To update such packages we use OBS branches.
- Branch the package
- Checkout the package to your local computer.
- Change the package as needed (update sources, update patches, or update the SPEC, as applies)
- Use
osc vc
to add changelog entries. Remember the guidelines above. - Commit your changes to your branched package (`osc ci -m "")
- Create a SR (
osc sr
or do it from the web interface).
You can help other people on the mailing lists, Gitter or by testing and reporting bugs.
Check the Contact Page for the details
Check the Translations section.