mirror of
https://github.com/mozilla/pdf.js.git
synced 2025-04-19 14:48:08 +02:00
141 lines
4.4 KiB
JavaScript
141 lines
4.4 KiB
JavaScript
/* Copyright 2022 Mozilla Foundation
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
import { CommandManager } from "../../src/display/editor/tools.js";
|
|
import { SignatureExtractor } from "../../src/display/editor/drawers/signaturedraw.js";
|
|
|
|
describe("editor", function () {
|
|
describe("Command Manager", function () {
|
|
it("should check undo/redo", function () {
|
|
const manager = new CommandManager(4);
|
|
let x = 0;
|
|
const makeDoUndo = n => ({ cmd: () => (x += n), undo: () => (x -= n) });
|
|
|
|
manager.add({ ...makeDoUndo(1), mustExec: true });
|
|
expect(x).toEqual(1);
|
|
|
|
manager.add({ ...makeDoUndo(2), mustExec: true });
|
|
expect(x).toEqual(3);
|
|
|
|
manager.add({ ...makeDoUndo(3), mustExec: true });
|
|
expect(x).toEqual(6);
|
|
|
|
manager.undo();
|
|
expect(x).toEqual(3);
|
|
|
|
manager.undo();
|
|
expect(x).toEqual(1);
|
|
|
|
manager.undo();
|
|
expect(x).toEqual(0);
|
|
|
|
manager.undo();
|
|
expect(x).toEqual(0);
|
|
|
|
manager.redo();
|
|
expect(x).toEqual(1);
|
|
|
|
manager.redo();
|
|
expect(x).toEqual(3);
|
|
|
|
manager.redo();
|
|
expect(x).toEqual(6);
|
|
|
|
manager.redo();
|
|
expect(x).toEqual(6);
|
|
|
|
manager.undo();
|
|
expect(x).toEqual(3);
|
|
|
|
manager.redo();
|
|
expect(x).toEqual(6);
|
|
});
|
|
});
|
|
|
|
it("should hit the limit of the manager", function () {
|
|
const manager = new CommandManager(3);
|
|
let x = 0;
|
|
const makeDoUndo = n => ({ cmd: () => (x += n), undo: () => (x -= n) });
|
|
|
|
manager.add({ ...makeDoUndo(1), mustExec: true }); // 1
|
|
manager.add({ ...makeDoUndo(2), mustExec: true }); // 3
|
|
manager.add({ ...makeDoUndo(3), mustExec: true }); // 6
|
|
manager.add({ ...makeDoUndo(4), mustExec: true }); // 10
|
|
expect(x).toEqual(10);
|
|
|
|
manager.undo();
|
|
manager.undo();
|
|
expect(x).toEqual(3);
|
|
|
|
manager.undo();
|
|
expect(x).toEqual(1);
|
|
|
|
manager.undo();
|
|
expect(x).toEqual(1);
|
|
|
|
manager.redo();
|
|
manager.redo();
|
|
expect(x).toEqual(6);
|
|
manager.add({ ...makeDoUndo(5), mustExec: true });
|
|
expect(x).toEqual(11);
|
|
});
|
|
|
|
it("should check signature compression/decompression", async () => {
|
|
let gen = n => new Float32Array(crypto.getRandomValues(new Uint16Array(n)));
|
|
let outlines = [102, 28, 254, 4536, 10, 14532, 512].map(gen);
|
|
const signature = {
|
|
outlines,
|
|
areContours: false,
|
|
thickness: 1,
|
|
width: 123,
|
|
height: 456,
|
|
};
|
|
let compressed = await SignatureExtractor.compressSignature(signature);
|
|
let decompressed = await SignatureExtractor.decompressSignature(compressed);
|
|
expect(decompressed).toEqual(signature);
|
|
|
|
signature.thickness = 2;
|
|
compressed = await SignatureExtractor.compressSignature(signature);
|
|
decompressed = await SignatureExtractor.decompressSignature(compressed);
|
|
expect(decompressed).toEqual(signature);
|
|
|
|
signature.areContours = true;
|
|
compressed = await SignatureExtractor.compressSignature(signature);
|
|
decompressed = await SignatureExtractor.decompressSignature(compressed);
|
|
expect(decompressed).toEqual(signature);
|
|
|
|
// Numbers are small enough to be compressed with Uint8Array.
|
|
gen = n =>
|
|
new Float32Array(
|
|
crypto.getRandomValues(new Uint8Array(n)).map(x => x / 10)
|
|
);
|
|
outlines = [100, 200, 300, 10, 80].map(gen);
|
|
signature.outlines = outlines;
|
|
compressed = await SignatureExtractor.compressSignature(signature);
|
|
decompressed = await SignatureExtractor.decompressSignature(compressed);
|
|
expect(decompressed).toEqual(signature);
|
|
|
|
// Numbers are large enough to be compressed with Uint16Array.
|
|
gen = n =>
|
|
new Float32Array(
|
|
crypto.getRandomValues(new Uint16Array(n)).map(x => x / 10)
|
|
);
|
|
outlines = [100, 200, 300, 10, 80].map(gen);
|
|
signature.outlines = outlines;
|
|
compressed = await SignatureExtractor.compressSignature(signature);
|
|
decompressed = await SignatureExtractor.decompressSignature(compressed);
|
|
expect(decompressed).toEqual(signature);
|
|
});
|
|
});
|