apache > cocoon
 

How to Contribute a Patch via Jira

As of 24 October 2005, all issues are moved to Jira: http://issues.apache.org/jira/browse/COCOON

Fixme
Update this info to reflect the move to Jira.

Overview

Bugzilla is the Internet-based mechanism to facilitate contributions to any Apache project. This includes changes to code and documents (Patches), and also reports of flaws in the system (Bugs), and suggestions for enhancement.

In this How-to we will concentrate on the Patch tracking capabilities of Bugzilla. We will explain how to create your Bugzilla account, how to enter a patch description, and finally how to attach the actual patch file.

Intended Audience

This document is meant for first-time users of Bugzilla. The web interface can be daunting, so this concise explanation will help you to start. After your first patch submission, you can proceed to make more substantial contributions.

As our example we use the contribution of a simple documentation patch for the Apache Cocoon project. The principles apply to any project.

Prerequisites

Bugzilla contributors should:

  • Understand what a Patch is and how to make one (see How to Prepare a Patch). Note that a new complete document is still just a "patch", though it does need separate treatment to a normal "diff".
  • Understand that Bugzilla is the Apache Bug Database. Bugzilla does not distinguish between a Bug report, a Patch submission, and an Enhancement suggestion. They are all "Bugs" as far as Bugzilla is concerned.

Steps

Here is how to proceed. Go to Bugzilla in another browser window.

1. Create your Bugzilla Account

Follow the link the home page to "Open a new Bugzilla account". Do not worry, you will not be sent spam email nor bombarded with advertisements by setting up this account. It is purely a workgroup tool.

Note that you can conduct queries in Bugzilla and review submissions without having an account. However, to make a contribution you must have an account. This ensures legitimacy. It also enables the system to send you email automatically when your patch is applied by a Cocoon committer.

2. Enter a new bug report

Follow the "Enter a new bug report" link from the Bugzilla home page. First, you will be asked to select the relevant project ... choose Cocoon 2 of course. Next, you will be asked to provide your account details. Following that, you will be presented an input form for the various details ...

3. Specify Version

This is the version of Cocoon that you prepared your patch against. Choose Current CVS if you have an up-to-date local working copy of HEAD branch or a very recent nightly build. Otherwise choose the relevant release version. This is a very important step, as you will confuse the committer if your changes do not match the repository. If you are unsure, then please say so in the description at step 12.

4. Specify Component

Follow the "Component" link for description of the available components. If you do not know which component is relevant, then just use core.

5. Specify Platform

This is really meant for bug reporting. Perhaps it could be relevant for a patch. You would usually specify the All option.

6. Specify Operating System (OS)

Really meant for bug reporting. Perhaps it could be relevant for a patch. You would usually specify the All option.

7. Specify Severity

The impact that would arise if your patch is not applied. For a documentation patch, the severity would usually be the default Normal. However, if it addressed some serious lack or fixed a misguided configuration statement, then the impact could be major.

(The enhancement option would not be used for a patch, as it is intended for suggesting something that should be done. Use this option wisely. It would be better to discuss it on the mailing list first.)

8. Specify Initial State

Use the New option.

9. Specify Assigned To

Leave it blank. Your patch will be automatically assigned to the cocoon-dev mailing list. When a committer takes on your patch, that committer will assign the bug to their own email address. This pevents duplication of effort by other committers.

The Cc field can be used if you need the bug reports, and any follow-up, to be copied to some other person. Remember that your report will be sent automatically to the cocoon-dev mailing list, so you do not need to Cc anyone there.

10. Specify URL

If the patch refers to a particular document, then provide the website URL. If it refers to an issue with one of the local Cocoon Samples, then provide the localhost URL.

11. Carefully choose the Summary

The summary will become the all-important title of the bug. Use it wisely. You want to draw attention to your patch. Just as with posting email to the listervers, choosing a poor title may cause your posting to be easily overlooked. Use up all the characters available ... about 60 maximum.

Start the Summary with the [PATCH] tag. This will ensure that it is included in the Cocoon automated patch queue summary posted to the mailing lists. The patch queue summary reminds people what patches are pending. If you omit this tag, then your patch may easily be overlooked.

12. Description

Provide a brief explanation of what your patch does. Supply any instructions to help the committer apply your patch efficiently. Note any issues that may remain. It may help to list each file that you are submitting and briefly describe what it is. A committer will need to provide a descriptive log message when committing your work. Providing a clear description here will help them.

Consider writing the Description and Summary text before you start entering your patch report. You could save it in a local text file beforehand and then copy-and-paste it when the time comes.

If this were a bug report, then it would need extensive description.

13. Send the patch report

Review your options, then press the Commit button. This will add an entry to the bug database and email a report to the cocoon-dev mailing list and a copy to you. Your submission will be assigned a unique Bug Number which you can use to review its progress.

The next steps will show you how to attach your patch to the report that you have just created ...

14. Create an attachment of the actual patch

You will be presented with a status screen saying that your bug report was accepted and that email was sent to cocoon-dev mailing list.

Now you have a choice ... proceed to review your bug report by selecting the link "Back to Bug #XXXXX". If you forgot to mention something, then you can add more comments. From that screen, follow the link "Create a new attachment". Otherwise follow the link from this status screen to "Attach a file to this bug".

15. Specify the file to be uploaded

Provide the local pathname to your patchfile, e.g. /home/me/work/cocoon/patch/howto-bugzilla.tar.gz

16. Describe the attachment

Provide a concise one line description, e.g. Gzipped TAR archive with new docs and diffs

17. Specify the contentType of the attachment

If it is a Gzipped TAR archive (*.tar.gz) or a .zip archive, then select "Binary file (application/octet-stream)". If it is just a single xml document, then select "Plain text (text/plain)". If the patch is just a single diff file, then select "Patch file (text/plain, diffs)".

18. Submit the attachment

When you are ready, press the Submit button. As for Step 13, you will be presented with a status screen saying that your attachment was accepted and that email was sent to cocoon-dev mailing list.

19. Be patient

Now your patch will wait inside Bugzilla until one of the Cocoon committers assigns the patch to their own email address and starts to process it to apply it to the master CVS repository. As the registered owner of the Bug, you will be sent an automatic email at each of these stages.

20. Add more description or attachments if necessary

Until the patch is applied by the committer and the Bug report is closed, you can still add more to your bug report. However, only do this when absolutely necessary because the patch should not be changing while the committer is trying to commit it. If you just want to make further changes, then it would be better to wait until your patch is applied. Then you can make a new patch. Remember that the committer has full veto and may decide to make some slight modifications to your patch. So it is far better to wait.

21. Adding subsequent patches to the same document or program

If you want to make more patches to the same file, then please open a new Bug rather than re-open the old one. After all, once the original patch is applied by the committer, its corresponding Bug report is closed.

Real World Extension

Contributing patches, in the form of documentation or code, is a vital way to give back to the Cocoon community. For example, you might consider contributing a timely patch in the form of a new FAQ, how-to, or tutorial. Or, you may also consider submitting a patch which updates Cocoon's existing user and developer guides.

Tips

Setting user preferences

You can configure certain preferences, though the Bugzilla defaults work just fine.

Review the bugzilla documentation

There are various explanations of terminology and procedures ... follow the links should you need to know more.

Search Bugzilla

Bugzilla has a very powerful search interface. Now that you have a login account, Bugzilla can remember customized queries which you can run with a single click.

References