Some checks failed
Types tests / Test (lts/*) (push) Has been cancelled
Lint / Lint (lts/*) (push) Has been cancelled
CodeQL / Analyze (javascript) (push) Has been cancelled
CI / Test (20) (push) Has been cancelled
CI / Test (22) (push) Has been cancelled
CI / Test (24) (push) Has been cancelled
882 lines
27 KiB
JavaScript
882 lines
27 KiB
JavaScript
/* 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.
|
|
*/
|
|
|
|
import {
|
|
closePages,
|
|
getAnnotationSelector,
|
|
getQuerySelector,
|
|
getRect,
|
|
getSelector,
|
|
loadAndWait,
|
|
} from "./test_utils.mjs";
|
|
|
|
describe("Annotation highlight", () => {
|
|
describe("annotation-highlight.pdf", () => {
|
|
let pages;
|
|
|
|
beforeEach(async () => {
|
|
pages = await loadAndWait(
|
|
"annotation-highlight.pdf",
|
|
getAnnotationSelector("19R")
|
|
);
|
|
});
|
|
|
|
afterEach(async () => {
|
|
await closePages(pages);
|
|
});
|
|
|
|
it("must check the popup position in the DOM", async () => {
|
|
await Promise.all(
|
|
pages.map(async ([browserName, page]) => {
|
|
const highlightSelector = getAnnotationSelector("19R");
|
|
const popupSelector = getAnnotationSelector("21R");
|
|
const areSiblings = await page.evaluate(
|
|
(highlightSel, popupSel) => {
|
|
const highlight = document.querySelector(highlightSel);
|
|
const popup = document.querySelector(popupSel);
|
|
return highlight.nextElementSibling === popup;
|
|
},
|
|
highlightSelector,
|
|
popupSelector
|
|
);
|
|
expect(areSiblings).withContext(`In ${browserName}`).toEqual(true);
|
|
})
|
|
);
|
|
});
|
|
|
|
it("must show a popup on mouseover", async () => {
|
|
await Promise.all(
|
|
pages.map(async ([browserName, page]) => {
|
|
let hidden = await page.$eval(
|
|
getAnnotationSelector("21R"),
|
|
el => el.hidden
|
|
);
|
|
expect(hidden).withContext(`In ${browserName}`).toEqual(true);
|
|
await page.hover(getAnnotationSelector("19R"));
|
|
await page.waitForSelector(getAnnotationSelector("21R"), {
|
|
visible: true,
|
|
timeout: 0,
|
|
});
|
|
hidden = await page.$eval(
|
|
getAnnotationSelector("21R"),
|
|
el => el.hidden
|
|
);
|
|
expect(hidden).withContext(`In ${browserName}`).toEqual(false);
|
|
})
|
|
);
|
|
});
|
|
});
|
|
|
|
describe("Check that widget annotations are in front of highlight ones", () => {
|
|
let pages;
|
|
|
|
beforeEach(async () => {
|
|
pages = await loadAndWait("bug1883609.pdf", getAnnotationSelector("23R"));
|
|
});
|
|
|
|
afterEach(async () => {
|
|
await closePages(pages);
|
|
});
|
|
|
|
it("must click on widget annotations", async () => {
|
|
await Promise.all(
|
|
pages.map(async ([browserName, page]) => {
|
|
for (const i of [23, 22, 14]) {
|
|
await page.click(getAnnotationSelector(`${i}R`));
|
|
await page.waitForSelector(`#pdfjs_internal_id_${i}R:focus`);
|
|
}
|
|
})
|
|
);
|
|
});
|
|
});
|
|
});
|
|
|
|
describe("Checkbox annotation", () => {
|
|
describe("issue12706.pdf", () => {
|
|
let pages;
|
|
|
|
beforeEach(async () => {
|
|
pages = await loadAndWait("issue12706.pdf", getAnnotationSelector("63R"));
|
|
});
|
|
|
|
afterEach(async () => {
|
|
await closePages(pages);
|
|
});
|
|
|
|
it("must let checkboxes with the same name behave like radio buttons", async () => {
|
|
const selectors = [63, 70, 79].map(n => getAnnotationSelector(`${n}R`));
|
|
await Promise.all(
|
|
pages.map(async ([browserName, page]) => {
|
|
for (const selector of selectors) {
|
|
await page.click(selector);
|
|
await page.waitForFunction(
|
|
`document.querySelector('${selector} > :first-child').checked`
|
|
);
|
|
|
|
for (const otherSelector of selectors) {
|
|
const checked = await page.$eval(
|
|
`${otherSelector} > :first-child`,
|
|
el => el.checked
|
|
);
|
|
expect(checked)
|
|
.withContext(`In ${browserName}`)
|
|
.toBe(selector === otherSelector);
|
|
}
|
|
}
|
|
})
|
|
);
|
|
});
|
|
});
|
|
|
|
describe("issue15597.pdf", () => {
|
|
let pages;
|
|
|
|
beforeEach(async () => {
|
|
pages = await loadAndWait("issue15597.pdf", getAnnotationSelector("7R"));
|
|
});
|
|
|
|
afterEach(async () => {
|
|
await closePages(pages);
|
|
});
|
|
|
|
it("must check the checkbox", async () => {
|
|
await Promise.all(
|
|
pages.map(async ([browserName, page]) => {
|
|
const selector = getAnnotationSelector("7R");
|
|
await page.click(selector);
|
|
await page.waitForFunction(
|
|
`document.querySelector('${selector} > :first-child').checked`
|
|
);
|
|
expect(true).withContext(`In ${browserName}`).toEqual(true);
|
|
})
|
|
);
|
|
});
|
|
});
|
|
|
|
describe("bug1847733.pdf", () => {
|
|
let pages;
|
|
|
|
beforeEach(async () => {
|
|
pages = await loadAndWait("bug1847733.pdf", getAnnotationSelector("18R"));
|
|
});
|
|
|
|
afterEach(async () => {
|
|
await closePages(pages);
|
|
});
|
|
|
|
it("must check the checkbox", async () => {
|
|
await Promise.all(
|
|
pages.map(async ([browserName, page]) => {
|
|
const selectors = [18, 30, 42, 54].map(id =>
|
|
getAnnotationSelector(`${id}R`)
|
|
);
|
|
for (const selector of selectors) {
|
|
await page.click(selector);
|
|
await page.waitForFunction(
|
|
`document.querySelector('${selector} > :first-child').checked`
|
|
);
|
|
}
|
|
})
|
|
);
|
|
});
|
|
});
|
|
});
|
|
|
|
describe("Text widget", () => {
|
|
describe("issue13271.pdf", () => {
|
|
let pages;
|
|
|
|
beforeEach(async () => {
|
|
pages = await loadAndWait("issue13271.pdf", getAnnotationSelector("24R"));
|
|
});
|
|
|
|
afterEach(async () => {
|
|
await closePages(pages);
|
|
});
|
|
|
|
it("must update all the fields with the same value", async () => {
|
|
const base = "hello world";
|
|
await Promise.all(
|
|
pages.map(async ([browserName, page]) => {
|
|
await page.type(getSelector("25R"), base);
|
|
await page.waitForFunction(`${getQuerySelector("24R")}.value !== ""`);
|
|
await page.waitForFunction(`${getQuerySelector("26R")}.value !== ""`);
|
|
|
|
let text = await page.$eval(getSelector("24R"), el => el.value);
|
|
expect(text).withContext(`In ${browserName}`).toEqual(base);
|
|
|
|
text = await page.$eval(getSelector("26R"), el => el.value);
|
|
expect(text).withContext(`In ${browserName}`).toEqual(base);
|
|
})
|
|
);
|
|
});
|
|
});
|
|
|
|
describe("issue16473.pdf", () => {
|
|
let pages;
|
|
|
|
beforeEach(async () => {
|
|
pages = await loadAndWait("issue16473.pdf", getAnnotationSelector("22R"));
|
|
});
|
|
|
|
afterEach(async () => {
|
|
await closePages(pages);
|
|
});
|
|
|
|
it("must reset a formatted value after a change", async () => {
|
|
await Promise.all(
|
|
pages.map(async ([browserName, page]) => {
|
|
await page.type(getSelector("22R"), "a");
|
|
await page.keyboard.press("Tab");
|
|
await page.waitForFunction(
|
|
`${getQuerySelector("22R")}.value !== "Hello world"`
|
|
);
|
|
|
|
const text = await page.$eval(getSelector("22R"), el => el.value);
|
|
expect(text).withContext(`In ${browserName}`).toEqual("aHello World");
|
|
})
|
|
);
|
|
});
|
|
});
|
|
});
|
|
|
|
describe("Link annotations with internal destinations", () => {
|
|
describe("bug1708041.pdf", () => {
|
|
let pages;
|
|
|
|
beforeEach(async () => {
|
|
pages = await loadAndWait(
|
|
"bug1708041.pdf",
|
|
".page[data-page-number='1'] .annotationLayer"
|
|
);
|
|
});
|
|
|
|
afterEach(async () => {
|
|
await closePages(pages);
|
|
});
|
|
|
|
it("must click on a link and check if it navigates to the correct page", async () => {
|
|
await Promise.all(
|
|
pages.map(async ([browserName, page]) => {
|
|
const pageOneSelector = ".page[data-page-number='1']";
|
|
const linkSelector = `${pageOneSelector} #pdfjs_internal_id_42R`;
|
|
await page.waitForSelector(linkSelector);
|
|
const linkTitle = await page.$eval(linkSelector, el => el.title);
|
|
expect(linkTitle)
|
|
.withContext(`In ${browserName}`)
|
|
.toEqual("Go to the last page");
|
|
await page.click(linkSelector);
|
|
const pageSixTextLayerSelector =
|
|
".page[data-page-number='6'] .textLayer";
|
|
await page.waitForSelector(pageSixTextLayerSelector, {
|
|
visible: true,
|
|
});
|
|
await page.waitForFunction(
|
|
sel => {
|
|
const textLayer = document.querySelector(sel);
|
|
return document.activeElement === textLayer;
|
|
},
|
|
{},
|
|
pageSixTextLayerSelector
|
|
);
|
|
})
|
|
);
|
|
});
|
|
});
|
|
});
|
|
|
|
describe("Annotation and storage", () => {
|
|
describe("issue14023.pdf", () => {
|
|
let pages;
|
|
|
|
beforeEach(async () => {
|
|
pages = await loadAndWait("issue14023.pdf", getAnnotationSelector("64R"));
|
|
});
|
|
|
|
afterEach(async () => {
|
|
await closePages(pages);
|
|
});
|
|
|
|
it("must let checkboxes with the same name behave like radio buttons", async () => {
|
|
const text1 = "hello world!";
|
|
const text2 = "!dlrow olleh";
|
|
await Promise.all(
|
|
pages.map(async ([browserName, page]) => {
|
|
// Text field.
|
|
await page.type(getSelector("64R"), text1);
|
|
// Checkbox.
|
|
await page.click(getAnnotationSelector("65R"));
|
|
// Radio.
|
|
await page.click(getAnnotationSelector("67R"));
|
|
|
|
for (const [pageNumber, textId, checkId, radio1Id, radio2Id] of [
|
|
[2, "18R", "19R", "21R", "20R"],
|
|
[5, "23R", "24R", "22R", "25R"],
|
|
]) {
|
|
await page.evaluate(n => {
|
|
window.document
|
|
.querySelectorAll(`[data-page-number="${n}"][class="page"]`)[0]
|
|
.scrollIntoView();
|
|
}, pageNumber);
|
|
|
|
// Need to wait to have a displayed text input.
|
|
await page.waitForSelector(getSelector(textId), {
|
|
timeout: 0,
|
|
});
|
|
|
|
const text = await page.$eval(getSelector(textId), el => el.value);
|
|
expect(text).withContext(`In ${browserName}`).toEqual(text1);
|
|
|
|
let checked = await page.$eval(
|
|
getSelector(checkId),
|
|
el => el.checked
|
|
);
|
|
expect(checked).toEqual(true);
|
|
|
|
checked = await page.$eval(getSelector(radio1Id), el => el.checked);
|
|
expect(checked).toEqual(false);
|
|
|
|
checked = await page.$eval(getSelector(radio2Id), el => el.checked);
|
|
expect(checked).toEqual(false);
|
|
}
|
|
|
|
// Change data on page 5 and check that other pages changed.
|
|
// Text field.
|
|
await page.type(getSelector("23R"), text2);
|
|
// Checkbox.
|
|
await page.click(getAnnotationSelector("24R"));
|
|
// Radio.
|
|
await page.click(getAnnotationSelector("25R"));
|
|
|
|
for (const [pageNumber, textId, checkId, radio1Id, radio2Id] of [
|
|
[1, "64R", "65R", "67R", "68R"],
|
|
[2, "18R", "19R", "21R", "20R"],
|
|
]) {
|
|
await page.evaluate(n => {
|
|
window.document
|
|
.querySelectorAll(`[data-page-number="${n}"][class="page"]`)[0]
|
|
.scrollIntoView();
|
|
}, pageNumber);
|
|
|
|
// Need to wait to have a displayed text input.
|
|
await page.waitForSelector(getSelector(textId), {
|
|
timeout: 0,
|
|
});
|
|
|
|
const text = await page.$eval(getSelector(textId), el => el.value);
|
|
expect(text)
|
|
.withContext(`In ${browserName}`)
|
|
.toEqual(text2 + text1);
|
|
|
|
let checked = await page.$eval(
|
|
getSelector(checkId),
|
|
el => el.checked
|
|
);
|
|
expect(checked).toEqual(false);
|
|
|
|
checked = await page.$eval(getSelector(radio1Id), el => el.checked);
|
|
expect(checked).toEqual(false);
|
|
|
|
checked = await page.$eval(getSelector(radio2Id), el => el.checked);
|
|
expect(checked).toEqual(false);
|
|
}
|
|
})
|
|
);
|
|
});
|
|
});
|
|
});
|
|
|
|
describe("ResetForm action", () => {
|
|
describe("resetform.pdf", () => {
|
|
let pages;
|
|
|
|
beforeEach(async () => {
|
|
pages = await loadAndWait("resetform.pdf", getAnnotationSelector("63R"));
|
|
});
|
|
|
|
afterEach(async () => {
|
|
await closePages(pages);
|
|
});
|
|
|
|
it("must reset all fields", async () => {
|
|
await Promise.all(
|
|
pages.map(async ([browserName, page]) => {
|
|
const base = "hello world";
|
|
for (let i = 63; i <= 67; i++) {
|
|
await page.type(getSelector(`${i}R`), base);
|
|
}
|
|
|
|
const selectors = [69, 71, 75].map(n =>
|
|
getAnnotationSelector(`${n}R`)
|
|
);
|
|
for (const selector of selectors) {
|
|
await page.click(selector);
|
|
}
|
|
|
|
await page.select(getSelector("78R"), "b");
|
|
await page.select(getSelector("81R"), "f");
|
|
|
|
await page.click(getAnnotationSelector("82R"));
|
|
await page.waitForFunction(`${getQuerySelector("63R")}.value === ""`);
|
|
|
|
for (let i = 63; i <= 68; i++) {
|
|
const text = await page.$eval(getSelector(`${i}R`), el => el.value);
|
|
expect(text).withContext(`In ${browserName}`).toEqual("");
|
|
}
|
|
|
|
const ids = [69, 71, 72, 73, 74, 75, 76, 77];
|
|
for (const id of ids) {
|
|
const checked = await page.$eval(
|
|
getSelector(`${id}R`),
|
|
el => el.checked
|
|
);
|
|
expect(checked).withContext(`In ${browserName}`).toEqual(false);
|
|
}
|
|
|
|
let selected = await page.$eval(
|
|
`${getSelector("78R")} [value="a"]`,
|
|
el => el.selected
|
|
);
|
|
expect(selected).withContext(`In ${browserName}`).toEqual(true);
|
|
|
|
selected = await page.$eval(
|
|
`${getSelector("81R")} [value="d"]`,
|
|
el => el.selected
|
|
);
|
|
expect(selected).withContext(`In ${browserName}`).toEqual(true);
|
|
})
|
|
);
|
|
});
|
|
|
|
it("must reset some fields", async () => {
|
|
await Promise.all(
|
|
pages.map(async ([browserName, page]) => {
|
|
const base = "hello world";
|
|
for (let i = 63; i <= 68; i++) {
|
|
await page.type(getSelector(`${i}R`), base);
|
|
}
|
|
|
|
const selectors = [69, 71, 72, 73, 75].map(n =>
|
|
getAnnotationSelector(`${n}R`)
|
|
);
|
|
for (const selector of selectors) {
|
|
await page.click(selector);
|
|
}
|
|
|
|
await page.select(getSelector("78R"), "b");
|
|
await page.select(getSelector("81R"), "f");
|
|
|
|
await page.click(getAnnotationSelector("84R"));
|
|
await page.waitForFunction(`${getQuerySelector("63R")}.value === ""`);
|
|
|
|
for (let i = 63; i <= 68; i++) {
|
|
const expected = (i - 3) % 2 === 0 ? "" : base;
|
|
const text = await page.$eval(getSelector(`${i}R`), el => el.value);
|
|
expect(text).withContext(`In ${browserName}`).toEqual(expected);
|
|
}
|
|
|
|
let ids = [69, 72, 73, 74, 76, 77];
|
|
for (const id of ids) {
|
|
const checked = await page.$eval(
|
|
getSelector(`${id}R`),
|
|
el => el.checked
|
|
);
|
|
expect(checked)
|
|
.withContext(`In ${browserName + id}`)
|
|
.toEqual(false);
|
|
}
|
|
|
|
ids = [71, 75];
|
|
for (const id of ids) {
|
|
const checked = await page.$eval(
|
|
getSelector(`${id}R`),
|
|
el => el.checked
|
|
);
|
|
expect(checked).withContext(`In ${browserName}`).toEqual(true);
|
|
}
|
|
|
|
let selected = await page.$eval(
|
|
`${getSelector("78R")} [value="a"]`,
|
|
el => el.selected
|
|
);
|
|
expect(selected).withContext(`In ${browserName}`).toEqual(true);
|
|
|
|
selected = await page.$eval(
|
|
`${getSelector("81R")} [value="f"]`,
|
|
el => el.selected
|
|
);
|
|
expect(selected).withContext(`In ${browserName}`).toEqual(true);
|
|
})
|
|
);
|
|
});
|
|
});
|
|
|
|
describe("FreeText widget", () => {
|
|
describe("issue14438.pdf", () => {
|
|
let pages;
|
|
|
|
beforeEach(async () => {
|
|
pages = await loadAndWait(
|
|
"issue14438.pdf",
|
|
getAnnotationSelector("10R")
|
|
);
|
|
});
|
|
|
|
afterEach(async () => {
|
|
await closePages(pages);
|
|
});
|
|
|
|
it("must check that the FreeText annotation has a popup", async () => {
|
|
await Promise.all(
|
|
pages.map(async ([browserName, page]) => {
|
|
const selector = getAnnotationSelector("10R");
|
|
await page.click(selector);
|
|
await page.waitForFunction(
|
|
`document.querySelector('${selector}').hidden === false`
|
|
);
|
|
})
|
|
);
|
|
});
|
|
});
|
|
});
|
|
|
|
describe("Ink widget and its popup after editing", () => {
|
|
describe("annotation-caret-ink.pdf", () => {
|
|
let pages;
|
|
|
|
beforeEach(async () => {
|
|
pages = await loadAndWait(
|
|
"annotation-caret-ink.pdf",
|
|
getAnnotationSelector("25R")
|
|
);
|
|
});
|
|
|
|
afterEach(async () => {
|
|
await closePages(pages);
|
|
});
|
|
|
|
it("must check that the Ink annotation has a popup", async () => {
|
|
await Promise.all(
|
|
pages.map(async ([browserName, page]) => {
|
|
const selector = getAnnotationSelector("25R");
|
|
await page.waitForFunction(
|
|
`document.querySelector('${selector}').hidden === false`
|
|
);
|
|
await page.click("#editorFreeText");
|
|
await page.waitForFunction(
|
|
`document.querySelector('${selector}').hidden === true`
|
|
);
|
|
await page.click("#editorFreeText");
|
|
await page.waitForFunction(
|
|
`document.querySelector('${selector}').hidden === false`
|
|
);
|
|
})
|
|
);
|
|
});
|
|
});
|
|
});
|
|
|
|
describe("Don't use AP when /NeedAppearances is true", () => {
|
|
describe("bug1844583.pdf", () => {
|
|
let pages;
|
|
|
|
beforeEach(async () => {
|
|
pages = await loadAndWait(
|
|
"bug1844583.pdf",
|
|
getAnnotationSelector("8R")
|
|
);
|
|
});
|
|
|
|
afterEach(async () => {
|
|
await closePages(pages);
|
|
});
|
|
|
|
it("must check the content of the text field", async () => {
|
|
await Promise.all(
|
|
pages.map(async ([browserName, page]) => {
|
|
const text = await page.$eval(getSelector("8R"), el => el.value);
|
|
expect(text)
|
|
.withContext(`In ${browserName}`)
|
|
.toEqual("Hello World");
|
|
})
|
|
);
|
|
});
|
|
});
|
|
});
|
|
|
|
describe("Toggle popup with keyboard", () => {
|
|
describe("tagged_stamp.pdf", () => {
|
|
let pages;
|
|
|
|
beforeEach(async () => {
|
|
pages = await loadAndWait(
|
|
"tagged_stamp.pdf",
|
|
getAnnotationSelector("20R")
|
|
);
|
|
});
|
|
|
|
afterEach(async () => {
|
|
await closePages(pages);
|
|
});
|
|
|
|
it("must check that the popup has the correct visibility", async () => {
|
|
await Promise.all(
|
|
pages.map(async ([browserName, page]) => {
|
|
const selector = getAnnotationSelector("21R");
|
|
let hidden = await page.$eval(selector, el => el.hidden);
|
|
expect(hidden).withContext(`In ${browserName}`).toEqual(true);
|
|
|
|
await page.focus(getAnnotationSelector("20R"));
|
|
await page.keyboard.press("Enter");
|
|
await page.waitForFunction(
|
|
`document.querySelector('${selector}').hidden !== true`
|
|
);
|
|
hidden = await page.$eval(selector, el => el.hidden);
|
|
expect(hidden).withContext(`In ${browserName}`).toEqual(false);
|
|
|
|
await page.keyboard.press("Enter");
|
|
await page.waitForFunction(
|
|
`document.querySelector('${selector}').hidden !== false`
|
|
);
|
|
hidden = await page.$eval(selector, el => el.hidden);
|
|
expect(hidden).withContext(`In ${browserName}`).toEqual(true);
|
|
|
|
await page.keyboard.press("Enter");
|
|
await page.waitForFunction(
|
|
`document.querySelector('${selector}').hidden !== true`
|
|
);
|
|
hidden = await page.$eval(selector, el => el.hidden);
|
|
expect(hidden).withContext(`In ${browserName}`).toEqual(false);
|
|
|
|
await page.keyboard.press("Escape");
|
|
await page.waitForFunction(
|
|
`document.querySelector('${selector}').hidden !== false`
|
|
);
|
|
hidden = await page.$eval(selector, el => el.hidden);
|
|
expect(hidden).withContext(`In ${browserName}`).toEqual(true);
|
|
})
|
|
);
|
|
});
|
|
});
|
|
});
|
|
|
|
describe("Annotation with empty popup and aria", () => {
|
|
describe("issue14438.pdf", () => {
|
|
let pages;
|
|
|
|
beforeEach(async () => {
|
|
pages = await loadAndWait(
|
|
"highlights.pdf",
|
|
getAnnotationSelector("693R")
|
|
);
|
|
});
|
|
|
|
afterEach(async () => {
|
|
await closePages(pages);
|
|
});
|
|
|
|
it("must check that the highlight annotation has no popup and no aria-haspopup attribute", async () => {
|
|
await Promise.all(
|
|
pages.map(async ([browserName, page]) => {
|
|
const highlightSelector = getAnnotationSelector("693R");
|
|
const popupSelector = getAnnotationSelector("694R");
|
|
await page.waitForFunction(
|
|
// No aria-haspopup attribute,
|
|
`document.querySelector('${highlightSelector}').ariaHasPopup === null ` +
|
|
// and no popup.
|
|
`&& document.querySelector('${popupSelector}') === null`
|
|
);
|
|
})
|
|
);
|
|
});
|
|
});
|
|
});
|
|
|
|
describe("Rotated annotation and its clickable area", () => {
|
|
describe("rotated_ink.pdf", () => {
|
|
let pages;
|
|
|
|
beforeEach(async () => {
|
|
pages = await loadAndWait(
|
|
"rotated_ink.pdf",
|
|
getAnnotationSelector("18R")
|
|
);
|
|
});
|
|
|
|
afterEach(async () => {
|
|
await closePages(pages);
|
|
});
|
|
|
|
it("must check that the clickable area has been rotated", async () => {
|
|
await Promise.all(
|
|
pages.map(async ([browserName, page]) => {
|
|
const rect = await getRect(page, getAnnotationSelector("18R"));
|
|
const promisePopup = page.waitForSelector(
|
|
getAnnotationSelector("19R"),
|
|
{ visible: true }
|
|
);
|
|
await page.mouse.move(
|
|
rect.x + rect.width * 0.1,
|
|
rect.y + rect.height * 0.9
|
|
);
|
|
await promisePopup;
|
|
})
|
|
);
|
|
});
|
|
});
|
|
});
|
|
|
|
describe("Text under some annotations", () => {
|
|
describe("bug1885505.pdf", () => {
|
|
let pages;
|
|
|
|
beforeEach(async () => {
|
|
pages = await loadAndWait(
|
|
"bug1885505.pdf",
|
|
":is(" +
|
|
[56, 58, 60, 65]
|
|
.map(id => getAnnotationSelector(`${id}R`))
|
|
.join(", ") +
|
|
")"
|
|
);
|
|
});
|
|
|
|
afterEach(async () => {
|
|
await closePages(pages);
|
|
});
|
|
|
|
it("must check that the text under a highlight annotation exist in the DOM", async () => {
|
|
await Promise.all(
|
|
pages.map(async ([browserName, page]) => {
|
|
const text = await page.$eval(
|
|
`${getAnnotationSelector("56R")} mark`,
|
|
el => el.textContent
|
|
);
|
|
expect(text).withContext(`In ${browserName}`).toEqual("Languages");
|
|
})
|
|
);
|
|
});
|
|
|
|
it("must check that the text under an underline annotation exist in the DOM", async () => {
|
|
await Promise.all(
|
|
pages.map(async ([browserName, page]) => {
|
|
const text = await page.$eval(
|
|
`${getAnnotationSelector("58R")} u`,
|
|
el => el.textContent
|
|
);
|
|
expect(text).withContext(`In ${browserName}`).toEqual("machine");
|
|
})
|
|
);
|
|
});
|
|
|
|
it("must check that the text under a squiggly annotation exist in the DOM", async () => {
|
|
await Promise.all(
|
|
pages.map(async ([browserName, page]) => {
|
|
const text = await page.$eval(
|
|
`${getAnnotationSelector("60R")} u`,
|
|
el => el.textContent
|
|
);
|
|
expect(text).withContext(`In ${browserName}`)
|
|
.toEqual(`paths through nested loops. We have implemented
|
|
a dynamic compiler for JavaScript based on our`);
|
|
})
|
|
);
|
|
});
|
|
|
|
it("must check that the text under a strikeout annotation exist in the DOM", async () => {
|
|
await Promise.all(
|
|
pages.map(async ([browserName, page]) => {
|
|
const text = await page.$eval(
|
|
`${getAnnotationSelector("65R")} s`,
|
|
el => el.textContent
|
|
);
|
|
expect(text)
|
|
.withContext(`In ${browserName}`)
|
|
.toEqual("Experimentation,");
|
|
})
|
|
);
|
|
});
|
|
});
|
|
});
|
|
|
|
describe("Annotation without popup and enableComment set to true", () => {
|
|
describe("annotation-text-without-popup.pdf", () => {
|
|
let pages;
|
|
|
|
beforeEach(async () => {
|
|
pages = await loadAndWait(
|
|
"annotation-text-without-popup.pdf",
|
|
getAnnotationSelector("4R"),
|
|
"page-fit",
|
|
null,
|
|
{ enableComment: true }
|
|
);
|
|
});
|
|
|
|
afterEach(async () => {
|
|
await closePages(pages);
|
|
});
|
|
|
|
it("must check that the popup is shown", async () => {
|
|
await Promise.all(
|
|
pages.map(async ([browserName, page]) => {
|
|
const rect = await getRect(page, getAnnotationSelector("4R"));
|
|
|
|
// Hover the annotation, the popup should be visible.
|
|
let promisePopup = page.waitForSelector("#commentPopup", {
|
|
visible: true,
|
|
});
|
|
await page.mouse.move(
|
|
rect.x + rect.width / 2,
|
|
rect.y + rect.height / 2
|
|
);
|
|
await promisePopup;
|
|
|
|
// Move the mouse away, the popup should be hidden.
|
|
promisePopup = page.waitForSelector("#commentPopup", {
|
|
visible: false,
|
|
});
|
|
await page.mouse.move(
|
|
rect.x - rect.width / 2,
|
|
rect.y - rect.height / 2
|
|
);
|
|
await promisePopup;
|
|
|
|
// Click the annotation, the popup should be visible.
|
|
promisePopup = page.waitForSelector("#commentPopup", {
|
|
visible: true,
|
|
});
|
|
await page.mouse.click(
|
|
rect.x + rect.width / 2,
|
|
rect.y + rect.height / 2
|
|
);
|
|
await promisePopup;
|
|
|
|
// Click again, the popup should be hidden.
|
|
promisePopup = page.waitForSelector("#commentPopup", {
|
|
visible: false,
|
|
});
|
|
await page.mouse.click(
|
|
rect.x + rect.width / 2,
|
|
rect.y + rect.height / 2
|
|
);
|
|
await promisePopup;
|
|
})
|
|
);
|
|
});
|
|
});
|
|
});
|
|
});
|