Description
Prerequisites
- I verified that this is not a filter issue (MUST be reported at filter issue tracker)
- This is not a support issue or a question
- I performed a cursory search of the issue tracker to avoid opening a duplicate issue
- The issue is not present after wholly disabling uBlock Origin ("uBO") in the browser
- I checked the documentation to understand that the issue I report is not a normal behavior
I tried to reproduce the issue when...
- uBO is the only extension
- uBO with default lists/settings
- using a new, unmodified browser profile
Description
There have been numerous occasions where Annoyance lists have blanked out websites because either html
or body
have contained values that have been matched by a generic cosmetic filter. This is a pretty common issue for Annoyance lists, though there have been a few occasions in normal adblocking as well.
Usually these issues have been fixed by adding :not(html)
or :not(body)
exception to the problematic generic filter.
I was wondering if it would be reasonable to add a safeguard measure to uBO: to prevent it from applying cosmetic filters, that have a match in html
or body
in websites where an user is visiting. I think that neither html
or body
should ever be blocked as that will result in a blank website.
One recent issue: easylist/easylist#8431 - https://webshop.elektroskandia.no/
was blanked out because body
in that website had a value of .consent-summary-shown
. It was matched by this generic GDPR banner filter: ##.consent-summary-shown
. (It was later fixed by adding an exception: ##.consent-summary-shown:not(body)
).
But that wasn't the only case. In Fanboy's Annoyance list, there are currently:
- 260
:not(html)
exceptions - 298
:not(body)
exceptions
Adguard Annoyance:
- 127
:not(html)
exceptions - 160
:not(body)
exceptions
Easylist:
- 4
:not(html)
exceptions - 7
:not(body)
exceptions
I know these website blanking issues are mainly related to Annoyance lists that are not turned on by default in uBO, but they are still available and people use them. Not all issues get reported to filter list maintainers and there could be many unreported issues relating to these lists. Each :not(html)
or :not(body)
exception that currently exists, are related to fixing blank websites.
A specific URL where the issue occurs
https://webshop.elektroskandia.no/
(fixed now but this one is a recent case so I'll use it as a sample)
Steps to Reproduce
- Disable any possible Annoyance lists (to get rid of later added whitelistings)
- Add filter
##.consent-summary-shown
to custom filters - Go to
https://webshop.elektroskandia.no/
Expected behavior
uBO would ignore this generic filter for this website, because it matches to the body
element.
Actual behavior
Website is blanked, due to a match to the body
element.
uBlock Origin version
1.37.3b13
Browser name and version
Firefox 91.0.1
Operating System and version
Windows 10
Activity