2017-01-10 01:40:57 +09:00
|
|
|
/* Copyright 2017 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.
|
|
|
|
*/
|
2017-04-17 05:30:27 +09:00
|
|
|
|
2017-05-16 20:01:03 +09:00
|
|
|
import {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
buildGetDocumentParams,
|
2021-01-09 01:12:58 +09:00
|
|
|
DefaultFileReaderFactory,
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
TEST_PDFS_PATH,
|
2020-01-02 20:00:16 +09:00
|
|
|
} from "./test_utils.js";
|
2017-04-17 05:30:27 +09:00
|
|
|
import {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
createPromiseCapability,
|
|
|
|
FontType,
|
Attempt to cache repeated images at the document, rather than the page, level (issue 11878)
Currently image resources, as opposed to e.g. font resources, are handled exclusively on a page-specific basis. Generally speaking this makes sense, since pages are separate from each other, however there's PDF documents where many (or even all) pages actually references exactly the same image resources (through the XRef table). Hence, in some cases, we're decoding the *same* images over and over for every page which is obviously slow and wasting both CPU and memory resources better used elsewhere.[1]
Obviously we cannot simply treat all image resources as-if they're used throughout the entire PDF document, since that would end up increasing memory usage too much.[2]
However, by introducing a `GlobalImageCache` in the worker we can track image resources that appear on more than one page. Hence we can switch image resources from being page-specific to being document-specific, once the image resource has been seen on more than a certain number of pages.
In many cases, such as e.g. the referenced issue, this patch will thus lead to reduced memory usage for image resources. Scrolling through all pages of the document, there's now only a few main-thread copies of the same image data, as opposed to one for each rendered page (i.e. there could theoretically be *twenty* copies of the image data).
While this obviously benefit both CPU and memory usage in this case, for *very* large image data this patch *may* possibly increase persistent main-thread memory usage a tiny bit. Thus to avoid negatively affecting memory usage too much in general, particularly on the main-thread, the `GlobalImageCache` will *only* cache a certain number of image resources at the document level and simply fallback to the default behaviour.
Unfortunately the asynchronous nature of the code, with ranged/streamed loading of data, actually makes all of this much more complicated than if all data could be assumed to be immediately available.[3]
*Please note:* The patch will lead to *small* movement in some existing test-cases, since we're now using the built-in PDF.js JPEG decoder more. This was done in order to simplify the overall implementation, especially on the main-thread, by limiting it to only the `OPS.paintImageXObject` operator.
---
[1] There's e.g. PDF documents that use the same image as background on all pages.
[2] Given that data stored in the `commonObjs`, on the main-thread, are only cleared manually through `PDFDocumentProxy.cleanup`. This as opposed to data stored in the `objs` of each page, which is automatically removed when the page is cleaned-up e.g. by being evicted from the cache in the default viewer.
[3] If the latter case were true, we could simply check for repeat images *before* parsing started and thus avoid handling *any* duplicate image resources.
2020-05-18 21:17:56 +09:00
|
|
|
ImageKind,
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
InvalidPDFException,
|
|
|
|
MissingPDFException,
|
|
|
|
OPS,
|
|
|
|
PasswordException,
|
|
|
|
PasswordResponses,
|
|
|
|
PermissionFlag,
|
|
|
|
StreamType,
|
2020-01-02 20:00:16 +09:00
|
|
|
} from "../../src/shared/util.js";
|
2017-04-17 05:30:27 +09:00
|
|
|
import {
|
2021-01-09 01:12:58 +09:00
|
|
|
DefaultCanvasFactory,
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
getDocument,
|
|
|
|
PDFDataRangeTransport,
|
|
|
|
PDFDocumentProxy,
|
|
|
|
PDFPageProxy,
|
|
|
|
PDFWorker,
|
2020-01-02 20:00:16 +09:00
|
|
|
} from "../../src/display/api.js";
|
2021-01-09 01:12:58 +09:00
|
|
|
import {
|
|
|
|
RenderingCancelledException,
|
|
|
|
StatTimer,
|
|
|
|
} from "../../src/display/display_utils.js";
|
2020-01-02 20:00:16 +09:00
|
|
|
import { AutoPrintRegExp } from "../../web/ui_utils.js";
|
Attempt to cache repeated images at the document, rather than the page, level (issue 11878)
Currently image resources, as opposed to e.g. font resources, are handled exclusively on a page-specific basis. Generally speaking this makes sense, since pages are separate from each other, however there's PDF documents where many (or even all) pages actually references exactly the same image resources (through the XRef table). Hence, in some cases, we're decoding the *same* images over and over for every page which is obviously slow and wasting both CPU and memory resources better used elsewhere.[1]
Obviously we cannot simply treat all image resources as-if they're used throughout the entire PDF document, since that would end up increasing memory usage too much.[2]
However, by introducing a `GlobalImageCache` in the worker we can track image resources that appear on more than one page. Hence we can switch image resources from being page-specific to being document-specific, once the image resource has been seen on more than a certain number of pages.
In many cases, such as e.g. the referenced issue, this patch will thus lead to reduced memory usage for image resources. Scrolling through all pages of the document, there's now only a few main-thread copies of the same image data, as opposed to one for each rendered page (i.e. there could theoretically be *twenty* copies of the image data).
While this obviously benefit both CPU and memory usage in this case, for *very* large image data this patch *may* possibly increase persistent main-thread memory usage a tiny bit. Thus to avoid negatively affecting memory usage too much in general, particularly on the main-thread, the `GlobalImageCache` will *only* cache a certain number of image resources at the document level and simply fallback to the default behaviour.
Unfortunately the asynchronous nature of the code, with ranged/streamed loading of data, actually makes all of this much more complicated than if all data could be assumed to be immediately available.[3]
*Please note:* The patch will lead to *small* movement in some existing test-cases, since we're now using the built-in PDF.js JPEG decoder more. This was done in order to simplify the overall implementation, especially on the main-thread, by limiting it to only the `OPS.paintImageXObject` operator.
---
[1] There's e.g. PDF documents that use the same image as background on all pages.
[2] Given that data stored in the `commonObjs`, on the main-thread, are only cleared manually through `PDFDocumentProxy.cleanup`. This as opposed to data stored in the `objs` of each page, which is automatically removed when the page is cleaned-up e.g. by being evicted from the cache in the default viewer.
[3] If the latter case were true, we could simply check for repeat images *before* parsing started and thus avoid handling *any* duplicate image resources.
2020-05-18 21:17:56 +09:00
|
|
|
import { GlobalImageCache } from "../../src/core/image_utils.js";
|
2020-01-02 20:00:16 +09:00
|
|
|
import { GlobalWorkerOptions } from "../../src/display/worker_options.js";
|
|
|
|
import { isNodeJS } from "../../src/shared/is_node.js";
|
|
|
|
import { Metadata } from "../../src/display/metadata.js";
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
|
2020-04-14 19:28:14 +09:00
|
|
|
describe("api", function () {
|
2020-01-24 17:48:21 +09:00
|
|
|
const basicApiFileName = "basicapi.pdf";
|
|
|
|
const basicApiFileLength = 105779; // bytes
|
|
|
|
const basicApiGetDocumentParams = buildGetDocumentParams(basicApiFileName);
|
2017-04-09 00:09:54 +09:00
|
|
|
|
|
|
|
let CanvasFactory;
|
2017-03-13 21:56:59 +09:00
|
|
|
|
2021-04-11 03:21:31 +09:00
|
|
|
beforeAll(function () {
|
2021-01-09 01:12:58 +09:00
|
|
|
CanvasFactory = new DefaultCanvasFactory();
|
2017-03-13 21:56:59 +09:00
|
|
|
});
|
|
|
|
|
2021-04-11 03:21:31 +09:00
|
|
|
afterAll(function () {
|
2017-03-13 21:56:59 +09:00
|
|
|
CanvasFactory = null;
|
|
|
|
});
|
2016-03-29 23:34:13 +09:00
|
|
|
|
2016-02-10 05:55:11 +09:00
|
|
|
function waitSome(callback) {
|
2020-10-25 23:40:51 +09:00
|
|
|
const WAIT_TIMEOUT = 10;
|
2020-04-14 19:28:14 +09:00
|
|
|
setTimeout(function () {
|
2016-02-10 05:55:11 +09:00
|
|
|
callback();
|
|
|
|
}, WAIT_TIMEOUT);
|
2014-08-24 04:08:27 +09:00
|
|
|
}
|
2015-10-17 23:08:10 +09:00
|
|
|
|
2020-04-14 19:28:14 +09:00
|
|
|
describe("getDocument", function () {
|
[api-minor] Support proper `URL`-objects, in addition to URL-strings, in `getDocument`
Currently only URL-strings are officially supported by `getDocument`, however at this point in time I cannot really see any compelling reason to not support `URL`-objects as well.
Most likely the reason that we've don't already support `URL`-objects, in `getDocument`, is that historically `URL` wasn't fully implemented across browsers and our old polyfill wasn't perfect; see https://developer.mozilla.org/en-US/docs/Web/API/URL/URL#browser_compatibility
*Please note:* Because of how the `url` parameter is currently handled, there's actually *some* cases where passing a `URL`-object to `getDocument` already works. That, in my opinion, provides additional motivation for supporting `URL`-objects officially, since it makes the API more consistent.
The following is an attempt to summarize the *current* situation, based on the actual code rather than the JSDocs:
- `getDocument("url string")` works and is documented.[1]
- `getDocument({ url: "url string", })` works and is documented.[1]
- `getDocument(new URL(...))` throws immediately, since no supported parameters are found.
- `getDocument({ url: new URL(...), })` actually works even though it's not documented.[1] Originally, when data was fetched on the worker-thread, this would likely have thrown since `URL` isn't clonable.[2]
- `getDocument({ url: { abc: 123, }, })`, or some similarily meaningless input, will be "accepted" by `getDocument` and then throw a `MissingPDFException` when attempting to fetch the bogus data.
With the changes in this patch, not only is `URL`-objects now officially supported and documented when calling `getDocument`, but we'll also do a much better job at actually validating any URL-data passed to `getDocument` (and instead fail early).
---
[1] In *browsers*, we create a valid URL thus indirectly validating the input. In Node.js environments, on the other hand, no validation is done since obtaining a baseUrl is more difficult (and PDF.js is primarily written for browsers anyway).
[2] https://developer.mozilla.org/en-US/docs/Web/API/Web_Workers_API/Structured_clone_algorithm#supported_types
2021-03-31 23:21:41 +09:00
|
|
|
it("creates pdf doc from URL-string", async function () {
|
|
|
|
const urlStr = TEST_PDFS_PATH + basicApiFileName;
|
|
|
|
const loadingTask = getDocument(urlStr);
|
|
|
|
const pdfDocument = await loadingTask.promise;
|
|
|
|
|
|
|
|
expect(typeof urlStr).toEqual("string");
|
|
|
|
expect(pdfDocument instanceof PDFDocumentProxy).toEqual(true);
|
|
|
|
expect(pdfDocument.numPages).toEqual(3);
|
|
|
|
|
|
|
|
await loadingTask.destroy();
|
|
|
|
});
|
|
|
|
|
|
|
|
it("creates pdf doc from URL-object", async function () {
|
|
|
|
if (isNodeJS) {
|
|
|
|
pending("window.location is not supported in Node.js.");
|
|
|
|
}
|
|
|
|
const urlObj = new URL(
|
|
|
|
TEST_PDFS_PATH + basicApiFileName,
|
|
|
|
window.location
|
|
|
|
);
|
|
|
|
const loadingTask = getDocument(urlObj);
|
|
|
|
const pdfDocument = await loadingTask.promise;
|
|
|
|
|
|
|
|
expect(urlObj instanceof URL).toEqual(true);
|
|
|
|
expect(pdfDocument instanceof PDFDocumentProxy).toEqual(true);
|
|
|
|
expect(pdfDocument.numPages).toEqual(3);
|
|
|
|
|
|
|
|
await loadingTask.destroy();
|
|
|
|
});
|
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("creates pdf doc from URL", async function () {
|
2020-10-25 23:40:51 +09:00
|
|
|
const loadingTask = getDocument(basicApiGetDocumentParams);
|
2015-10-17 23:08:10 +09:00
|
|
|
|
2020-10-25 23:40:51 +09:00
|
|
|
const progressReportedCapability = createPromiseCapability();
|
2018-02-18 07:51:24 +09:00
|
|
|
// Attach the callback that is used to report loading progress;
|
|
|
|
// similarly to how viewer.js works.
|
2020-04-14 19:28:14 +09:00
|
|
|
loadingTask.onProgress = function (progressData) {
|
2019-02-02 21:10:06 +09:00
|
|
|
if (!progressReportedCapability.settled) {
|
2018-02-18 07:51:24 +09:00
|
|
|
progressReportedCapability.resolve(progressData);
|
|
|
|
}
|
|
|
|
};
|
2015-10-17 23:08:10 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
const data = await Promise.all([
|
2020-10-25 23:40:51 +09:00
|
|
|
progressReportedCapability.promise,
|
|
|
|
loadingTask.promise,
|
2021-04-17 04:48:42 +09:00
|
|
|
]);
|
|
|
|
|
|
|
|
expect(data[0].loaded / data[0].total >= 0).toEqual(true);
|
|
|
|
expect(data[1] instanceof PDFDocumentProxy).toEqual(true);
|
|
|
|
expect(loadingTask).toEqual(data[1].loadingTask);
|
|
|
|
|
|
|
|
await loadingTask.destroy();
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
it("creates pdf doc from URL and aborts before worker initialized", async function () {
|
2020-10-25 23:40:51 +09:00
|
|
|
const loadingTask = getDocument(basicApiGetDocumentParams);
|
2020-01-24 17:48:21 +09:00
|
|
|
const destroyed = loadingTask.destroy();
|
2017-05-10 07:21:09 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
try {
|
|
|
|
await loadingTask.promise;
|
|
|
|
|
|
|
|
// Shouldn't get here.
|
|
|
|
expect(false).toEqual(true);
|
|
|
|
} catch (reason) {
|
|
|
|
expect(true).toEqual(true);
|
|
|
|
await destroyed;
|
|
|
|
}
|
2018-02-18 07:51:24 +09:00
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
it("creates pdf doc from URL and aborts loading after worker initialized", async function () {
|
2020-10-25 23:40:51 +09:00
|
|
|
const loadingTask = getDocument(basicApiGetDocumentParams);
|
2018-02-18 07:51:24 +09:00
|
|
|
// This can be somewhat random -- we cannot guarantee perfect
|
|
|
|
// 'Terminate' message to the worker before/after setting up pdfManager.
|
2020-10-25 23:40:51 +09:00
|
|
|
const destroyed = loadingTask._worker.promise.then(function () {
|
2018-02-18 07:51:24 +09:00
|
|
|
return loadingTask.destroy();
|
2012-04-13 09:59:30 +09:00
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
await destroyed;
|
|
|
|
expect(true).toEqual(true);
|
2018-02-18 07:51:24 +09:00
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
it("creates pdf doc from typed array", async function () {
|
|
|
|
const typedArrayPdf = await DefaultFileReaderFactory.fetch({
|
2021-01-09 01:12:58 +09:00
|
|
|
path: TEST_PDFS_PATH + basicApiFileName,
|
|
|
|
});
|
2014-08-15 23:04:39 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
// Sanity check to make sure that we fetched the entire PDF file.
|
|
|
|
expect(typedArrayPdf.length).toEqual(basicApiFileLength);
|
Ensure that `onProgress` is always called when the entire PDF file has been loaded, regardless of how it was fetched (issue 10160)
*Please note:* I'm totally fine with this patch being rejected, and the issue closed as WONTFIX; however these changes should address the issue if that's desired.
From a conceptual point of view, reporting loading progress doesn't really make a lot of sense for PDF files opened by passing raw binary data directly to `getDocument` (since obviously *all* data was loaded).
This is compared to PDF files loaded via e.g. `XMLHttpRequest` or the Fetch API, where the entire PDF file isn't available from the start and knowing the loading progress makes total sense.
However I can certainly see why the current API could be considered inconsistent, which isn't great, since a registered `onProgress` callback will never be called for certain `getDocument` calls.
The simplest solution to this inconsistency thus seem to be to ensure that `onProgress` is always called when handling the `DataLoaded` message, since that will *always* be dispatched[1] from the worker-thread.
---
[1] Note that this isn't guaranteed to happen, since setting `disableAutoFetch = true` often prevents the *entire* file from ever loading. However, this isn't relevant for the issue at hand, and is a well-known consequence of using `disableAutoFetch = true`; note how the default viewer even has a specialized code-path for hiding the loadingBar.
2018-10-16 20:24:02 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
const loadingTask = getDocument(typedArrayPdf);
|
Ensure that `onProgress` is always called when the entire PDF file has been loaded, regardless of how it was fetched (issue 10160)
*Please note:* I'm totally fine with this patch being rejected, and the issue closed as WONTFIX; however these changes should address the issue if that's desired.
From a conceptual point of view, reporting loading progress doesn't really make a lot of sense for PDF files opened by passing raw binary data directly to `getDocument` (since obviously *all* data was loaded).
This is compared to PDF files loaded via e.g. `XMLHttpRequest` or the Fetch API, where the entire PDF file isn't available from the start and knowing the loading progress makes total sense.
However I can certainly see why the current API could be considered inconsistent, which isn't great, since a registered `onProgress` callback will never be called for certain `getDocument` calls.
The simplest solution to this inconsistency thus seem to be to ensure that `onProgress` is always called when handling the `DataLoaded` message, since that will *always* be dispatched[1] from the worker-thread.
---
[1] Note that this isn't guaranteed to happen, since setting `disableAutoFetch = true` often prevents the *entire* file from ever loading. However, this isn't relevant for the issue at hand, and is a well-known consequence of using `disableAutoFetch = true`; note how the default viewer even has a specialized code-path for hiding the loadingBar.
2018-10-16 20:24:02 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
const progressReportedCapability = createPromiseCapability();
|
|
|
|
loadingTask.onProgress = function (data) {
|
|
|
|
progressReportedCapability.resolve(data);
|
|
|
|
};
|
Ensure that `onProgress` is always called when the entire PDF file has been loaded, regardless of how it was fetched (issue 10160)
*Please note:* I'm totally fine with this patch being rejected, and the issue closed as WONTFIX; however these changes should address the issue if that's desired.
From a conceptual point of view, reporting loading progress doesn't really make a lot of sense for PDF files opened by passing raw binary data directly to `getDocument` (since obviously *all* data was loaded).
This is compared to PDF files loaded via e.g. `XMLHttpRequest` or the Fetch API, where the entire PDF file isn't available from the start and knowing the loading progress makes total sense.
However I can certainly see why the current API could be considered inconsistent, which isn't great, since a registered `onProgress` callback will never be called for certain `getDocument` calls.
The simplest solution to this inconsistency thus seem to be to ensure that `onProgress` is always called when handling the `DataLoaded` message, since that will *always* be dispatched[1] from the worker-thread.
---
[1] Note that this isn't guaranteed to happen, since setting `disableAutoFetch = true` often prevents the *entire* file from ever loading. However, this isn't relevant for the issue at hand, and is a well-known consequence of using `disableAutoFetch = true`; note how the default viewer even has a specialized code-path for hiding the loadingBar.
2018-10-16 20:24:02 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
const data = await Promise.all([
|
|
|
|
loadingTask.promise,
|
|
|
|
progressReportedCapability.promise,
|
|
|
|
]);
|
|
|
|
expect(data[0] instanceof PDFDocumentProxy).toEqual(true);
|
|
|
|
expect(data[1].loaded / data[1].total).toEqual(1);
|
2019-02-17 20:34:37 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
await loadingTask.destroy();
|
2018-02-18 07:51:24 +09:00
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
it("creates pdf doc from invalid PDF file", async function () {
|
2018-02-18 07:51:24 +09:00
|
|
|
// A severely corrupt PDF file (even Adobe Reader fails to open it).
|
2020-10-25 23:40:51 +09:00
|
|
|
const loadingTask = getDocument(buildGetDocumentParams("bug1020226.pdf"));
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
try {
|
|
|
|
await loadingTask.promise;
|
|
|
|
|
|
|
|
// Shouldn't get here.
|
|
|
|
expect(false).toEqual(true);
|
|
|
|
} catch (reason) {
|
|
|
|
expect(reason instanceof InvalidPDFException).toEqual(true);
|
|
|
|
expect(reason.message).toEqual("Invalid PDF structure.");
|
|
|
|
}
|
|
|
|
|
|
|
|
await loadingTask.destroy();
|
2018-02-18 07:51:24 +09:00
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
it("creates pdf doc from non-existent URL", async function () {
|
2021-03-11 03:38:09 +09:00
|
|
|
if (!isNodeJS) {
|
2021-04-17 04:48:42 +09:00
|
|
|
// Re-enable in https://github.com/mozilla/pdf.js/issues/13061.
|
|
|
|
pending("Fails intermittently on Linux in browsers.");
|
2021-03-11 03:38:09 +09:00
|
|
|
}
|
2020-10-25 23:40:51 +09:00
|
|
|
const loadingTask = getDocument(
|
|
|
|
buildGetDocumentParams("non-existent.pdf")
|
|
|
|
);
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
try {
|
|
|
|
await loadingTask.promise;
|
|
|
|
|
|
|
|
// Shouldn't get here.
|
|
|
|
expect(false).toEqual(true);
|
|
|
|
} catch (reason) {
|
|
|
|
expect(reason instanceof MissingPDFException).toEqual(true);
|
|
|
|
}
|
|
|
|
|
|
|
|
await loadingTask.destroy();
|
2018-02-18 07:51:24 +09:00
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
it("creates pdf doc from PDF file protected with user and owner password", async function () {
|
2020-10-25 23:40:51 +09:00
|
|
|
const loadingTask = getDocument(buildGetDocumentParams("pr6531_1.pdf"));
|
2015-10-17 01:48:26 +09:00
|
|
|
|
2020-10-25 23:40:51 +09:00
|
|
|
const passwordNeededCapability = createPromiseCapability();
|
|
|
|
const passwordIncorrectCapability = createPromiseCapability();
|
2018-02-18 07:51:24 +09:00
|
|
|
// Attach the callback that is used to request a password;
|
|
|
|
// similarly to how viewer.js handles passwords.
|
2020-04-14 19:28:14 +09:00
|
|
|
loadingTask.onPassword = function (updatePassword, reason) {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
if (
|
|
|
|
reason === PasswordResponses.NEED_PASSWORD &&
|
|
|
|
!passwordNeededCapability.settled
|
|
|
|
) {
|
2018-02-18 07:51:24 +09:00
|
|
|
passwordNeededCapability.resolve();
|
2015-10-17 01:48:26 +09:00
|
|
|
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
updatePassword("qwerty"); // Provide an incorrect password.
|
2018-02-18 07:51:24 +09:00
|
|
|
return;
|
|
|
|
}
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
if (
|
|
|
|
reason === PasswordResponses.INCORRECT_PASSWORD &&
|
|
|
|
!passwordIncorrectCapability.settled
|
|
|
|
) {
|
2018-02-18 07:51:24 +09:00
|
|
|
passwordIncorrectCapability.resolve();
|
2015-10-17 23:08:10 +09:00
|
|
|
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
updatePassword("asdfasdf"); // Provide the correct password.
|
2018-02-18 07:51:24 +09:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
// Shouldn't get here.
|
|
|
|
expect(false).toEqual(true);
|
|
|
|
};
|
2015-10-17 23:08:10 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
const data = await Promise.all([
|
2018-02-18 07:51:24 +09:00
|
|
|
passwordNeededCapability.promise,
|
|
|
|
passwordIncorrectCapability.promise,
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
loadingTask.promise,
|
2021-04-17 04:48:42 +09:00
|
|
|
]);
|
|
|
|
expect(data[2] instanceof PDFDocumentProxy).toEqual(true);
|
|
|
|
|
|
|
|
await loadingTask.destroy();
|
2018-02-18 07:51:24 +09:00
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
it("creates pdf doc from PDF file protected with only a user password", async function () {
|
2020-10-25 23:40:51 +09:00
|
|
|
const filename = "pr6531_2.pdf";
|
2015-10-17 01:48:26 +09:00
|
|
|
|
2020-10-25 23:40:51 +09:00
|
|
|
const passwordNeededLoadingTask = getDocument(
|
2018-02-18 07:51:24 +09:00
|
|
|
buildGetDocumentParams(filename, {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
password: "",
|
|
|
|
})
|
|
|
|
);
|
2020-10-25 23:40:51 +09:00
|
|
|
const result1 = passwordNeededLoadingTask.promise.then(
|
2020-04-14 19:28:14 +09:00
|
|
|
function () {
|
2021-04-17 04:48:42 +09:00
|
|
|
// Shouldn't get here.
|
|
|
|
expect(false).toEqual(true);
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
return Promise.reject(new Error("loadingTask should be rejected"));
|
|
|
|
},
|
2020-04-14 19:28:14 +09:00
|
|
|
function (data) {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
expect(data instanceof PasswordException).toEqual(true);
|
|
|
|
expect(data.code).toEqual(PasswordResponses.NEED_PASSWORD);
|
|
|
|
return passwordNeededLoadingTask.destroy();
|
|
|
|
}
|
|
|
|
);
|
2015-10-17 01:48:26 +09:00
|
|
|
|
2020-10-25 23:40:51 +09:00
|
|
|
const passwordIncorrectLoadingTask = getDocument(
|
2018-02-18 07:51:24 +09:00
|
|
|
buildGetDocumentParams(filename, {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
password: "qwerty",
|
|
|
|
})
|
|
|
|
);
|
2020-10-25 23:40:51 +09:00
|
|
|
const result2 = passwordIncorrectLoadingTask.promise.then(
|
2020-04-14 19:28:14 +09:00
|
|
|
function () {
|
2021-04-17 04:48:42 +09:00
|
|
|
// Shouldn't get here.
|
|
|
|
expect(false).toEqual(true);
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
return Promise.reject(new Error("loadingTask should be rejected"));
|
|
|
|
},
|
2020-04-14 19:28:14 +09:00
|
|
|
function (data) {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
expect(data instanceof PasswordException).toEqual(true);
|
|
|
|
expect(data.code).toEqual(PasswordResponses.INCORRECT_PASSWORD);
|
|
|
|
return passwordIncorrectLoadingTask.destroy();
|
|
|
|
}
|
|
|
|
);
|
2015-10-17 01:48:26 +09:00
|
|
|
|
2020-10-25 23:40:51 +09:00
|
|
|
const passwordAcceptedLoadingTask = getDocument(
|
2018-02-18 07:51:24 +09:00
|
|
|
buildGetDocumentParams(filename, {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
password: "asdfasdf",
|
|
|
|
})
|
|
|
|
);
|
2020-10-25 23:40:51 +09:00
|
|
|
const result3 = passwordAcceptedLoadingTask.promise.then(function (data) {
|
2018-02-18 07:51:24 +09:00
|
|
|
expect(data instanceof PDFDocumentProxy).toEqual(true);
|
|
|
|
return passwordAcceptedLoadingTask.destroy();
|
2015-10-17 01:48:26 +09:00
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
await Promise.all([result1, result2, result3]);
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
});
|
|
|
|
|
|
|
|
it(
|
|
|
|
"creates pdf doc from password protected PDF file and aborts/throws " +
|
|
|
|
"in the onPassword callback (issue 7806)",
|
2021-04-17 04:48:42 +09:00
|
|
|
async function () {
|
2020-10-25 23:40:51 +09:00
|
|
|
const filename = "issue3371.pdf";
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
|
2020-10-25 23:40:51 +09:00
|
|
|
const passwordNeededLoadingTask = getDocument(
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
buildGetDocumentParams(filename)
|
|
|
|
);
|
2020-10-25 23:40:51 +09:00
|
|
|
const passwordIncorrectLoadingTask = getDocument(
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
buildGetDocumentParams(filename, {
|
|
|
|
password: "qwerty",
|
|
|
|
})
|
|
|
|
);
|
|
|
|
|
|
|
|
let passwordNeededDestroyed;
|
2020-04-14 19:28:14 +09:00
|
|
|
passwordNeededLoadingTask.onPassword = function (callback, reason) {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
if (reason === PasswordResponses.NEED_PASSWORD) {
|
|
|
|
passwordNeededDestroyed = passwordNeededLoadingTask.destroy();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
// Shouldn't get here.
|
|
|
|
expect(false).toEqual(true);
|
|
|
|
};
|
2020-10-25 23:40:51 +09:00
|
|
|
const result1 = passwordNeededLoadingTask.promise.then(
|
2020-04-14 19:28:14 +09:00
|
|
|
function () {
|
2021-04-17 04:48:42 +09:00
|
|
|
// Shouldn't get here.
|
|
|
|
expect(false).toEqual(true);
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
return Promise.reject(new Error("loadingTask should be rejected"));
|
|
|
|
},
|
2020-04-14 19:28:14 +09:00
|
|
|
function (reason) {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
expect(reason instanceof PasswordException).toEqual(true);
|
|
|
|
expect(reason.code).toEqual(PasswordResponses.NEED_PASSWORD);
|
|
|
|
return passwordNeededDestroyed;
|
|
|
|
}
|
|
|
|
);
|
2016-12-31 21:59:07 +09:00
|
|
|
|
2020-04-14 19:28:14 +09:00
|
|
|
passwordIncorrectLoadingTask.onPassword = function (callback, reason) {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
if (reason === PasswordResponses.INCORRECT_PASSWORD) {
|
|
|
|
throw new Error("Incorrect password");
|
|
|
|
}
|
|
|
|
// Shouldn't get here.
|
|
|
|
expect(false).toEqual(true);
|
|
|
|
};
|
2020-10-25 23:40:51 +09:00
|
|
|
const result2 = passwordIncorrectLoadingTask.promise.then(
|
2020-04-14 19:28:14 +09:00
|
|
|
function () {
|
2021-04-17 04:48:42 +09:00
|
|
|
// Shouldn't get here.
|
|
|
|
expect(false).toEqual(true);
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
return Promise.reject(new Error("loadingTask should be rejected"));
|
|
|
|
},
|
2020-04-14 19:28:14 +09:00
|
|
|
function (reason) {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
expect(reason instanceof PasswordException).toEqual(true);
|
|
|
|
expect(reason.code).toEqual(PasswordResponses.INCORRECT_PASSWORD);
|
|
|
|
return passwordIncorrectLoadingTask.destroy();
|
|
|
|
}
|
|
|
|
);
|
2016-12-31 21:59:07 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
await Promise.all([result1, result2]);
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
}
|
|
|
|
);
|
2019-12-09 23:00:45 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("creates pdf doc from empty typed array", async function () {
|
2019-12-09 23:00:45 +09:00
|
|
|
const loadingTask = getDocument(new Uint8Array(0));
|
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
try {
|
|
|
|
await loadingTask.promise;
|
2019-12-09 23:00:45 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
// Shouldn't get here.
|
|
|
|
expect(false).toEqual(true);
|
|
|
|
} catch (reason) {
|
|
|
|
expect(reason instanceof InvalidPDFException).toEqual(true);
|
|
|
|
expect(reason.message).toEqual(
|
|
|
|
"The PDF file is empty, i.e. its size is zero bytes."
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
await loadingTask.destroy();
|
2019-12-09 23:00:45 +09:00
|
|
|
});
|
2012-04-13 09:59:30 +09:00
|
|
|
});
|
2018-02-18 07:51:24 +09:00
|
|
|
|
2020-04-14 19:28:14 +09:00
|
|
|
describe("PDFWorker", function () {
|
2021-04-17 04:48:42 +09:00
|
|
|
it("worker created or destroyed", async function () {
|
2019-11-11 00:42:46 +09:00
|
|
|
if (isNodeJS) {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
pending("Worker is not supported in Node.js.");
|
2018-03-18 03:56:39 +09:00
|
|
|
}
|
|
|
|
|
2020-10-25 23:40:51 +09:00
|
|
|
const worker = new PDFWorker({ name: "test1" });
|
2021-04-17 04:48:42 +09:00
|
|
|
await worker.promise;
|
|
|
|
expect(worker.name).toEqual("test1");
|
|
|
|
expect(!!worker.port).toEqual(true);
|
|
|
|
expect(worker.destroyed).toEqual(false);
|
|
|
|
expect(!!worker._webWorker).toEqual(true);
|
|
|
|
expect(worker.port === worker._webWorker).toEqual(true);
|
|
|
|
|
|
|
|
worker.destroy();
|
|
|
|
expect(!!worker.port).toEqual(false);
|
|
|
|
expect(worker.destroyed).toEqual(true);
|
2015-10-28 02:55:15 +09:00
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
it("worker created or destroyed by getDocument", async function () {
|
2019-11-11 00:42:46 +09:00
|
|
|
if (isNodeJS) {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
pending("Worker is not supported in Node.js.");
|
2018-03-18 03:56:39 +09:00
|
|
|
}
|
|
|
|
|
2020-10-25 23:40:51 +09:00
|
|
|
const loadingTask = getDocument(basicApiGetDocumentParams);
|
|
|
|
let worker;
|
2020-04-14 19:28:14 +09:00
|
|
|
loadingTask.promise.then(function () {
|
2015-10-28 02:55:15 +09:00
|
|
|
worker = loadingTask._worker;
|
|
|
|
expect(!!worker).toEqual(true);
|
|
|
|
});
|
|
|
|
|
2020-10-25 23:40:51 +09:00
|
|
|
const destroyPromise = loadingTask.promise.then(function () {
|
2015-10-28 02:55:15 +09:00
|
|
|
return loadingTask.destroy();
|
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
await destroyPromise;
|
|
|
|
|
|
|
|
const destroyedWorker = loadingTask._worker;
|
|
|
|
expect(!!destroyedWorker).toEqual(false);
|
|
|
|
expect(worker.destroyed).toEqual(true);
|
2015-10-28 02:55:15 +09:00
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
it("worker created and can be used in getDocument", async function () {
|
2019-11-11 00:42:46 +09:00
|
|
|
if (isNodeJS) {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
pending("Worker is not supported in Node.js.");
|
2018-03-18 03:56:39 +09:00
|
|
|
}
|
|
|
|
|
2020-10-25 23:40:51 +09:00
|
|
|
const worker = new PDFWorker({ name: "test1" });
|
|
|
|
const loadingTask = getDocument(
|
2017-04-09 00:09:54 +09:00
|
|
|
buildGetDocumentParams(basicApiFileName, {
|
|
|
|
worker,
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
})
|
|
|
|
);
|
2020-04-14 19:28:14 +09:00
|
|
|
loadingTask.promise.then(function () {
|
2020-10-25 23:40:51 +09:00
|
|
|
const docWorker = loadingTask._worker;
|
2015-10-28 02:55:15 +09:00
|
|
|
expect(!!docWorker).toEqual(false);
|
|
|
|
// checking is the same port is used in the MessageHandler
|
2020-10-25 23:40:51 +09:00
|
|
|
const messageHandlerPort = loadingTask._transport.messageHandler.comObj;
|
2015-10-28 02:55:15 +09:00
|
|
|
expect(messageHandlerPort === worker.port).toEqual(true);
|
|
|
|
});
|
|
|
|
|
2020-10-25 23:40:51 +09:00
|
|
|
const destroyPromise = loadingTask.promise.then(function () {
|
2015-10-28 02:55:15 +09:00
|
|
|
return loadingTask.destroy();
|
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
await destroyPromise;
|
|
|
|
|
|
|
|
expect(worker.destroyed).toEqual(false);
|
|
|
|
worker.destroy();
|
2015-10-28 02:55:15 +09:00
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
it("creates more than one worker", async function () {
|
2019-11-11 00:42:46 +09:00
|
|
|
if (isNodeJS) {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
pending("Worker is not supported in Node.js.");
|
2018-03-18 03:56:39 +09:00
|
|
|
}
|
|
|
|
|
2020-10-25 23:40:51 +09:00
|
|
|
const worker1 = new PDFWorker({ name: "test1" });
|
|
|
|
const worker2 = new PDFWorker({ name: "test2" });
|
|
|
|
const worker3 = new PDFWorker({ name: "test3" });
|
2021-04-17 04:48:42 +09:00
|
|
|
await Promise.all([worker1.promise, worker2.promise, worker3.promise]);
|
|
|
|
|
|
|
|
expect(
|
|
|
|
worker1.port !== worker2.port &&
|
|
|
|
worker1.port !== worker3.port &&
|
|
|
|
worker2.port !== worker3.port
|
|
|
|
).toEqual(true);
|
|
|
|
worker1.destroy();
|
|
|
|
worker2.destroy();
|
|
|
|
worker3.destroy();
|
2015-10-28 02:55:15 +09:00
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
2020-04-14 19:28:14 +09:00
|
|
|
it("gets current workerSrc", function () {
|
2019-11-11 00:42:46 +09:00
|
|
|
if (isNodeJS) {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
pending("Worker is not supported in Node.js.");
|
2018-03-18 03:56:39 +09:00
|
|
|
}
|
|
|
|
|
2020-01-24 17:48:21 +09:00
|
|
|
const workerSrc = PDFWorker.getWorkerSrc();
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
expect(typeof workerSrc).toEqual("string");
|
2018-02-14 22:49:24 +09:00
|
|
|
expect(workerSrc).toEqual(GlobalWorkerOptions.workerSrc);
|
2018-01-29 23:58:40 +09:00
|
|
|
});
|
2015-10-28 02:55:15 +09:00
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
2020-04-14 19:28:14 +09:00
|
|
|
describe("PDFDocument", function () {
|
2020-03-24 18:44:17 +09:00
|
|
|
let pdfLoadingTask, pdfDocument;
|
2016-01-21 07:57:17 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
beforeAll(async function () {
|
2020-03-24 18:44:17 +09:00
|
|
|
pdfLoadingTask = getDocument(basicApiGetDocumentParams);
|
2021-04-17 04:48:42 +09:00
|
|
|
pdfDocument = await pdfLoadingTask.promise;
|
2016-01-21 07:57:17 +09:00
|
|
|
});
|
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
afterAll(async function () {
|
|
|
|
await pdfLoadingTask.destroy();
|
2012-04-13 09:59:30 +09:00
|
|
|
});
|
2016-01-21 07:57:17 +09:00
|
|
|
|
2020-04-14 19:28:14 +09:00
|
|
|
it("gets number of pages", function () {
|
2020-03-24 18:44:17 +09:00
|
|
|
expect(pdfDocument.numPages).toEqual(3);
|
2012-04-13 09:59:30 +09:00
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
2021-07-02 23:36:27 +09:00
|
|
|
it("gets fingerprints", function () {
|
|
|
|
expect(pdfDocument.fingerprints).toEqual([
|
|
|
|
"ea8b35919d6279a369e835bde778611b",
|
|
|
|
null,
|
|
|
|
]);
|
|
|
|
});
|
|
|
|
|
|
|
|
it("gets fingerprints, from modified document", async function () {
|
|
|
|
const loadingTask = getDocument(
|
|
|
|
buildGetDocumentParams("annotation-tx.pdf")
|
2020-03-24 18:44:17 +09:00
|
|
|
);
|
2021-07-02 23:36:27 +09:00
|
|
|
const pdfDoc = await loadingTask.promise;
|
|
|
|
|
|
|
|
expect(pdfDoc.fingerprints).toEqual([
|
|
|
|
"3ebd77c320274649a68f10dbf3b9f882",
|
|
|
|
"e7087346aa4b4ae0911c1f1643b57345",
|
|
|
|
]);
|
|
|
|
|
|
|
|
await loadingTask.destroy();
|
2012-04-13 09:59:30 +09:00
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
it("gets page", async function () {
|
|
|
|
const data = await pdfDocument.getPage(1);
|
|
|
|
expect(data instanceof PDFPageProxy).toEqual(true);
|
|
|
|
expect(data.pageNumber).toEqual(1);
|
2015-10-04 21:28:24 +09:00
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
it("gets non-existent page", async function () {
|
2020-10-25 23:40:51 +09:00
|
|
|
let outOfRangePromise = pdfDocument.getPage(100);
|
|
|
|
let nonIntegerPromise = pdfDocument.getPage(2.5);
|
|
|
|
let nonNumberPromise = pdfDocument.getPage("1");
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
|
|
|
|
outOfRangePromise = outOfRangePromise.then(
|
2020-04-14 19:28:14 +09:00
|
|
|
function () {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
throw new Error("shall fail for out-of-range pageNumber parameter");
|
|
|
|
},
|
2020-04-14 19:28:14 +09:00
|
|
|
function (reason) {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
expect(reason instanceof Error).toEqual(true);
|
|
|
|
}
|
|
|
|
);
|
|
|
|
nonIntegerPromise = nonIntegerPromise.then(
|
2020-04-14 19:28:14 +09:00
|
|
|
function () {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
throw new Error("shall fail for non-integer pageNumber parameter");
|
|
|
|
},
|
2020-04-14 19:28:14 +09:00
|
|
|
function (reason) {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
expect(reason instanceof Error).toEqual(true);
|
|
|
|
}
|
|
|
|
);
|
|
|
|
nonNumberPromise = nonNumberPromise.then(
|
2020-04-14 19:28:14 +09:00
|
|
|
function () {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
throw new Error("shall fail for non-number pageNumber parameter");
|
|
|
|
},
|
2020-04-14 19:28:14 +09:00
|
|
|
function (reason) {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
expect(reason instanceof Error).toEqual(true);
|
|
|
|
}
|
|
|
|
);
|
2016-09-05 21:43:16 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
await Promise.all([
|
|
|
|
outOfRangePromise,
|
|
|
|
nonIntegerPromise,
|
|
|
|
nonNumberPromise,
|
|
|
|
]);
|
2012-04-13 09:59:30 +09:00
|
|
|
});
|
2020-02-09 01:43:53 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("gets page, from /Pages tree with circular reference", async function () {
|
2020-02-09 01:43:53 +09:00
|
|
|
const loadingTask = getDocument(
|
|
|
|
buildGetDocumentParams("Pages-tree-refs.pdf")
|
|
|
|
);
|
|
|
|
|
2020-04-14 19:28:14 +09:00
|
|
|
const page1 = loadingTask.promise.then(function (pdfDoc) {
|
2020-02-09 01:43:53 +09:00
|
|
|
return pdfDoc.getPage(1).then(
|
2020-04-14 19:28:14 +09:00
|
|
|
function (pdfPage) {
|
2020-02-09 01:43:53 +09:00
|
|
|
expect(pdfPage instanceof PDFPageProxy).toEqual(true);
|
|
|
|
expect(pdfPage.ref).toEqual({ num: 6, gen: 0 });
|
|
|
|
},
|
2020-04-14 19:28:14 +09:00
|
|
|
function (reason) {
|
2020-02-09 01:43:53 +09:00
|
|
|
throw new Error("shall not fail for valid page");
|
|
|
|
}
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
2020-04-14 19:28:14 +09:00
|
|
|
const page2 = loadingTask.promise.then(function (pdfDoc) {
|
2020-02-09 01:43:53 +09:00
|
|
|
return pdfDoc.getPage(2).then(
|
2020-04-14 19:28:14 +09:00
|
|
|
function (pdfPage) {
|
2020-02-09 01:43:53 +09:00
|
|
|
throw new Error("shall fail for invalid page");
|
|
|
|
},
|
2020-04-14 19:28:14 +09:00
|
|
|
function (reason) {
|
2020-02-09 01:43:53 +09:00
|
|
|
expect(reason instanceof Error).toEqual(true);
|
|
|
|
expect(reason.message).toEqual(
|
|
|
|
"Pages tree contains circular reference."
|
|
|
|
);
|
|
|
|
}
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
await Promise.all([page1, page2]);
|
|
|
|
await loadingTask.destroy();
|
2020-02-09 01:43:53 +09:00
|
|
|
});
|
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("gets page index", async function () {
|
|
|
|
const ref = { num: 17, gen: 0 }; // Reference to second page.
|
|
|
|
const pageIndex = await pdfDocument.getPageIndex(ref);
|
|
|
|
expect(pageIndex).toEqual(1);
|
2014-03-19 18:17:58 +09:00
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
it("gets invalid page index", async function () {
|
2020-10-25 23:40:51 +09:00
|
|
|
const ref = { num: 3, gen: 0 }; // Reference to a font dictionary.
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
try {
|
|
|
|
await pdfDocument.getPageIndex(ref);
|
|
|
|
|
|
|
|
// Shouldn't get here.
|
|
|
|
expect(false).toEqual(true);
|
|
|
|
} catch (reason) {
|
|
|
|
expect(reason instanceof Error).toEqual(true);
|
|
|
|
}
|
2016-05-16 23:28:25 +09:00
|
|
|
});
|
2016-03-29 22:46:21 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("gets destinations, from /Dests dictionary", async function () {
|
|
|
|
const destinations = await pdfDocument.getDestinations();
|
|
|
|
expect(destinations).toEqual({
|
|
|
|
chapter1: [{ gen: 0, num: 17 }, { name: "XYZ" }, 0, 841.89, null],
|
|
|
|
});
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
it("gets a destination, from /Dests dictionary", async function () {
|
|
|
|
const destination = await pdfDocument.getDestination("chapter1");
|
|
|
|
expect(destination).toEqual([
|
|
|
|
{ gen: 0, num: 17 },
|
|
|
|
{ name: "XYZ" },
|
|
|
|
0,
|
|
|
|
841.89,
|
|
|
|
null,
|
|
|
|
]);
|
2014-10-05 22:56:40 +09:00
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
it("gets a non-existent destination, from /Dests dictionary", async function () {
|
|
|
|
const destination = await pdfDocument.getDestination(
|
2020-03-24 18:44:17 +09:00
|
|
|
"non-existent-named-destination"
|
|
|
|
);
|
2021-04-17 04:48:42 +09:00
|
|
|
expect(destination).toEqual(null);
|
2015-07-08 04:48:57 +09:00
|
|
|
});
|
2016-03-29 22:46:21 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("gets destinations, from /Names (NameTree) dictionary", async function () {
|
2020-10-25 23:40:51 +09:00
|
|
|
const loadingTask = getDocument(buildGetDocumentParams("issue6204.pdf"));
|
2021-04-17 04:48:42 +09:00
|
|
|
const pdfDoc = await loadingTask.promise;
|
|
|
|
const destinations = await pdfDoc.getDestinations();
|
|
|
|
expect(destinations).toEqual({
|
|
|
|
"Page.1": [{ num: 1, gen: 0 }, { name: "XYZ" }, 0, 375, null],
|
|
|
|
"Page.2": [{ num: 6, gen: 0 }, { name: "XYZ" }, 0, 375, null],
|
2016-03-29 22:46:21 +09:00
|
|
|
});
|
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
await loadingTask.destroy();
|
2016-03-29 22:46:21 +09:00
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
it("gets a destination, from /Names (NameTree) dictionary", async function () {
|
2020-10-25 23:40:51 +09:00
|
|
|
const loadingTask = getDocument(buildGetDocumentParams("issue6204.pdf"));
|
2021-04-17 04:48:42 +09:00
|
|
|
const pdfDoc = await loadingTask.promise;
|
|
|
|
const destination = await pdfDoc.getDestination("Page.1");
|
|
|
|
expect(destination).toEqual([
|
|
|
|
{ num: 1, gen: 0 },
|
|
|
|
{ name: "XYZ" },
|
|
|
|
0,
|
|
|
|
375,
|
|
|
|
null,
|
|
|
|
]);
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
await loadingTask.destroy();
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
it("gets a non-existent destination, from /Names (NameTree) dictionary", async function () {
|
2020-10-25 23:40:51 +09:00
|
|
|
const loadingTask = getDocument(buildGetDocumentParams("issue6204.pdf"));
|
2021-04-17 04:48:42 +09:00
|
|
|
const pdfDoc = await loadingTask.promise;
|
|
|
|
const destination = await pdfDoc.getDestination(
|
|
|
|
"non-existent-named-destination"
|
|
|
|
);
|
|
|
|
expect(destination).toEqual(null);
|
2016-03-29 22:46:21 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
await loadingTask.destroy();
|
2016-03-29 22:46:21 +09:00
|
|
|
});
|
|
|
|
|
Improve handling of named destinations in out-of-order NameTrees (PR 10274 follow-up)
According to the specification, see https://web.archive.org/web/20210404042322if_/https://www.adobe.com/content/dam/acom/en/devnet/acrobat/pdfs/PDF32000_2008.pdf#G6.2384179, the keys of a NameTree/NumberTree should be ordered.
For corrupt PDF files, which violate this assumption, it's thus possible that trying to lookup a single entry fails.
Previously, in PR 10274, we implemented a fallback that only applies to the "bottom" node of a NameTree/NumberTree, which in general might not actually help for sufficiently corrupt NameTree/NumberTree data.
Instead we remove the current *limited* fallback from `NameOrNumberTree.get`, and defer to the call-site to handle this case explicitly e.g. by using `NameOrNumberTree.getAll` for data where that makes sense. For well-formed documents, these changes should *not* lead to any additional data fetching/parsing.
Finally, as part of these changes, the validation of named destination data is improved in the `Catalog` and a new unit-test is also added.
2021-05-21 20:58:33 +09:00
|
|
|
it("gets a destination, from out-of-order /Names (NameTree) dictionary (issue 10272)", async function () {
|
|
|
|
if (isNodeJS) {
|
|
|
|
pending("Linked test-cases are not supported in Node.js.");
|
|
|
|
}
|
|
|
|
const loadingTask = getDocument(buildGetDocumentParams("issue10272.pdf"));
|
|
|
|
const pdfDoc = await loadingTask.promise;
|
|
|
|
const destination = await pdfDoc.getDestination("link_1");
|
|
|
|
expect(destination).toEqual([
|
|
|
|
{ num: 17, gen: 0 },
|
|
|
|
{ name: "XYZ" },
|
|
|
|
69,
|
|
|
|
125,
|
|
|
|
0,
|
|
|
|
]);
|
|
|
|
|
|
|
|
await loadingTask.destroy();
|
|
|
|
});
|
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("gets non-string destination", async function () {
|
2020-03-24 18:44:17 +09:00
|
|
|
let numberPromise = pdfDocument.getDestination(4.3);
|
|
|
|
let booleanPromise = pdfDocument.getDestination(true);
|
|
|
|
let arrayPromise = pdfDocument.getDestination([
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
{ num: 17, gen: 0 },
|
|
|
|
{ name: "XYZ" },
|
|
|
|
0,
|
|
|
|
841.89,
|
|
|
|
null,
|
|
|
|
]);
|
|
|
|
|
|
|
|
numberPromise = numberPromise.then(
|
2020-04-14 19:28:14 +09:00
|
|
|
function () {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
throw new Error("shall fail for non-string destination.");
|
|
|
|
},
|
2020-04-14 19:28:14 +09:00
|
|
|
function (reason) {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
expect(reason instanceof Error).toEqual(true);
|
|
|
|
}
|
|
|
|
);
|
|
|
|
booleanPromise = booleanPromise.then(
|
2020-04-14 19:28:14 +09:00
|
|
|
function () {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
throw new Error("shall fail for non-string destination.");
|
|
|
|
},
|
2020-04-14 19:28:14 +09:00
|
|
|
function (reason) {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
expect(reason instanceof Error).toEqual(true);
|
|
|
|
}
|
|
|
|
);
|
|
|
|
arrayPromise = arrayPromise.then(
|
2020-04-14 19:28:14 +09:00
|
|
|
function () {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
throw new Error("shall fail for non-string destination.");
|
|
|
|
},
|
2020-04-14 19:28:14 +09:00
|
|
|
function (reason) {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
expect(reason instanceof Error).toEqual(true);
|
|
|
|
}
|
|
|
|
);
|
2018-08-11 23:00:48 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
await Promise.all([numberPromise, booleanPromise, arrayPromise]);
|
2018-08-11 23:00:48 +09:00
|
|
|
});
|
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("gets non-existent page labels", async function () {
|
|
|
|
const pageLabels = await pdfDocument.getPageLabels();
|
|
|
|
expect(pageLabels).toEqual(null);
|
2015-12-26 05:57:08 +09:00
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
it("gets page labels", async function () {
|
2015-12-26 05:57:08 +09:00
|
|
|
// PageLabels with Roman/Arabic numerals.
|
2020-10-25 23:40:51 +09:00
|
|
|
const loadingTask0 = getDocument(buildGetDocumentParams("bug793632.pdf"));
|
|
|
|
const promise0 = loadingTask0.promise.then(function (pdfDoc) {
|
2015-12-26 05:57:08 +09:00
|
|
|
return pdfDoc.getPageLabels();
|
|
|
|
});
|
2016-01-27 07:01:38 +09:00
|
|
|
|
2015-12-26 05:57:08 +09:00
|
|
|
// PageLabels with only a label prefix.
|
2020-10-25 23:40:51 +09:00
|
|
|
const loadingTask1 = getDocument(buildGetDocumentParams("issue1453.pdf"));
|
|
|
|
const promise1 = loadingTask1.promise.then(function (pdfDoc) {
|
2015-12-26 05:57:08 +09:00
|
|
|
return pdfDoc.getPageLabels();
|
|
|
|
});
|
2016-01-27 07:01:38 +09:00
|
|
|
|
2015-12-26 05:57:08 +09:00
|
|
|
// PageLabels identical to standard page numbering.
|
2020-10-25 23:40:51 +09:00
|
|
|
const loadingTask2 = getDocument(buildGetDocumentParams("rotation.pdf"));
|
|
|
|
const promise2 = loadingTask2.promise.then(function (pdfDoc) {
|
2015-12-26 05:57:08 +09:00
|
|
|
return pdfDoc.getPageLabels();
|
|
|
|
});
|
|
|
|
|
2016-11-04 03:48:08 +09:00
|
|
|
// PageLabels with bad "Prefix" entries.
|
2020-10-25 23:40:51 +09:00
|
|
|
const loadingTask3 = getDocument(
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
buildGetDocumentParams("bad-PageLabels.pdf")
|
|
|
|
);
|
2020-10-25 23:40:51 +09:00
|
|
|
const promise3 = loadingTask3.promise.then(function (pdfDoc) {
|
2016-11-04 03:48:08 +09:00
|
|
|
return pdfDoc.getPageLabels();
|
|
|
|
});
|
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
const pageLabels = await Promise.all([
|
|
|
|
promise0,
|
|
|
|
promise1,
|
|
|
|
promise2,
|
|
|
|
promise3,
|
|
|
|
]);
|
|
|
|
expect(pageLabels[0]).toEqual(["i", "ii", "iii", "1"]);
|
|
|
|
expect(pageLabels[1]).toEqual(["Front Page1"]);
|
|
|
|
expect(pageLabels[2]).toEqual(["1", "2"]);
|
|
|
|
expect(pageLabels[3]).toEqual(["X3"]);
|
|
|
|
|
|
|
|
await Promise.all([
|
|
|
|
loadingTask0.destroy(),
|
|
|
|
loadingTask1.destroy(),
|
|
|
|
loadingTask2.destroy(),
|
|
|
|
loadingTask3.destroy(),
|
|
|
|
]);
|
2015-12-26 05:57:08 +09:00
|
|
|
});
|
2016-07-02 20:13:30 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("gets default page layout", async function () {
|
2020-10-25 23:40:51 +09:00
|
|
|
const loadingTask = getDocument(
|
|
|
|
buildGetDocumentParams("tracemonkey.pdf")
|
|
|
|
);
|
2021-04-17 04:48:42 +09:00
|
|
|
const pdfDoc = await loadingTask.promise;
|
|
|
|
const pageLayout = await pdfDoc.getPageLayout();
|
|
|
|
expect(pageLayout).toEqual("");
|
2019-04-03 20:48:18 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
await loadingTask.destroy();
|
|
|
|
});
|
2019-04-03 20:48:18 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("gets non-default page layout", async function () {
|
|
|
|
const pageLayout = await pdfDocument.getPageLayout();
|
|
|
|
expect(pageLayout).toEqual("SinglePage");
|
2019-04-03 20:48:18 +09:00
|
|
|
});
|
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("gets default page mode", async function () {
|
2020-10-25 23:40:51 +09:00
|
|
|
const loadingTask = getDocument(
|
|
|
|
buildGetDocumentParams("tracemonkey.pdf")
|
|
|
|
);
|
2021-04-17 04:48:42 +09:00
|
|
|
const pdfDoc = await loadingTask.promise;
|
|
|
|
const pageMode = await pdfDoc.getPageMode();
|
|
|
|
expect(pageMode).toEqual("UseNone");
|
2017-07-18 20:08:02 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
await loadingTask.destroy();
|
|
|
|
});
|
2017-07-18 20:08:02 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("gets non-default page mode", async function () {
|
|
|
|
const pageMode = await pdfDocument.getPageMode();
|
|
|
|
expect(pageMode).toEqual("UseOutlines");
|
2017-07-18 20:08:02 +09:00
|
|
|
});
|
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("gets default viewer preferences", async function () {
|
2020-10-25 23:40:51 +09:00
|
|
|
const loadingTask = getDocument(
|
|
|
|
buildGetDocumentParams("tracemonkey.pdf")
|
|
|
|
);
|
2021-04-17 04:48:42 +09:00
|
|
|
const pdfDoc = await loadingTask.promise;
|
|
|
|
const prefs = await pdfDoc.getViewerPreferences();
|
|
|
|
expect(prefs).toEqual(null);
|
2019-04-14 20:13:59 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
await loadingTask.destroy();
|
|
|
|
});
|
2019-04-14 20:13:59 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("gets non-default viewer preferences", async function () {
|
|
|
|
const prefs = await pdfDocument.getViewerPreferences();
|
|
|
|
expect(prefs).toEqual({ Direction: "L2R" });
|
2019-04-14 20:13:59 +09:00
|
|
|
});
|
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("gets default open action", async function () {
|
2020-10-25 23:40:51 +09:00
|
|
|
const loadingTask = getDocument(
|
|
|
|
buildGetDocumentParams("tracemonkey.pdf")
|
|
|
|
);
|
2021-04-17 04:48:42 +09:00
|
|
|
const pdfDoc = await loadingTask.promise;
|
|
|
|
const openAction = await pdfDoc.getOpenAction();
|
|
|
|
expect(openAction).toEqual(null);
|
2018-12-06 04:09:15 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
await loadingTask.destroy();
|
2018-12-06 04:09:15 +09:00
|
|
|
});
|
2020-02-28 22:54:07 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("gets non-default open action (with destination)", async function () {
|
|
|
|
const openAction = await pdfDocument.getOpenAction();
|
|
|
|
expect(openAction.dest).toEqual([
|
|
|
|
{ num: 15, gen: 0 },
|
|
|
|
{ name: "FitH" },
|
|
|
|
null,
|
|
|
|
]);
|
|
|
|
expect(openAction.action).toBeUndefined();
|
2018-12-06 04:09:15 +09:00
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
it("gets non-default open action (with Print action)", async function () {
|
2020-02-28 22:54:07 +09:00
|
|
|
// PDF document with "Print" Named action in the OpenAction dictionary.
|
|
|
|
const loadingTask1 = getDocument(
|
|
|
|
buildGetDocumentParams("bug1001080.pdf")
|
|
|
|
);
|
|
|
|
// PDF document with "Print" Named action in the OpenAction dictionary,
|
|
|
|
// but the OpenAction dictionary is missing the `Type` entry.
|
|
|
|
const loadingTask2 = getDocument(
|
|
|
|
buildGetDocumentParams("issue11442_reduced.pdf")
|
|
|
|
);
|
|
|
|
|
|
|
|
const promise1 = loadingTask1.promise
|
2020-04-14 19:28:14 +09:00
|
|
|
.then(function (pdfDoc) {
|
2020-03-24 18:44:17 +09:00
|
|
|
return pdfDoc.getOpenAction();
|
2020-02-28 22:54:07 +09:00
|
|
|
})
|
2020-04-14 19:28:14 +09:00
|
|
|
.then(function (openAction) {
|
2020-02-28 22:54:07 +09:00
|
|
|
expect(openAction.dest).toBeUndefined();
|
|
|
|
expect(openAction.action).toEqual("Print");
|
|
|
|
|
|
|
|
return loadingTask1.destroy();
|
|
|
|
});
|
|
|
|
const promise2 = loadingTask2.promise
|
2020-04-14 19:28:14 +09:00
|
|
|
.then(function (pdfDoc) {
|
2020-03-24 18:44:17 +09:00
|
|
|
return pdfDoc.getOpenAction();
|
2020-02-28 22:54:07 +09:00
|
|
|
})
|
2020-04-14 19:28:14 +09:00
|
|
|
.then(function (openAction) {
|
2020-02-28 22:54:07 +09:00
|
|
|
expect(openAction.dest).toBeUndefined();
|
|
|
|
expect(openAction.action).toEqual("Print");
|
|
|
|
|
|
|
|
return loadingTask2.destroy();
|
|
|
|
});
|
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
await Promise.all([promise1, promise2]);
|
2020-02-28 22:54:07 +09:00
|
|
|
});
|
2018-12-06 04:09:15 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("gets non-existent attachments", async function () {
|
|
|
|
const attachments = await pdfDocument.getAttachments();
|
|
|
|
expect(attachments).toEqual(null);
|
2014-05-19 06:35:29 +09:00
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
it("gets attachments", async function () {
|
2020-10-25 23:40:51 +09:00
|
|
|
const loadingTask = getDocument(buildGetDocumentParams("attachment.pdf"));
|
2021-04-17 04:48:42 +09:00
|
|
|
const pdfDoc = await loadingTask.promise;
|
|
|
|
const attachments = await pdfDoc.getAttachments();
|
2016-07-02 20:13:30 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
const attachment = attachments["foo.txt"];
|
|
|
|
expect(attachment.filename).toEqual("foo.txt");
|
|
|
|
expect(attachment.content).toEqual(
|
|
|
|
new Uint8Array([98, 97, 114, 32, 98, 97, 122, 32, 10])
|
|
|
|
);
|
|
|
|
|
|
|
|
await loadingTask.destroy();
|
2016-07-02 20:13:30 +09:00
|
|
|
});
|
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("gets javascript", async function () {
|
|
|
|
const javascript = await pdfDocument.getJavaScript();
|
|
|
|
expect(javascript).toEqual(null);
|
2014-05-19 06:35:29 +09:00
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
it("gets javascript with printing instructions (JS action)", async function () {
|
2019-12-25 07:42:42 +09:00
|
|
|
// PDF document with "JavaScript" action in the OpenAction dictionary.
|
2020-10-25 23:40:51 +09:00
|
|
|
const loadingTask = getDocument(buildGetDocumentParams("issue6106.pdf"));
|
2021-04-17 04:48:42 +09:00
|
|
|
const pdfDoc = await loadingTask.promise;
|
|
|
|
const javascript = await pdfDoc.getJavaScript();
|
|
|
|
|
|
|
|
expect(javascript).toEqual([
|
|
|
|
"this.print({bUI:true,bSilent:false,bShrinkToFit:true});",
|
|
|
|
]);
|
|
|
|
expect(javascript[0]).toMatch(AutoPrintRegExp);
|
|
|
|
|
|
|
|
await loadingTask.destroy();
|
2015-07-21 01:25:02 +09:00
|
|
|
});
|
2019-12-25 07:42:42 +09:00
|
|
|
|
2021-04-13 19:30:20 +09:00
|
|
|
it("gets hasJSActions, in document without javaScript", async function () {
|
|
|
|
const hasJSActions = await pdfDocument.hasJSActions();
|
|
|
|
|
|
|
|
expect(hasJSActions).toEqual(false);
|
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
2021-04-13 19:30:20 +09:00
|
|
|
it("gets hasJSActions, in document with javaScript", async function () {
|
|
|
|
const loadingTask = getDocument(
|
|
|
|
buildGetDocumentParams("doc_actions.pdf")
|
|
|
|
);
|
|
|
|
const pdfDoc = await loadingTask.promise;
|
|
|
|
const hasJSActions = await pdfDoc.hasJSActions();
|
|
|
|
|
|
|
|
expect(hasJSActions).toEqual(true);
|
|
|
|
|
|
|
|
await loadingTask.destroy();
|
|
|
|
});
|
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("gets non-existent JSActions", async function () {
|
|
|
|
const jsActions = await pdfDocument.getJSActions();
|
|
|
|
expect(jsActions).toEqual(null);
|
2020-12-08 03:22:14 +09:00
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
it("gets JSActions", async function () {
|
2020-12-08 03:22:14 +09:00
|
|
|
// PDF document with "JavaScript" action in the OpenAction dictionary.
|
2020-12-24 02:57:44 +09:00
|
|
|
const loadingTask = getDocument(
|
|
|
|
buildGetDocumentParams("doc_actions.pdf")
|
|
|
|
);
|
2021-04-17 04:48:42 +09:00
|
|
|
const pdfDoc = await loadingTask.promise;
|
|
|
|
const docActions = await pdfDoc.getJSActions();
|
|
|
|
const page1 = await pdfDoc.getPage(1);
|
|
|
|
const page1Actions = await page1.getJSActions();
|
|
|
|
const page3 = await pdfDoc.getPage(3);
|
|
|
|
const page3Actions = await page3.getJSActions();
|
|
|
|
|
|
|
|
expect(docActions).toEqual({
|
|
|
|
DidPrint: [`this.getField("Text2").value = "DidPrint";`],
|
|
|
|
DidSave: [`this.getField("Text2").value = "DidSave";`],
|
|
|
|
WillClose: [`this.getField("Text1").value = "WillClose";`],
|
|
|
|
WillPrint: [`this.getField("Text1").value = "WillPrint";`],
|
|
|
|
WillSave: [`this.getField("Text1").value = "WillSave";`],
|
2020-12-08 03:22:14 +09:00
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
expect(page1Actions).toEqual({
|
|
|
|
PageOpen: [`this.getField("Text1").value = "PageOpen 1";`],
|
|
|
|
PageClose: [`this.getField("Text2").value = "PageClose 1";`],
|
|
|
|
});
|
|
|
|
expect(page3Actions).toEqual({
|
|
|
|
PageOpen: [`this.getField("Text5").value = "PageOpen 3";`],
|
|
|
|
PageClose: [`this.getField("Text6").value = "PageClose 3";`],
|
|
|
|
});
|
|
|
|
|
|
|
|
await loadingTask.destroy();
|
2020-12-08 03:22:14 +09:00
|
|
|
});
|
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("gets non-existent outline", async function () {
|
2020-10-25 23:40:51 +09:00
|
|
|
const loadingTask = getDocument(
|
|
|
|
buildGetDocumentParams("tracemonkey.pdf")
|
|
|
|
);
|
2021-04-17 04:48:42 +09:00
|
|
|
const pdfDoc = await loadingTask.promise;
|
|
|
|
const outline = await pdfDoc.getOutline();
|
|
|
|
expect(outline).toEqual(null);
|
2016-02-14 07:13:01 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
await loadingTask.destroy();
|
|
|
|
});
|
2016-02-14 07:13:01 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("gets outline", async function () {
|
|
|
|
const outline = await pdfDocument.getOutline();
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
// Two top level entries.
|
|
|
|
expect(Array.isArray(outline)).toEqual(true);
|
|
|
|
expect(outline.length).toEqual(2);
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
// Make sure some basic attributes are set.
|
|
|
|
const outlineItem = outline[1];
|
|
|
|
expect(outlineItem.title).toEqual("Chapter 1");
|
|
|
|
expect(Array.isArray(outlineItem.dest)).toEqual(true);
|
|
|
|
expect(outlineItem.url).toEqual(null);
|
|
|
|
expect(outlineItem.unsafeUrl).toBeUndefined();
|
|
|
|
expect(outlineItem.newWindow).toBeUndefined();
|
2015-12-22 20:59:23 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
expect(outlineItem.bold).toEqual(true);
|
|
|
|
expect(outlineItem.italic).toEqual(false);
|
|
|
|
expect(outlineItem.color).toEqual(new Uint8ClampedArray([0, 64, 128]));
|
|
|
|
|
|
|
|
expect(outlineItem.items.length).toEqual(1);
|
|
|
|
expect(outlineItem.items[0].title).toEqual("Paragraph 1.1");
|
2012-04-13 09:59:30 +09:00
|
|
|
});
|
2018-08-27 04:37:05 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("gets outline containing a URL", async function () {
|
|
|
|
const loadingTask = getDocument(buildGetDocumentParams("issue3214.pdf"));
|
|
|
|
const pdfDoc = await loadingTask.promise;
|
|
|
|
const outline = await pdfDoc.getOutline();
|
|
|
|
expect(Array.isArray(outline)).toEqual(true);
|
|
|
|
expect(outline.length).toEqual(5);
|
|
|
|
|
|
|
|
const outlineItemTwo = outline[2];
|
|
|
|
expect(typeof outlineItemTwo.title).toEqual("string");
|
|
|
|
expect(outlineItemTwo.dest).toEqual(null);
|
|
|
|
expect(outlineItemTwo.url).toEqual("http://google.com/");
|
|
|
|
expect(outlineItemTwo.unsafeUrl).toEqual("http://google.com");
|
|
|
|
expect(outlineItemTwo.newWindow).toBeUndefined();
|
|
|
|
|
|
|
|
const outlineItemOne = outline[1];
|
|
|
|
expect(outlineItemOne.bold).toEqual(false);
|
|
|
|
expect(outlineItemOne.italic).toEqual(true);
|
|
|
|
expect(outlineItemOne.color).toEqual(new Uint8ClampedArray([0, 0, 0]));
|
2018-08-27 04:37:05 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
await loadingTask.destroy();
|
2018-08-27 04:37:05 +09:00
|
|
|
});
|
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("gets non-existent permissions", async function () {
|
|
|
|
const permissions = await pdfDocument.getPermissions();
|
|
|
|
expect(permissions).toEqual(null);
|
|
|
|
});
|
|
|
|
|
|
|
|
it("gets permissions", async function () {
|
2018-08-27 04:37:05 +09:00
|
|
|
// Editing not allowed.
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
const loadingTask0 = getDocument(
|
|
|
|
buildGetDocumentParams("issue9972-1.pdf")
|
|
|
|
);
|
2020-04-14 19:28:14 +09:00
|
|
|
const promise0 = loadingTask0.promise.then(function (pdfDoc) {
|
2020-03-24 18:44:17 +09:00
|
|
|
return pdfDoc.getPermissions();
|
2018-08-27 04:37:05 +09:00
|
|
|
});
|
|
|
|
|
|
|
|
// Printing not allowed.
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
const loadingTask1 = getDocument(
|
|
|
|
buildGetDocumentParams("issue9972-2.pdf")
|
|
|
|
);
|
2020-04-14 19:28:14 +09:00
|
|
|
const promise1 = loadingTask1.promise.then(function (pdfDoc) {
|
2020-03-24 18:44:17 +09:00
|
|
|
return pdfDoc.getPermissions();
|
2018-08-27 04:37:05 +09:00
|
|
|
});
|
|
|
|
|
|
|
|
// Copying not allowed.
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
const loadingTask2 = getDocument(
|
|
|
|
buildGetDocumentParams("issue9972-3.pdf")
|
|
|
|
);
|
2020-04-14 19:28:14 +09:00
|
|
|
const promise2 = loadingTask2.promise.then(function (pdfDoc) {
|
2020-03-24 18:44:17 +09:00
|
|
|
return pdfDoc.getPermissions();
|
2018-08-27 04:37:05 +09:00
|
|
|
});
|
|
|
|
|
|
|
|
const totalPermissionCount = Object.keys(PermissionFlag).length;
|
2021-04-17 04:48:42 +09:00
|
|
|
const permissions = await Promise.all([promise0, promise1, promise2]);
|
|
|
|
|
|
|
|
expect(permissions[0].length).toEqual(totalPermissionCount - 1);
|
|
|
|
expect(
|
|
|
|
permissions[0].includes(PermissionFlag.MODIFY_CONTENTS)
|
|
|
|
).toBeFalsy();
|
|
|
|
|
|
|
|
expect(permissions[1].length).toEqual(totalPermissionCount - 2);
|
|
|
|
expect(permissions[1].includes(PermissionFlag.PRINT)).toBeFalsy();
|
|
|
|
expect(
|
|
|
|
permissions[1].includes(PermissionFlag.PRINT_HIGH_QUALITY)
|
|
|
|
).toBeFalsy();
|
|
|
|
|
|
|
|
expect(permissions[2].length).toEqual(totalPermissionCount - 1);
|
|
|
|
expect(permissions[2].includes(PermissionFlag.COPY)).toBeFalsy();
|
|
|
|
|
|
|
|
await Promise.all([
|
|
|
|
loadingTask0.destroy(),
|
|
|
|
loadingTask1.destroy(),
|
|
|
|
loadingTask2.destroy(),
|
|
|
|
]);
|
|
|
|
});
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("gets metadata", async function () {
|
2021-05-16 17:58:34 +09:00
|
|
|
const { info, metadata, contentDispositionFilename, contentLength } =
|
|
|
|
await pdfDocument.getMetadata();
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
expect(info.Title).toEqual("Basic API Test");
|
|
|
|
// Custom, non-standard, information dictionary entries.
|
|
|
|
expect(info.Custom).toEqual(undefined);
|
|
|
|
// The following are PDF.js specific, non-standard, properties.
|
|
|
|
expect(info.PDFFormatVersion).toEqual("1.7");
|
|
|
|
expect(info.IsLinearized).toEqual(false);
|
|
|
|
expect(info.IsAcroFormPresent).toEqual(false);
|
|
|
|
expect(info.IsXFAPresent).toEqual(false);
|
|
|
|
expect(info.IsCollectionPresent).toEqual(false);
|
|
|
|
expect(info.IsSignaturesPresent).toEqual(false);
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
expect(metadata instanceof Metadata).toEqual(true);
|
|
|
|
expect(metadata.get("dc:title")).toEqual("Basic API Test");
|
|
|
|
|
|
|
|
expect(contentDispositionFilename).toEqual(null);
|
|
|
|
expect(contentLength).toEqual(basicApiFileLength);
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
it("gets metadata, with custom info dict entries", async function () {
|
2020-10-25 23:40:51 +09:00
|
|
|
const loadingTask = getDocument(
|
|
|
|
buildGetDocumentParams("tracemonkey.pdf")
|
|
|
|
);
|
2021-04-17 04:48:42 +09:00
|
|
|
const pdfDoc = await loadingTask.promise;
|
2021-05-16 17:58:34 +09:00
|
|
|
const { info, metadata, contentDispositionFilename, contentLength } =
|
|
|
|
await pdfDoc.getMetadata();
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
expect(info.Creator).toEqual("TeX");
|
|
|
|
expect(info.Producer).toEqual("pdfeTeX-1.21a");
|
|
|
|
expect(info.CreationDate).toEqual("D:20090401163925-07'00'");
|
|
|
|
// Custom, non-standard, information dictionary entries.
|
|
|
|
const custom = info.Custom;
|
|
|
|
expect(typeof custom === "object" && custom !== null).toEqual(true);
|
|
|
|
|
|
|
|
expect(custom["PTEX.Fullbanner"]).toEqual(
|
|
|
|
"This is pdfeTeX, " +
|
|
|
|
"Version 3.141592-1.21a-2.2 (Web2C 7.5.4) kpathsea version 3.5.6"
|
|
|
|
);
|
|
|
|
// The following are PDF.js specific, non-standard, properties.
|
|
|
|
expect(info.PDFFormatVersion).toEqual("1.4");
|
|
|
|
expect(info.IsLinearized).toEqual(false);
|
|
|
|
expect(info.IsAcroFormPresent).toEqual(false);
|
|
|
|
expect(info.IsXFAPresent).toEqual(false);
|
|
|
|
expect(info.IsCollectionPresent).toEqual(false);
|
|
|
|
expect(info.IsSignaturesPresent).toEqual(false);
|
|
|
|
|
|
|
|
expect(metadata).toEqual(null);
|
|
|
|
expect(contentDispositionFilename).toEqual(null);
|
|
|
|
expect(contentLength).toEqual(1016315);
|
2018-08-27 04:37:05 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
await loadingTask.destroy();
|
2018-08-27 04:37:05 +09:00
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
it("gets metadata, with missing PDF header (bug 1606566)", async function () {
|
2020-02-05 21:59:47 +09:00
|
|
|
const loadingTask = getDocument(buildGetDocumentParams("bug1606566.pdf"));
|
2021-04-17 04:48:42 +09:00
|
|
|
const pdfDoc = await loadingTask.promise;
|
2021-05-16 17:58:34 +09:00
|
|
|
const { info, metadata, contentDispositionFilename, contentLength } =
|
|
|
|
await pdfDoc.getMetadata();
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
// The following are PDF.js specific, non-standard, properties.
|
|
|
|
expect(info.PDFFormatVersion).toEqual(null);
|
|
|
|
expect(info.IsLinearized).toEqual(false);
|
|
|
|
expect(info.IsAcroFormPresent).toEqual(false);
|
|
|
|
expect(info.IsXFAPresent).toEqual(false);
|
|
|
|
expect(info.IsCollectionPresent).toEqual(false);
|
|
|
|
expect(info.IsSignaturesPresent).toEqual(false);
|
|
|
|
|
|
|
|
expect(metadata).toEqual(null);
|
|
|
|
expect(contentDispositionFilename).toEqual(null);
|
|
|
|
expect(contentLength).toEqual(624);
|
2020-02-05 21:59:47 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
await loadingTask.destroy();
|
2018-08-27 04:37:05 +09:00
|
|
|
});
|
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("gets markInfo", async function () {
|
2020-10-24 08:30:36 +09:00
|
|
|
const loadingTask = getDocument(
|
|
|
|
buildGetDocumentParams("annotation-line.pdf")
|
|
|
|
);
|
2021-04-17 04:48:42 +09:00
|
|
|
const pdfDoc = await loadingTask.promise;
|
|
|
|
const markInfo = await pdfDoc.getMarkInfo();
|
|
|
|
expect(markInfo.Marked).toEqual(true);
|
|
|
|
expect(markInfo.UserProperties).toEqual(false);
|
|
|
|
expect(markInfo.Suspects).toEqual(false);
|
|
|
|
});
|
2020-10-24 08:30:36 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("gets data", async function () {
|
|
|
|
const data = await pdfDocument.getData();
|
|
|
|
expect(data instanceof Uint8Array).toEqual(true);
|
|
|
|
expect(data.length).toEqual(basicApiFileLength);
|
2020-10-24 08:30:36 +09:00
|
|
|
});
|
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("gets download info", async function () {
|
|
|
|
const downloadInfo = await pdfDocument.getDownloadInfo();
|
|
|
|
expect(downloadInfo).toEqual({ length: basicApiFileLength });
|
2014-05-14 18:57:48 +09:00
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
it("gets document stats", async function () {
|
|
|
|
const stats = await pdfDocument.getStats();
|
|
|
|
expect(stats).toEqual({ streamTypes: {}, fontTypes: {} });
|
2014-08-31 05:12:34 +09:00
|
|
|
});
|
2015-10-24 21:15:47 +09:00
|
|
|
|
2021-04-02 19:26:46 +09:00
|
|
|
it("cleans up document resources", async function () {
|
|
|
|
await pdfDocument.cleanup();
|
|
|
|
|
|
|
|
expect(true).toEqual(true);
|
[api-minor] Change `PDFDocumentProxy.cleanup`/`PDFPageProxy.cleanup` to return data
This patch makes the following changes, to improve these API methods:
- Let `PDFPageProxy.cleanup` return a boolean indicating if clean-up actually happened, since ongoing rendering will block clean-up.
Besides being used in other parts of this patch, it seems that an API user may also be interested in the return value given that clean-up isn't *guaranteed* to happen.
- Let `PDFDocumentProxy.cleanup` return the promise indicating when clean-up is finished.
- Improve the JSDoc comment for `PDFDocumentProxy.cleanup` to mention that clean-up is triggered on *both* threads (without going into unnecessary specifics regarding what *exactly* said data actually is).
Add a note in the JSDoc comment about not calling this method when rendering is ongoing.
- Change `WorkerTransport.startCleanup` to throw an `Error` if it's called when rendering is ongoing, to prevent rendering from breaking.
Please note that this won't stop *worker-thread* clean-up from happening (since there's no general "something is rendering"-flag), however I'm not sure if that's really a problem; but please don't quote me on that :-)
All of the caches that's being cleared in `Catalog.cleanup`, on the worker-thread, *should* be re-filled automatically even if cleared *during* parsing/rendering, and the only thing that probably happens is that e.g. font data would have to be re-parsed.
On the main-thread, on the other hand, clearing the caches is more-or-less guaranteed to cause rendering errors, since the rendering code in `src/display/canvas.js` isn't able to re-request any image/font data that's suddenly being pulled out from under it.
- Last, but not least, add a couple of basic unit-tests for the clean-up functionality.
2020-02-07 23:48:58 +09:00
|
|
|
});
|
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("checks that fingerprints are unique", async function () {
|
2019-07-15 18:19:17 +09:00
|
|
|
const loadingTask1 = getDocument(
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
buildGetDocumentParams("issue4436r.pdf")
|
|
|
|
);
|
|
|
|
const loadingTask2 = getDocument(buildGetDocumentParams("issue4575.pdf"));
|
2015-10-24 21:15:47 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
const data = await Promise.all([
|
|
|
|
loadingTask1.promise,
|
|
|
|
loadingTask2.promise,
|
|
|
|
]);
|
2021-07-02 23:36:27 +09:00
|
|
|
const fingerprints1 = data[0].fingerprints;
|
|
|
|
const fingerprints2 = data[1].fingerprints;
|
2015-10-24 21:15:47 +09:00
|
|
|
|
2021-07-02 23:36:27 +09:00
|
|
|
expect(fingerprints1).not.toEqual(fingerprints2);
|
2016-01-21 07:57:17 +09:00
|
|
|
|
2021-07-02 23:36:27 +09:00
|
|
|
expect(fingerprints1).toEqual(["2f695a83d6e7553c24fc08b7ac69712d", null]);
|
|
|
|
expect(fingerprints2).toEqual(["04c7126b34a46b6d4d6e7a1eff7edcb6", null]);
|
2019-07-15 18:19:17 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
await Promise.all([loadingTask1.destroy(), loadingTask2.destroy()]);
|
2015-10-24 21:15:47 +09:00
|
|
|
});
|
2017-08-31 21:08:22 +09:00
|
|
|
|
2020-04-14 19:28:14 +09:00
|
|
|
describe("Cross-origin", function () {
|
2020-10-25 23:40:51 +09:00
|
|
|
let loadingTask;
|
2017-08-31 21:08:22 +09:00
|
|
|
function _checkCanLoad(expectSuccess, filename, options) {
|
2019-11-11 00:42:46 +09:00
|
|
|
if (isNodeJS) {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
pending("Cannot simulate cross-origin requests in Node.js");
|
2017-08-31 21:08:22 +09:00
|
|
|
}
|
2020-10-25 23:40:51 +09:00
|
|
|
const params = buildGetDocumentParams(filename, options);
|
|
|
|
const url = new URL(params.url);
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
if (url.hostname === "localhost") {
|
|
|
|
url.hostname = "127.0.0.1";
|
|
|
|
} else if (params.url.hostname === "127.0.0.1") {
|
|
|
|
url.hostname = "localhost";
|
2017-08-31 21:08:22 +09:00
|
|
|
} else {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
pending("Can only run cross-origin test on localhost!");
|
2017-08-31 21:08:22 +09:00
|
|
|
}
|
|
|
|
params.url = url.href;
|
|
|
|
loadingTask = getDocument(params);
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
return loadingTask.promise
|
2020-04-14 19:28:14 +09:00
|
|
|
.then(function (pdf) {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
return pdf.destroy();
|
|
|
|
})
|
|
|
|
.then(
|
2020-04-14 19:28:14 +09:00
|
|
|
function () {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
expect(expectSuccess).toEqual(true);
|
|
|
|
},
|
2020-04-14 19:28:14 +09:00
|
|
|
function (error) {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
if (expectSuccess) {
|
|
|
|
// For ease of debugging.
|
|
|
|
expect(error).toEqual("There should not be any error");
|
|
|
|
}
|
|
|
|
expect(expectSuccess).toEqual(false);
|
|
|
|
}
|
|
|
|
);
|
2017-08-31 21:08:22 +09:00
|
|
|
}
|
|
|
|
function testCanLoad(filename, options) {
|
|
|
|
return _checkCanLoad(true, filename, options);
|
|
|
|
}
|
|
|
|
function testCannotLoad(filename, options) {
|
|
|
|
return _checkCanLoad(false, filename, options);
|
|
|
|
}
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
afterEach(async function () {
|
2019-03-11 20:43:44 +09:00
|
|
|
if (loadingTask && !loadingTask.destroyed) {
|
2021-04-17 04:48:42 +09:00
|
|
|
await loadingTask.destroy();
|
2017-08-31 21:08:22 +09:00
|
|
|
}
|
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
it("server disallows cors", async function () {
|
|
|
|
await testCannotLoad("basicapi.pdf");
|
2017-08-31 21:08:22 +09:00
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
it("server allows cors without credentials, default withCredentials", async function () {
|
|
|
|
await testCanLoad("basicapi.pdf?cors=withoutCredentials");
|
2017-08-31 21:08:22 +09:00
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
it("server allows cors without credentials, and withCredentials=false", async function () {
|
|
|
|
await testCanLoad("basicapi.pdf?cors=withoutCredentials", {
|
2017-08-31 21:08:22 +09:00
|
|
|
withCredentials: false,
|
2021-04-17 04:48:42 +09:00
|
|
|
});
|
2017-08-31 21:08:22 +09:00
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
it("server allows cors without credentials, but withCredentials=true", async function () {
|
|
|
|
await testCannotLoad("basicapi.pdf?cors=withoutCredentials", {
|
2017-08-31 21:08:22 +09:00
|
|
|
withCredentials: true,
|
2021-04-17 04:48:42 +09:00
|
|
|
});
|
2017-08-31 21:08:22 +09:00
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
it("server allows cors with credentials, and withCredentials=true", async function () {
|
|
|
|
await testCanLoad("basicapi.pdf?cors=withCredentials", {
|
2017-08-31 21:08:22 +09:00
|
|
|
withCredentials: true,
|
2021-04-17 04:48:42 +09:00
|
|
|
});
|
2017-08-31 21:08:22 +09:00
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
it("server allows cors with credentials, and withCredentials=false", async function () {
|
2017-08-31 21:08:22 +09:00
|
|
|
// The server supports even more than we need, so if the previous tests
|
|
|
|
// pass, then this should pass for sure.
|
|
|
|
// The only case where this test fails is when the server does not reply
|
|
|
|
// with the Access-Control-Allow-Origin header.
|
2021-04-17 04:48:42 +09:00
|
|
|
await testCanLoad("basicapi.pdf?cors=withCredentials", {
|
2017-08-31 21:08:22 +09:00
|
|
|
withCredentials: false,
|
2021-04-17 04:48:42 +09:00
|
|
|
});
|
2017-08-31 21:08:22 +09:00
|
|
|
});
|
|
|
|
});
|
2012-04-13 09:59:30 +09:00
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
2020-04-14 19:28:14 +09:00
|
|
|
describe("Page", function () {
|
2020-03-24 18:44:17 +09:00
|
|
|
let pdfLoadingTask, pdfDocument, page;
|
2016-01-21 07:57:17 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
beforeAll(async function () {
|
2020-03-24 18:44:17 +09:00
|
|
|
pdfLoadingTask = getDocument(basicApiGetDocumentParams);
|
2021-04-17 04:48:42 +09:00
|
|
|
pdfDocument = await pdfLoadingTask.promise;
|
|
|
|
page = await pdfDocument.getPage(1);
|
2012-04-13 09:59:30 +09:00
|
|
|
});
|
2016-01-21 07:57:17 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
afterAll(async function () {
|
|
|
|
await pdfLoadingTask.destroy();
|
2012-04-13 09:59:30 +09:00
|
|
|
});
|
2016-01-21 07:57:17 +09:00
|
|
|
|
2020-04-14 19:28:14 +09:00
|
|
|
it("gets page number", function () {
|
2014-08-12 19:04:00 +09:00
|
|
|
expect(page.pageNumber).toEqual(1);
|
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
2020-04-14 19:28:14 +09:00
|
|
|
it("gets rotate", function () {
|
2014-08-12 19:04:00 +09:00
|
|
|
expect(page.rotate).toEqual(0);
|
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
2020-04-14 19:28:14 +09:00
|
|
|
it("gets ref", function () {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
expect(page.ref).toEqual({ num: 15, gen: 0 });
|
2014-08-12 19:04:00 +09:00
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
2020-04-14 19:28:14 +09:00
|
|
|
it("gets userUnit", function () {
|
2016-11-22 06:39:04 +09:00
|
|
|
expect(page.userUnit).toEqual(1.0);
|
|
|
|
});
|
Fallback gracefully when encountering corrupt PDF files with empty /MediaBox and /CropBox entries
This is based on a real-world PDF file I encountered very recently[1], although I'm currently unable to recall where I saw it.
Note that different PDF viewers handle these sort of errors differently, with Adobe Reader outright failing to render the attached PDF file whereas PDFium mostly handles it "correctly".
The patch makes the following notable changes:
- Refactor the `cropBox` and `mediaBox` getters, on the `Page`, to reduce unnecessary duplication. (This will also help in the future, if support for extracting additional page bounding boxes are added to the API.)
- Ensure that the page bounding boxes, i.e. `cropBox` and `mediaBox`, are never empty to prevent issues/weirdness in the viewer.
- Ensure that the `view` getter on the `Page` will never return an empty intersection of the `cropBox` and `mediaBox`.
- Add an *optional* parameter to `Util.intersect`, to allow checking that the computed intersection isn't actually empty.
- Change `Util.intersect` to have consistent return types, since Arrays are of type `Object` and falling back to returning a `Boolean` thus seem strange.
---
[1] In that case I believe that only the `cropBox` was empty, but it seemed like a good idea to attempt to fix a bunch of related cases all at once.
2019-08-08 22:54:46 +09:00
|
|
|
|
2020-04-14 19:28:14 +09:00
|
|
|
it("gets view", function () {
|
2014-08-12 19:04:00 +09:00
|
|
|
expect(page.view).toEqual([0, 0, 595.28, 841.89]);
|
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
it("gets view, with empty/invalid bounding boxes", async function () {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
const viewLoadingTask = getDocument(
|
|
|
|
buildGetDocumentParams("boundingBox_invalid.pdf")
|
|
|
|
);
|
Fallback gracefully when encountering corrupt PDF files with empty /MediaBox and /CropBox entries
This is based on a real-world PDF file I encountered very recently[1], although I'm currently unable to recall where I saw it.
Note that different PDF viewers handle these sort of errors differently, with Adobe Reader outright failing to render the attached PDF file whereas PDFium mostly handles it "correctly".
The patch makes the following notable changes:
- Refactor the `cropBox` and `mediaBox` getters, on the `Page`, to reduce unnecessary duplication. (This will also help in the future, if support for extracting additional page bounding boxes are added to the API.)
- Ensure that the page bounding boxes, i.e. `cropBox` and `mediaBox`, are never empty to prevent issues/weirdness in the viewer.
- Ensure that the `view` getter on the `Page` will never return an empty intersection of the `cropBox` and `mediaBox`.
- Add an *optional* parameter to `Util.intersect`, to allow checking that the computed intersection isn't actually empty.
- Change `Util.intersect` to have consistent return types, since Arrays are of type `Object` and falling back to returning a `Boolean` thus seem strange.
---
[1] In that case I believe that only the `cropBox` was empty, but it seemed like a good idea to attempt to fix a bunch of related cases all at once.
2019-08-08 22:54:46 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
const pdfDoc = await viewLoadingTask.promise;
|
|
|
|
const numPages = pdfDoc.numPages;
|
|
|
|
expect(numPages).toEqual(3);
|
Fallback gracefully when encountering corrupt PDF files with empty /MediaBox and /CropBox entries
This is based on a real-world PDF file I encountered very recently[1], although I'm currently unable to recall where I saw it.
Note that different PDF viewers handle these sort of errors differently, with Adobe Reader outright failing to render the attached PDF file whereas PDFium mostly handles it "correctly".
The patch makes the following notable changes:
- Refactor the `cropBox` and `mediaBox` getters, on the `Page`, to reduce unnecessary duplication. (This will also help in the future, if support for extracting additional page bounding boxes are added to the API.)
- Ensure that the page bounding boxes, i.e. `cropBox` and `mediaBox`, are never empty to prevent issues/weirdness in the viewer.
- Ensure that the `view` getter on the `Page` will never return an empty intersection of the `cropBox` and `mediaBox`.
- Add an *optional* parameter to `Util.intersect`, to allow checking that the computed intersection isn't actually empty.
- Change `Util.intersect` to have consistent return types, since Arrays are of type `Object` and falling back to returning a `Boolean` thus seem strange.
---
[1] In that case I believe that only the `cropBox` was empty, but it seemed like a good idea to attempt to fix a bunch of related cases all at once.
2019-08-08 22:54:46 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
const viewPromises = [];
|
|
|
|
for (let i = 0; i < numPages; i++) {
|
|
|
|
viewPromises[i] = pdfDoc.getPage(i + 1).then(pdfPage => {
|
|
|
|
return pdfPage.view;
|
|
|
|
});
|
|
|
|
}
|
Fallback gracefully when encountering corrupt PDF files with empty /MediaBox and /CropBox entries
This is based on a real-world PDF file I encountered very recently[1], although I'm currently unable to recall where I saw it.
Note that different PDF viewers handle these sort of errors differently, with Adobe Reader outright failing to render the attached PDF file whereas PDFium mostly handles it "correctly".
The patch makes the following notable changes:
- Refactor the `cropBox` and `mediaBox` getters, on the `Page`, to reduce unnecessary duplication. (This will also help in the future, if support for extracting additional page bounding boxes are added to the API.)
- Ensure that the page bounding boxes, i.e. `cropBox` and `mediaBox`, are never empty to prevent issues/weirdness in the viewer.
- Ensure that the `view` getter on the `Page` will never return an empty intersection of the `cropBox` and `mediaBox`.
- Add an *optional* parameter to `Util.intersect`, to allow checking that the computed intersection isn't actually empty.
- Change `Util.intersect` to have consistent return types, since Arrays are of type `Object` and falling back to returning a `Boolean` thus seem strange.
---
[1] In that case I believe that only the `cropBox` was empty, but it seemed like a good idea to attempt to fix a bunch of related cases all at once.
2019-08-08 22:54:46 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
const [page1, page2, page3] = await Promise.all(viewPromises);
|
|
|
|
expect(page1).toEqual([0, 0, 612, 792]);
|
|
|
|
expect(page2).toEqual([0, 0, 800, 600]);
|
|
|
|
expect(page3).toEqual([0, 0, 600, 800]);
|
Fallback gracefully when encountering corrupt PDF files with empty /MediaBox and /CropBox entries
This is based on a real-world PDF file I encountered very recently[1], although I'm currently unable to recall where I saw it.
Note that different PDF viewers handle these sort of errors differently, with Adobe Reader outright failing to render the attached PDF file whereas PDFium mostly handles it "correctly".
The patch makes the following notable changes:
- Refactor the `cropBox` and `mediaBox` getters, on the `Page`, to reduce unnecessary duplication. (This will also help in the future, if support for extracting additional page bounding boxes are added to the API.)
- Ensure that the page bounding boxes, i.e. `cropBox` and `mediaBox`, are never empty to prevent issues/weirdness in the viewer.
- Ensure that the `view` getter on the `Page` will never return an empty intersection of the `cropBox` and `mediaBox`.
- Add an *optional* parameter to `Util.intersect`, to allow checking that the computed intersection isn't actually empty.
- Change `Util.intersect` to have consistent return types, since Arrays are of type `Object` and falling back to returning a `Boolean` thus seem strange.
---
[1] In that case I believe that only the `cropBox` was empty, but it seemed like a good idea to attempt to fix a bunch of related cases all at once.
2019-08-08 22:54:46 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
await viewLoadingTask.destroy();
|
Fallback gracefully when encountering corrupt PDF files with empty /MediaBox and /CropBox entries
This is based on a real-world PDF file I encountered very recently[1], although I'm currently unable to recall where I saw it.
Note that different PDF viewers handle these sort of errors differently, with Adobe Reader outright failing to render the attached PDF file whereas PDFium mostly handles it "correctly".
The patch makes the following notable changes:
- Refactor the `cropBox` and `mediaBox` getters, on the `Page`, to reduce unnecessary duplication. (This will also help in the future, if support for extracting additional page bounding boxes are added to the API.)
- Ensure that the page bounding boxes, i.e. `cropBox` and `mediaBox`, are never empty to prevent issues/weirdness in the viewer.
- Ensure that the `view` getter on the `Page` will never return an empty intersection of the `cropBox` and `mediaBox`.
- Add an *optional* parameter to `Util.intersect`, to allow checking that the computed intersection isn't actually empty.
- Change `Util.intersect` to have consistent return types, since Arrays are of type `Object` and falling back to returning a `Boolean` thus seem strange.
---
[1] In that case I believe that only the `cropBox` was empty, but it seemed like a good idea to attempt to fix a bunch of related cases all at once.
2019-08-08 22:54:46 +09:00
|
|
|
});
|
|
|
|
|
2020-04-14 19:28:14 +09:00
|
|
|
it("gets viewport", function () {
|
2020-10-25 23:40:51 +09:00
|
|
|
const viewport = page.getViewport({ scale: 1.5, rotation: 90 });
|
2014-08-12 19:04:00 +09:00
|
|
|
expect(viewport.viewBox).toEqual(page.view);
|
|
|
|
expect(viewport.scale).toEqual(1.5);
|
|
|
|
expect(viewport.rotation).toEqual(90);
|
|
|
|
expect(viewport.transform).toEqual([0, 1.5, 1.5, 0, 0, 0]);
|
|
|
|
expect(viewport.width).toEqual(1262.835);
|
|
|
|
expect(viewport.height).toEqual(892.92);
|
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
2020-04-14 19:28:14 +09:00
|
|
|
it('gets viewport with "offsetX/offsetY" arguments', function () {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
const viewport = page.getViewport({
|
|
|
|
scale: 1,
|
|
|
|
rotation: 0,
|
|
|
|
offsetX: 100,
|
|
|
|
offsetY: -100,
|
|
|
|
});
|
2019-10-24 03:35:49 +09:00
|
|
|
expect(viewport.transform).toEqual([1, 0, 0, -1, 100, 741.89]);
|
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
2020-04-14 19:28:14 +09:00
|
|
|
it('gets viewport respecting "dontFlip" argument', function () {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
const scale = 1,
|
|
|
|
rotation = 0;
|
2020-01-24 17:48:21 +09:00
|
|
|
const viewport = page.getViewport({ scale, rotation });
|
|
|
|
const dontFlipViewport = page.getViewport({
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
scale,
|
|
|
|
rotation,
|
|
|
|
dontFlip: true,
|
|
|
|
});
|
2017-11-04 01:05:53 +09:00
|
|
|
|
|
|
|
expect(dontFlipViewport).not.toEqual(viewport);
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
expect(dontFlipViewport).toEqual(viewport.clone({ dontFlip: true }));
|
2017-11-04 01:05:53 +09:00
|
|
|
|
|
|
|
expect(viewport.transform).toEqual([1, 0, 0, -1, 0, 841.89]);
|
|
|
|
expect(dontFlipViewport.transform).toEqual([1, 0, -0, 1, 0, 0]);
|
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
2020-04-22 22:18:27 +09:00
|
|
|
it("gets viewport with invalid rotation", function () {
|
|
|
|
expect(function () {
|
|
|
|
page.getViewport({ scale: 1, rotation: 45 });
|
|
|
|
}).toThrow(
|
|
|
|
new Error(
|
|
|
|
"PageViewport: Invalid rotation, must be a multiple of 90 degrees."
|
|
|
|
)
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("gets annotations", async function () {
|
2020-10-25 23:40:51 +09:00
|
|
|
const defaultPromise = page.getAnnotations().then(function (data) {
|
2015-11-22 21:56:52 +09:00
|
|
|
expect(data.length).toEqual(4);
|
|
|
|
});
|
|
|
|
|
2020-10-25 23:40:51 +09:00
|
|
|
const displayPromise = page
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
.getAnnotations({ intent: "display" })
|
2020-04-14 19:28:14 +09:00
|
|
|
.then(function (data) {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
expect(data.length).toEqual(4);
|
|
|
|
});
|
2015-11-22 21:56:52 +09:00
|
|
|
|
2020-10-25 23:40:51 +09:00
|
|
|
const printPromise = page
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
.getAnnotations({ intent: "print" })
|
2020-04-14 19:28:14 +09:00
|
|
|
.then(function (data) {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
expect(data.length).toEqual(4);
|
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
await Promise.all([defaultPromise, displayPromise, printPromise]);
|
2014-08-12 19:04:00 +09:00
|
|
|
});
|
2016-10-01 19:05:07 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("gets annotations containing relative URLs (bug 766086)", async function () {
|
2020-10-25 23:40:51 +09:00
|
|
|
const filename = "bug766086.pdf";
|
2016-10-01 19:05:07 +09:00
|
|
|
|
2020-10-25 23:40:51 +09:00
|
|
|
const defaultLoadingTask = getDocument(buildGetDocumentParams(filename));
|
|
|
|
const defaultPromise = defaultLoadingTask.promise.then(function (pdfDoc) {
|
2020-04-14 19:28:14 +09:00
|
|
|
return pdfDoc.getPage(1).then(function (pdfPage) {
|
2016-10-01 19:05:07 +09:00
|
|
|
return pdfPage.getAnnotations();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2020-10-25 23:40:51 +09:00
|
|
|
const docBaseUrlLoadingTask = getDocument(
|
2017-04-09 00:09:54 +09:00
|
|
|
buildGetDocumentParams(filename, {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
docBaseUrl: "http://www.example.com/test/pdfs/qwerty.pdf",
|
|
|
|
})
|
|
|
|
);
|
2020-10-25 23:40:51 +09:00
|
|
|
const docBaseUrlPromise = docBaseUrlLoadingTask.promise.then(function (
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
pdfDoc
|
|
|
|
) {
|
2020-04-14 19:28:14 +09:00
|
|
|
return pdfDoc.getPage(1).then(function (pdfPage) {
|
2016-10-01 19:05:07 +09:00
|
|
|
return pdfPage.getAnnotations();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2020-10-25 23:40:51 +09:00
|
|
|
const invalidDocBaseUrlLoadingTask = getDocument(
|
2017-04-09 00:09:54 +09:00
|
|
|
buildGetDocumentParams(filename, {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
docBaseUrl: "qwerty.pdf",
|
|
|
|
})
|
|
|
|
);
|
2021-05-16 17:58:34 +09:00
|
|
|
const invalidDocBaseUrlPromise =
|
|
|
|
invalidDocBaseUrlLoadingTask.promise.then(function (pdfDoc) {
|
2020-04-14 19:28:14 +09:00
|
|
|
return pdfDoc.getPage(1).then(function (pdfPage) {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
return pdfPage.getAnnotations();
|
|
|
|
});
|
2021-05-16 17:58:34 +09:00
|
|
|
});
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
const [
|
|
|
|
defaultAnnotations,
|
|
|
|
docBaseUrlAnnotations,
|
|
|
|
invalidDocBaseUrlAnnotations,
|
|
|
|
] = await Promise.all([
|
|
|
|
defaultPromise,
|
|
|
|
docBaseUrlPromise,
|
|
|
|
invalidDocBaseUrlPromise,
|
|
|
|
]);
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
expect(defaultAnnotations[0].url).toBeUndefined();
|
|
|
|
expect(defaultAnnotations[0].unsafeUrl).toEqual(
|
|
|
|
"../../0021/002156/215675E.pdf#15"
|
|
|
|
);
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
expect(docBaseUrlAnnotations[0].url).toEqual(
|
|
|
|
"http://www.example.com/0021/002156/215675E.pdf#15"
|
|
|
|
);
|
|
|
|
expect(docBaseUrlAnnotations[0].unsafeUrl).toEqual(
|
|
|
|
"../../0021/002156/215675E.pdf#15"
|
|
|
|
);
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
expect(invalidDocBaseUrlAnnotations[0].url).toBeUndefined();
|
|
|
|
expect(invalidDocBaseUrlAnnotations[0].unsafeUrl).toEqual(
|
|
|
|
"../../0021/002156/215675E.pdf#15"
|
|
|
|
);
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
await Promise.all([
|
|
|
|
defaultLoadingTask.destroy(),
|
|
|
|
docBaseUrlLoadingTask.destroy(),
|
|
|
|
invalidDocBaseUrlLoadingTask.destroy(),
|
|
|
|
]);
|
2016-10-01 19:05:07 +09:00
|
|
|
});
|
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("gets text content", async function () {
|
2020-10-25 23:40:51 +09:00
|
|
|
const defaultPromise = page.getTextContent();
|
|
|
|
const parametersPromise = page.getTextContent({
|
2016-07-04 01:29:47 +09:00
|
|
|
normalizeWhitespace: true,
|
|
|
|
disableCombineTextItems: true,
|
|
|
|
});
|
2015-11-24 00:57:43 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
const data = await Promise.all([defaultPromise, parametersPromise]);
|
2021-04-30 21:41:13 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
expect(!!data[0].items).toEqual(true);
|
2021-04-30 21:41:13 +09:00
|
|
|
expect(data[0].items.length).toEqual(12);
|
2021-04-17 04:48:42 +09:00
|
|
|
expect(!!data[0].styles).toEqual(true);
|
2015-11-24 00:57:43 +09:00
|
|
|
|
2021-04-30 21:41:13 +09:00
|
|
|
expect(!!data[1].items).toEqual(true);
|
|
|
|
expect(data[1].items.length).toEqual(7);
|
|
|
|
expect(!!data[1].styles).toEqual(true);
|
2012-04-13 09:59:30 +09:00
|
|
|
});
|
2019-01-29 22:24:48 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("gets text content, with correct properties (issue 8276)", async function () {
|
2019-01-29 22:24:48 +09:00
|
|
|
const loadingTask = getDocument(
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
buildGetDocumentParams("issue8276_reduced.pdf")
|
|
|
|
);
|
2021-04-17 04:48:42 +09:00
|
|
|
const pdfDoc = await loadingTask.promise;
|
|
|
|
const pdfPage = await pdfDoc.getPage(1);
|
|
|
|
const { items, styles } = await pdfPage.getTextContent();
|
|
|
|
expect(items.length).toEqual(1);
|
2020-12-11 10:32:18 +09:00
|
|
|
// Font name will a random object id.
|
|
|
|
const fontName = items[0].fontName;
|
|
|
|
expect(Object.keys(styles)).toEqual([fontName]);
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
expect(items[0]).toEqual({
|
|
|
|
dir: "ltr",
|
2020-12-11 10:32:18 +09:00
|
|
|
fontName,
|
2021-04-17 04:48:42 +09:00
|
|
|
height: 18,
|
|
|
|
str: "Issue 8276",
|
|
|
|
transform: [18, 0, 0, 18, 441.81, 708.4499999999999],
|
|
|
|
width: 77.49,
|
2021-04-30 21:41:13 +09:00
|
|
|
hasEOL: false,
|
2021-04-17 04:48:42 +09:00
|
|
|
});
|
2020-12-11 10:32:18 +09:00
|
|
|
expect(styles[fontName]).toEqual({
|
2021-04-17 04:48:42 +09:00
|
|
|
fontFamily: "serif",
|
|
|
|
ascent: NaN,
|
|
|
|
descent: NaN,
|
|
|
|
vertical: false,
|
|
|
|
});
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
await loadingTask.destroy();
|
2019-01-29 22:24:48 +09:00
|
|
|
});
|
|
|
|
|
2021-04-11 19:04:29 +09:00
|
|
|
it("gets empty structure tree", async function () {
|
|
|
|
const tree = await page.getStructTree();
|
|
|
|
|
|
|
|
expect(tree).toEqual(null);
|
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
2021-04-11 19:04:29 +09:00
|
|
|
it("gets simple structure tree", async function () {
|
|
|
|
const loadingTask = getDocument(
|
|
|
|
buildGetDocumentParams("structure_simple.pdf")
|
|
|
|
);
|
|
|
|
const pdfDoc = await loadingTask.promise;
|
|
|
|
const pdfPage = await pdfDoc.getPage(1);
|
|
|
|
const tree = await pdfPage.getStructTree();
|
|
|
|
|
|
|
|
expect(tree).toEqual({
|
|
|
|
role: "Root",
|
|
|
|
children: [
|
|
|
|
{
|
|
|
|
role: "Document",
|
|
|
|
children: [
|
|
|
|
{
|
|
|
|
role: "H1",
|
|
|
|
children: [
|
|
|
|
{
|
|
|
|
role: "NonStruct",
|
|
|
|
children: [{ type: "content", id: "page2R_mcid0" }],
|
|
|
|
},
|
|
|
|
],
|
|
|
|
},
|
|
|
|
{
|
|
|
|
role: "P",
|
|
|
|
children: [
|
|
|
|
{
|
|
|
|
role: "NonStruct",
|
|
|
|
children: [{ type: "content", id: "page2R_mcid1" }],
|
|
|
|
},
|
|
|
|
],
|
|
|
|
},
|
|
|
|
{
|
|
|
|
role: "H2",
|
|
|
|
children: [
|
|
|
|
{
|
|
|
|
role: "NonStruct",
|
|
|
|
children: [{ type: "content", id: "page2R_mcid2" }],
|
|
|
|
},
|
|
|
|
],
|
|
|
|
},
|
|
|
|
{
|
|
|
|
role: "P",
|
|
|
|
children: [
|
|
|
|
{
|
|
|
|
role: "NonStruct",
|
|
|
|
children: [{ type: "content", id: "page2R_mcid3" }],
|
|
|
|
},
|
|
|
|
],
|
|
|
|
},
|
|
|
|
],
|
|
|
|
},
|
|
|
|
],
|
|
|
|
});
|
|
|
|
|
|
|
|
await loadingTask.destroy();
|
|
|
|
});
|
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("gets operator list", async function () {
|
|
|
|
const operatorList = await page.getOperatorList();
|
[api-minor] Add `intent` support to the `PDFPageProxy.getOperatorList` method (issue 13704)
With this patch, the `PDFPageProxy.getOperatorList` method will now return `PDFOperatorList`-instances that also include Annotation-operatorLists (when those exist). Hence this closes a small, but potentially confusing, gap between the `render` and `getOperatorList` methods.
Previously we've been somewhat reluctant to do this, as explained below, but given that there's actual use-cases where it's required probably means that we'll *have* to implement it now.
Since we still need the ability to separate "normal" rendering operations from direct `getOperatorList` calls in the worker-thread, this API-change unfortunately causes the *internal* renderingIntent to become a bit "messy" which is indeed unfortunate (note the `"oplist-"` strings in various spots). As-is I suppose that it's not all that bad, but we may want to consider changing the *internal* renderingIntent to e.g. a bitfield in the future.
Besides fixing issue 13704, this patch would also be necessary if someone ever tries to implement e.g. issue 10165 (since currently `PDFPageProxy.getOperatorList` doesn't include Annotation-operatorLists).
*Please note:* This patch is *also* tagged "api-minor" for a second reason, which is that we're now including the Annotation-id in the `beginAnnotation` argument. The reason for this is to allow correlating the Annotation-data returned by `PDFPageProxy.getAnnotations`, with its corresponding operatorList-data (for those Annotations that have it).
2021-07-10 23:47:39 +09:00
|
|
|
|
|
|
|
expect(operatorList.fnArray.length).toBeGreaterThan(100);
|
|
|
|
expect(operatorList.argsArray.length).toBeGreaterThan(100);
|
2021-04-17 04:48:42 +09:00
|
|
|
expect(operatorList.lastChunk).toEqual(true);
|
2014-06-17 03:35:38 +09:00
|
|
|
});
|
2019-07-13 23:06:05 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("gets operatorList with JPEG image (issue 4888)", async function () {
|
2020-01-24 17:48:21 +09:00
|
|
|
const loadingTask = getDocument(buildGetDocumentParams("cmykjpeg.pdf"));
|
2018-02-11 21:13:11 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
const pdfDoc = await loadingTask.promise;
|
|
|
|
const pdfPage = await pdfDoc.getPage(1);
|
|
|
|
const operatorList = await pdfPage.getOperatorList();
|
2018-02-11 21:13:11 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
const imgIndex = operatorList.fnArray.indexOf(OPS.paintImageXObject);
|
|
|
|
const imgArgs = operatorList.argsArray[imgIndex];
|
|
|
|
const { data } = pdfPage.objs.get(imgArgs[0]);
|
2019-01-29 22:25:47 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
expect(data instanceof Uint8ClampedArray).toEqual(true);
|
|
|
|
expect(data.length).toEqual(90000);
|
|
|
|
|
|
|
|
await loadingTask.destroy();
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
});
|
|
|
|
|
|
|
|
it(
|
|
|
|
"gets operatorList, from corrupt PDF file (issue 8702), " +
|
|
|
|
"with/without `stopAtErrors` set",
|
2021-04-17 04:48:42 +09:00
|
|
|
async function () {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
const loadingTask1 = getDocument(
|
|
|
|
buildGetDocumentParams("issue8702.pdf", {
|
|
|
|
stopAtErrors: false, // The default value.
|
|
|
|
})
|
|
|
|
);
|
|
|
|
const loadingTask2 = getDocument(
|
|
|
|
buildGetDocumentParams("issue8702.pdf", {
|
|
|
|
stopAtErrors: true,
|
|
|
|
})
|
|
|
|
);
|
|
|
|
|
|
|
|
const result1 = loadingTask1.promise.then(pdfDoc => {
|
|
|
|
return pdfDoc.getPage(1).then(pdfPage => {
|
|
|
|
return pdfPage.getOperatorList().then(opList => {
|
2020-07-15 07:17:27 +09:00
|
|
|
expect(opList.fnArray.length).toBeGreaterThan(100);
|
|
|
|
expect(opList.argsArray.length).toBeGreaterThan(100);
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
expect(opList.lastChunk).toEqual(true);
|
|
|
|
|
|
|
|
return loadingTask1.destroy();
|
|
|
|
});
|
2019-07-13 23:06:05 +09:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
const result2 = loadingTask2.promise.then(pdfDoc => {
|
|
|
|
return pdfDoc.getPage(1).then(pdfPage => {
|
|
|
|
return pdfPage.getOperatorList().then(opList => {
|
|
|
|
expect(opList.fnArray.length).toEqual(0);
|
|
|
|
expect(opList.argsArray.length).toEqual(0);
|
|
|
|
expect(opList.lastChunk).toEqual(true);
|
2019-07-13 23:06:05 +09:00
|
|
|
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
return loadingTask2.destroy();
|
|
|
|
});
|
2019-07-13 23:06:05 +09:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
await Promise.all([result1, result2]);
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
}
|
|
|
|
);
|
2019-07-13 23:06:05 +09:00
|
|
|
|
[api-minor] Add `intent` support to the `PDFPageProxy.getOperatorList` method (issue 13704)
With this patch, the `PDFPageProxy.getOperatorList` method will now return `PDFOperatorList`-instances that also include Annotation-operatorLists (when those exist). Hence this closes a small, but potentially confusing, gap between the `render` and `getOperatorList` methods.
Previously we've been somewhat reluctant to do this, as explained below, but given that there's actual use-cases where it's required probably means that we'll *have* to implement it now.
Since we still need the ability to separate "normal" rendering operations from direct `getOperatorList` calls in the worker-thread, this API-change unfortunately causes the *internal* renderingIntent to become a bit "messy" which is indeed unfortunate (note the `"oplist-"` strings in various spots). As-is I suppose that it's not all that bad, but we may want to consider changing the *internal* renderingIntent to e.g. a bitfield in the future.
Besides fixing issue 13704, this patch would also be necessary if someone ever tries to implement e.g. issue 10165 (since currently `PDFPageProxy.getOperatorList` doesn't include Annotation-operatorLists).
*Please note:* This patch is *also* tagged "api-minor" for a second reason, which is that we're now including the Annotation-id in the `beginAnnotation` argument. The reason for this is to allow correlating the Annotation-data returned by `PDFPageProxy.getAnnotations`, with its corresponding operatorList-data (for those Annotations that have it).
2021-07-10 23:47:39 +09:00
|
|
|
it("gets operator list, containing Annotation-operatorLists", async function () {
|
|
|
|
const loadingTask = getDocument(
|
|
|
|
buildGetDocumentParams("annotation-line.pdf")
|
|
|
|
);
|
|
|
|
const pdfDoc = await loadingTask.promise;
|
|
|
|
const pdfPage = await pdfDoc.getPage(1);
|
|
|
|
const operatorList = await pdfPage.getOperatorList();
|
|
|
|
|
|
|
|
expect(operatorList.fnArray.length).toBeGreaterThan(20);
|
|
|
|
expect(operatorList.argsArray.length).toBeGreaterThan(20);
|
|
|
|
expect(operatorList.lastChunk).toEqual(true);
|
|
|
|
|
|
|
|
// The `getOperatorList` method, similar to the `render` method,
|
|
|
|
// is supposed to include any existing Annotation-operatorLists.
|
|
|
|
expect(operatorList.fnArray.includes(OPS.beginAnnotation)).toEqual(true);
|
|
|
|
expect(operatorList.fnArray.includes(OPS.endAnnotation)).toEqual(true);
|
|
|
|
|
|
|
|
await loadingTask.destroy();
|
|
|
|
});
|
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("gets document stats after parsing page", async function () {
|
|
|
|
const stats = await page.getOperatorList().then(function () {
|
2015-06-26 05:51:17 +09:00
|
|
|
return pdfDocument.getStats();
|
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
2020-10-25 23:40:51 +09:00
|
|
|
const expectedStreamTypes = {};
|
2015-06-26 05:51:17 +09:00
|
|
|
expectedStreamTypes[StreamType.FLATE] = true;
|
2020-10-25 23:40:51 +09:00
|
|
|
const expectedFontTypes = {};
|
2020-12-11 10:32:18 +09:00
|
|
|
expectedFontTypes[FontType.TYPE1STANDARD] = true;
|
2015-06-26 05:51:17 +09:00
|
|
|
expectedFontTypes[FontType.CIDFONTTYPE2] = true;
|
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
expect(stats).toEqual({
|
|
|
|
streamTypes: expectedStreamTypes,
|
|
|
|
fontTypes: expectedFontTypes,
|
|
|
|
});
|
2015-06-26 05:51:17 +09:00
|
|
|
});
|
2017-03-13 21:32:23 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("gets page stats after parsing page, without `pdfBug` set", async function () {
|
|
|
|
await page.getOperatorList();
|
|
|
|
expect(page.stats).toEqual(null);
|
2018-06-25 20:19:29 +09:00
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
it("gets page stats after parsing page, with `pdfBug` set", async function () {
|
2020-01-24 17:48:21 +09:00
|
|
|
const loadingTask = getDocument(
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
buildGetDocumentParams(basicApiFileName, { pdfBug: true })
|
|
|
|
);
|
2021-04-17 04:48:42 +09:00
|
|
|
const pdfDoc = await loadingTask.promise;
|
|
|
|
const pdfPage = await pdfDoc.getPage(1);
|
|
|
|
await pdfPage.getOperatorList();
|
|
|
|
const stats = pdfPage.stats;
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
expect(stats instanceof StatTimer).toEqual(true);
|
|
|
|
expect(stats.times.length).toEqual(1);
|
2018-06-25 20:19:29 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
const [statEntry] = stats.times;
|
|
|
|
expect(statEntry.name).toEqual("Page Request");
|
|
|
|
expect(statEntry.end - statEntry.start).toBeGreaterThanOrEqual(0);
|
2018-06-25 20:19:29 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
await loadingTask.destroy();
|
2018-06-25 20:19:29 +09:00
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
it("gets page stats after rendering page, with `pdfBug` set", async function () {
|
2020-01-24 17:48:21 +09:00
|
|
|
const loadingTask = getDocument(
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
buildGetDocumentParams(basicApiFileName, { pdfBug: true })
|
|
|
|
);
|
2021-04-17 04:48:42 +09:00
|
|
|
const pdfDoc = await loadingTask.promise;
|
|
|
|
const pdfPage = await pdfDoc.getPage(1);
|
|
|
|
const viewport = pdfPage.getViewport({ scale: 1 });
|
|
|
|
const canvasAndCtx = CanvasFactory.create(
|
|
|
|
viewport.width,
|
|
|
|
viewport.height
|
|
|
|
);
|
|
|
|
const renderTask = pdfPage.render({
|
|
|
|
canvasContext: canvasAndCtx.context,
|
|
|
|
canvasFactory: CanvasFactory,
|
|
|
|
viewport,
|
|
|
|
});
|
|
|
|
await renderTask.promise;
|
|
|
|
const stats = pdfPage.stats;
|
2018-06-25 20:19:29 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
expect(stats instanceof StatTimer).toEqual(true);
|
|
|
|
expect(stats.times.length).toEqual(3);
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
const [statEntryOne, statEntryTwo, statEntryThree] = stats.times;
|
|
|
|
expect(statEntryOne.name).toEqual("Page Request");
|
|
|
|
expect(statEntryOne.end - statEntryOne.start).toBeGreaterThanOrEqual(0);
|
2018-06-25 20:19:29 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
expect(statEntryTwo.name).toEqual("Rendering");
|
|
|
|
expect(statEntryTwo.end - statEntryTwo.start).toBeGreaterThan(0);
|
2018-06-25 20:19:29 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
expect(statEntryThree.name).toEqual("Overall");
|
|
|
|
expect(statEntryThree.end - statEntryThree.start).toBeGreaterThan(0);
|
2018-06-25 20:19:29 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
CanvasFactory.destroy(canvasAndCtx);
|
|
|
|
await loadingTask.destroy();
|
2018-06-25 20:19:29 +09:00
|
|
|
});
|
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("cancels rendering of page", async function () {
|
2020-10-25 23:40:51 +09:00
|
|
|
const viewport = page.getViewport({ scale: 1 });
|
|
|
|
const canvasAndCtx = CanvasFactory.create(
|
|
|
|
viewport.width,
|
|
|
|
viewport.height
|
|
|
|
);
|
2017-03-13 21:32:23 +09:00
|
|
|
|
2020-10-25 23:40:51 +09:00
|
|
|
const renderTask = page.render({
|
2017-03-13 21:56:59 +09:00
|
|
|
canvasContext: canvasAndCtx.context,
|
2019-02-11 03:29:38 +09:00
|
|
|
canvasFactory: CanvasFactory,
|
2017-04-28 20:40:47 +09:00
|
|
|
viewport,
|
2017-03-13 21:32:23 +09:00
|
|
|
});
|
|
|
|
renderTask.cancel();
|
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
try {
|
|
|
|
await renderTask.promise;
|
2020-03-19 23:36:09 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
// Shouldn't get here.
|
|
|
|
expect(false).toEqual(true);
|
|
|
|
} catch (reason) {
|
|
|
|
expect(reason instanceof RenderingCancelledException).toEqual(true);
|
|
|
|
expect(reason.message).toEqual("Rendering cancelled, page 1");
|
|
|
|
expect(reason.type).toEqual("canvas");
|
|
|
|
}
|
|
|
|
|
|
|
|
CanvasFactory.destroy(canvasAndCtx);
|
2017-03-13 21:32:23 +09:00
|
|
|
});
|
2018-06-29 05:38:09 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("re-render page, using the same canvas, after cancelling rendering", async function () {
|
2020-01-24 17:48:21 +09:00
|
|
|
const viewport = page.getViewport({ scale: 1 });
|
|
|
|
const canvasAndCtx = CanvasFactory.create(
|
|
|
|
viewport.width,
|
|
|
|
viewport.height
|
|
|
|
);
|
2018-06-29 05:38:09 +09:00
|
|
|
|
2020-01-24 17:48:21 +09:00
|
|
|
const renderTask = page.render({
|
2018-06-29 05:38:09 +09:00
|
|
|
canvasContext: canvasAndCtx.context,
|
2019-02-11 03:29:38 +09:00
|
|
|
canvasFactory: CanvasFactory,
|
2018-06-29 05:38:09 +09:00
|
|
|
viewport,
|
|
|
|
});
|
|
|
|
renderTask.cancel();
|
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
try {
|
|
|
|
await renderTask.promise;
|
|
|
|
|
|
|
|
// Shouldn't get here.
|
|
|
|
expect(false).toEqual(true);
|
|
|
|
} catch (reason) {
|
|
|
|
expect(reason instanceof RenderingCancelledException).toEqual(true);
|
|
|
|
}
|
|
|
|
|
|
|
|
const reRenderTask = page.render({
|
|
|
|
canvasContext: canvasAndCtx.context,
|
|
|
|
canvasFactory: CanvasFactory,
|
|
|
|
viewport,
|
|
|
|
});
|
|
|
|
await reRenderTask.promise;
|
|
|
|
|
|
|
|
CanvasFactory.destroy(canvasAndCtx);
|
2018-06-29 05:38:09 +09:00
|
|
|
});
|
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("multiple render() on the same canvas", async function () {
|
2021-05-16 17:58:34 +09:00
|
|
|
const optionalContentConfigPromise =
|
|
|
|
pdfDocument.getOptionalContentConfig();
|
2020-08-05 05:31:24 +09:00
|
|
|
|
2020-10-25 23:40:51 +09:00
|
|
|
const viewport = page.getViewport({ scale: 1 });
|
|
|
|
const canvasAndCtx = CanvasFactory.create(
|
|
|
|
viewport.width,
|
|
|
|
viewport.height
|
|
|
|
);
|
2017-06-13 06:04:35 +09:00
|
|
|
|
2020-10-25 23:40:51 +09:00
|
|
|
const renderTask1 = page.render({
|
2017-06-13 06:04:35 +09:00
|
|
|
canvasContext: canvasAndCtx.context,
|
2019-02-11 03:29:38 +09:00
|
|
|
canvasFactory: CanvasFactory,
|
2017-06-13 06:04:35 +09:00
|
|
|
viewport,
|
2020-08-05 05:31:24 +09:00
|
|
|
optionalContentConfigPromise,
|
2017-06-13 06:04:35 +09:00
|
|
|
});
|
2020-10-25 23:40:51 +09:00
|
|
|
const renderTask2 = page.render({
|
2017-06-13 06:04:35 +09:00
|
|
|
canvasContext: canvasAndCtx.context,
|
2019-02-11 03:29:38 +09:00
|
|
|
canvasFactory: CanvasFactory,
|
2017-06-13 06:04:35 +09:00
|
|
|
viewport,
|
2020-08-05 05:31:24 +09:00
|
|
|
optionalContentConfigPromise,
|
2017-06-13 06:04:35 +09:00
|
|
|
});
|
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
await Promise.all([
|
2017-06-13 06:04:35 +09:00
|
|
|
renderTask1.promise,
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
renderTask2.promise.then(
|
|
|
|
() => {
|
2021-04-17 04:48:42 +09:00
|
|
|
// Shouldn't get here.
|
|
|
|
expect(false).toEqual(true);
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
},
|
|
|
|
reason => {
|
2021-04-17 04:48:42 +09:00
|
|
|
// It fails because we are already using this canvas.
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
expect(/multiple render\(\)/.test(reason.message)).toEqual(true);
|
|
|
|
}
|
|
|
|
),
|
2021-04-17 04:48:42 +09:00
|
|
|
]);
|
2017-06-13 06:04:35 +09:00
|
|
|
});
|
[api-minor] Change `PDFDocumentProxy.cleanup`/`PDFPageProxy.cleanup` to return data
This patch makes the following changes, to improve these API methods:
- Let `PDFPageProxy.cleanup` return a boolean indicating if clean-up actually happened, since ongoing rendering will block clean-up.
Besides being used in other parts of this patch, it seems that an API user may also be interested in the return value given that clean-up isn't *guaranteed* to happen.
- Let `PDFDocumentProxy.cleanup` return the promise indicating when clean-up is finished.
- Improve the JSDoc comment for `PDFDocumentProxy.cleanup` to mention that clean-up is triggered on *both* threads (without going into unnecessary specifics regarding what *exactly* said data actually is).
Add a note in the JSDoc comment about not calling this method when rendering is ongoing.
- Change `WorkerTransport.startCleanup` to throw an `Error` if it's called when rendering is ongoing, to prevent rendering from breaking.
Please note that this won't stop *worker-thread* clean-up from happening (since there's no general "something is rendering"-flag), however I'm not sure if that's really a problem; but please don't quote me on that :-)
All of the caches that's being cleared in `Catalog.cleanup`, on the worker-thread, *should* be re-filled automatically even if cleared *during* parsing/rendering, and the only thing that probably happens is that e.g. font data would have to be re-parsed.
On the main-thread, on the other hand, clearing the caches is more-or-less guaranteed to cause rendering errors, since the rendering code in `src/display/canvas.js` isn't able to re-request any image/font data that's suddenly being pulled out from under it.
- Last, but not least, add a couple of basic unit-tests for the clean-up functionality.
2020-02-07 23:48:58 +09:00
|
|
|
|
2021-04-02 19:26:46 +09:00
|
|
|
it("cleans up document resources after rendering of page", async function () {
|
[api-minor] Change `PDFDocumentProxy.cleanup`/`PDFPageProxy.cleanup` to return data
This patch makes the following changes, to improve these API methods:
- Let `PDFPageProxy.cleanup` return a boolean indicating if clean-up actually happened, since ongoing rendering will block clean-up.
Besides being used in other parts of this patch, it seems that an API user may also be interested in the return value given that clean-up isn't *guaranteed* to happen.
- Let `PDFDocumentProxy.cleanup` return the promise indicating when clean-up is finished.
- Improve the JSDoc comment for `PDFDocumentProxy.cleanup` to mention that clean-up is triggered on *both* threads (without going into unnecessary specifics regarding what *exactly* said data actually is).
Add a note in the JSDoc comment about not calling this method when rendering is ongoing.
- Change `WorkerTransport.startCleanup` to throw an `Error` if it's called when rendering is ongoing, to prevent rendering from breaking.
Please note that this won't stop *worker-thread* clean-up from happening (since there's no general "something is rendering"-flag), however I'm not sure if that's really a problem; but please don't quote me on that :-)
All of the caches that's being cleared in `Catalog.cleanup`, on the worker-thread, *should* be re-filled automatically even if cleared *during* parsing/rendering, and the only thing that probably happens is that e.g. font data would have to be re-parsed.
On the main-thread, on the other hand, clearing the caches is more-or-less guaranteed to cause rendering errors, since the rendering code in `src/display/canvas.js` isn't able to re-request any image/font data that's suddenly being pulled out from under it.
- Last, but not least, add a couple of basic unit-tests for the clean-up functionality.
2020-02-07 23:48:58 +09:00
|
|
|
const loadingTask = getDocument(buildGetDocumentParams(basicApiFileName));
|
2021-04-02 19:26:46 +09:00
|
|
|
const pdfDoc = await loadingTask.promise;
|
|
|
|
const pdfPage = await pdfDoc.getPage(1);
|
[api-minor] Change `PDFDocumentProxy.cleanup`/`PDFPageProxy.cleanup` to return data
This patch makes the following changes, to improve these API methods:
- Let `PDFPageProxy.cleanup` return a boolean indicating if clean-up actually happened, since ongoing rendering will block clean-up.
Besides being used in other parts of this patch, it seems that an API user may also be interested in the return value given that clean-up isn't *guaranteed* to happen.
- Let `PDFDocumentProxy.cleanup` return the promise indicating when clean-up is finished.
- Improve the JSDoc comment for `PDFDocumentProxy.cleanup` to mention that clean-up is triggered on *both* threads (without going into unnecessary specifics regarding what *exactly* said data actually is).
Add a note in the JSDoc comment about not calling this method when rendering is ongoing.
- Change `WorkerTransport.startCleanup` to throw an `Error` if it's called when rendering is ongoing, to prevent rendering from breaking.
Please note that this won't stop *worker-thread* clean-up from happening (since there's no general "something is rendering"-flag), however I'm not sure if that's really a problem; but please don't quote me on that :-)
All of the caches that's being cleared in `Catalog.cleanup`, on the worker-thread, *should* be re-filled automatically even if cleared *during* parsing/rendering, and the only thing that probably happens is that e.g. font data would have to be re-parsed.
On the main-thread, on the other hand, clearing the caches is more-or-less guaranteed to cause rendering errors, since the rendering code in `src/display/canvas.js` isn't able to re-request any image/font data that's suddenly being pulled out from under it.
- Last, but not least, add a couple of basic unit-tests for the clean-up functionality.
2020-02-07 23:48:58 +09:00
|
|
|
|
2021-04-02 19:26:46 +09:00
|
|
|
const viewport = pdfPage.getViewport({ scale: 1 });
|
|
|
|
const canvasAndCtx = CanvasFactory.create(
|
|
|
|
viewport.width,
|
|
|
|
viewport.height
|
|
|
|
);
|
[api-minor] Change `PDFDocumentProxy.cleanup`/`PDFPageProxy.cleanup` to return data
This patch makes the following changes, to improve these API methods:
- Let `PDFPageProxy.cleanup` return a boolean indicating if clean-up actually happened, since ongoing rendering will block clean-up.
Besides being used in other parts of this patch, it seems that an API user may also be interested in the return value given that clean-up isn't *guaranteed* to happen.
- Let `PDFDocumentProxy.cleanup` return the promise indicating when clean-up is finished.
- Improve the JSDoc comment for `PDFDocumentProxy.cleanup` to mention that clean-up is triggered on *both* threads (without going into unnecessary specifics regarding what *exactly* said data actually is).
Add a note in the JSDoc comment about not calling this method when rendering is ongoing.
- Change `WorkerTransport.startCleanup` to throw an `Error` if it's called when rendering is ongoing, to prevent rendering from breaking.
Please note that this won't stop *worker-thread* clean-up from happening (since there's no general "something is rendering"-flag), however I'm not sure if that's really a problem; but please don't quote me on that :-)
All of the caches that's being cleared in `Catalog.cleanup`, on the worker-thread, *should* be re-filled automatically even if cleared *during* parsing/rendering, and the only thing that probably happens is that e.g. font data would have to be re-parsed.
On the main-thread, on the other hand, clearing the caches is more-or-less guaranteed to cause rendering errors, since the rendering code in `src/display/canvas.js` isn't able to re-request any image/font data that's suddenly being pulled out from under it.
- Last, but not least, add a couple of basic unit-tests for the clean-up functionality.
2020-02-07 23:48:58 +09:00
|
|
|
|
2021-04-02 19:26:46 +09:00
|
|
|
const renderTask = pdfPage.render({
|
|
|
|
canvasContext: canvasAndCtx.context,
|
|
|
|
canvasFactory: CanvasFactory,
|
|
|
|
viewport,
|
|
|
|
});
|
|
|
|
await renderTask.promise;
|
[api-minor] Change `PDFDocumentProxy.cleanup`/`PDFPageProxy.cleanup` to return data
This patch makes the following changes, to improve these API methods:
- Let `PDFPageProxy.cleanup` return a boolean indicating if clean-up actually happened, since ongoing rendering will block clean-up.
Besides being used in other parts of this patch, it seems that an API user may also be interested in the return value given that clean-up isn't *guaranteed* to happen.
- Let `PDFDocumentProxy.cleanup` return the promise indicating when clean-up is finished.
- Improve the JSDoc comment for `PDFDocumentProxy.cleanup` to mention that clean-up is triggered on *both* threads (without going into unnecessary specifics regarding what *exactly* said data actually is).
Add a note in the JSDoc comment about not calling this method when rendering is ongoing.
- Change `WorkerTransport.startCleanup` to throw an `Error` if it's called when rendering is ongoing, to prevent rendering from breaking.
Please note that this won't stop *worker-thread* clean-up from happening (since there's no general "something is rendering"-flag), however I'm not sure if that's really a problem; but please don't quote me on that :-)
All of the caches that's being cleared in `Catalog.cleanup`, on the worker-thread, *should* be re-filled automatically even if cleared *during* parsing/rendering, and the only thing that probably happens is that e.g. font data would have to be re-parsed.
On the main-thread, on the other hand, clearing the caches is more-or-less guaranteed to cause rendering errors, since the rendering code in `src/display/canvas.js` isn't able to re-request any image/font data that's suddenly being pulled out from under it.
- Last, but not least, add a couple of basic unit-tests for the clean-up functionality.
2020-02-07 23:48:58 +09:00
|
|
|
|
2021-04-02 19:26:46 +09:00
|
|
|
await pdfDoc.cleanup();
|
|
|
|
|
|
|
|
expect(true).toEqual(true);
|
|
|
|
|
|
|
|
CanvasFactory.destroy(canvasAndCtx);
|
|
|
|
await loadingTask.destroy();
|
[api-minor] Change `PDFDocumentProxy.cleanup`/`PDFPageProxy.cleanup` to return data
This patch makes the following changes, to improve these API methods:
- Let `PDFPageProxy.cleanup` return a boolean indicating if clean-up actually happened, since ongoing rendering will block clean-up.
Besides being used in other parts of this patch, it seems that an API user may also be interested in the return value given that clean-up isn't *guaranteed* to happen.
- Let `PDFDocumentProxy.cleanup` return the promise indicating when clean-up is finished.
- Improve the JSDoc comment for `PDFDocumentProxy.cleanup` to mention that clean-up is triggered on *both* threads (without going into unnecessary specifics regarding what *exactly* said data actually is).
Add a note in the JSDoc comment about not calling this method when rendering is ongoing.
- Change `WorkerTransport.startCleanup` to throw an `Error` if it's called when rendering is ongoing, to prevent rendering from breaking.
Please note that this won't stop *worker-thread* clean-up from happening (since there's no general "something is rendering"-flag), however I'm not sure if that's really a problem; but please don't quote me on that :-)
All of the caches that's being cleared in `Catalog.cleanup`, on the worker-thread, *should* be re-filled automatically even if cleared *during* parsing/rendering, and the only thing that probably happens is that e.g. font data would have to be re-parsed.
On the main-thread, on the other hand, clearing the caches is more-or-less guaranteed to cause rendering errors, since the rendering code in `src/display/canvas.js` isn't able to re-request any image/font data that's suddenly being pulled out from under it.
- Last, but not least, add a couple of basic unit-tests for the clean-up functionality.
2020-02-07 23:48:58 +09:00
|
|
|
});
|
|
|
|
|
2021-04-02 19:26:46 +09:00
|
|
|
it("cleans up document resources during rendering of page", async function () {
|
[api-minor] Change `PDFDocumentProxy.cleanup`/`PDFPageProxy.cleanup` to return data
This patch makes the following changes, to improve these API methods:
- Let `PDFPageProxy.cleanup` return a boolean indicating if clean-up actually happened, since ongoing rendering will block clean-up.
Besides being used in other parts of this patch, it seems that an API user may also be interested in the return value given that clean-up isn't *guaranteed* to happen.
- Let `PDFDocumentProxy.cleanup` return the promise indicating when clean-up is finished.
- Improve the JSDoc comment for `PDFDocumentProxy.cleanup` to mention that clean-up is triggered on *both* threads (without going into unnecessary specifics regarding what *exactly* said data actually is).
Add a note in the JSDoc comment about not calling this method when rendering is ongoing.
- Change `WorkerTransport.startCleanup` to throw an `Error` if it's called when rendering is ongoing, to prevent rendering from breaking.
Please note that this won't stop *worker-thread* clean-up from happening (since there's no general "something is rendering"-flag), however I'm not sure if that's really a problem; but please don't quote me on that :-)
All of the caches that's being cleared in `Catalog.cleanup`, on the worker-thread, *should* be re-filled automatically even if cleared *during* parsing/rendering, and the only thing that probably happens is that e.g. font data would have to be re-parsed.
On the main-thread, on the other hand, clearing the caches is more-or-less guaranteed to cause rendering errors, since the rendering code in `src/display/canvas.js` isn't able to re-request any image/font data that's suddenly being pulled out from under it.
- Last, but not least, add a couple of basic unit-tests for the clean-up functionality.
2020-02-07 23:48:58 +09:00
|
|
|
const loadingTask = getDocument(
|
|
|
|
buildGetDocumentParams("tracemonkey.pdf")
|
|
|
|
);
|
2021-04-02 19:26:46 +09:00
|
|
|
const pdfDoc = await loadingTask.promise;
|
|
|
|
const pdfPage = await pdfDoc.getPage(1);
|
[api-minor] Change `PDFDocumentProxy.cleanup`/`PDFPageProxy.cleanup` to return data
This patch makes the following changes, to improve these API methods:
- Let `PDFPageProxy.cleanup` return a boolean indicating if clean-up actually happened, since ongoing rendering will block clean-up.
Besides being used in other parts of this patch, it seems that an API user may also be interested in the return value given that clean-up isn't *guaranteed* to happen.
- Let `PDFDocumentProxy.cleanup` return the promise indicating when clean-up is finished.
- Improve the JSDoc comment for `PDFDocumentProxy.cleanup` to mention that clean-up is triggered on *both* threads (without going into unnecessary specifics regarding what *exactly* said data actually is).
Add a note in the JSDoc comment about not calling this method when rendering is ongoing.
- Change `WorkerTransport.startCleanup` to throw an `Error` if it's called when rendering is ongoing, to prevent rendering from breaking.
Please note that this won't stop *worker-thread* clean-up from happening (since there's no general "something is rendering"-flag), however I'm not sure if that's really a problem; but please don't quote me on that :-)
All of the caches that's being cleared in `Catalog.cleanup`, on the worker-thread, *should* be re-filled automatically even if cleared *during* parsing/rendering, and the only thing that probably happens is that e.g. font data would have to be re-parsed.
On the main-thread, on the other hand, clearing the caches is more-or-less guaranteed to cause rendering errors, since the rendering code in `src/display/canvas.js` isn't able to re-request any image/font data that's suddenly being pulled out from under it.
- Last, but not least, add a couple of basic unit-tests for the clean-up functionality.
2020-02-07 23:48:58 +09:00
|
|
|
|
2021-04-02 19:26:46 +09:00
|
|
|
const viewport = pdfPage.getViewport({ scale: 1 });
|
|
|
|
const canvasAndCtx = CanvasFactory.create(
|
|
|
|
viewport.width,
|
|
|
|
viewport.height
|
|
|
|
);
|
[api-minor] Change `PDFDocumentProxy.cleanup`/`PDFPageProxy.cleanup` to return data
This patch makes the following changes, to improve these API methods:
- Let `PDFPageProxy.cleanup` return a boolean indicating if clean-up actually happened, since ongoing rendering will block clean-up.
Besides being used in other parts of this patch, it seems that an API user may also be interested in the return value given that clean-up isn't *guaranteed* to happen.
- Let `PDFDocumentProxy.cleanup` return the promise indicating when clean-up is finished.
- Improve the JSDoc comment for `PDFDocumentProxy.cleanup` to mention that clean-up is triggered on *both* threads (without going into unnecessary specifics regarding what *exactly* said data actually is).
Add a note in the JSDoc comment about not calling this method when rendering is ongoing.
- Change `WorkerTransport.startCleanup` to throw an `Error` if it's called when rendering is ongoing, to prevent rendering from breaking.
Please note that this won't stop *worker-thread* clean-up from happening (since there's no general "something is rendering"-flag), however I'm not sure if that's really a problem; but please don't quote me on that :-)
All of the caches that's being cleared in `Catalog.cleanup`, on the worker-thread, *should* be re-filled automatically even if cleared *during* parsing/rendering, and the only thing that probably happens is that e.g. font data would have to be re-parsed.
On the main-thread, on the other hand, clearing the caches is more-or-less guaranteed to cause rendering errors, since the rendering code in `src/display/canvas.js` isn't able to re-request any image/font data that's suddenly being pulled out from under it.
- Last, but not least, add a couple of basic unit-tests for the clean-up functionality.
2020-02-07 23:48:58 +09:00
|
|
|
|
2021-04-02 19:26:46 +09:00
|
|
|
const renderTask = pdfPage.render({
|
|
|
|
canvasContext: canvasAndCtx.context,
|
|
|
|
canvasFactory: CanvasFactory,
|
|
|
|
viewport,
|
|
|
|
});
|
|
|
|
// Ensure that clean-up runs during rendering.
|
|
|
|
renderTask.onContinue = function (cont) {
|
|
|
|
waitSome(cont);
|
|
|
|
};
|
[api-minor] Change `PDFDocumentProxy.cleanup`/`PDFPageProxy.cleanup` to return data
This patch makes the following changes, to improve these API methods:
- Let `PDFPageProxy.cleanup` return a boolean indicating if clean-up actually happened, since ongoing rendering will block clean-up.
Besides being used in other parts of this patch, it seems that an API user may also be interested in the return value given that clean-up isn't *guaranteed* to happen.
- Let `PDFDocumentProxy.cleanup` return the promise indicating when clean-up is finished.
- Improve the JSDoc comment for `PDFDocumentProxy.cleanup` to mention that clean-up is triggered on *both* threads (without going into unnecessary specifics regarding what *exactly* said data actually is).
Add a note in the JSDoc comment about not calling this method when rendering is ongoing.
- Change `WorkerTransport.startCleanup` to throw an `Error` if it's called when rendering is ongoing, to prevent rendering from breaking.
Please note that this won't stop *worker-thread* clean-up from happening (since there's no general "something is rendering"-flag), however I'm not sure if that's really a problem; but please don't quote me on that :-)
All of the caches that's being cleared in `Catalog.cleanup`, on the worker-thread, *should* be re-filled automatically even if cleared *during* parsing/rendering, and the only thing that probably happens is that e.g. font data would have to be re-parsed.
On the main-thread, on the other hand, clearing the caches is more-or-less guaranteed to cause rendering errors, since the rendering code in `src/display/canvas.js` isn't able to re-request any image/font data that's suddenly being pulled out from under it.
- Last, but not least, add a couple of basic unit-tests for the clean-up functionality.
2020-02-07 23:48:58 +09:00
|
|
|
|
2021-04-02 19:26:46 +09:00
|
|
|
try {
|
|
|
|
await pdfDoc.cleanup();
|
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
// Shouldn't get here.
|
|
|
|
expect(false).toEqual(true);
|
2021-04-02 19:26:46 +09:00
|
|
|
} catch (reason) {
|
|
|
|
expect(reason instanceof Error).toEqual(true);
|
|
|
|
expect(reason.message).toEqual(
|
|
|
|
"startCleanup: Page 1 is currently rendering."
|
|
|
|
);
|
|
|
|
}
|
|
|
|
await renderTask.promise;
|
|
|
|
|
|
|
|
CanvasFactory.destroy(canvasAndCtx);
|
|
|
|
await loadingTask.destroy();
|
[api-minor] Change `PDFDocumentProxy.cleanup`/`PDFPageProxy.cleanup` to return data
This patch makes the following changes, to improve these API methods:
- Let `PDFPageProxy.cleanup` return a boolean indicating if clean-up actually happened, since ongoing rendering will block clean-up.
Besides being used in other parts of this patch, it seems that an API user may also be interested in the return value given that clean-up isn't *guaranteed* to happen.
- Let `PDFDocumentProxy.cleanup` return the promise indicating when clean-up is finished.
- Improve the JSDoc comment for `PDFDocumentProxy.cleanup` to mention that clean-up is triggered on *both* threads (without going into unnecessary specifics regarding what *exactly* said data actually is).
Add a note in the JSDoc comment about not calling this method when rendering is ongoing.
- Change `WorkerTransport.startCleanup` to throw an `Error` if it's called when rendering is ongoing, to prevent rendering from breaking.
Please note that this won't stop *worker-thread* clean-up from happening (since there's no general "something is rendering"-flag), however I'm not sure if that's really a problem; but please don't quote me on that :-)
All of the caches that's being cleared in `Catalog.cleanup`, on the worker-thread, *should* be re-filled automatically even if cleared *during* parsing/rendering, and the only thing that probably happens is that e.g. font data would have to be re-parsed.
On the main-thread, on the other hand, clearing the caches is more-or-less guaranteed to cause rendering errors, since the rendering code in `src/display/canvas.js` isn't able to re-request any image/font data that's suddenly being pulled out from under it.
- Last, but not least, add a couple of basic unit-tests for the clean-up functionality.
2020-02-07 23:48:58 +09:00
|
|
|
});
|
Attempt to cache repeated images at the document, rather than the page, level (issue 11878)
Currently image resources, as opposed to e.g. font resources, are handled exclusively on a page-specific basis. Generally speaking this makes sense, since pages are separate from each other, however there's PDF documents where many (or even all) pages actually references exactly the same image resources (through the XRef table). Hence, in some cases, we're decoding the *same* images over and over for every page which is obviously slow and wasting both CPU and memory resources better used elsewhere.[1]
Obviously we cannot simply treat all image resources as-if they're used throughout the entire PDF document, since that would end up increasing memory usage too much.[2]
However, by introducing a `GlobalImageCache` in the worker we can track image resources that appear on more than one page. Hence we can switch image resources from being page-specific to being document-specific, once the image resource has been seen on more than a certain number of pages.
In many cases, such as e.g. the referenced issue, this patch will thus lead to reduced memory usage for image resources. Scrolling through all pages of the document, there's now only a few main-thread copies of the same image data, as opposed to one for each rendered page (i.e. there could theoretically be *twenty* copies of the image data).
While this obviously benefit both CPU and memory usage in this case, for *very* large image data this patch *may* possibly increase persistent main-thread memory usage a tiny bit. Thus to avoid negatively affecting memory usage too much in general, particularly on the main-thread, the `GlobalImageCache` will *only* cache a certain number of image resources at the document level and simply fallback to the default behaviour.
Unfortunately the asynchronous nature of the code, with ranged/streamed loading of data, actually makes all of this much more complicated than if all data could be assumed to be immediately available.[3]
*Please note:* The patch will lead to *small* movement in some existing test-cases, since we're now using the built-in PDF.js JPEG decoder more. This was done in order to simplify the overall implementation, especially on the main-thread, by limiting it to only the `OPS.paintImageXObject` operator.
---
[1] There's e.g. PDF documents that use the same image as background on all pages.
[2] Given that data stored in the `commonObjs`, on the main-thread, are only cleared manually through `PDFDocumentProxy.cleanup`. This as opposed to data stored in the `objs` of each page, which is automatically removed when the page is cleaned-up e.g. by being evicted from the cache in the default viewer.
[3] If the latter case were true, we could simply check for repeat images *before* parsing started and thus avoid handling *any* duplicate image resources.
2020-05-18 21:17:56 +09:00
|
|
|
|
2021-03-21 19:33:39 +09:00
|
|
|
it("caches image resources at the document/page level as expected (issue 11878)", async function () {
|
Attempt to cache repeated images at the document, rather than the page, level (issue 11878)
Currently image resources, as opposed to e.g. font resources, are handled exclusively on a page-specific basis. Generally speaking this makes sense, since pages are separate from each other, however there's PDF documents where many (or even all) pages actually references exactly the same image resources (through the XRef table). Hence, in some cases, we're decoding the *same* images over and over for every page which is obviously slow and wasting both CPU and memory resources better used elsewhere.[1]
Obviously we cannot simply treat all image resources as-if they're used throughout the entire PDF document, since that would end up increasing memory usage too much.[2]
However, by introducing a `GlobalImageCache` in the worker we can track image resources that appear on more than one page. Hence we can switch image resources from being page-specific to being document-specific, once the image resource has been seen on more than a certain number of pages.
In many cases, such as e.g. the referenced issue, this patch will thus lead to reduced memory usage for image resources. Scrolling through all pages of the document, there's now only a few main-thread copies of the same image data, as opposed to one for each rendered page (i.e. there could theoretically be *twenty* copies of the image data).
While this obviously benefit both CPU and memory usage in this case, for *very* large image data this patch *may* possibly increase persistent main-thread memory usage a tiny bit. Thus to avoid negatively affecting memory usage too much in general, particularly on the main-thread, the `GlobalImageCache` will *only* cache a certain number of image resources at the document level and simply fallback to the default behaviour.
Unfortunately the asynchronous nature of the code, with ranged/streamed loading of data, actually makes all of this much more complicated than if all data could be assumed to be immediately available.[3]
*Please note:* The patch will lead to *small* movement in some existing test-cases, since we're now using the built-in PDF.js JPEG decoder more. This was done in order to simplify the overall implementation, especially on the main-thread, by limiting it to only the `OPS.paintImageXObject` operator.
---
[1] There's e.g. PDF documents that use the same image as background on all pages.
[2] Given that data stored in the `commonObjs`, on the main-thread, are only cleared manually through `PDFDocumentProxy.cleanup`. This as opposed to data stored in the `objs` of each page, which is automatically removed when the page is cleaned-up e.g. by being evicted from the cache in the default viewer.
[3] If the latter case were true, we could simply check for repeat images *before* parsing started and thus avoid handling *any* duplicate image resources.
2020-05-18 21:17:56 +09:00
|
|
|
const { NUM_PAGES_THRESHOLD } = GlobalImageCache,
|
|
|
|
EXPECTED_WIDTH = 2550,
|
|
|
|
EXPECTED_HEIGHT = 3300;
|
|
|
|
|
|
|
|
const loadingTask = getDocument(buildGetDocumentParams("issue11878.pdf"));
|
2021-03-21 19:33:39 +09:00
|
|
|
const pdfDoc = await loadingTask.promise;
|
Attempt to cache repeated images at the document, rather than the page, level (issue 11878)
Currently image resources, as opposed to e.g. font resources, are handled exclusively on a page-specific basis. Generally speaking this makes sense, since pages are separate from each other, however there's PDF documents where many (or even all) pages actually references exactly the same image resources (through the XRef table). Hence, in some cases, we're decoding the *same* images over and over for every page which is obviously slow and wasting both CPU and memory resources better used elsewhere.[1]
Obviously we cannot simply treat all image resources as-if they're used throughout the entire PDF document, since that would end up increasing memory usage too much.[2]
However, by introducing a `GlobalImageCache` in the worker we can track image resources that appear on more than one page. Hence we can switch image resources from being page-specific to being document-specific, once the image resource has been seen on more than a certain number of pages.
In many cases, such as e.g. the referenced issue, this patch will thus lead to reduced memory usage for image resources. Scrolling through all pages of the document, there's now only a few main-thread copies of the same image data, as opposed to one for each rendered page (i.e. there could theoretically be *twenty* copies of the image data).
While this obviously benefit both CPU and memory usage in this case, for *very* large image data this patch *may* possibly increase persistent main-thread memory usage a tiny bit. Thus to avoid negatively affecting memory usage too much in general, particularly on the main-thread, the `GlobalImageCache` will *only* cache a certain number of image resources at the document level and simply fallback to the default behaviour.
Unfortunately the asynchronous nature of the code, with ranged/streamed loading of data, actually makes all of this much more complicated than if all data could be assumed to be immediately available.[3]
*Please note:* The patch will lead to *small* movement in some existing test-cases, since we're now using the built-in PDF.js JPEG decoder more. This was done in order to simplify the overall implementation, especially on the main-thread, by limiting it to only the `OPS.paintImageXObject` operator.
---
[1] There's e.g. PDF documents that use the same image as background on all pages.
[2] Given that data stored in the `commonObjs`, on the main-thread, are only cleared manually through `PDFDocumentProxy.cleanup`. This as opposed to data stored in the `objs` of each page, which is automatically removed when the page is cleaned-up e.g. by being evicted from the cache in the default viewer.
[3] If the latter case were true, we could simply check for repeat images *before* parsing started and thus avoid handling *any* duplicate image resources.
2020-05-18 21:17:56 +09:00
|
|
|
let firstImgData = null;
|
|
|
|
|
2021-03-21 19:33:39 +09:00
|
|
|
for (let i = 1; i <= pdfDoc.numPages; i++) {
|
|
|
|
const pdfPage = await pdfDoc.getPage(i);
|
|
|
|
const opList = await pdfPage.getOperatorList();
|
Attempt to cache repeated images at the document, rather than the page, level (issue 11878)
Currently image resources, as opposed to e.g. font resources, are handled exclusively on a page-specific basis. Generally speaking this makes sense, since pages are separate from each other, however there's PDF documents where many (or even all) pages actually references exactly the same image resources (through the XRef table). Hence, in some cases, we're decoding the *same* images over and over for every page which is obviously slow and wasting both CPU and memory resources better used elsewhere.[1]
Obviously we cannot simply treat all image resources as-if they're used throughout the entire PDF document, since that would end up increasing memory usage too much.[2]
However, by introducing a `GlobalImageCache` in the worker we can track image resources that appear on more than one page. Hence we can switch image resources from being page-specific to being document-specific, once the image resource has been seen on more than a certain number of pages.
In many cases, such as e.g. the referenced issue, this patch will thus lead to reduced memory usage for image resources. Scrolling through all pages of the document, there's now only a few main-thread copies of the same image data, as opposed to one for each rendered page (i.e. there could theoretically be *twenty* copies of the image data).
While this obviously benefit both CPU and memory usage in this case, for *very* large image data this patch *may* possibly increase persistent main-thread memory usage a tiny bit. Thus to avoid negatively affecting memory usage too much in general, particularly on the main-thread, the `GlobalImageCache` will *only* cache a certain number of image resources at the document level and simply fallback to the default behaviour.
Unfortunately the asynchronous nature of the code, with ranged/streamed loading of data, actually makes all of this much more complicated than if all data could be assumed to be immediately available.[3]
*Please note:* The patch will lead to *small* movement in some existing test-cases, since we're now using the built-in PDF.js JPEG decoder more. This was done in order to simplify the overall implementation, especially on the main-thread, by limiting it to only the `OPS.paintImageXObject` operator.
---
[1] There's e.g. PDF documents that use the same image as background on all pages.
[2] Given that data stored in the `commonObjs`, on the main-thread, are only cleared manually through `PDFDocumentProxy.cleanup`. This as opposed to data stored in the `objs` of each page, which is automatically removed when the page is cleaned-up e.g. by being evicted from the cache in the default viewer.
[3] If the latter case were true, we could simply check for repeat images *before* parsing started and thus avoid handling *any* duplicate image resources.
2020-05-18 21:17:56 +09:00
|
|
|
|
2021-03-21 19:33:39 +09:00
|
|
|
const { commonObjs, objs } = pdfPage;
|
|
|
|
const imgIndex = opList.fnArray.indexOf(OPS.paintImageXObject);
|
|
|
|
const [objId, width, height] = opList.argsArray[imgIndex];
|
Attempt to cache repeated images at the document, rather than the page, level (issue 11878)
Currently image resources, as opposed to e.g. font resources, are handled exclusively on a page-specific basis. Generally speaking this makes sense, since pages are separate from each other, however there's PDF documents where many (or even all) pages actually references exactly the same image resources (through the XRef table). Hence, in some cases, we're decoding the *same* images over and over for every page which is obviously slow and wasting both CPU and memory resources better used elsewhere.[1]
Obviously we cannot simply treat all image resources as-if they're used throughout the entire PDF document, since that would end up increasing memory usage too much.[2]
However, by introducing a `GlobalImageCache` in the worker we can track image resources that appear on more than one page. Hence we can switch image resources from being page-specific to being document-specific, once the image resource has been seen on more than a certain number of pages.
In many cases, such as e.g. the referenced issue, this patch will thus lead to reduced memory usage for image resources. Scrolling through all pages of the document, there's now only a few main-thread copies of the same image data, as opposed to one for each rendered page (i.e. there could theoretically be *twenty* copies of the image data).
While this obviously benefit both CPU and memory usage in this case, for *very* large image data this patch *may* possibly increase persistent main-thread memory usage a tiny bit. Thus to avoid negatively affecting memory usage too much in general, particularly on the main-thread, the `GlobalImageCache` will *only* cache a certain number of image resources at the document level and simply fallback to the default behaviour.
Unfortunately the asynchronous nature of the code, with ranged/streamed loading of data, actually makes all of this much more complicated than if all data could be assumed to be immediately available.[3]
*Please note:* The patch will lead to *small* movement in some existing test-cases, since we're now using the built-in PDF.js JPEG decoder more. This was done in order to simplify the overall implementation, especially on the main-thread, by limiting it to only the `OPS.paintImageXObject` operator.
---
[1] There's e.g. PDF documents that use the same image as background on all pages.
[2] Given that data stored in the `commonObjs`, on the main-thread, are only cleared manually through `PDFDocumentProxy.cleanup`. This as opposed to data stored in the `objs` of each page, which is automatically removed when the page is cleaned-up e.g. by being evicted from the cache in the default viewer.
[3] If the latter case were true, we could simply check for repeat images *before* parsing started and thus avoid handling *any* duplicate image resources.
2020-05-18 21:17:56 +09:00
|
|
|
|
2021-03-21 19:33:39 +09:00
|
|
|
if (i < NUM_PAGES_THRESHOLD) {
|
|
|
|
expect(objId).toEqual(`img_p${i - 1}_1`);
|
Attempt to cache repeated images at the document, rather than the page, level (issue 11878)
Currently image resources, as opposed to e.g. font resources, are handled exclusively on a page-specific basis. Generally speaking this makes sense, since pages are separate from each other, however there's PDF documents where many (or even all) pages actually references exactly the same image resources (through the XRef table). Hence, in some cases, we're decoding the *same* images over and over for every page which is obviously slow and wasting both CPU and memory resources better used elsewhere.[1]
Obviously we cannot simply treat all image resources as-if they're used throughout the entire PDF document, since that would end up increasing memory usage too much.[2]
However, by introducing a `GlobalImageCache` in the worker we can track image resources that appear on more than one page. Hence we can switch image resources from being page-specific to being document-specific, once the image resource has been seen on more than a certain number of pages.
In many cases, such as e.g. the referenced issue, this patch will thus lead to reduced memory usage for image resources. Scrolling through all pages of the document, there's now only a few main-thread copies of the same image data, as opposed to one for each rendered page (i.e. there could theoretically be *twenty* copies of the image data).
While this obviously benefit both CPU and memory usage in this case, for *very* large image data this patch *may* possibly increase persistent main-thread memory usage a tiny bit. Thus to avoid negatively affecting memory usage too much in general, particularly on the main-thread, the `GlobalImageCache` will *only* cache a certain number of image resources at the document level and simply fallback to the default behaviour.
Unfortunately the asynchronous nature of the code, with ranged/streamed loading of data, actually makes all of this much more complicated than if all data could be assumed to be immediately available.[3]
*Please note:* The patch will lead to *small* movement in some existing test-cases, since we're now using the built-in PDF.js JPEG decoder more. This was done in order to simplify the overall implementation, especially on the main-thread, by limiting it to only the `OPS.paintImageXObject` operator.
---
[1] There's e.g. PDF documents that use the same image as background on all pages.
[2] Given that data stored in the `commonObjs`, on the main-thread, are only cleared manually through `PDFDocumentProxy.cleanup`. This as opposed to data stored in the `objs` of each page, which is automatically removed when the page is cleaned-up e.g. by being evicted from the cache in the default viewer.
[3] If the latter case were true, we could simply check for repeat images *before* parsing started and thus avoid handling *any* duplicate image resources.
2020-05-18 21:17:56 +09:00
|
|
|
|
2021-03-21 19:33:39 +09:00
|
|
|
expect(objs.has(objId)).toEqual(true);
|
|
|
|
expect(commonObjs.has(objId)).toEqual(false);
|
|
|
|
} else {
|
|
|
|
expect(objId).toEqual(
|
|
|
|
`g_${loadingTask.docId}_img_p${NUM_PAGES_THRESHOLD - 1}_1`
|
|
|
|
);
|
Attempt to cache repeated images at the document, rather than the page, level (issue 11878)
Currently image resources, as opposed to e.g. font resources, are handled exclusively on a page-specific basis. Generally speaking this makes sense, since pages are separate from each other, however there's PDF documents where many (or even all) pages actually references exactly the same image resources (through the XRef table). Hence, in some cases, we're decoding the *same* images over and over for every page which is obviously slow and wasting both CPU and memory resources better used elsewhere.[1]
Obviously we cannot simply treat all image resources as-if they're used throughout the entire PDF document, since that would end up increasing memory usage too much.[2]
However, by introducing a `GlobalImageCache` in the worker we can track image resources that appear on more than one page. Hence we can switch image resources from being page-specific to being document-specific, once the image resource has been seen on more than a certain number of pages.
In many cases, such as e.g. the referenced issue, this patch will thus lead to reduced memory usage for image resources. Scrolling through all pages of the document, there's now only a few main-thread copies of the same image data, as opposed to one for each rendered page (i.e. there could theoretically be *twenty* copies of the image data).
While this obviously benefit both CPU and memory usage in this case, for *very* large image data this patch *may* possibly increase persistent main-thread memory usage a tiny bit. Thus to avoid negatively affecting memory usage too much in general, particularly on the main-thread, the `GlobalImageCache` will *only* cache a certain number of image resources at the document level and simply fallback to the default behaviour.
Unfortunately the asynchronous nature of the code, with ranged/streamed loading of data, actually makes all of this much more complicated than if all data could be assumed to be immediately available.[3]
*Please note:* The patch will lead to *small* movement in some existing test-cases, since we're now using the built-in PDF.js JPEG decoder more. This was done in order to simplify the overall implementation, especially on the main-thread, by limiting it to only the `OPS.paintImageXObject` operator.
---
[1] There's e.g. PDF documents that use the same image as background on all pages.
[2] Given that data stored in the `commonObjs`, on the main-thread, are only cleared manually through `PDFDocumentProxy.cleanup`. This as opposed to data stored in the `objs` of each page, which is automatically removed when the page is cleaned-up e.g. by being evicted from the cache in the default viewer.
[3] If the latter case were true, we could simply check for repeat images *before* parsing started and thus avoid handling *any* duplicate image resources.
2020-05-18 21:17:56 +09:00
|
|
|
|
2021-03-21 19:33:39 +09:00
|
|
|
expect(objs.has(objId)).toEqual(false);
|
|
|
|
expect(commonObjs.has(objId)).toEqual(true);
|
|
|
|
}
|
|
|
|
expect(width).toEqual(EXPECTED_WIDTH);
|
|
|
|
expect(height).toEqual(EXPECTED_HEIGHT);
|
Attempt to cache repeated images at the document, rather than the page, level (issue 11878)
Currently image resources, as opposed to e.g. font resources, are handled exclusively on a page-specific basis. Generally speaking this makes sense, since pages are separate from each other, however there's PDF documents where many (or even all) pages actually references exactly the same image resources (through the XRef table). Hence, in some cases, we're decoding the *same* images over and over for every page which is obviously slow and wasting both CPU and memory resources better used elsewhere.[1]
Obviously we cannot simply treat all image resources as-if they're used throughout the entire PDF document, since that would end up increasing memory usage too much.[2]
However, by introducing a `GlobalImageCache` in the worker we can track image resources that appear on more than one page. Hence we can switch image resources from being page-specific to being document-specific, once the image resource has been seen on more than a certain number of pages.
In many cases, such as e.g. the referenced issue, this patch will thus lead to reduced memory usage for image resources. Scrolling through all pages of the document, there's now only a few main-thread copies of the same image data, as opposed to one for each rendered page (i.e. there could theoretically be *twenty* copies of the image data).
While this obviously benefit both CPU and memory usage in this case, for *very* large image data this patch *may* possibly increase persistent main-thread memory usage a tiny bit. Thus to avoid negatively affecting memory usage too much in general, particularly on the main-thread, the `GlobalImageCache` will *only* cache a certain number of image resources at the document level and simply fallback to the default behaviour.
Unfortunately the asynchronous nature of the code, with ranged/streamed loading of data, actually makes all of this much more complicated than if all data could be assumed to be immediately available.[3]
*Please note:* The patch will lead to *small* movement in some existing test-cases, since we're now using the built-in PDF.js JPEG decoder more. This was done in order to simplify the overall implementation, especially on the main-thread, by limiting it to only the `OPS.paintImageXObject` operator.
---
[1] There's e.g. PDF documents that use the same image as background on all pages.
[2] Given that data stored in the `commonObjs`, on the main-thread, are only cleared manually through `PDFDocumentProxy.cleanup`. This as opposed to data stored in the `objs` of each page, which is automatically removed when the page is cleaned-up e.g. by being evicted from the cache in the default viewer.
[3] If the latter case were true, we could simply check for repeat images *before* parsing started and thus avoid handling *any* duplicate image resources.
2020-05-18 21:17:56 +09:00
|
|
|
|
2021-03-21 19:33:39 +09:00
|
|
|
// Ensure that the actual image data is identical for all pages.
|
|
|
|
if (i === 1) {
|
|
|
|
firstImgData = objs.get(objId);
|
Attempt to cache repeated images at the document, rather than the page, level (issue 11878)
Currently image resources, as opposed to e.g. font resources, are handled exclusively on a page-specific basis. Generally speaking this makes sense, since pages are separate from each other, however there's PDF documents where many (or even all) pages actually references exactly the same image resources (through the XRef table). Hence, in some cases, we're decoding the *same* images over and over for every page which is obviously slow and wasting both CPU and memory resources better used elsewhere.[1]
Obviously we cannot simply treat all image resources as-if they're used throughout the entire PDF document, since that would end up increasing memory usage too much.[2]
However, by introducing a `GlobalImageCache` in the worker we can track image resources that appear on more than one page. Hence we can switch image resources from being page-specific to being document-specific, once the image resource has been seen on more than a certain number of pages.
In many cases, such as e.g. the referenced issue, this patch will thus lead to reduced memory usage for image resources. Scrolling through all pages of the document, there's now only a few main-thread copies of the same image data, as opposed to one for each rendered page (i.e. there could theoretically be *twenty* copies of the image data).
While this obviously benefit both CPU and memory usage in this case, for *very* large image data this patch *may* possibly increase persistent main-thread memory usage a tiny bit. Thus to avoid negatively affecting memory usage too much in general, particularly on the main-thread, the `GlobalImageCache` will *only* cache a certain number of image resources at the document level and simply fallback to the default behaviour.
Unfortunately the asynchronous nature of the code, with ranged/streamed loading of data, actually makes all of this much more complicated than if all data could be assumed to be immediately available.[3]
*Please note:* The patch will lead to *small* movement in some existing test-cases, since we're now using the built-in PDF.js JPEG decoder more. This was done in order to simplify the overall implementation, especially on the main-thread, by limiting it to only the `OPS.paintImageXObject` operator.
---
[1] There's e.g. PDF documents that use the same image as background on all pages.
[2] Given that data stored in the `commonObjs`, on the main-thread, are only cleared manually through `PDFDocumentProxy.cleanup`. This as opposed to data stored in the `objs` of each page, which is automatically removed when the page is cleaned-up e.g. by being evicted from the cache in the default viewer.
[3] If the latter case were true, we could simply check for repeat images *before* parsing started and thus avoid handling *any* duplicate image resources.
2020-05-18 21:17:56 +09:00
|
|
|
|
2021-03-21 19:33:39 +09:00
|
|
|
expect(firstImgData.width).toEqual(EXPECTED_WIDTH);
|
|
|
|
expect(firstImgData.height).toEqual(EXPECTED_HEIGHT);
|
Attempt to cache repeated images at the document, rather than the page, level (issue 11878)
Currently image resources, as opposed to e.g. font resources, are handled exclusively on a page-specific basis. Generally speaking this makes sense, since pages are separate from each other, however there's PDF documents where many (or even all) pages actually references exactly the same image resources (through the XRef table). Hence, in some cases, we're decoding the *same* images over and over for every page which is obviously slow and wasting both CPU and memory resources better used elsewhere.[1]
Obviously we cannot simply treat all image resources as-if they're used throughout the entire PDF document, since that would end up increasing memory usage too much.[2]
However, by introducing a `GlobalImageCache` in the worker we can track image resources that appear on more than one page. Hence we can switch image resources from being page-specific to being document-specific, once the image resource has been seen on more than a certain number of pages.
In many cases, such as e.g. the referenced issue, this patch will thus lead to reduced memory usage for image resources. Scrolling through all pages of the document, there's now only a few main-thread copies of the same image data, as opposed to one for each rendered page (i.e. there could theoretically be *twenty* copies of the image data).
While this obviously benefit both CPU and memory usage in this case, for *very* large image data this patch *may* possibly increase persistent main-thread memory usage a tiny bit. Thus to avoid negatively affecting memory usage too much in general, particularly on the main-thread, the `GlobalImageCache` will *only* cache a certain number of image resources at the document level and simply fallback to the default behaviour.
Unfortunately the asynchronous nature of the code, with ranged/streamed loading of data, actually makes all of this much more complicated than if all data could be assumed to be immediately available.[3]
*Please note:* The patch will lead to *small* movement in some existing test-cases, since we're now using the built-in PDF.js JPEG decoder more. This was done in order to simplify the overall implementation, especially on the main-thread, by limiting it to only the `OPS.paintImageXObject` operator.
---
[1] There's e.g. PDF documents that use the same image as background on all pages.
[2] Given that data stored in the `commonObjs`, on the main-thread, are only cleared manually through `PDFDocumentProxy.cleanup`. This as opposed to data stored in the `objs` of each page, which is automatically removed when the page is cleaned-up e.g. by being evicted from the cache in the default viewer.
[3] If the latter case were true, we could simply check for repeat images *before* parsing started and thus avoid handling *any* duplicate image resources.
2020-05-18 21:17:56 +09:00
|
|
|
|
2021-03-21 19:33:39 +09:00
|
|
|
expect(firstImgData.kind).toEqual(ImageKind.RGB_24BPP);
|
|
|
|
expect(firstImgData.data instanceof Uint8ClampedArray).toEqual(true);
|
|
|
|
expect(firstImgData.data.length).toEqual(25245000);
|
|
|
|
} else {
|
|
|
|
const objsPool = i >= NUM_PAGES_THRESHOLD ? commonObjs : objs;
|
|
|
|
const currentImgData = objsPool.get(objId);
|
Attempt to cache repeated images at the document, rather than the page, level (issue 11878)
Currently image resources, as opposed to e.g. font resources, are handled exclusively on a page-specific basis. Generally speaking this makes sense, since pages are separate from each other, however there's PDF documents where many (or even all) pages actually references exactly the same image resources (through the XRef table). Hence, in some cases, we're decoding the *same* images over and over for every page which is obviously slow and wasting both CPU and memory resources better used elsewhere.[1]
Obviously we cannot simply treat all image resources as-if they're used throughout the entire PDF document, since that would end up increasing memory usage too much.[2]
However, by introducing a `GlobalImageCache` in the worker we can track image resources that appear on more than one page. Hence we can switch image resources from being page-specific to being document-specific, once the image resource has been seen on more than a certain number of pages.
In many cases, such as e.g. the referenced issue, this patch will thus lead to reduced memory usage for image resources. Scrolling through all pages of the document, there's now only a few main-thread copies of the same image data, as opposed to one for each rendered page (i.e. there could theoretically be *twenty* copies of the image data).
While this obviously benefit both CPU and memory usage in this case, for *very* large image data this patch *may* possibly increase persistent main-thread memory usage a tiny bit. Thus to avoid negatively affecting memory usage too much in general, particularly on the main-thread, the `GlobalImageCache` will *only* cache a certain number of image resources at the document level and simply fallback to the default behaviour.
Unfortunately the asynchronous nature of the code, with ranged/streamed loading of data, actually makes all of this much more complicated than if all data could be assumed to be immediately available.[3]
*Please note:* The patch will lead to *small* movement in some existing test-cases, since we're now using the built-in PDF.js JPEG decoder more. This was done in order to simplify the overall implementation, especially on the main-thread, by limiting it to only the `OPS.paintImageXObject` operator.
---
[1] There's e.g. PDF documents that use the same image as background on all pages.
[2] Given that data stored in the `commonObjs`, on the main-thread, are only cleared manually through `PDFDocumentProxy.cleanup`. This as opposed to data stored in the `objs` of each page, which is automatically removed when the page is cleaned-up e.g. by being evicted from the cache in the default viewer.
[3] If the latter case were true, we could simply check for repeat images *before* parsing started and thus avoid handling *any* duplicate image resources.
2020-05-18 21:17:56 +09:00
|
|
|
|
2021-03-21 19:33:39 +09:00
|
|
|
expect(currentImgData.width).toEqual(firstImgData.width);
|
|
|
|
expect(currentImgData.height).toEqual(firstImgData.height);
|
Attempt to cache repeated images at the document, rather than the page, level (issue 11878)
Currently image resources, as opposed to e.g. font resources, are handled exclusively on a page-specific basis. Generally speaking this makes sense, since pages are separate from each other, however there's PDF documents where many (or even all) pages actually references exactly the same image resources (through the XRef table). Hence, in some cases, we're decoding the *same* images over and over for every page which is obviously slow and wasting both CPU and memory resources better used elsewhere.[1]
Obviously we cannot simply treat all image resources as-if they're used throughout the entire PDF document, since that would end up increasing memory usage too much.[2]
However, by introducing a `GlobalImageCache` in the worker we can track image resources that appear on more than one page. Hence we can switch image resources from being page-specific to being document-specific, once the image resource has been seen on more than a certain number of pages.
In many cases, such as e.g. the referenced issue, this patch will thus lead to reduced memory usage for image resources. Scrolling through all pages of the document, there's now only a few main-thread copies of the same image data, as opposed to one for each rendered page (i.e. there could theoretically be *twenty* copies of the image data).
While this obviously benefit both CPU and memory usage in this case, for *very* large image data this patch *may* possibly increase persistent main-thread memory usage a tiny bit. Thus to avoid negatively affecting memory usage too much in general, particularly on the main-thread, the `GlobalImageCache` will *only* cache a certain number of image resources at the document level and simply fallback to the default behaviour.
Unfortunately the asynchronous nature of the code, with ranged/streamed loading of data, actually makes all of this much more complicated than if all data could be assumed to be immediately available.[3]
*Please note:* The patch will lead to *small* movement in some existing test-cases, since we're now using the built-in PDF.js JPEG decoder more. This was done in order to simplify the overall implementation, especially on the main-thread, by limiting it to only the `OPS.paintImageXObject` operator.
---
[1] There's e.g. PDF documents that use the same image as background on all pages.
[2] Given that data stored in the `commonObjs`, on the main-thread, are only cleared manually through `PDFDocumentProxy.cleanup`. This as opposed to data stored in the `objs` of each page, which is automatically removed when the page is cleaned-up e.g. by being evicted from the cache in the default viewer.
[3] If the latter case were true, we could simply check for repeat images *before* parsing started and thus avoid handling *any* duplicate image resources.
2020-05-18 21:17:56 +09:00
|
|
|
|
2021-03-21 19:33:39 +09:00
|
|
|
expect(currentImgData.kind).toEqual(firstImgData.kind);
|
|
|
|
expect(currentImgData.data instanceof Uint8ClampedArray).toEqual(
|
|
|
|
true
|
|
|
|
);
|
|
|
|
expect(
|
|
|
|
currentImgData.data.every((value, index) => {
|
|
|
|
return value === firstImgData.data[index];
|
|
|
|
})
|
|
|
|
).toEqual(true);
|
Attempt to cache repeated images at the document, rather than the page, level (issue 11878)
Currently image resources, as opposed to e.g. font resources, are handled exclusively on a page-specific basis. Generally speaking this makes sense, since pages are separate from each other, however there's PDF documents where many (or even all) pages actually references exactly the same image resources (through the XRef table). Hence, in some cases, we're decoding the *same* images over and over for every page which is obviously slow and wasting both CPU and memory resources better used elsewhere.[1]
Obviously we cannot simply treat all image resources as-if they're used throughout the entire PDF document, since that would end up increasing memory usage too much.[2]
However, by introducing a `GlobalImageCache` in the worker we can track image resources that appear on more than one page. Hence we can switch image resources from being page-specific to being document-specific, once the image resource has been seen on more than a certain number of pages.
In many cases, such as e.g. the referenced issue, this patch will thus lead to reduced memory usage for image resources. Scrolling through all pages of the document, there's now only a few main-thread copies of the same image data, as opposed to one for each rendered page (i.e. there could theoretically be *twenty* copies of the image data).
While this obviously benefit both CPU and memory usage in this case, for *very* large image data this patch *may* possibly increase persistent main-thread memory usage a tiny bit. Thus to avoid negatively affecting memory usage too much in general, particularly on the main-thread, the `GlobalImageCache` will *only* cache a certain number of image resources at the document level and simply fallback to the default behaviour.
Unfortunately the asynchronous nature of the code, with ranged/streamed loading of data, actually makes all of this much more complicated than if all data could be assumed to be immediately available.[3]
*Please note:* The patch will lead to *small* movement in some existing test-cases, since we're now using the built-in PDF.js JPEG decoder more. This was done in order to simplify the overall implementation, especially on the main-thread, by limiting it to only the `OPS.paintImageXObject` operator.
---
[1] There's e.g. PDF documents that use the same image as background on all pages.
[2] Given that data stored in the `commonObjs`, on the main-thread, are only cleared manually through `PDFDocumentProxy.cleanup`. This as opposed to data stored in the `objs` of each page, which is automatically removed when the page is cleaned-up e.g. by being evicted from the cache in the default viewer.
[3] If the latter case were true, we could simply check for repeat images *before* parsing started and thus avoid handling *any* duplicate image resources.
2020-05-18 21:17:56 +09:00
|
|
|
}
|
|
|
|
}
|
2021-03-21 19:33:39 +09:00
|
|
|
|
|
|
|
await loadingTask.destroy();
|
|
|
|
firstImgData = null;
|
Attempt to cache repeated images at the document, rather than the page, level (issue 11878)
Currently image resources, as opposed to e.g. font resources, are handled exclusively on a page-specific basis. Generally speaking this makes sense, since pages are separate from each other, however there's PDF documents where many (or even all) pages actually references exactly the same image resources (through the XRef table). Hence, in some cases, we're decoding the *same* images over and over for every page which is obviously slow and wasting both CPU and memory resources better used elsewhere.[1]
Obviously we cannot simply treat all image resources as-if they're used throughout the entire PDF document, since that would end up increasing memory usage too much.[2]
However, by introducing a `GlobalImageCache` in the worker we can track image resources that appear on more than one page. Hence we can switch image resources from being page-specific to being document-specific, once the image resource has been seen on more than a certain number of pages.
In many cases, such as e.g. the referenced issue, this patch will thus lead to reduced memory usage for image resources. Scrolling through all pages of the document, there's now only a few main-thread copies of the same image data, as opposed to one for each rendered page (i.e. there could theoretically be *twenty* copies of the image data).
While this obviously benefit both CPU and memory usage in this case, for *very* large image data this patch *may* possibly increase persistent main-thread memory usage a tiny bit. Thus to avoid negatively affecting memory usage too much in general, particularly on the main-thread, the `GlobalImageCache` will *only* cache a certain number of image resources at the document level and simply fallback to the default behaviour.
Unfortunately the asynchronous nature of the code, with ranged/streamed loading of data, actually makes all of this much more complicated than if all data could be assumed to be immediately available.[3]
*Please note:* The patch will lead to *small* movement in some existing test-cases, since we're now using the built-in PDF.js JPEG decoder more. This was done in order to simplify the overall implementation, especially on the main-thread, by limiting it to only the `OPS.paintImageXObject` operator.
---
[1] There's e.g. PDF documents that use the same image as background on all pages.
[2] Given that data stored in the `commonObjs`, on the main-thread, are only cleared manually through `PDFDocumentProxy.cleanup`. This as opposed to data stored in the `objs` of each page, which is automatically removed when the page is cleaned-up e.g. by being evicted from the cache in the default viewer.
[3] If the latter case were true, we could simply check for repeat images *before* parsing started and thus avoid handling *any* duplicate image resources.
2020-05-18 21:17:56 +09:00
|
|
|
});
|
2012-04-13 09:59:30 +09:00
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
2020-04-14 19:28:14 +09:00
|
|
|
describe("Multiple `getDocument` instances", function () {
|
2015-07-14 18:43:20 +09:00
|
|
|
// Regression test for https://github.com/mozilla/pdf.js/issues/6205
|
|
|
|
// A PDF using the Helvetica font.
|
2020-10-25 23:40:51 +09:00
|
|
|
const pdf1 = buildGetDocumentParams("tracemonkey.pdf");
|
2015-07-14 18:43:20 +09:00
|
|
|
// A PDF using the Times font.
|
2020-10-25 23:40:51 +09:00
|
|
|
const pdf2 = buildGetDocumentParams("TAMReview.pdf");
|
2015-07-14 18:43:20 +09:00
|
|
|
// A PDF using the Arial font.
|
2020-10-25 23:40:51 +09:00
|
|
|
const pdf3 = buildGetDocumentParams("issue6068.pdf");
|
|
|
|
const loadingTasks = [];
|
2015-07-14 18:43:20 +09:00
|
|
|
|
|
|
|
// Render the first page of the given PDF file.
|
|
|
|
// Fulfills the promise with the base64-encoded version of the PDF.
|
2018-11-08 21:46:02 +09:00
|
|
|
async function renderPDF(filename) {
|
|
|
|
const loadingTask = getDocument(filename);
|
2016-01-21 07:57:17 +09:00
|
|
|
loadingTasks.push(loadingTask);
|
2018-11-08 21:46:02 +09:00
|
|
|
const pdf = await loadingTask.promise;
|
|
|
|
const page = await pdf.getPage(1);
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
const viewport = page.getViewport({ scale: 1.2 });
|
|
|
|
const canvasAndCtx = CanvasFactory.create(
|
|
|
|
viewport.width,
|
|
|
|
viewport.height
|
|
|
|
);
|
2018-11-08 21:46:02 +09:00
|
|
|
const renderTask = page.render({
|
|
|
|
canvasContext: canvasAndCtx.context,
|
2019-02-11 03:29:38 +09:00
|
|
|
canvasFactory: CanvasFactory,
|
2018-11-08 21:46:02 +09:00
|
|
|
viewport,
|
|
|
|
});
|
|
|
|
await renderTask.promise;
|
|
|
|
const data = canvasAndCtx.canvas.toDataURL();
|
|
|
|
CanvasFactory.destroy(canvasAndCtx);
|
|
|
|
return data;
|
2015-07-14 18:43:20 +09:00
|
|
|
}
|
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
afterEach(async function () {
|
2015-07-14 18:43:20 +09:00
|
|
|
// Issue 6205 reported an issue with font rendering, so clear the loaded
|
|
|
|
// fonts so that we can see whether loading PDFs in parallel does not
|
|
|
|
// cause any issues with the rendered fonts.
|
2020-04-14 19:28:14 +09:00
|
|
|
const destroyPromises = loadingTasks.map(function (loadingTask) {
|
2016-01-21 07:57:17 +09:00
|
|
|
return loadingTask.destroy();
|
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
await Promise.all(destroyPromises);
|
2015-07-14 18:43:20 +09:00
|
|
|
});
|
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("should correctly render PDFs in parallel", async function () {
|
2020-10-25 23:40:51 +09:00
|
|
|
let baseline1, baseline2, baseline3;
|
|
|
|
const promiseDone = renderPDF(pdf1)
|
2020-04-14 19:28:14 +09:00
|
|
|
.then(function (data1) {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
baseline1 = data1;
|
|
|
|
return renderPDF(pdf2);
|
|
|
|
})
|
2020-04-14 19:28:14 +09:00
|
|
|
.then(function (data2) {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
baseline2 = data2;
|
|
|
|
return renderPDF(pdf3);
|
|
|
|
})
|
2020-04-14 19:28:14 +09:00
|
|
|
.then(function (data3) {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
baseline3 = data3;
|
|
|
|
return Promise.all([
|
|
|
|
renderPDF(pdf1),
|
|
|
|
renderPDF(pdf2),
|
|
|
|
renderPDF(pdf3),
|
|
|
|
]);
|
|
|
|
})
|
2020-04-14 19:28:14 +09:00
|
|
|
.then(function (dataUrls) {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
expect(dataUrls[0]).toEqual(baseline1);
|
|
|
|
expect(dataUrls[1]).toEqual(baseline2);
|
|
|
|
expect(dataUrls[2]).toEqual(baseline3);
|
|
|
|
return true;
|
|
|
|
});
|
2021-04-17 04:48:42 +09:00
|
|
|
|
|
|
|
await promiseDone;
|
2015-07-14 18:43:20 +09:00
|
|
|
});
|
|
|
|
});
|
2019-02-17 22:38:41 +09:00
|
|
|
|
2020-04-14 19:28:14 +09:00
|
|
|
describe("PDFDataRangeTransport", function () {
|
2019-02-17 22:38:41 +09:00
|
|
|
let dataPromise;
|
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
beforeAll(function () {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
const fileName = "tracemonkey.pdf";
|
2021-01-09 01:12:58 +09:00
|
|
|
dataPromise = DefaultFileReaderFactory.fetch({
|
|
|
|
path: TEST_PDFS_PATH + fileName,
|
|
|
|
});
|
2019-02-17 22:38:41 +09:00
|
|
|
});
|
|
|
|
|
2020-04-14 19:28:14 +09:00
|
|
|
afterAll(function () {
|
2019-02-17 22:38:41 +09:00
|
|
|
dataPromise = null;
|
|
|
|
});
|
2018-03-18 03:56:39 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("should fetch document info and page using ranges", async function () {
|
2019-02-17 22:38:41 +09:00
|
|
|
const initialDataLength = 4000;
|
2021-04-17 04:48:42 +09:00
|
|
|
let fetches = 0;
|
|
|
|
|
|
|
|
const data = await dataPromise;
|
|
|
|
const initialData = data.subarray(0, initialDataLength);
|
|
|
|
const transport = new PDFDataRangeTransport(data.length, initialData);
|
|
|
|
transport.requestDataRange = function (begin, end) {
|
|
|
|
fetches++;
|
|
|
|
waitSome(function () {
|
|
|
|
transport.onDataProgress(4000);
|
|
|
|
transport.onDataRange(begin, data.subarray(begin, end));
|
|
|
|
});
|
|
|
|
};
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
const loadingTask = getDocument(transport);
|
|
|
|
const pdfDocument = await loadingTask.promise;
|
|
|
|
expect(pdfDocument.numPages).toEqual(14);
|
2019-02-17 22:38:41 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
const pdfPage = await pdfDocument.getPage(10);
|
|
|
|
expect(pdfPage.rotate).toEqual(0);
|
|
|
|
expect(fetches).toBeGreaterThan(2);
|
2019-02-17 22:38:41 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
await loadingTask.destroy();
|
2016-02-10 05:55:11 +09:00
|
|
|
});
|
[Firefox regression] Fix `disableRange=true` bug in `PDFDataTransportStream`
Currently if trying to set `disableRange=true` in the built-in PDF Viewer in Firefox, either through `about:config` or via the URL hash, the PDF document will never load. It appears that this has been broken for a couple of years, without anyone noticing.
Obviously it's not a good idea to set `disableRange=true`, however it seems that this bug affects the PDF Viewer in Firefox even with default settings:
- In the case where `initialData` already contains the *entire* file, we're forced to dispatch a range request to re-fetch already available data just so that file loading may complete.
- (In the case where the data arrives, via streaming, before being specifically requested through `requestDataRange`, we're also forced to re-fetch data unnecessarily.) *This part was removed, to reduce the scope/risk of the patch somewhat.*
In the cases outlined above, we're having to re-fetch already available data thus potentially delaying loading/rendering of PDF files in Firefox (and wasting resources in the process).
2019-03-27 00:05:30 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
it("should fetch document info and page using range and streaming", async function () {
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
const initialDataLength = 4000;
|
2021-04-17 04:48:42 +09:00
|
|
|
let fetches = 0;
|
|
|
|
|
|
|
|
const data = await dataPromise;
|
|
|
|
const initialData = data.subarray(0, initialDataLength);
|
|
|
|
const transport = new PDFDataRangeTransport(data.length, initialData);
|
|
|
|
transport.requestDataRange = function (begin, end) {
|
|
|
|
fetches++;
|
|
|
|
if (fetches === 1) {
|
|
|
|
// Send rest of the data on first range request.
|
|
|
|
transport.onDataProgressiveRead(data.subarray(initialDataLength));
|
|
|
|
}
|
|
|
|
waitSome(function () {
|
|
|
|
transport.onDataRange(begin, data.subarray(begin, end));
|
|
|
|
});
|
|
|
|
};
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
const loadingTask = getDocument(transport);
|
|
|
|
const pdfDocument = await loadingTask.promise;
|
|
|
|
expect(pdfDocument.numPages).toEqual(14);
|
[Firefox regression] Fix `disableRange=true` bug in `PDFDataTransportStream`
Currently if trying to set `disableRange=true` in the built-in PDF Viewer in Firefox, either through `about:config` or via the URL hash, the PDF document will never load. It appears that this has been broken for a couple of years, without anyone noticing.
Obviously it's not a good idea to set `disableRange=true`, however it seems that this bug affects the PDF Viewer in Firefox even with default settings:
- In the case where `initialData` already contains the *entire* file, we're forced to dispatch a range request to re-fetch already available data just so that file loading may complete.
- (In the case where the data arrives, via streaming, before being specifically requested through `requestDataRange`, we're also forced to re-fetch data unnecessarily.) *This part was removed, to reduce the scope/risk of the patch somewhat.*
In the cases outlined above, we're having to re-fetch already available data thus potentially delaying loading/rendering of PDF files in Firefox (and wasting resources in the process).
2019-03-27 00:05:30 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
const pdfPage = await pdfDocument.getPage(10);
|
|
|
|
expect(pdfPage.rotate).toEqual(0);
|
|
|
|
expect(fetches).toEqual(1);
|
[Firefox regression] Fix `disableRange=true` bug in `PDFDataTransportStream`
Currently if trying to set `disableRange=true` in the built-in PDF Viewer in Firefox, either through `about:config` or via the URL hash, the PDF document will never load. It appears that this has been broken for a couple of years, without anyone noticing.
Obviously it's not a good idea to set `disableRange=true`, however it seems that this bug affects the PDF Viewer in Firefox even with default settings:
- In the case where `initialData` already contains the *entire* file, we're forced to dispatch a range request to re-fetch already available data just so that file loading may complete.
- (In the case where the data arrives, via streaming, before being specifically requested through `requestDataRange`, we're also forced to re-fetch data unnecessarily.) *This part was removed, to reduce the scope/risk of the patch somewhat.*
In the cases outlined above, we're having to re-fetch already available data thus potentially delaying loading/rendering of PDF files in Firefox (and wasting resources in the process).
2019-03-27 00:05:30 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
await new Promise(resolve => {
|
|
|
|
waitSome(resolve);
|
|
|
|
});
|
|
|
|
await loadingTask.destroy();
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
});
|
|
|
|
|
|
|
|
it(
|
|
|
|
"should fetch document info and page, without range, " +
|
|
|
|
"using complete initialData",
|
2021-04-17 04:48:42 +09:00
|
|
|
async function () {
|
|
|
|
let fetches = 0;
|
|
|
|
|
|
|
|
const data = await dataPromise;
|
|
|
|
const transport = new PDFDataRangeTransport(
|
|
|
|
data.length,
|
|
|
|
data,
|
|
|
|
/* progressiveDone = */ true
|
|
|
|
);
|
|
|
|
transport.requestDataRange = function (begin, end) {
|
|
|
|
fetches++;
|
|
|
|
};
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
const loadingTask = getDocument({
|
|
|
|
disableRange: true,
|
|
|
|
range: transport,
|
|
|
|
});
|
|
|
|
const pdfDocument = await loadingTask.promise;
|
|
|
|
expect(pdfDocument.numPages).toEqual(14);
|
[Firefox regression] Fix `disableRange=true` bug in `PDFDataTransportStream`
Currently if trying to set `disableRange=true` in the built-in PDF Viewer in Firefox, either through `about:config` or via the URL hash, the PDF document will never load. It appears that this has been broken for a couple of years, without anyone noticing.
Obviously it's not a good idea to set `disableRange=true`, however it seems that this bug affects the PDF Viewer in Firefox even with default settings:
- In the case where `initialData` already contains the *entire* file, we're forced to dispatch a range request to re-fetch already available data just so that file loading may complete.
- (In the case where the data arrives, via streaming, before being specifically requested through `requestDataRange`, we're also forced to re-fetch data unnecessarily.) *This part was removed, to reduce the scope/risk of the patch somewhat.*
In the cases outlined above, we're having to re-fetch already available data thus potentially delaying loading/rendering of PDF files in Firefox (and wasting resources in the process).
2019-03-27 00:05:30 +09:00
|
|
|
|
2021-04-17 04:48:42 +09:00
|
|
|
const pdfPage = await pdfDocument.getPage(10);
|
|
|
|
expect(pdfPage.rotate).toEqual(0);
|
|
|
|
expect(fetches).toEqual(0);
|
|
|
|
|
|
|
|
await loadingTask.destroy();
|
Enable auto-formatting of the entire code-base using Prettier (issue 11444)
Note that Prettier, purposely, has only limited [configuration options](https://prettier.io/docs/en/options.html). The configuration file is based on [the one in `mozilla central`](https://searchfox.org/mozilla-central/source/.prettierrc) with just a few additions (to avoid future breakage if the defaults ever changes).
Prettier is being used for a couple of reasons:
- To be consistent with `mozilla-central`, where Prettier is already in use across the tree.
- To ensure a *consistent* coding style everywhere, which is automatically enforced during linting (since Prettier is used as an ESLint plugin). This thus ends "all" formatting disussions once and for all, removing the need for review comments on most stylistic matters.
Many ESLint options are now redundant, and I've tried my best to remove all the now unnecessary options (but I may have missed some).
Note also that since Prettier considers the `printWidth` option as a guide, rather than a hard rule, this patch resorts to a small hack in the ESLint config to ensure that *comments* won't become too long.
*Please note:* This patch is generated automatically, by appending the `--fix` argument to the ESLint call used in the `gulp lint` task. It will thus require some additional clean-up, which will be done in a *separate* commit.
(On a more personal note, I'll readily admit that some of the changes Prettier makes are *extremely* ugly. However, in the name of consistency we'll probably have to live with that.)
2019-12-25 23:59:37 +09:00
|
|
|
}
|
|
|
|
);
|
2016-02-10 05:55:11 +09:00
|
|
|
});
|
2012-04-13 09:59:30 +09:00
|
|
|
});
|