From Fedora Project Wiki

Revision as of 21:34, 27 February 2017 by Tflink (talk | contribs) (first draft of dist-git test storage)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)

Summary

This page describes the current state of task storage in dist-git repositories. This is not yet final thing but it is what we're starting with. Any changes to this will be announced on devel-announce before any breaking changes are put into place.

Motivation

There is a strong push for more CI-like features for testing Fedora but in order to support that, we need a way for contributors to submit tests that will scale with the number of components we have and require minimal human intervention.

People to Pester

In general, the best place to start is with the Taskotron devs who can be most easily found in the following ways:

How to write tasks

For now, all tasks will need to be written for libtaskotron. Current documentation can be found here

Phase 1

For phase 1, the idea is to start getting tasks and tests into place The most straight-forward way to do this is to store the tests with the "code" which, in this case is the files in the rpms namespace in dist-git. For example:

rpms/foo
rpms/foo/test/
rpms/foo/test/SOME_TASK_NAME
rpms/foo/test/SOME_TASK_NAME/runtask.yml

In phase 1, all tasks will be run on build for that rpm.

Should I Participate?

All folks putting tasks into dist-git during phase 1 should consider themselves "early adopters". Everything should work and documentation should be in place but we really want feedback. Are the docs not clear? Is there a missing feature that is keeping you from doing the tests you want to do? We want to know!

Why Only Koji Builds?

We're starting small and will continue to add features as time goes on. In future phases, this restriction will be lifted.

What about non-rpm content

The above description should translate well to the current set of non-rpm content (docker images, modules) where the tasks in test/ are run whenever there is a build of said item.