Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add test cases for redirected responses #19074

Merged
merged 2 commits into from
Dec 2, 2024

Conversation

Rob--W
Copy link
Member

@Rob--W Rob--W commented Nov 20, 2024

These are regression tests for issue #12744 and PR #19028.

@Rob--W
Copy link
Member Author

Rob--W commented Nov 20, 2024

Note: rebase this when #19028 is merged. The new test is expected to fail right now because the fix has not been applied yet.

Copy link
Collaborator

@Snuffleupagus Snuffleupagus left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for helping out with the tests!

test/unit/api_spec.js Outdated Show resolved Hide resolved
test/unit/api_spec.js Outdated Show resolved Hide resolved
test/unit/network_spec.js Outdated Show resolved Hide resolved
test/unit/network_spec.js Outdated Show resolved Hide resolved
@Rob--W Rob--W force-pushed the issue-12744-test branch 2 times, most recently from 914df5d to 1e53500 Compare November 23, 2024 18:42
@Rob--W
Copy link
Member Author

Rob--W commented Nov 23, 2024

@Snuffleupagus I have addressed the nits, and also updated the PR to run the tests for all IPDFStream implementations where this is relevant, instead of just PDFNetworkStream - i.e. I repeated the test for PDFFetchStream.

@Rob--W
Copy link
Member Author

Rob--W commented Nov 24, 2024

@Snuffleupagus I've updated the test by moving it to a separate file. After doing that, I ran into a new issue: while the network_spec.js test ran in the browser only, the fetch_stream_spec.js test was also run in Node.js. I looked into re-using the existing "temporary node server" helper, but then I would have to re-implement the redirect functionality of webserver.mjs there.

So in the end I decided to prepend another commit that replaces createTemporaryNodeServer with a new test helper that offers a uniform test server interface. Please let me know what you think of it. I can also split that test server to a separate PR if you'd like.

@Snuffleupagus
Copy link
Collaborator

Locally (on Windows) the new tests unfortunately seem to fail when running gulp unittest, which is the "normal" way to run the unit-tests and also what's used on the bots.

/botio unittest

@moz-tools-bot

This comment was marked as outdated.

@moz-tools-bot

This comment was marked as outdated.

@moz-tools-bot

This comment was marked as outdated.

@moz-tools-bot

This comment was marked as outdated.

@Rob--W
Copy link
Member Author

Rob--W commented Nov 24, 2024

Locally (on Windows) the new tests unfortunately seem to fail when running gulp unittest, which is the "normal" way to run the unit-tests and also what's used on the bots.

Sorry about that, I accidentally lost some lines while rebasing.

This is the diff compared to before:

diff --git a/test/unit/network_spec.js b/test/unit/network_spec.js
index 4c2624a8b..367e52560 100644
--- a/test/unit/network_spec.js
+++ b/test/unit/network_spec.js
@@ -16,6 +16,7 @@
 import { AbortException } from "../../src/shared/util.js";
 import { PDFNetworkStream } from "../../src/display/network.js";
 import { testCrossOriginRedirects } from "./common_pdfstream_tests.js";
