Add a bug reporting and triaging guide
Change-Id: If692795221661414b2990f8131433678402dd45b
This commit is contained in:
parent
a2ad31ddef
commit
2f5456759e
128
doc/source/contributor/bugs.rst
Normal file
128
doc/source/contributor/bugs.rst
Normal file
@ -0,0 +1,128 @@
|
|||||||
|
Bug Reporting and Triaging Guide
|
||||||
|
================================
|
||||||
|
|
||||||
|
StoryBoard
|
||||||
|
----------
|
||||||
|
|
||||||
|
All ironic projects use StoryBoard_ for tracking both bugs and enhancement
|
||||||
|
requests (RFE). The `ironic project group`_ lists all our projects.
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
Ironic is developed as part of OpenStack and therefore uses
|
||||||
|
the ``openstack/`` namespace.
|
||||||
|
|
||||||
|
StoryBoard is somewhat different from traditional bug tracking
|
||||||
|
systems because every *story* is not linked to a project itself, but rather
|
||||||
|
through its *tasks*. A story represents an issue you are facing or an
|
||||||
|
enhancement you want to see, while tasks represent individual action items
|
||||||
|
which can span several projects. When creating a story, you'll also need to
|
||||||
|
create the first task. If unsure, create a task against ``openstack/ironic``.
|
||||||
|
|
||||||
|
Reporting Guide
|
||||||
|
---------------
|
||||||
|
|
||||||
|
We are constantly receiving a lot of requests, so it's important to file a
|
||||||
|
meaningful story for it to be acted upon. A good story:
|
||||||
|
|
||||||
|
* specifies **why** a change is needed.
|
||||||
|
* explains how to reproduce the described condition.
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
Please try to provide a reproducer based on unit tests, :ref:`devstack
|
||||||
|
<deploy_devstack>` or bifrost_. While we try our best to support users
|
||||||
|
using other installers and distributions, it may be non-trivial without
|
||||||
|
deep knowledge of them. If you're using a commercial distribution or
|
||||||
|
a product, please try contacting support first.
|
||||||
|
|
||||||
|
* should be understandable without additional context. For example, if you see
|
||||||
|
an exception, we will need the full traceback.
|
||||||
|
|
||||||
|
* should not be too verbose either. Unfortunately, we cannot process a few days
|
||||||
|
worth of system logs to find the problems, we expect your collaboration.
|
||||||
|
|
||||||
|
* is not a question or a support request. Please see :doc:`contributing` for
|
||||||
|
the ways to contact us.
|
||||||
|
|
||||||
|
* provides a way to contact the reporter. Please follow the comments and
|
||||||
|
expect follow-up emails, but ideally also be on IRC for questions.
|
||||||
|
|
||||||
|
An enhancement request additionally:
|
||||||
|
|
||||||
|
* benefits the overall project, not just one consumer. If you have a case that
|
||||||
|
is specific to your requirements, think about ways to make ironic extensible
|
||||||
|
to be able to cover it.
|
||||||
|
|
||||||
|
* does not unnecessary increase the project scope. Consider if your idea can be
|
||||||
|
implemented without changing ironic or its projects, maybe it actually
|
||||||
|
should?
|
||||||
|
|
||||||
|
Triaging Guide
|
||||||
|
--------------
|
||||||
|
|
||||||
|
The bug triaging process involves checking new stories to make sure they are
|
||||||
|
actionable by the team. This guide is mostly targeting the project team, but we
|
||||||
|
would appreciate if reporters could partly self-triage their own requests.
|
||||||
|
|
||||||
|
* Determine if the request is valid and complete. Use the checklist in the
|
||||||
|
`Reporting Guide`_ for that.
|
||||||
|
|
||||||
|
* Is the request a bug report or an enhancement request (an RFE)? The
|
||||||
|
difference is often subtle, the key question to answer is if the described
|
||||||
|
behavior is expected.
|
||||||
|
|
||||||
|
Add an ``rfe`` tag to all enhancement requests and propose it for the "RFE
|
||||||
|
Review" section of the `weekly meeting`_.
|
||||||
|
|
||||||
|
* Does the RFE obviously require a spec_? Usually this is decided when an RFE
|
||||||
|
is reviewed during the meeting, but some requests are undoubtedly complex,
|
||||||
|
involve changing a lot of critical parts and thus demand a spec.
|
||||||
|
|
||||||
|
Add a ``needs-spec`` tag to enhancement requests that obviously need a
|
||||||
|
spec. Otherwise leave it until the meeting.
|
||||||
|
|
||||||
|
* Apply additional tags:
|
||||||
|
|
||||||
|
* All hardware type specific stories should receive a corresponding tag (e.g.
|
||||||
|
``ipmi``, ``idrac``, etc).
|
||||||
|
|
||||||
|
* API-related stories should have an ``api`` tag.
|
||||||
|
|
||||||
|
* CI issues should have a ``gate`` tag.
|
||||||
|
|
||||||
|
The next actions **must only** be done by a core team member (or an experienced
|
||||||
|
full-time contributor appoined by the PTL):
|
||||||
|
|
||||||
|
* Can the RFE be automatically approved? It happens if the RFE requests an
|
||||||
|
implementation of a driver feature that is already implemented for other
|
||||||
|
drivers and does not pose additional complexity.
|
||||||
|
|
||||||
|
If the RFE can be automatically approved, apply the ``rfe-approved`` tag.
|
||||||
|
If unsure, never apply the tag! Talk to the PTL instead.
|
||||||
|
|
||||||
|
* Does the RFE have a corresponding spec approved? If yes, apply the
|
||||||
|
``rfe-approved`` tag.
|
||||||
|
|
||||||
|
* In the end, apply the ``ironic-triaged`` tag to make the story as triaged.
|
||||||
|
|
||||||
|
Expiring Bugs
|
||||||
|
-------------
|
||||||
|
|
||||||
|
While we hope to fix all issues that our consumers hit, it is unfortunately not
|
||||||
|
realistic. Stories **may** be closed by marking all their tasks ``INVALID`` in
|
||||||
|
the following cases:
|
||||||
|
|
||||||
|
* No solution has been proposed in 1 calendar year.
|
||||||
|
|
||||||
|
* Additional information has been requested from the reporter, and no update
|
||||||
|
has been provided in 1 calendar month.
|
||||||
|
|
||||||
|
* The request no longer aligns with the direction of the project.
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
As usual, common sense should be applied when closing stories.
|
||||||
|
|
||||||
|
.. _StoryBoard: https://storyboard.openstack.org
|
||||||
|
.. _ironic project group: https://storyboard.openstack.org/#!/project_group/ironic
|
||||||
|
.. _bifrost: https://docs.openstack.org/bifrost
|
||||||
|
.. _spec: https://specs.openstack.org/openstack/ironic-specs/
|
||||||
|
.. _weekly meeting: https://wiki.openstack.org/wiki/Meetings/Ironic
|
@ -36,11 +36,13 @@ The ironic project moved from Launchpad to `StoryBoard
|
|||||||
<https://storyboard.openstack.org/>`_ for work and task tracking.
|
<https://storyboard.openstack.org/>`_ for work and task tracking.
|
||||||
This provides an aggregate view called a "Project Group"
|
This provides an aggregate view called a "Project Group"
|
||||||
and individual "Projects". A good starting place is the
|
and individual "Projects". A good starting place is the
|
||||||
`project group <https://storyboard.openstack.org/#!/project_group/75>`_
|
`project group <https://storyboard.openstack.org/#!/project_group/ironic>`_
|
||||||
representing the whole of the ironic community, as opposed to
|
representing the whole of the ironic community, as opposed to
|
||||||
the `ironic project <https://storyboard.openstack.org/#!/project/943>`_
|
the `ironic project <https://storyboard.openstack.org/#!/project/943>`_
|
||||||
storyboard which represents ironic as a repository.
|
storyboard which represents ironic as a repository.
|
||||||
|
|
||||||
|
See :doc:`bugs` for more details on how we track bugs.
|
||||||
|
|
||||||
Internet Relay Chat 'IRC'
|
Internet Relay Chat 'IRC'
|
||||||
-------------------------
|
-------------------------
|
||||||
|
|
||||||
|
@ -12,6 +12,7 @@ project.
|
|||||||
:maxdepth: 1
|
:maxdepth: 1
|
||||||
|
|
||||||
Developer Contribution Guide <contributing>
|
Developer Contribution Guide <contributing>
|
||||||
|
Bugs Reporting and Triaging Guide <bugs>
|
||||||
Setting Up Your Development Environment <dev-quickstart>
|
Setting Up Your Development Environment <dev-quickstart>
|
||||||
Priorities <https://specs.openstack.org/openstack/ironic-specs/#priorities>
|
Priorities <https://specs.openstack.org/openstack/ironic-specs/#priorities>
|
||||||
Specifications <https://specs.openstack.org/openstack/ironic-specs/>
|
Specifications <https://specs.openstack.org/openstack/ironic-specs/>
|
||||||
|
@ -22,6 +22,8 @@ previous release of ironic, append the OpenStack release name to the URL; for
|
|||||||
example, the ``ocata`` release is available at
|
example, the ``ocata`` release is available at
|
||||||
https://docs.openstack.org/ironic/ocata/.
|
https://docs.openstack.org/ironic/ocata/.
|
||||||
|
|
||||||
|
Found a bug in one of our projects? Please see :doc:`/contributor/bugs`.
|
||||||
|
|
||||||
Installation Guide
|
Installation Guide
|
||||||
==================
|
==================
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user