diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 19:33:14 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 19:33:14 +0000 |
commit | 36d22d82aa202bb199967e9512281e9a53db42c9 (patch) | |
tree | 105e8c98ddea1c1e4784a60a5a6410fa416be2de /dom/base/test/browser_refresh_content.js | |
parent | Initial commit. (diff) | |
download | firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.tar.xz firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.zip |
Adding upstream version 115.7.0esr.upstream/115.7.0esr
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'dom/base/test/browser_refresh_content.js')
-rw-r--r-- | dom/base/test/browser_refresh_content.js | 127 |
1 files changed, 127 insertions, 0 deletions
diff --git a/dom/base/test/browser_refresh_content.js b/dom/base/test/browser_refresh_content.js new file mode 100644 index 0000000000..0ff61db423 --- /dev/null +++ b/dom/base/test/browser_refresh_content.js @@ -0,0 +1,127 @@ +/* Any copyright is dedicated to the Public Domain. + * http://creativecommons.org/publicdomain/zero/1.0/ */ + +/* + * Ensures resources can still be fetched without validation + */ + +const CONTENT_URL = + "http://www.example.com/browser/dom/base/test/file_browser_refresh_content.html"; + +async function run_test_browser_refresh(forceRevalidate) { + let tab = await BrowserTestUtils.openNewForegroundTab({ + gBrowser, + url: CONTENT_URL, + waitForLoad: true, + /* Ensures each run is started with a fresh state */ + forceNewProcess: true, + }); + + let originalAttributes = await SpecialPowers.spawn( + tab.linkedBrowser, + [], + async () => { + let result = content.document.getElementById("result"); + await ContentTaskUtils.waitForCondition(() => { + return ( + result.getAttribute("imageDataURL") && + result.getAttribute("iframeContent") && + result.getAttribute("expiredResourceCacheControl") + ); + }); + return { + imageDataURL: result.getAttribute("imageDataURL"), + iframeContent: result.getAttribute("iframeContent"), + expiredResourceCacheControl: result.getAttribute( + "expiredResourceCacheControl" + ), + }; + } + ); + + let imageDataURL = originalAttributes.imageDataURL; + let expiredResourceCacheControl = + originalAttributes.expiredResourceCacheControl; + + is( + originalAttributes.iframeContent, + "first load", + "Iframe is loaded with the initial content" + ); + + tab.linkedBrowser.reload(); + + await BrowserTestUtils.browserLoaded(tab.linkedBrowser); + + let attributes = await SpecialPowers.spawn( + tab.linkedBrowser, + [], + async () => { + let result = content.document.getElementById("result"); + + await ContentTaskUtils.waitForCondition(() => { + return ( + result.getAttribute("imageDataURL") && + result.getAttribute("expiredResourceCacheControl") && + result.getAttribute("nonCacheableResourceCompleted") + ); + }); + + return { + iframeContent: result.getAttribute("iframeContent"), + imageDataURL: result.getAttribute("imageDataURL"), + expiredResourceCacheControl: result.getAttribute( + "expiredResourceCacheControl" + ), + nonCacheableResourceCompleted: result.getAttribute( + "nonCacheableResourceCompleted" + ), + }; + } + ); + + is( + attributes.iframeContent, + "second load", + "Iframe should always be revalidated" + ); + + if (!forceRevalidate) { + ok(attributes.imageDataURL === imageDataURL, "Image should use cache"); + } else { + ok(attributes.imageDataURL !== imageDataURL, "Image should be revalidated"); + } + + if (!forceRevalidate) { + ok( + attributes.expiredResourceCacheControl === expiredResourceCacheControl, + "max-age shouldn't be changed after reload because it didn't revalidate" + ); + } else { + ok( + attributes.expiredResourceCacheControl !== expiredResourceCacheControl, + "max-age should be changed after reload because it got revalidated" + ); + } + + is( + attributes.nonCacheableResourceCompleted, + "true", + "Non cacheable resource should still be loaded" + ); + + await BrowserTestUtils.removeTab(tab); +} + +add_task(async function test_browser_refresh() { + Services.prefs.setBoolPref( + "browser.soft_reload.only_force_validate_top_level_document", + true + ); + await run_test_browser_refresh(false); + Services.prefs.setBoolPref( + "browser.soft_reload.only_force_validate_top_level_document", + false + ); + await run_test_browser_refresh(true); +}); |