diff options
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(); +}); |