Skip to content

Commit

Permalink
Follow-up of #12707: Add an integration test for checkboxes as radio …
Browse files Browse the repository at this point in the history
…buttons

 * Integration tests: Add a function to load a pdf and wait for a selected element
 * Integration tests: Add a function to close all the open pages
  • Loading branch information
calixteman committed Dec 10, 2020
1 parent 31ea30a commit c939468
Show file tree
Hide file tree
Showing 5 changed files with 84 additions and 38 deletions.
63 changes: 43 additions & 20 deletions test/integration/annotation_spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -13,49 +13,72 @@
* limitations under the License.
*/

const { closeAll, loadAndWait } = require("./commons.js");

describe("Annotation highlight", () => {
describe("annotation-highlight.pdf", () => {
let pages;

beforeAll(async () => {
pages = await Promise.all(
global.integrationSessions.map(async session => {
const page = await session.browser.newPage();
await page.goto(
`${global.integrationBaseUrl}?file=/test/pdfs/annotation-highlight.pdf`
);
await page.bringToFront();
await page.waitForSelector("[data-annotation-id='19R']", {
timeout: 0,
});
return page;
})
pages = await loadAndWait(
"annotation-highlight.pdf",
"[data-annotation-id='19R']"
);
});

afterAll(async () => {
await Promise.all(
pages.map(async page => {
await page.close();
})
);
await closeAll(pages);
});

it("must show a popup on mouseover", async () => {
await Promise.all(
pages.map(async page => {
pages.map(async ([name, page]) => {
let hidden = await page.$eval(
"[data-annotation-id='21R']",
el => el.hidden
);
expect(hidden).toEqual(true);
expect(hidden).withContext(`In ${name}`).toEqual(true);
await page.hover("[data-annotation-id='19R']");
await page.waitForTimeout(100);
hidden = await page.$eval(
"[data-annotation-id='21R']",
el => el.hidden
);
expect(hidden).toEqual(false);
expect(hidden).withContext(`In ${name}`).toEqual(false);
})
);
});
});
});

describe("Checkbox annotation", () => {
describe("issue12706.pdf", () => {
let pages;

beforeAll(async () => {
pages = await loadAndWait("issue12706.pdf", "[data-annotation-id='63R']");
});

afterAll(async () => {
await closeAll(pages);
});

it("must click on different checkboxes and they must behave like radio buttons", async () => {
const selectors = [63, 70, 79].map(n => `[data-annotation-id='${n}R']`);
await Promise.all(
pages.map(async ([name, page]) => {
for (const sel of selectors) {
await page.click(sel);
for (const otherSel of selectors) {
const checked = await page.$eval(
`${otherSel} > :first-child`,
el => el.checked
);
expect(checked)
.withContext(`In ${name}`)
.toBe(sel === otherSel);
}
}
})
);
});
Expand Down
36 changes: 36 additions & 0 deletions test/integration/commons.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
/* Copyright 2020 Mozilla Foundation
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/

exports.loadAndWait = (filename, selector) =>
Promise.all(
global.integrationSessions.map(async session => {
const page = await session.browser.newPage();
await page.goto(
`${global.integrationBaseUrl}?file=/test/pdfs/${filename}`
);
await page.bringToFront();
await page.waitForSelector(selector, {
timeout: 0,
});
return [session.name, page];
})
);

exports.closeAll = pages =>
Promise.all(
pages.map(async ([_, page]) => {
await page.close();
})
);
22 changes: 4 additions & 18 deletions test/integration/scripting_spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -13,32 +13,18 @@
* limitations under the License.
*/

const { closeAll, loadAndWait } = require("./commons.js");

describe("Interaction", () => {
describe("in 160F-2019.pdf", () => {
let pages;

beforeAll(async () => {
pages = await Promise.all(
global.integrationSessions.map(async session => {
const page = await session.browser.newPage();
await page.goto(
`${global.integrationBaseUrl}?file=/test/pdfs/160F-2019.pdf`
);
await page.bringToFront();
await page.waitForSelector("#\\34 16R", {
timeout: 0,
});
return [session.name, page];
})
);
pages = await loadAndWait("160F-2019.pdf", "#\\34 16R");
});

afterAll(async () => {
await Promise.all(
pages.map(async ([_, page]) => {
await page.close();
})
);
await closeAll(pages);
});

it("must format the field with 2 digits and leave field with a click", async () => {
Expand Down
1 change: 1 addition & 0 deletions test/pdfs/.gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -330,6 +330,7 @@
!issue5334.pdf
!annotation-caret-ink.pdf
!bug1186827.pdf
!issue12706.pdf
!issue215.pdf
!issue5044.pdf
!issue1512r.pdf
Expand Down
Binary file added test/pdfs/issue12706.pdf
Binary file not shown.

0 comments on commit c939468

Please sign in to comment.