+import { TestPdfsServer } from "./test_utils.js";
 
 describe("network", function () {
   const pdf1 = new URL("../pdfs/tracemonkey.pdf", window.location).href;
@@ -118,6 +119,14 @@ describe("network", function () {
   });
 
   describe("Redirects", function () {
+    beforeAll(async function () {
+      await TestPdfsServer.ensureStarted();
+    });
+
+    afterAll(async function () {
+      await TestPdfsServer.ensureStopped();
+    });
+
     it("redirects allowed if all responses are same-origin", async function () {
       await testCrossOriginRedirects({
         PDFStreamClass: PDFNetworkStream,

@mozilla mozilla deleted a comment from moz-tools-bot Nov 24, 2024
@mozilla mozilla deleted a comment from moz-tools-bot Nov 24, 2024
@Rob--W
Copy link
Member Author

Rob--W commented Nov 24, 2024

Oddly, the test passes in Firefox but failed in Chrome, with the following error:

TEST-UNEXPECTED-FAIL | redirects blocked if any response is cross-origin | in chrome | Expected a promise to be rejected but it was resolved. Expected a promise to be rejected but it was resolved.

I updated the patch to add a cache buster, to see if that fixes the test.

/botio unittest

@moz-tools-bot
Copy link
Collaborator

From: Bot.io (Linux m4)


Failed

Full output at http://54.241.84.105:8877/efefda0bf24c87e/output.txt

Total script time: 2.48 mins

  • Unit Tests: FAILED

@Rob--W
Copy link
Member Author

Rob--W commented Nov 24, 2024

??? The test output is inconsistent. Within the same file in the test on Linux, I see the following (one for network, one for fetch_stream, unclear which is which): http://54.241.84.105:8877/efefda0bf24c87e/output.txt

TEST-UNEXPECTED-FAIL | redirects blocked if any response is cross-origin | in chrome | Expected a promise to be rejected but it was resolved. Expected a promise to be rejected but it was resolved.
TEST-PASSED | redirects blocked if any response is cross-origin | in chrome

@mozilla mozilla deleted a comment from moz-tools-bot Nov 24, 2024
@Rob--W
Copy link
Member Author

Rob--W commented Nov 25, 2024

Another attempt - adding Vary:Origin at the server side instead of cache buster at the client side.

@Rob--W
Copy link
Member Author

Rob--W commented Nov 25, 2024

/botio unittest

@moz-tools-bot
Copy link
Collaborator

From: Bot.io (Windows)


Received

Command cmd_unittest from @Rob--W received. Current queue size: 0

Live output at: http://54.193.163.58:8877/cf821e7cebb656b/output.txt

@moz-tools-bot
Copy link
Collaborator

From: Bot.io (Linux m4)


Received

Command cmd_unittest from @Rob--W received. Current queue size: 0

Live output at: http://54.241.84.105:8877/203b9ff7350ccec/output.txt

@mozilla mozilla deleted a comment from moz-tools-bot Nov 25, 2024
@mozilla mozilla deleted a comment from moz-tools-bot Nov 25, 2024
@mozilla mozilla deleted a comment from moz-tools-bot Nov 25, 2024
@moz-tools-bot
Copy link
Collaborator

From: Bot.io (Linux m4)


Failed

Full output at http://54.241.84.105:8877/203b9ff7350ccec/output.txt

Total script time: 2.53 mins

  • Unit Tests: FAILED

@moz-tools-bot
Copy link
Collaborator

From: Bot.io (Windows)


Failed

Full output at http://54.193.163.58:8877/cf821e7cebb656b/output.txt

Total script time: 6.44 mins

  • Unit Tests: FAILED

@Rob--W
Copy link
Member Author

Rob--W commented Nov 25, 2024

I suspect that Chrome serves the range response directly from its own cache (based on the response from the full request), without reaching the server, and thus never triggering the redirect, and therefore not triggering the expected failure.

I'll look into a way to avoid that, later.

@Rob--W
Copy link
Member Author

Rob--W commented Nov 27, 2024

I've added Cache-Control: no-store,max-age=0 to the relevant requests from the new test.

/botio unittest

@moz-tools-bot
Copy link
Collaborator

From: Bot.io (Linux m4)


Received

Command cmd_unittest from @Rob--W received. Current queue size: 0

Live output at: http://54.241.84.105:8877/3bf4c156cad42c5/output.txt

@moz-tools-bot
Copy link
Collaborator

From: Bot.io (Windows)


Received

Command cmd_unittest from @Rob--W received. Current queue size: 1

Live output at: http://54.193.163.58:8877/180e7f620d54e71/output.txt

@moz-tools-bot
Copy link
Collaborator

From: Bot.io (Linux m4)


Success

Full output at http://54.241.84.105:8877/3bf4c156cad42c5/output.txt

Total script time: 2.49 mins

  • Unit Tests: Passed

@moz-tools-bot
Copy link
Collaborator

From: Bot.io (Windows)


Success

Full output at http://54.193.163.58:8877/180e7f620d54e71/output.txt

Total script time: 6.36 mins

  • Unit Tests: Passed

@Rob--W
Copy link
Member Author

Rob--W commented Nov 27, 2024

@Snuffleupagus The tests now pass in Chrome, it looks like my analysis of the issue along with the fix is correct. Please review again.

Analysis:

I suspect that Chrome serves the range response directly from its own cache (based on the response from the full request), without reaching the server, and thus never triggering the redirect, and therefore not triggering the expected failure.

I'll look into a way to avoid that, later.

Fix:

I've added Cache-Control: no-store,max-age=0 to the relevant requests from the new test.

test/unit/test_utils.js Outdated Show resolved Hide resolved
test/unit/test_utils.js Show resolved Hide resolved
test/unit/common_pdfstream_tests.js Outdated Show resolved Hide resolved
Some tests rely on the presence of a server that serves PDF files.
When tests are run from a web browser, the test files and PDF files are
served by the same server (WebServer), but in Node.js that server is not
around.

Currently, the tests that depend on it start a minimal Node.js server
that re-implements part of the functionality from WebServer.

To avoid code duplication when tests depend on more complex behaviors,
this patch replaces createTemporaryNodeServer with the existing
WebServer, wrapped in a new test utility that has the same interface in
Node.js and non-Node.js environments (=TestPdfsServer).

This patch has been tested by running the refactored tests in the
following three configurations:

1. From the browser:
   - http://localhost:8888/test/unit/unit_test.html?spec=api
   - http://localhost:8888/test/unit/unit_test.html?spec=fetch_stream

2. Run specific tests directly with jasmine without legacy bundling:
   `JASMINE_CONFIG_PATH=test/unit/clitests.json ./node_modules/.bin/jasmine --filter='^api|^fetch_stream'`

3. `gulp unittestcli`
Copy link
Collaborator

@Snuffleupagus Snuffleupagus left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

r=me, assuming passing unit-tests; thank you.

@Snuffleupagus
Copy link
Collaborator

/botio unittest

@moz-tools-bot
Copy link
Collaborator

From: Bot.io (Linux m4)


Received

Command cmd_unittest from @Snuffleupagus received. Current queue size: 0

Live output at: http://54.241.84.105:8877/6ab44c041e86752/output.txt

@moz-tools-bot
Copy link
Collaborator

From: Bot.io (Windows)


Received

Command cmd_unittest from @Snuffleupagus received. Current queue size: 0

Live output at: http://54.193.163.58:8877/37771b586565f75/output.txt

@moz-tools-bot
Copy link
Collaborator

From: Bot.io (Linux m4)


Success

Full output at http://54.241.84.105:8877/6ab44c041e86752/output.txt

Total script time: 2.50 mins

  • Unit Tests: Passed

@moz-tools-bot
Copy link
Collaborator

From: Bot.io (Windows)


Success

Full output at http://54.193.163.58:8877/37771b586565f75/output.txt

Total script time: 6.77 mins

  • Unit Tests: Passed

@Snuffleupagus Snuffleupagus merged commit f8d11a3 into mozilla:master Dec 2, 2024
7 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants