Some checks failed
		
		
	
	Types tests / Test (lts/*) (push) Has been cancelled
				
			Lint / Lint (lts/*) (push) Has been cancelled
				
			CodeQL / Analyze (javascript) (push) Has been cancelled
				
			CI / Test (20) (push) Has been cancelled
				
			CI / Test (22) (push) Has been cancelled
				
			CI / Test (24) (push) Has been cancelled
				
			
		
			
				
	
	
		
			142 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			142 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);
 | 
						|
  });
 | 
						|
});
 |