File: contributing.rst

package info (click to toggle)
rauc 1.15-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 6,336 kB
  • sloc: ansic: 36,989; python: 3,354; sh: 1,391; xml: 53; makefile: 41
file content (226 lines) | stat: -rw-r--r-- 8,158 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
Contributing
============

Thank you for thinking about contributing to RAUC!
Some different backgrounds and use-cases are essential for making RAUC work
well for all users.

The following should help you with submitting your changes, but don't let these
guidelines keep you from opening a pull request.
If in doubt, we'd prefer to see the code earlier as a work-in-progress PR and
help you with the submission process.

Workflow
--------

- Changes should be submitted via a `GitHub pull request
  <https://github.com/rauc/rauc/pulls>`_.
- Try to limit each commit to a single conceptual change.
- Add a signed-off-by line to your commits according to the :ref:`Developer's
  Certificate of Origin <sec-dco>`.
- Check that the tests still work before submitting the pull request. Also
  check the CI's feedback on the pull request after submission.
- When adding new features, please also add the corresponding
  documentation and test code.
- If your change affects backward compatibility, describe the necessary changes
  in the commit message and update the examples where needed.

Code
----

- The projects coding style is inspired by the Linux kernel, but also deviates
  from it in some points.
  For details, see :ref:`sec-code-style`.

Documentation
-------------
- Use `semantic linefeeds
  <http://rhodesmill.org/brandon/2012/one-sentence-per-line/>`_ in .rst files.

Check Scripts & Test Suite
--------------------------

To ensure we do not break existing behavior and detect potential bugs, RAUC
runs a test suite consisting of several components.
Some of them only run in CI, but most of them can be executed locally.
When working on a new feature or fixing a bug, please make sure these tests
succeed.

.. _sec-code-style:

Code Style - uncrustify
~~~~~~~~~~~~~~~~~~~~~~~

To maintain a consistent code style, we use the `uncrustify
<https://github.com/uncrustify/uncrustify>`_ code beautifier that also runs in
the CI loop.

To make sure your changes match the expected code style, run::

  ./uncrustify.sh

from the RAUC source code's root directory.
It will adapt style where necessary.

CLI Tests - pytest
~~~~~~~~~~~~~~~~~~

For high-level tests of the RAUC command line interface we use `pytest
<https://docs.pytest.org/>`_.

You can run these checks manually by executing::

  pytest test/

from the RAUC source code's root directory but they will also be triggered by
the general test suite run (see below).
If you add or change subcommands or arguments of the CLI tool, make sure these
tests succeed and extend them if possible.
When touching the test code, make sure to run the 'ruff' linter/formatter on
the changed code::

  ruff format test/
  ruff check test/

As many of these tests need root permissions, we recommend running them using the
``qemu-test`` helper below.

glib Unit Tests - gtest
~~~~~~~~~~~~~~~~~~~~~~~

For testing the different C modules of RAUC's source code, we use the `glib
Test Framework <https://developer.gnome.org/glib/stable/glib-Testing.html>`_.

All tests reside in the ``test/`` folder and are named according to the module
they test (``test/bundle.c`` contains tests for ``src/bundle.c``).

The tests are built by default. To explicitly switch them on or off in meson,
use ``-Dtest=`` option::

  meson setup -Dtests=true build

You can run each compiled test individually::

  ./build/test/bundle-test

To run all tests, run::

  meson test -C build

This will also run the pytest CLI tests mentioned above.

.. note:: Although some of the tests need to run as root, do NOT use 'sudo', but
   use our ``qemu-test`` helper instead!

.. _sec-contributing-qemu-test:

QEMU Test Runner - qemu-test
~~~~~~~~~~~~~~~~~~~~~~~~~~~~

As many of the unit tests require root privileges and thus could potentially
damage your host system, we provide a QEMU-based test environment where one can
run all checks in a virtual environment.
By using a VM, the tests can access diverse emulated storage devices (block,
NAND/MTD, eMMC) without any dependency on or risk to the host environment.
Furthermore no root privileges are needed on the host.

Note that this does **not** run in a full VM with its own filesystem,
but instead passes the host's VFS to the guest using virtfs (and adds some
tmpfs overlays).
This allows seamless access to the sources and binaries built on the host,
which saves a lot of time during the edit-compile-test loop.
Accordingly, the test dependencies need to be installed on the host.

To run the entire test suite, type::

  ./qemu-test

To run individual tests, you can either specify them by using the ``test=``
parameter::

  ./qemu-test test=install

The test name will be forwarded to ``meson test`` and thus must match the meson
test names (e.g. ``install`` for a glib-based unit test or ``pytest-install``
for a pytest-based test).

Or you start an interactive shell with access to the test environment::

  ./qemu-test shell

From which you run the tests manually (as shown in the previous sections).

Additional parameters that you can add to a ``./qemu-test`` call are:

:passthrough: for optimal performance (by passing through your host's CPU
  features to the guest).

:asan: sets up environment variables to support the address sanitizer.
  This requires meson was set up with ``-Db_sanitize=address,undefined``.

If you want to collect coverage information (built with ``-Db_coverage=true``),
you need to copy the generated gcov files from the VM back to the host system
using the ``save_gcov_data`` helper before using ``ninja coverage-html`` on the
host.
To avoid inconsistent coverage data when recompiling without restarting
qemu-test or to remove any coverage data in the VM, use ``clear_gcov_data``.

Interactive Test System
^^^^^^^^^^^^^^^^^^^^^^^

Beside providing a safe test environment, the ``./qemu-test`` script also
supports running RAUC interactively in the QEMU environment by calling::

  ./qemu-test system

This setup initializes QEMU to run with the RAUC service started, alongside a
configured D-Bus and dummy target slots to simulate a real firmware update
scenario.
The configuration uses GRUB as a mock boot selection backend, allowing RAUC to
interact with it as it would in a real system.
Notably, rebooting the environment is not supported in this setup, meaning the
testing is limited to a single boot cycle.
This is sufficient for testing RAUC’s update mechanism but does not cover
reboot-based validation.

.. _sec-dco:

Developer's Certificate of Origin
---------------------------------

RAUC uses the `Developer's Certificate of Origin 1.1
<https://developercertificate.org/>`_ with the same `process
<https://www.kernel.org/doc/html/latest/process/submitting-patches.html#sign-your-work-the-developer-s-certificate-of-origin>`_
as used for the Linux kernel:

  Developer's Certificate of Origin 1.1

  By making a contribution to this project, I certify that:

  (a) The contribution was created in whole or in part by me and I
      have the right to submit it under the open source license
      indicated in the file; or

  (b) The contribution is based upon previous work that, to the best
      of my knowledge, is covered under an appropriate open source
      license and I have the right under that license to submit that
      work with modifications, whether created in whole or in part
      by me, under the same open source license (unless I am
      permitted to submit under a different license), as indicated
      in the file; or

  (c) The contribution was provided directly to me by some other
      person who certified (a), (b) or (c) and I have not modified
      it.

  (d) I understand and agree that this project and the contribution
      are public and that a record of the contribution (including all
      personal information I submit with it, including my sign-off) is
      maintained indefinitely and may be redistributed consistent with
      this project or the open source license(s) involved.

Then you just add a line (using ``git commit -s``) saying:

  Signed-off-by: Random J Developer <random@developer.example.org>

using your real name (sorry, no pseudonyms or anonymous contributions).