FilingBugs
| Size: 2823 Comment:  | Size: 8286 Comment:  | 
| Deletions are marked like this. | Additions are marked like this. | 
| Line 1: | Line 1: | 
| If you find an issue with Unity, here are some guidelines for filing bugs and providing details to the development team | <<Include(Debugging/Header)>> ||<tablestyle="float:right; font-size: 0.9em; width:30%; background:#F1F1ED; background-image: url('https://librarian.launchpad.net/1812570/bugsquad.png'); background-repeat: no-repeat; background-position: 98% 0.5ex; margin: 0 0 1em 1em; padding: 0.5em;"><<TableOfContents>>|| | 
| Line 3: | Line 4: | 
| == Where to file bugs? == | = Introduction = | 
| Line 5: | Line 6: | 
| You should file bugs against [[http://bugs.launchpad.net/unity|Unity]] in Launchpad. | This page provides guidelines for filing bugs related to Unity, how to provide the debugging information required to analyze the issue, and how to triage Unity bugs. | 
| Line 7: | Line 8: | 
| == Natty == | = Filing bugs = | 
| Line 9: | Line 10: | 
| == Getting a backtrace == | == Technical issues == | 
| Line 11: | Line 12: | 
| Ensure that you have the [[https://wiki.ubuntu.com/DebuggingProgramCrash#Hardy 8.04 and Newer|debugging symbols]] for the compiz, nux and unity packages. If you want compiz to spit out a backtrace when it crashes, you can grab the crashhandler plugin from [[http://git.compiz.org/compiz/plugins/crashhandler|git]] and enable that in ccsm. | Use the standard ubuntu bug reporting tool as it gathers detailed information regarding your systems configuration. From the command line: {{{ubuntu-bug unity}}} When a crasher occurs on your system you should automatically see a dialog inviting you to report the issue. It will collect useful information from your system, automatically as well. But here is what you can also add to your bug report to help us confirm the issue more easily: * Provide the result of the command glxinfo. It contains important graphics information that can help us identify your issue. (glxinfo is provided by the package mesa-utils and is automatically run in Natty) * Provide the complete description of your GPU and how much video RAM it has. For instance, the market name of your graphics card may be Radeon HD 4650 or NVidia Geforce GTX 280. For embedded Intel GPU, you don't need to provide that information. * Your monitor resolution and screen setup (single, dual monitor, triple monitor) If the dialog doesn't appear for some reason, see the "advanced" procedure below. Even if the issue is actually in [[http://bugs.launchpad.net/compiz|Compiz]], it's still worth filing the bug against Unity, and we'll triage things to point to compiz as well. We're working very closely with the Compiz project. Now, if you know the bug is with Compiz, you can read the [[DebuggingCompiz]] page to help us get more info to solve the problem. == Design and usability issues == Because Unity is a user interface, certain problems may be related to usability or design aspects, and not technical aspects. In this case, contact the [[http://design.canonical.com/|Design Team]] first before filing a bug against Unity. You can reach them on the ayatana list or on #ayatana on freenode. If the issue is acknowledged, or if you really want to file a bug, then tag it as 'opinion' or 'wishlist', and link the issue to the 'ayatana-design' project. This will follow a different workflow. = Advanced debugging procedure = == Stale crashers == If apport did not automatically report the issue, you can check that a crasher trace has been collected by looking into the {{{/var/crash}}} directory. You should see a filename containing 'compiz'. {{{ls -altr /var/crash}}} to list them in chronological order. To manually file a bug report using a crash file: * stay in your current X session * add a window manager from a TTY if needed, ie CTRL-ALT-F1, login, {{{DISPLAY=:0 metacity --replace}}} * then, from your X session, do: {{{apport-bug -c /var/crash/<compiz crash file>}}} and follow the procedure in the web page that should open shortly after you invoke this command. Note that focus issues may prevent the page to appear on the top, but look for a new browser window opened in your workspace. == Getting a stack trace == If for some reason apport was not enabled on your system, or if you have a reproducible issue we ask you to investigate, here is how you can generate a stack trace and inspect internal variables. Ensure that you have the [[https://wiki.ubuntu.com/DebuggingProgramCrash#Hardy 8.04 and Newer|debugging symbols]] for the compiz, nux and unity packages. | 
| Line 16: | Line 55: | 
| $ DISPLAY=:0 gdb compiz | $ unity --advanced-debug | 
| Line 25: | Line 64: | 
| <http://www.gnu.org/software/gdb/bugs/>... Reading symbols from /usr/bin/mutter...(no debugging symbols found)...done. (gdb) set args --replace ccp (gdb) set logging file 'compiz.log' | <http://www.gnu.org/software/gdb/bugs/> ... (gdb) set logging file 'unity.log' | 
| Line 31: | Line 71: | 
| [ and when compiz crashes, do...] | [ and when compiz/unity crash, do...] | 
| Line 40: | Line 80: | 
| You can also get a valgrind trace by running {{{valgrind compiz --replace ccp &}}} in a terminal. This is a little bit slower to get because it runs compiz under emulation, but it does produce some output which isn't possible to get from gdb. | You can also get a valgrind trace by running {{{valgrind compiz --replace &}}} in a terminal. This is a little bit slower to get because it runs compiz under emulation, but it does produce some output which isn't possible to get from gdb. | 
| Line 42: | Line 82: | 
| == Maverick == | In extreme circumstances, we may ask you to use the crashhandler plugin from [[http://git.compiz.org/compiz/plugins/crashhandler|git]] and enable that in ccsm. | 
| Line 44: | Line 84: | 
| === How to produce record a backtrace? === | |
| Line 46: | Line 85: | 
| Ensure you have the [[https://wiki.ubuntu.com/DebuggingProgramCrash#Hardy 8.04 and Newer|debugging symbols]] for mutter and unity and unity places packages. | = Triaging instructions = | 
| Line 48: | Line 87: | 
| Then, from tty1 (Ctrl + Alt + F1) | == Design Bugs == Some bugs are not technical defects, but behavioral, or visual ones. These often require input from the design team before they can be fixed. When a bug is determined to be a design bug, it should have an ''Ayatana design'' task added to it, and its Unity status should be set to ''confirmed''. After a design decision has been reached the Unity status should be set to ''triaged'' as there is then enough information for the bug to be fixed. See also the ''Blocked waiting for design decision'' canned response. | 
| Line 50: | Line 90: | 
| {{{ $ DISPLAY=:0 gdb mutter GNU gdb (GDB) 7.2-ubuntu Copyright (C) 2010 Free Software Foundation, Inc. License GPLv3+: GNU GPL version 3 or later <http://gnu.org/licenses/gpl.html> This is free software: you are free to change and redistribute it. There is NO WARRANTY, to the extent permitted by law. Type "show copying" and "show warranty" for details. This GDB was configured as "i686-linux-gnu". For bug reporting instructions, please see: <http://www.gnu.org/software/gdb/bugs/>... Reading symbols from /usr/bin/mutter...(no debugging symbols found)...done. (gdb) set args --replace (gdb) set logging file 'mutter.log' (gdb) run | An example (real world) design bug: [[https://bugs.launchpad.net/unity/+bug/649560]] | 
| Line 66: | Line 92: | 
| [ and when mutter crashes, do...] | == Canned Responses == || '''Situation''' || '''Response''' || '''Note''' || || Patch needs author to sign Canonical Contributer agreement || Looks good but before we merge it we need you to sign the Canonical contributer agreement. It's a quick, but necessary step to getting your code into the tree. Luckily you only need to sign it once and it will apply to all other Canonical project contributions you may make in the future. http://www.canonical.com/contributors Make sure to CC David Barth when you send it in. || || || Blocked waiting for design decision || This bug is awaiting design feedback before progress can be made. Confirming that there is a question to be answered. Will be marked triage when design gives a suitable direction forward. || || || Bug reported from clutter based Unity || This bug was reported against and old version of Unity. The new version of Unity is almost an entire rewrite based on very different technologies. Could you please check if this issue is present in the current version, and if it is reopen the bug to a NEW status. || Set the bug to invalid, and let the user reopen it || | 
| Line 68: | Line 98: | 
| (gdb) bt full | = Bug Tags = | 
| Line 70: | Line 100: | 
| [ then CTRL-D or re-run mutter to continue working ] | These tags allow isolation of bugs into smaller groups, providing an easier and faster way to work on specific issues. | 
| Line 72: | Line 102: | 
| (gdb) run }}} | ||<rowbgcolor="#FFEBBB"> '''Tag''' || '''Use case''' || || [[https://launchpad.net/ubuntu/+source/compiz/+bugs?field.tag=unity|`unity`]] || Compiz bugs which are affecting Unity || || [[https://launchpad.net/ubuntu/+bugs?field.tag=running-unity|`running-unity`]] || Bugs reported by people who are running Unity || || [[https://launchpad.net/unity/+bugs?field.tag=bitesize|`bitesize`]] || Smaller bugs that would be ideal for new contributors. || || ... || ... || | 
| Line 75: | Line 109: | 
| Then, you should have a mutter.log file that you need to attach to the bug report. | = Testing a fix = Sometimes a developer might ask you to test a quick patch he came up with: check the [[https://launchpad.net/~unity/+archive/daily|Daily builds PPA]] to see if an updated version of Unity fixes the bugs you are experiencing. Be careful though, as those are daily builds that may break other things, and are to be considered unstable. = Known bugs = Known bugs, or missing features, are tracked in Launchpad and assigned to milestones to indicate when it is planned to be fixed and/or released. * Unity milestones: https://bugs.launchpad.net/unity/+milestones * https://launchpad.net/unity/+milestone/3.4 - ubuntu milestones * https://launchpad.net/unity/+milestone/3.4.4 - weekly milestones * https://launchpad.net/unity/+milestone/3.4.4 * https://launchpad.net/unity/+milestone/3.6 * https://launchpad.net/unity/+milestone/3.8 ------ '''Also see:''' * DebuggingProcedures ---- CategoryBugSquad CategoryDesktopTeam CategoryDebugging | 
| This page is part of the debugging series — pages with debugging details for a variety of Ubuntu packages. | 
Introduction
This page provides guidelines for filing bugs related to Unity, how to provide the debugging information required to analyze the issue, and how to triage Unity bugs.
Filing bugs
Technical issues
Use the standard ubuntu bug reporting tool as it gathers detailed information regarding your systems configuration. From the command line:
ubuntu-bug unity
When a crasher occurs on your system you should automatically see a dialog inviting you to report the issue. It will collect useful information from your system, automatically as well. But here is what you can also add to your bug report to help us confirm the issue more easily:
- Provide the result of the command glxinfo. It contains important graphics information that can help us identify your issue. (glxinfo is provided by the package mesa-utils and is automatically run in Natty)
- Provide the complete description of your GPU and how much video RAM it has. For instance, the market name of your graphics card may be Radeon HD 4650 or NVidia Geforce GTX 280. For embedded Intel GPU, you don't need to provide that information.
- Your monitor resolution and screen setup (single, dual monitor, triple monitor)
If the dialog doesn't appear for some reason, see the "advanced" procedure below.
Even if the issue is actually in Compiz, it's still worth filing the bug against Unity, and we'll triage things to point to compiz as well. We're working very closely with the Compiz project. Now, if you know the bug is with Compiz, you can read the DebuggingCompiz page to help us get more info to solve the problem.
Design and usability issues
Because Unity is a user interface, certain problems may be related to usability or design aspects, and not technical aspects.
In this case, contact the Design Team first before filing a bug against Unity. You can reach them on the ayatana list or on #ayatana on freenode. If the issue is acknowledged, or if you really want to file a bug, then tag it as 'opinion' or 'wishlist', and link the issue to the 'ayatana-design' project. This will follow a different workflow.
Advanced debugging procedure
Stale crashers
If apport did not automatically report the issue, you can check that a crasher trace has been collected by looking into the /var/crash directory. You should see a filename containing 'compiz'.
ls -altr /var/crash to list them in chronological order.
To manually file a bug report using a crash file:
- stay in your current X session
- add a window manager from a TTY if needed, ie CTRL-ALT-F1, login, DISPLAY=:0 metacity --replace 
- then, from your X session, do: apport-bug -c /var/crash/<compiz crash file> and follow the procedure in the web page that should open shortly after you invoke this command. Note that focus issues may prevent the page to appear on the top, but look for a new browser window opened in your workspace. 
Getting a stack trace
If for some reason apport was not enabled on your system, or if you have a reproducible issue we ask you to investigate, here is how you can generate a stack trace and inspect internal variables.
Ensure that you have the debugging symbols for the compiz, nux and unity packages.
Otherwise, from tty1 (Ctrl + Alt + F1)
$ unity --advanced-debug GNU gdb (GDB) 7.2-ubuntu Copyright (C) 2010 Free Software Foundation, Inc. License GPLv3+: GNU GPL version 3 or later <http://gnu.org/licenses/gpl.html> This is free software: you are free to change and redistribute it. There is NO WARRANTY, to the extent permitted by law. Type "show copying" and "show warranty" for details. This GDB was configured as "i686-linux-gnu". For bug reporting instructions, please see: <http://www.gnu.org/software/gdb/bugs/> ... (gdb) set logging file 'unity.log' (gdb) run [ and when compiz/unity crash, do...] (gdb) bt full [ then CTRL-D or re-run compiz to continue working ] (gdb) run
You can also get a valgrind trace by running valgrind compiz --replace & in a terminal. This is a little bit slower to get because it runs compiz under emulation, but it does produce some output which isn't possible to get from gdb.
In extreme circumstances, we may ask you to use the crashhandler plugin from git and enable that in ccsm.
Triaging instructions
Design Bugs
Some bugs are not technical defects, but behavioral, or visual ones. These often require input from the design team before they can be fixed. When a bug is determined to be a design bug, it should have an Ayatana design task added to it, and its Unity status should be set to confirmed. After a design decision has been reached the Unity status should be set to triaged as there is then enough information for the bug to be fixed. See also the Blocked waiting for design decision canned response.
An example (real world) design bug: https://bugs.launchpad.net/unity/+bug/649560
Canned Responses
| Situation | Response | Note | 
| Patch needs author to sign Canonical Contributer agreement | Looks good but before we merge it we need you to sign the Canonical contributer agreement. It's a quick, but necessary step to getting your code into the tree. Luckily you only need to sign it once and it will apply to all other Canonical project contributions you may make in the future. http://www.canonical.com/contributors Make sure to CC David Barth when you send it in. | 
 | 
| Blocked waiting for design decision | This bug is awaiting design feedback before progress can be made. Confirming that there is a question to be answered. Will be marked triage when design gives a suitable direction forward. | 
 | 
| Bug reported from clutter based Unity | This bug was reported against and old version of Unity. The new version of Unity is almost an entire rewrite based on very different technologies. Could you please check if this issue is present in the current version, and if it is reopen the bug to a NEW status. | Set the bug to invalid, and let the user reopen it | 
Bug Tags
These tags allow isolation of bugs into smaller groups, providing an easier and faster way to work on specific issues.
| Tag | Use case | 
| Compiz bugs which are affecting Unity | 
|| `running-unity` || Bugs reported by people who are running Unity ||
| Smaller bugs that would be ideal for new contributors. | |
| ... | ... | 
Testing a fix
Sometimes a developer might ask you to test a quick patch he came up with: check the Daily builds PPA to see if an updated version of Unity fixes the bugs you are experiencing. Be careful though, as those are daily builds that may break other things, and are to be considered unstable.
Known bugs
Known bugs, or missing features, are tracked in Launchpad and assigned to milestones to indicate when it is planned to be fixed and/or released.
- Unity milestones: https://bugs.launchpad.net/unity/+milestones 
Also see:
Unity/FilingBugs (last edited 2023-12-04 16:43:22 by jbicha)