UNPKG

@launchmenu/core

Version:

An environment for visual keyboard controlled applets

108 lines 14 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); const SearchCache_1 = require("../SearchCache"); describe("SearchCache", () => { describe("new SearchCache", () => { it("Properly creates a search cache", () => { new SearchCache_1.SearchCache(() => 5); }); }); describe("SearchCache.get", () => { describe("1 part key", () => { it("Retrieves the item", () => { const cache = new SearchCache_1.SearchCache((key) => key * 5); expect(cache.get(5)).toBe(25); expect(cache.get(1)).toBe(5); }); it("Caches the item", () => { const cache = new SearchCache_1.SearchCache((key) => Math.random()); const v23 = cache.get(23); const v3 = cache.get(3); expect(cache.get(23)).toBe(v23); expect(cache.get(3)).toBe(v3); }); it("Deletes the item when capacity is hit", () => { const cache = new SearchCache_1.SearchCache((key) => Math.random(), 2); const v23 = cache.get(23); expect(cache.get(23)).toBe(v23); cache.get(5); const v6 = cache.get(6); expect(cache.get(23)).not.toBe(v23); expect(cache.get(6)).toBe(v6); }); it("Resets item 'age' when item is requested", () => { // See: https://github.com/LaunchMenu/LaunchMenu/issues/90 const cache = new SearchCache_1.SearchCache((key) => Math.random(), 3); const v1 = cache.get(1); const v2 = cache.get(2); expect(cache.get(1)).toBe(v1); const v3 = cache.get(3); expect(cache.get(1)).toBe(v1); const v4 = cache.get(4); expect(cache.get(1)).toBe(v1); expect(cache.queue.getSize()).toBe(3); }); }); describe("multiple part keys", () => { it("Retrieves the item", () => { const cache = new SearchCache_1.SearchCache((k1, k2, k3) => k1 * 5); expect(cache.get(5, "hoi", false)).toBe(25); expect(cache.get(1, "bye", true)).toBe(5); }); it("Caches the item", () => { const cache = new SearchCache_1.SearchCache((k1, k2, k3) => Math.random()); const v1 = cache.get(23, "hoi", false); const v2 = cache.get(3, "bye", true); const v3 = cache.get(23, "hoi", true); const v4 = cache.get(23, "stuff", false); expect(cache.get(23, "hoi", false)).toBe(v1); expect(cache.get(3, "bye", true)).toBe(v2); expect(v3).not.toBe(v1); expect(v4).not.toBe(v1); }); it("Deletes the item when capacity is hit", () => { const cache = new SearchCache_1.SearchCache((k1, k2, k3) => Math.random(), 2); const v23 = cache.get(23, "hoi", false); expect(cache.get(23, "hoi", false)).toBe(v23); cache.get(23, "shit", true); const v23True = cache.get(23, "hoi", true); expect(cache.get(23, "hoi", false)).not.toBe(v23); expect(cache.get(23, "hoi", true)).toBe(v23True); }); it("Resets item 'age' when item is requested", () => { // See: https://github.com/LaunchMenu/LaunchMenu/issues/90 const cache = new SearchCache_1.SearchCache((k1, k2) => Math.random(), 3); const vA1 = cache.get("A", 1); const vA2 = cache.get("A", 2); expect(cache.get("A", 1)).toBe(vA1); const vB1 = cache.get("B", 1); expect(cache.get("A", 1)).toBe(vA1); const vB2 = cache.get("B", 2); expect(cache.get("A", 1)).toBe(vA1); expect(cache.queue.getSize()).toBe(3); }); }); it("Cleans up the cache", () => { const cache = new SearchCache_1.SearchCache((k1, k2, k3) => Math.random(), 2); cache.get(23, "hoi", false); expect(cache.map.get(23)).not.toBe(undefined); cache.get(2, "shit", true); cache.get(3, "hoi", true); expect(cache.map.get(23)).toBe(undefined); }); }); describe("SearchCache.getAll", () => { it("Retrieves all items for 1 part keys", () => { const cache = new SearchCache_1.SearchCache((k1) => k1); expect(cache.getAll([25, 50, 75, 100])).toEqual([25, 50, 75, 100]); }); it("Retrieves all items for multiple part keys", () => { const cache = new SearchCache_1.SearchCache((k1, k2, k3) => k1); expect(cache.getAll([ [24, "yes", true], [22, "", false], ])).toEqual([24, 22]); }); }); }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"SearchCache.js","sourceRoot":"","sources":["../../../../src/utils/search/_tests/SearchCache.ts"],"names":[],"mappings":"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"}