Skip to content

Writing Good Bug Reports

Alan Dipert edited this page May 10, 2019 · 7 revisions

Welcome! This is a guide for effective community bug reporting for the Shiny; its goal is to help you write better bug reports.

Basics

A good bug report follows the Show, Don't Tell principle. It has three basic components:

  1. What you did.
  2. What happened.
  3. What you expected to happen.

The impatient reader can stop now, as a well-specified report featuring these three components alone will put you in the upper echelon of bug reporters!

Where is the bug?

When you're having a problem with a Shiny application, there are a number of places that it can be coming from. Just to list a few:

  1. Your own R code
  2. Code in another R package you're using
  3. R itself
  4. Ephemeral networking problems

For this reason, we get many bug reports for Shiny which turn out not to have anything to do with Shiny itself. We help here where we can, but many of these reports don't go anywhere. To try to avoid filing them, the most helpful question you can ask yourself is:

What makes the bug occur?

Minimal Example

Create a minimal example application demonstrating the problem, and try to eliminate any code that isn't really necessary to make the bug happen. Most bugs can be demonstrated with a small amount of code, and there's a certain kind of fun in trying to find the most elegant way to reproduce them.

A minimal example application is the #1 absolutely most helpful thing you could possibly provide with your report, and we thank you in advance for providing one.

For step-by-step instructions on exactly how to create such an example, please see our Community post on the topic:

Shiny debugging and reprex guide

Self-contained

If at all possible, your minimal reproducible example application shouldn't require any setup beyond sourcing the code and observing the bug in the application or an error in the R console.

If your bug does only repro with certain data or files, try to either:

  • trim the data or files until they are as small as possible while still demonstrating the problem, or
  • create synthetic data or files which demonstrates the problem instead.

Reproducible

Finally, you want your example code to make the bug happen every time. If it only happens sometimes, it's hard for us to know whether we've fixed the bug or whether we've just gotten lucky! Some bugs are truly nondeterministic, and arise from timing and environment issues outside your control. However, the vast majority of sometimes bugs are really bugs that happen every time once you have figured out the preconditions.

Sometimes I see this error when I knit R Markdown documents with runtime: shiny ...

... Are there any documents that always make the error occur? If there are, can you try trimming bits off the document until you isolate the part that causes the error?

When I load this huge, private dataset, the UI doesn't look right

...Can you share a small, public dataset that has the same problem? If not, can you share a smaller, sanitized portion of your private dataset in the report?

... You get the idea.

We realize that a minimal, self-contained, reproducible example is an ideal which not every bug report can reach, but we promise that if it's obvious you've tried your best to make one, your bug will get a lot more traction.

What does the bug look like?

You'd be surprised how many folks take the time to describe what they're doing, but fail to describe the actual issue they encounter. Avoid saying that something "doesn't work". Instead, show, don't tell exactly what happened.

  • Did nothing happen when something should have?
  • Did the wrong thing happen? If so, what?
  • Did you see an error message? If so, what did it say?

When in doubt, share a screenshot showing exactly what the bug looks like when it happens. If you really want to impress us, you could make a short animated gif of the bug happening on your screen. One free program to help do that, that we use ourselves all the time, is LICEcap.

What did you expect to happen?

Sometimes a bug report is a feature request in disguise, and what seems like a problem is actually just something working as designed rather than as expected. For this reason, it's very helpful to tell us why you think the behavior you saw is wrong, if it isn't blindingly obvious.

Don't be afraid or embarrassed to file an issue that might be "as designed". If Shiny isn't working the way most people expect, that's a kind of bug, and we want to know about it!

That said, avoid disguising feature requests as bug reports; read our guide to Writing Good Feature Requests instead.

What problem are you trying to solve?

It's often helpful to describe the larger task you were trying to accomplish. Sometimes what looks like a bug is actually just a symptom of trying to put a round peg in a square hole. If you describe your larger task, we can often suggest a better way to do it, and suggest a workaround that can get you back in business before the bug is fixed.

Does the issue happen in master?

Even if you're using the latest stable version of Shiny, your issue might already be fixed on the master branch on GitHub! If you're able, it's very helpful for you to try to reproduce your problem in the very latest Shiny.

You can always install the latest version of Shiny from GitHub using devtools with the command devtools::install_github("rstudio/shiny")

If you tried more than one version of Shiny, let us know every version you tried (for example: "I use Shiny 1.3.2, but I also tried 92d32cb from GitHub and saw the problem there too.").

And if your bug reproduces in the latest stable version but does not reproduce in a newer build, it's probably not worth filing. Unless the issue is urgent enough to be backported (this is rare), it will probably be closed as "already fixed".

What does your environment look like?

A minority of bugs only reproduce on certain systems, with certain browsers, or when Shiny is combined with certain other packages in an application. To help us make sure our environment matches yours when we try to reproduce, it's always helpful to know your:

  1. Browser Version. For example, "Firefox 66" or "Edge 44.17763.1.0" (You can check your version of Edge with these instructions
  2. Operating System Version. For example, "macOS 10.14" or "Windows 10"
  3. sessionInfo() output.

Can you fix the bug yourself?

Here's where we remind you gently that Shiny is an open-source product, and we welcome contributions. If you have some programming experience, you can try your hand at fixing the issue yourself! We'd be very happy to help you do this (just ask when you file the bug).

Thank you

Finally — thank you for taking the time to read this, and to write a good bug report. It's an old open-source adage that given enough eyeballs, all bugs are shallow — but that only holds true if those eyeballs are connected to hands that take the time to report what they're seeing! We're very grateful to the Shiny community for the many thoughtful, high-quality bug reports we receive every year.

Clone this wiki locally