sampledoc
News and Announcements »

Report and fixing bugs

I found a bug in QIIME. What should I do?

If you find a bug in QIIME, you should report it as a bug in the bug tracker on sourceforge. It’s useful to report even small bugs with the bug tracker, and it allows us to keep records of how frequently bugs are found and fixed. You may first want to review the Qiime Forum to ensure that no one has run into your issue before.

This will alert the project managers about the bug, and the bug tracker is actively monitored by the QIIME team.

Please include some way for us to get it touch with you regarding the bug as we may have questions about your bug report. You can do this by logging in with your sourceforge account before reporting the bug, including your e-mail address in the bug report (which you may not want to do), or sending an e-mail to qiime-help@colorado.edu with the bug tracker ID number, and any contact details that we might need.

We aim to be very responsive regarding QIIME bugs, and we greatly appreciate your help in making QIIME a better software package.

Writing useful bug reports

Regardless of whether you plan to fix the bug yourself, or wait for the developer to fix it, you should write a good bug report. If you do plan to fix it, this is important for the records. If you are not comfortable with fixing the bug because you don’t know what’s causing it, or because you are not familiar with the code that is failing, a good bug report is likely to speed up the bug fix. Since you are the person who found it, you know the most about it, so you’re in a position to help out a lot.

The developers will need to reproduce the bug into order to fix it, so part of the purpose of a bug report is to help the developers reproduce the bug. To do this, you should include the following information in your sourceforge bug report:

  1. The exact command or function call that you issue to create the bug.
  2. All necessary input files for reproducing the bug. These files should only be as large as necessary to create the bug. For example, if you have an input file with 10,000 fasta-formatted sequences but the error only arises due to one of the sequences, create a new fasta file with only that sequence, run the command that was giving you problems, and verify that you still get an error. Then post that command and the trimmed fasta file. This is extremely useful to the developer, and it is likely that if you don’t provide this information, you’ll get a response asking for it.

Fixing bugs yourself

After adding a bug report, there are two paths you can follow. If you are comfortable with fixing the bug, you should do that. The steps you should take are as follows:

  1. Contact the primary developer of the relevant file(s), to let them know you found a bug and would like to fix it. The primary developer is the person listed in the __maintainer__ variable at the top of the file. You should include a description of the bug, the ID for the bug report, and a proposal for how you plan to fix it.
  2. Once you hear back that it is OK to make changes (i.e., they don’t have local edits, they agree with the change you’d like to make, and they’re comfortable your editing their code), you should assign the bug to yourself on Sourceforge.
  3. Run an svn update to ensure that you have the latest version of all files (especially important for the file(s) you plan to edit).
  4. Run Qiime/tests/all_tests.py to confirm that tests pass before you make any changes. You make get some failures, for example if you don’t have an external application (e.g., PyroNoise) installed. It is acceptable to continue if the failing tests are unrelated to the the code your working with. However, if you want to make changes to align_seqs.py and test_align_seqs.py is failing because of missing external applications, you should not proceed until you have installed the external applications and all tests pass.
  5. Make your changes to the code and the tests.
  6. Run Qiime/tests/all_tests.py to ensure that your changes did not cause anything unexpected to break.
  7. Once all of the tests pass, you should check your changes in with svn. Note that some tests may fail again because you do not have external applications installed. This is OK, but this is why it is important that you run all_tests.py prior to making changes: if the same tests fail, then you should be OK.

sampledoc