qubes-doc/user/downloading-installing-upgrading/testing.rst

129 lines
5.4 KiB
ReStructuredText
Raw Normal View History

2024-05-21 14:59:46 -04:00
================================
Testing new releases and updates
================================
Testing new Qubes OS releases and updates is one of the most helpful
ways in which you can :doc:`contribute </introduction/contributing>` to the Qubes
OS Project. If youre interested in helping with this, please `join the testing team <https://forum.qubes-os.org/t/joining-the-testing-team/5190>`__.
There are several different types of testing, which well cover below.
**Warning:** Software testing is intended for advanced users and
developers. You should only attempt to do this if you know what youre
doing. Never rely on code that is in testing for critical work!
Releases
--------
How to test upcoming Qubes OS releases:
- Test the latest release candidate (RC) on the
:doc:`downloads </user/downloading-installing-upgrading/downloads>` page, if one is currently available. (Or
try an older RC from our `FTP server <https://ftp.qubes-os.org/iso/>`__.)
- Try the `signed weekly builds <https://qubes.notset.fr/iso/>`__.
(`Learn more <https://forum.qubes-os.org/t/16929>`__ and `track their status <https://github.com/fepitre/updates-status-iso/issues>`__.)
- Use :doc:`qubes-builder </developer/building/qubes-builder>` to build the latest
release yourself.
- (No support) Experiment with developer alpha ISOs found from time to
time at `Qubes OpenQA <https://openqa.qubes-os.org/>`__.
Please make sure to :doc:`report any bugs you encounter </introduction/issue-tracking>`.
See :doc:`Version scheme </developer/releases/version-scheme>` for details about release
versions and schedules. See :doc:`Release checklist </developer/releases/todo>`
for details about the RC process.
Updates
-------
How to test updates:
- Enable :ref:`dom0 testing repositories <user/advanced-topics/how-to-install-software-in-dom0:testing repositories>`.
- Enable :ref:`template testing repositories <user/how-to-guides/how-to-install-software:testing repositories>`.
Every new update is first uploaded to the ``security-testing``
repository if it is a security update or ``current-testing`` if it is a
normal update. The update remains in ``security-testing`` or
``current-testing`` for a minimum of one week. On occasion, an exception
is made for a particularly critical security update, which is
immediately pushed to the ``current`` stable repository. In general,
however, security updates remain in ``security-testing`` for two weeks
before migrating to ``current``. Normal updates generally remain in
``current-testing`` until they have been sufficiently tested by the
community, which can last weeks or even months, depending on the amount
of feedback received (see `Providing feedback <#providing-feedback>`__).
“Sufficient testing” is, in practice, a fluid term that is up the
developers judgment. In general, it means either that no negative
feedback and at least one piece of positive feedback has been received
or that the package has been in ``current-testing`` for long enough,
depending on the component and the complexity of the changes.
A limitation of the current testing setup is that it is only possible to
migrate the *most recent version* of a package from ``current-testing``
to ``current``. This means that, if a newer version of a package is
uploaded to ``current-testing``, it will no longer be possible to
migrate any older versions of that same package from ``current-testing``
to ``current``, even if one of those older versions has been deemed
stable enough. While this limitation can be inconvenient, the benefits
outweigh the costs, since it greatly simplifies the testing and
reporting process.
Templates
---------
How to test :doc:`templates </user/templates/templates>`:
- For official templates, enable the ``qubes-templates-itl-testing``
repository, then :ref:`install <user/templates/templates:installing>` the desired
template.
- For community templates, enable the
``qubes-templates-community-testing`` repository, then
:ref:`install <user/templates/templates:installing>` the desired template.
To temporarily enable any of these repos, use the
``--enablerepo=<repo-name>`` option. Example commands:
.. code:: bash
qvm-template --enablerepo=qubes-templates-itl-testing list --available
qvm-template --enablerepo=qubes-templates-itl-testing install <template_name>
To enable any of these repos permanently, change the corresponding
``enabled`` value to ``1`` in ``/etc/qubes/repo-templates``. To disable
any of these repos permanently, change the corresponding ``enabled``
value to ``0``.
Providing feedback
------------------
Since the whole point of testing software is to discover and fix bugs,
your feedback is an essential part of this process. We use an `automated build process <https://github.com/QubesOS/qubes-infrastructure/blob/master/README.md>`__.
For every package that is uploaded to a testing repository, a GitHub
issue is created in the
`updates-status <https://github.com/QubesOS/updates-status/issues>`__
repository for tracking purposes. We welcome any kind of feedback on any
package in any testing repository. Even a simple “thumbs up” or “thumbs
down” reaction on the packages associated issue would help us to decide
whether the package is ready to be migrated to a stable repository. If
you :doc:`report a bug </introduction/issue-tracking>` in a package that is in a
testing repository, please reference the appropriate issue in
`updates-status <https://github.com/QubesOS/updates-status/issues>`__.