Bugzilla/Issue Tracking in Fedora
Background
Fedora currently shares a bugzilla instance with Red Hat. This instance is managed and run by Red Hat. Some new features or changes that would assist Fedora are not a priority for this instance, which must focus on business needs. This page is an attempt to summarize the advantages and disadvantages in Fedora running their own seperate Bugzilla instance. No decisions have been made, this is in a information gathering stage at this point.
Bugzilla.redhat.com pain points
We should note here pain points or issues with current bugzilla. We may be able to get the bugzilla team to help fix or work around them.
- There's sometimes private bugs cloned to Fedora components. Can we clear those flags when Fedora is the component?
- fedmsg integration
- openid logins
Why does Fedora need its own BZ?
(This is to list out issues that the community faces with shared BZ instance with RH, and the points which make it easier to decide to host Fedora's own instance. Please list out exact features missing/wanted which are not available in RH instance rather than just saying more/better features.)
* *
Other bug tracking systems
If Fedora went to managing it's own bug tracking system, is bugzilla the best fit for this use?
Most of the other free bug / issue tracking systems are a poor fit for a distribution managing a large number of components that additionally have their own upstreams.
Some other systems that don't really fit:
- redmine: ruby, not packaged yet for epel.
- trac: poor performance, has a bunch of additional things over bug tracking we don't need.
- flyspray: dead upstream.
- mantis: php-based
- rt: perl based, much more trouble ticketing than software bugs.
- launchpad: has a number of downsides for us. Big ones: "Building and running Launchpad requires a computer running Ubuntu" and it includes a bunch more things that we don't need like bzr integration, personal archives, etc.
- allura: (powers sourceforge). Provides a bunch of stuff we don't need like source code control, forums, mailing lists, etc.
- buggenie: php-based
Possible ones that do:
- roundup: written in python (python issue tracker), designed to be flexible, ability to interact with bugs via more than just web interface or XML-RPC.
The main disadvantages with roundup would be : very foreign to existing contributors, impedance mismatch with RHBZ for bugs that exist in both trackers, require rewriting a bunch of tools.
Advantages: email gateway support, ability to craft schema/templates for our needs, smaller footprint, python, ability to run seperate trackers per component.
Features needed/wanted.
MUST HAVE
These items are required in any solution we offer:
- fedmsg support
- openid / fas support (possibly via persona support)
- Support current maintainer / qa / release engineering / program manager workflows or provider better workflows.
- Way to file bugs against any shipped component for users.
- Way to mark bugs as blockers or FE's
- Way to make sure anyone intrested gets email for bugs and updates on bugs.
- Way to move between components
- Way to mark bugs needing scm admin attention.
- Way to mark bugs under review / approved / rejected for package reviews
- Way to mark status on bugs per whatever workflow.
- Way to reassign bugs to someone else.
- Way to note information needed and from whom
- Must have a way for bodhi to note when a update is tied to a bug and what state it's in.
SHOULD HAVE
These items are things we really should provide, but we might be willing to not have them if there's workarounds:
- Support for all infrastructure scripts that need to interface with the bug tracking system.
- Way to move bugs from one component to another.
- ability to note an upstream bug in upstream bug trackers.
- support all the maintainer / qa states bugs can/should be in.
- Interaction with abrt/faf
Nice to have
These are things we would find nice to have, but aren't required right away:
- subcomponent support?
- ie, kernel could have networking and filesystems with different owners
- Retheme and branded to match the other fedora project web tools
- email support for reporting/updating bugs with gpg signed emails.
- ability to mark a bug affecting multiple releases.
Wishlist / Future
These are things we would like to have someday, but they aren't critical to an initial release:
- way to archive old releases to static pages to avoid rendering time/queries.
- Possibly add caching (may be difficult to do correctly).
Problems/issues
- Free sysadmin/dev cycles already low
- Could end up being slower due to lack of resources
- cannot clone bugs over to rhel packages/products easily. <-- This is irrelevant to Fedora
- when a bug is mis-assigned to an epel pkg (in fedora) can't reassign to rhel <-- This is irrelevant to Fedora
- security bugs cannot easily refer to both rhel/fedora versions. <-- No need to RHEL != Fedora there can be much newer releases of the components in Fedora then in RHEL
- Database knowledge low on team, would need to figure out replication/ha.
- would need to somehow keep python-bugzilla in sync with both new instance, and b.z.c
- we don't have much perl dev depth in our team and bz is all perl
help that would be needed
- db people
- perl hackers
- bugzilla experenced admins.
- bugzilla and deps packagers for epel.
- load and functionality testing scripts (selenium, pymechanize, etc)
Next steps
- Need to collect more things in the Features needed section of this page.
- Need to setup some proof of concept bugzilla and roundup instances to test ideas with.