What are some examples of obvious bugs?

Following Jerry Weinberg and James Bach, I understand that bugs exist between product, user and environment.

It means that behavior that is considered a bug in one product isn’t necessarily a bug in another product. One example could be Microsoft Excel incorrect treatment of 1900 as leap year - Microsoft explained that they needed to be compatible with Lotus 1-2-3, dominating spreadsheet at the time.

It means that behavior considered to be a bug by one person might not be a bug by another person. See social media discussions about pretty much any change in popular products for examples :wink: .

It means that behavior considered to be a bug in one situation might not be a bug in another situation. I generally don’t mind recharging my phone every day, but it is a problem when I am hiking - away from power source, where phone might be needed in case of emergency.

But then, there are some problems that are “obvious” and “universal”, i.e. they are always bug and don’t need explanation that they should be changed. One example might be application crashing. Another example might be application showing just plain background, with no controls. Yet another example might be form with no submit button or autosave feature - where data cannot be transferred anywhere.

Can you help me challenge Weinberg and Bach claim that all bugs are relative? What are some other examples of “obvious” bugs?

1 Like

Aren’t all bugs as relative as one project/company is able or willing to fix it?

Does it matter whether it is a bug or not, it matters more whether it is important or relevant to fix it?

A calculation error may be really important in one situation, but not another. Budget. Contracts. Politics. Legalities. All have a play in the decisions.

And sure, a bug in one scenario, may not be a bug in another. Or maybe it’s just much lower on the priority/severity scale kinda bug.

I think anything that stops a user doing the task they need to be doing is an ‘automatic bug’. Like you say - a crash. Or a button not working. Or severe slowness/performance inadequacy.

I’m not sure I want to challenge Jerry Weinberg or James Bach, but more clarification or links to references may be helpful to clarify my own thoughts.

2 Likes

I’d say that the importance of a bug is relative - misspelling the product name on the splash screen/front page is always a bug, but whether it’s considered an important bug is a different matter.

At that, I’ve dealt with web applications that simply fail to start unless IE is used - which was a major pain when my primary system ran Linux. The organization did not regard that as a bug because they developed for IE only.

Unfortunately, I can’t challenge Weinberg and Bach, simply because in my experience no matter what users say it won’t be a bug (and probably won’t be fixed) until the product creators agree that it’s a bug. Even then, it may or may not be fixed depending on whether or not it’s worth the time to the organization to fix it.

1 Like

I’m also curious about what Weinberg and Bach said.

Once the product is in the field, there are additional considerations. There are risks, some of which can lead to significant costs. Here I’m thinking of systems for transportation, healthcare, banking, and their infrastructure. The need to fix such bugs may be obvious. You can still argue that they are relative when you rank them by cost. But when dealing with safety, brand reputation, or even bankruptcy, fixing the bug is part of the remedy.

You said “Unfortunately, I can’t challenge Weinberg and Bach, simply because in my experience no matter what users say it won’t be a bug (and probably won’t be fixed) until the product creators agree that it’s a bug.”

Well, that fits their analysis as far as the definition of relativity between “product, user and environment” as long as you realise that there may be more than one environment. A business decision not to fix a particular bug is taken within the business environment, where different rules may apply. I’ve seen an online presentation with an appallingly egregious typo which appeared above a picture of the CEO and a voiceover from him. It was so bad, I got into a major argument with the Technology Director because (having bought this app in from a third party) he said that it “wasn’t my job” to test third-party apps. Fixing that bug had low priority in their business environment. (Our employment relationship lasted perhaps another six months.) In a previous role though, not fixing that bug would have gotten me sacked. That level of bugfix had a far higher priority in that business environment!

1 Like

Testing is context dependent so you have functional bugs and user acceptance bugs. Smth that isn’t a bug for the dev can be a bug for a user and vice versa. Smth that is a bug for the user won’t be a bug for the dev.
If the user perceives smth as a bug then it is up to dev team to decide if they want to fix it or not.

The severity and priority will very much differ depending on time and costs(in terms of money that you have to put into fixing vs the impact on the user which can also cost you in the long run).

Risks should always be assessed individually I am afraid and there is no golden rule. I think that we as testers should do whatever we can to present issues to devs with all the info we could gather (repro rate and severity) and its up to them to decide : )

@rosie

Aren’t all bugs as relative as one project/company is able or willing to fix it?

Does it matter whether it is a bug or not, it matters more whether it is important or relevant to fix it?

These are very good questions and I appreciate you asking them. I didn’t follow relativity path to the end and did not consider option that we should question the very existence and usefulness of “bug” category itself. I think it deserves some deeper thought.

But then, I’m not fully convinced that abandoning “bug” is a way forward. I can see a value of differentiating between “this is not a bug” and “this is a bug, but we do not have resources to fix it at this time”. If nothing else, we might want to find and review reports from the second category to see if maybe we can tackle them now. The first category can also be used as appendix/clarification of other requirement documents or to teach new team members about some mistakes that we did in the past.

@gingernatt

Smth that isn’t a bug for the dev can be a bug for a user and vice versa. Smth that is a bug for the user won’t be a bug for the dev.

Yes, but I am specifically looking for cases when something is a bug for user and dev (and tester, and product manager, and designer, and support person and whoever else you might have in the team), especially regardless of the particular product and context. Something that, when seen, can only be responded with “this isn’t right”.

Thanks everyone for your responses and thoughts!

Then obvious or universal would be:

  • any debug/placeholder text/asset
  • broken/corrupted assets
  • unclickable buttons/functionalities (anything really that causes a blocker or blocks out the functionality of an application.
  • any 100% crash with easy steps to reproduce

Those are from the top of my head. No dev can argue those aren’t bugs and would have to fix cause if they won’t, their reputation and usability and user experience will be damaged.

1 Like

As previously mentioned, anything that prevents a someone using the product from doing a task they should be able to do.
This means that bugs are relative, as different users of the product will have different ways of interacting with it, different levels of proficiencies in using it and so they will be using the most basic functionality all the way up to the most advanced functionality. Therefore a certain user may or may not discover a problem.