diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-28 14:29:10 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-28 14:29:10 +0000 |
commit | 2aa4a82499d4becd2284cdb482213d541b8804dd (patch) | |
tree | b80bf8bf13c3766139fbacc530efd0dd9d54394c /browser/base/content/test/protectionsUI/browser_protectionsUI_animation.js | |
parent | Initial commit. (diff) | |
download | firefox-upstream.tar.xz firefox-upstream.zip |
Adding upstream version 86.0.1.upstream/86.0.1upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'browser/base/content/test/protectionsUI/browser_protectionsUI_animation.js')
-rw-r--r-- | browser/base/content/test/protectionsUI/browser_protectionsUI_animation.js | 72 |
1 files changed, 72 insertions, 0 deletions
diff --git a/browser/base/content/test/protectionsUI/browser_protectionsUI_animation.js b/browser/base/content/test/protectionsUI/browser_protectionsUI_animation.js new file mode 100644 index 0000000000..2d11bd5b25 --- /dev/null +++ b/browser/base/content/test/protectionsUI/browser_protectionsUI_animation.js @@ -0,0 +1,72 @@ +/* Any copyright is dedicated to the Public Domain. + * http://creativecommons.org/publicdomain/zero/1.0/ */ + +"use strict"; + +const TRACKING_PAGE = + "http://tracking.example.org/browser/browser/base/content/test/protectionsUI/trackingPage.html"; +const BENIGN_PAGE = + "http://tracking.example.org/browser/browser/base/content/test/protectionsUI/benignPage.html"; +const TP_PREF = "privacy.trackingprotection.enabled"; +const PREFER_REDUCED_MOTION_PREF = "ui.prefersReducedMotion"; +const DTSCBN_PREF = "dom.testing.sync-content-blocking-notifications"; + +// Test that the shield icon animation can be controlled by the cosmetic +// animations pref and that one of the icons is visible in each case. +add_task(async function testShieldAnimation() { + await UrlClassifierTestUtils.addTestTrackers(); + Services.prefs.setBoolPref(TP_PREF, true); + Services.prefs.setBoolPref(DTSCBN_PREF, true); + + let tab = (gBrowser.selectedTab = BrowserTestUtils.addTab(gBrowser)); + + let animationIcon = document.getElementById( + "tracking-protection-icon-animatable-image" + ); + let noAnimationIcon = document.getElementById("tracking-protection-icon"); + + Services.prefs.setIntPref(PREFER_REDUCED_MOTION_PREF, 0); + await Promise.all([ + promiseTabLoadEvent(tab, TRACKING_PAGE), + waitForContentBlockingEvent(2, tab.linkedBrowser.ownerGlobal), + ]); + ok( + BrowserTestUtils.is_hidden(noAnimationIcon), + "the default icon is hidden when animations are enabled" + ); + ok( + BrowserTestUtils.is_visible(animationIcon), + "the animated icon is shown when animations are enabled" + ); + + await promiseTabLoadEvent(tab, BENIGN_PAGE); + ok(BrowserTestUtils.is_hidden(animationIcon), "the animated icon is hidden"); + ok( + BrowserTestUtils.is_visible(noAnimationIcon), + "the default icon is visible" + ); + + Services.prefs.setIntPref(PREFER_REDUCED_MOTION_PREF, 1); + await Promise.all([ + promiseTabLoadEvent(tab, TRACKING_PAGE), + waitForContentBlockingEvent(2, tab.linkedBrowser.ownerGlobal), + ]); + + // We will only show the last frame of the animation when the animation is + // disable. So, the animated icon would be shown but the default icon + // wouldn't. + ok( + BrowserTestUtils.is_hidden(noAnimationIcon), + "the default icon is hidden when animations are disabled" + ); + ok( + BrowserTestUtils.is_visible(animationIcon), + "the animated icon is shown when animations are disabled" + ); + + gBrowser.removeCurrentTab(); + Services.prefs.clearUserPref(PREFER_REDUCED_MOTION_PREF); + Services.prefs.clearUserPref(TP_PREF); + Services.prefs.clearUserPref(DTSCBN_PREF); + UrlClassifierTestUtils.cleanupTestTrackers(); +}); |