From f50eb73c17df9375cf719c61bb32287adacb779f Mon Sep 17 00:00:00 2001 From: Amin Yahyaabadi Date: Tue, 22 Jun 2021 01:56:40 -0500 Subject: [PATCH 1/5] fix: use const/let instead of var/let Automated change using eslint-config-atomic --- packages/solid/src/reactive/mutable.ts | 2 +- packages/solid/src/reactive/scheduler.ts | 4 ++-- packages/solid/src/reactive/signal.ts | 10 +++++----- packages/solid/src/reactive/state.ts | 4 ++-- packages/solid/src/reactive/stateModifiers.ts | 2 +- packages/solid/src/static/reactive.ts | 6 +++--- packages/solid/src/static/rendering.ts | 2 +- 7 files changed, 15 insertions(+), 15 deletions(-) diff --git a/packages/solid/src/reactive/mutable.ts b/packages/solid/src/reactive/mutable.ts index 4a679e1e4..151a0b6d5 100644 --- a/packages/solid/src/reactive/mutable.ts +++ b/packages/solid/src/reactive/mutable.ts @@ -54,7 +54,7 @@ function wrap(value: T, name?: string): State { let p = value[$PROXY]; if (!p) { Object.defineProperty(value, $PROXY, { value: (p = new Proxy(value, proxyTraps)) }); - let keys = Object.keys(value), + const keys = Object.keys(value), desc = Object.getOwnPropertyDescriptors(value); for (let i = 0, l = keys.length; i < l; i++) { const prop = keys[i]; diff --git a/packages/solid/src/reactive/scheduler.ts b/packages/solid/src/reactive/scheduler.ts index 0c292b157..c58a1cc66 100644 --- a/packages/solid/src/reactive/scheduler.ts +++ b/packages/solid/src/reactive/scheduler.ts @@ -89,8 +89,8 @@ function enqueue(taskQueue: Task[], task: Task) { let n = taskQueue.length - 1; while (m <= n) { - let k = (n + m) >> 1; - let cmp = task.expirationTime - taskQueue[k].expirationTime; + const k = (n + m) >> 1; + const cmp = task.expirationTime - taskQueue[k].expirationTime; if (cmp > 0) m = k + 1; else if (cmp < 0) n = k - 1; else return k; diff --git a/packages/solid/src/reactive/signal.ts b/packages/solid/src/reactive/signal.ts index 2b1616236..fcfe7f01a 100644 --- a/packages/solid/src/reactive/signal.ts +++ b/packages/solid/src/reactive/signal.ts @@ -288,7 +288,7 @@ export function createResource( batch(() => { set(() => v); setLoading(false); - for (let c of contexts.keys()) c.decrement!(); + for (const c of contexts.keys()) c.decrement!(); contexts.clear(); }); } @@ -313,7 +313,7 @@ export function createResource( } function load() { setError((err = undefined)); - let lookup = dynamic ? (source as () => U)() : (source as U); + const lookup = dynamic ? (source as () => U)() : (source as U); loadedUnderTransition = (Transition && Transition.running) as boolean; if (lookup == null || (lookup as any) === false) { loadEnd(pr, untrack(s)!); @@ -386,7 +386,7 @@ export function createSelector( fn: (a: U, b: T) => boolean = equalFn as any, options?: { name?: string } ): (key: U) => boolean { - let subs = new Map>>(); + const subs = new Map>>(); const node = createComputation( (p: T | undefined) => { const v = source(); @@ -476,7 +476,7 @@ export function on any) | (() => any)[], U>( fn: (values: ReturnTypes, prev: ReturnTypes, prevResults?: U) => U, options?: { defer?: boolean } ): (prev?: U) => U | undefined { - let isArray = Array.isArray(deps); + const isArray = Array.isArray(deps); let prev: ReturnTypes; let defer = options && options.defer; return prevResult => { @@ -1009,7 +1009,7 @@ function resolveChildren(children: any): unknown { if (Array.isArray(children)) { const results: any[] = []; for (let i = 0; i < children.length; i++) { - let result = resolveChildren(children[i]); + const result = resolveChildren(children[i]); Array.isArray(result) ? results.push.apply(results, result) : results.push(result); } return results; diff --git a/packages/solid/src/reactive/state.ts b/packages/solid/src/reactive/state.ts index 5a3ab76d4..9b1e021bd 100644 --- a/packages/solid/src/reactive/state.ts +++ b/packages/solid/src/reactive/state.ts @@ -47,7 +47,7 @@ function wrap(value: T, name?: string): State { let p = value[$PROXY]; if (!p) { Object.defineProperty(value, $PROXY, { value: (p = new Proxy(value, proxyTraps)) }); - let keys = Object.keys(value), + const keys = Object.keys(value), desc = Object.getOwnPropertyDescriptors(value); for (let i = 0, l = keys.length; i < l; i++) { const prop = keys[i]; @@ -86,7 +86,7 @@ export function unwrap(item: any, set = new Set()): T { } else { if (Object.isFrozen(item)) item = Object.assign({}, item); else set.add(item); - let keys = Object.keys(item), + const keys = Object.keys(item), desc = Object.getOwnPropertyDescriptors(item); for (let i = 0, l = keys.length; i < l; i++) { prop = keys[i]; diff --git a/packages/solid/src/reactive/stateModifiers.ts b/packages/solid/src/reactive/stateModifiers.ts index ccdac3c5c..1cb23ded1 100644 --- a/packages/solid/src/reactive/stateModifiers.ts +++ b/packages/solid/src/reactive/stateModifiers.ts @@ -21,7 +21,7 @@ function applyState( merge: boolean | undefined, key: string | null ) { - let previous = parent[property]; + const previous = parent[property]; if (target === previous) return; if (!isWrappable(target) || !isWrappable(previous) || (key && target[key] !== previous[key])) { target !== previous && setProperty(parent, property, target); diff --git a/packages/solid/src/static/reactive.ts b/packages/solid/src/static/reactive.ts index e8162aab8..52f67483b 100644 --- a/packages/solid/src/static/reactive.ts +++ b/packages/solid/src/static/reactive.ts @@ -76,8 +76,8 @@ export function on( fn: (value: Array | T, prev?: Array | T, prevResults?: U) => U, options: { defer?: boolean } = {} ): (prev?: U) => U | undefined { - let isArray = Array.isArray(deps); - let defer = options.defer; + const isArray = Array.isArray(deps); + const defer = options.defer; return () => { if (defer) return undefined; let value: Array | T; @@ -151,7 +151,7 @@ function resolveChildren(children: any): unknown { if (Array.isArray(children)) { const results: any[] = []; for (let i = 0; i < children.length; i++) { - let result = resolveChildren(children[i]); + const result = resolveChildren(children[i]); Array.isArray(result) ? results.push.apply(results, result) : results.push(result); } return results; diff --git a/packages/solid/src/static/rendering.ts b/packages/solid/src/static/rendering.ts index 2889273b4..cc257a714 100644 --- a/packages/solid/src/static/rendering.ts +++ b/packages/solid/src/static/rendering.ts @@ -359,7 +359,7 @@ export function lazy(fn: () => Promise<{ default: any }>): (props: any) => strin } function suspenseComplete(c: SuspenseContextType) { - for (let r of c.resources.values()) { + for (const r of c.resources.values()) { if (r.loading) return false; } return true; From d4d5550622b25b02b76b91e81a25fe75f2d27466 Mon Sep 17 00:00:00 2001 From: Amin Yahyaabadi Date: Tue, 22 Jun 2021 01:43:07 -0500 Subject: [PATCH 2/5] fix: use Boolean instead of double not --- packages/solid/src/reactive/signal.ts | 2 +- packages/solid/test/state.spec.ts | 2 +- packages/solid/web/test/switch.spec.tsx | 10 +++++----- 3 files changed, 7 insertions(+), 7 deletions(-) diff --git a/packages/solid/src/reactive/signal.ts b/packages/solid/src/reactive/signal.ts index fcfe7f01a..b4f96b3a7 100644 --- a/packages/solid/src/reactive/signal.ts +++ b/packages/solid/src/reactive/signal.ts @@ -85,7 +85,7 @@ export function createRoot(fn: (dispose: () => void) => T, detachedOwner?: Ow root: Owner = fn.length === 0 && !"_SOLID_DEV_" ? UNOWNED - : { owned: null, cleanups: null, context: null, owner, attached: !!detachedOwner }; + : { owned: null, cleanups: null, context: null, owner, attached: Boolean(detachedOwner) }; if ("_SOLID_DEV_" && owner) root.name = (owner as Computation).name + "-r" + rootCount++; Owner = root; diff --git a/packages/solid/test/state.spec.ts b/packages/solid/test/state.spec.ts index c3edbf1fb..efc24d2fa 100644 --- a/packages/solid/test/state.spec.ts +++ b/packages/solid/test/state.spec.ts @@ -122,7 +122,7 @@ describe("Array setState modes", () => { const [state, setState] = createState({ rows: [1, 2, 3, 4, 5] }); setState( "rows", - (r, i) => !!(i % 2), + (r, i) => Boolean(i % 2), r => r * 2 ); expect(state.rows[0]).toBe(1); diff --git a/packages/solid/web/test/switch.spec.tsx b/packages/solid/web/test/switch.spec.tsx index 877d528c1..a0b27ea7a 100644 --- a/packages/solid/web/test/switch.spec.tsx +++ b/packages/solid/web/test/switch.spec.tsx @@ -8,7 +8,7 @@ describe("Testing a single match switch control flow", () => { const Component = () => (
- 1 + 1
); @@ -38,9 +38,9 @@ describe("Testing an only child Switch control flow", () => { const Component = () => (
- 1 - 2 - 3 + 1 + 2 + 3
); @@ -160,7 +160,7 @@ describe("Test top level switch control flow", () => { const [count, setCount] = createSignal(0); const Component = () => ( - 1 + 1 ); From 7569fa2f384b9113b612eb220eb9352a5e7357e1 Mon Sep 17 00:00:00 2001 From: Amin Yahyaabadi Date: Tue, 22 Jun 2021 01:45:59 -0500 Subject: [PATCH 3/5] fix: use string interpolation --- packages/solid/src/reactive/signal.ts | 16 ++++++++-------- packages/solid/test/signals.spec.ts | 20 ++++++++++---------- packages/solid/web/test/for.spec.tsx | 2 +- packages/solid/web/test/index.spec.tsx | 2 +- 4 files changed, 20 insertions(+), 20 deletions(-) diff --git a/packages/solid/src/reactive/signal.ts b/packages/solid/src/reactive/signal.ts index b4f96b3a7..d82f381b9 100644 --- a/packages/solid/src/reactive/signal.ts +++ b/packages/solid/src/reactive/signal.ts @@ -87,7 +87,7 @@ export function createRoot(fn: (dispose: () => void) => T, detachedOwner?: Ow ? UNOWNED : { owned: null, cleanups: null, context: null, owner, attached: Boolean(detachedOwner) }; - if ("_SOLID_DEV_" && owner) root.name = (owner as Computation).name + "-r" + rootCount++; + if ("_SOLID_DEV_" && owner) root.name = `${(owner as Computation).name}-r${rootCount++}`; Owner = root; Listener = null; let result: T; @@ -585,8 +585,8 @@ export function devComponent(Comp: (props: T) => JSX.Element, props: T) { export function hashValue(v: any): string { const s = new Set(); return ( - "s" + - (typeof v === "string" + `s${ + typeof v === "string" ? hash(v) : hash( JSON.stringify(v, (k, v) => { @@ -596,7 +596,7 @@ export function hashValue(v: any): string { } return v; }) || "" - )) + )}` ); } @@ -605,7 +605,7 @@ export function registerGraph(name: string, value: { value: unknown }): string { if (Owner) { let i = 0; Owner.sourceMap || (Owner.sourceMap = {}); - while (Owner.sourceMap[tryName]) tryName = name + "-" + ++i; + while (Owner.sourceMap[tryName]) tryName = `${name}-${++i}`; Owner.sourceMap[tryName] = value; } return tryName; @@ -804,9 +804,9 @@ function createComputation( if ("_SOLID_DEV_") c.name = (options && options.name) || - ((Owner as Computation).name || "c") + - "-" + - (Owner.owned || (Owner as Memo).tOwned!).length; + `${(Owner as Computation).name || "c"}-${ + (Owner.owned || (Owner as Memo).tOwned!).length + }`; } return c; } diff --git a/packages/solid/test/signals.spec.ts b/packages/solid/test/signals.spec.ts index 7b0620146..15345c302 100644 --- a/packages/solid/test/signals.spec.ts +++ b/packages/solid/test/signals.spec.ts @@ -36,7 +36,7 @@ describe("Create signals", () => { }); test("Create and read a Memo with initial value", () => { createRoot(() => { - const memo = createMemo(i => i + " John", "Hello"); + const memo = createMemo(i => `${i} John`, "Hello"); expect(memo()).toBe("Hello John"); }); }); @@ -51,7 +51,7 @@ describe("Create signals", () => { createRoot(() => { let temp: string; const [sign] = createSignal("thoughts"); - createComputed(on(sign, v => (temp = "impure " + v))); + createComputed(on(sign, v => (temp = `impure ${v}`))); expect(temp!).toBe("impure thoughts"); }); }); @@ -60,7 +60,7 @@ describe("Create signals", () => { let temp: string; const [sign] = createSignal("thoughts"); const [num] = createSignal(3); - createComputed(on([sign, num], v => (temp = "impure " + v[1]))); + createComputed(on([sign, num], v => (temp = `impure ${v[1]}`))); expect(temp!).toBe("impure 3"); }); }); @@ -68,7 +68,7 @@ describe("Create signals", () => { createRoot(() => { let temp: string; const [sign, set] = createSignal("thoughts"); - createComputed(on(sign, v => (temp = "impure " + v), { defer: true })); + createComputed(on(sign, v => (temp = `impure ${v}`), { defer: true })); expect(temp!).toBeUndefined(); set("minds"); expect(temp!).toBe("impure minds"); @@ -100,7 +100,7 @@ describe("Update signals", () => { test("Create and trigger a Memo", () => { createRoot(() => { const [name, setName] = createSignal("John"), - memo = createMemo(() => "Hello " + name()); + memo = createMemo(() => `Hello ${name()}`); expect(memo()).toBe("Hello John"); setName("Jake"); expect(memo()).toBe("Hello Jake"); @@ -110,8 +110,8 @@ describe("Update signals", () => { createRoot(() => { let temp: string; const [name, setName] = createSignal("John"), - memo = createMemo(() => "Hello " + name()); - createEffect(() => (temp = memo() + "!!!")); + memo = createMemo(() => `Hello ${name()}`); + createEffect(() => (temp = `${memo()}!!!`)); setTimeout(() => { expect(temp).toBe("Hello John!!!"); setName("Jake"); @@ -124,7 +124,7 @@ describe("Update signals", () => { createRoot(() => { let temp: string; const [sign, setSign] = createSignal("thoughts"); - createEffect(() => (temp = "unpure " + sign())); + createEffect(() => (temp = `unpure ${sign()}`)); setTimeout(() => { expect(temp).toBe("unpure thoughts"); setSign("mind"); @@ -151,7 +151,7 @@ describe("Untrack signals", () => { createRoot(() => { let temp: string; const [sign, setSign] = createSignal("thoughts"); - createEffect(() => (temp = "unpure " + untrack(sign))); + createEffect(() => (temp = `unpure ${untrack(sign)}`)); setTimeout(() => { expect(temp).toBe("unpure thoughts"); setSign("mind"); @@ -240,7 +240,7 @@ describe("Batch signals", () => { expect(count).toBe(2); done(); }); - }) + }); }); }); test("Handles errors gracefully", done => { diff --git a/packages/solid/web/test/for.spec.tsx b/packages/solid/web/test/for.spec.tsx index b3bfba2a2..8b1a67d20 100644 --- a/packages/solid/web/test/for.spec.tsx +++ b/packages/solid/web/test/for.spec.tsx @@ -99,7 +99,7 @@ describe("Testing an multi child each control flow", () => { function apply(array: string[]) { setList(array); - expect(div.innerHTML).toBe(array.join("") + "z"); + expect(div.innerHTML).toBe(`${array.join("")}z`); setList([n1, n2, n3, n4]); expect(div.innerHTML).toBe("abcdz"); } diff --git a/packages/solid/web/test/index.spec.tsx b/packages/solid/web/test/index.spec.tsx index 924418beb..54556da1e 100644 --- a/packages/solid/web/test/index.spec.tsx +++ b/packages/solid/web/test/index.spec.tsx @@ -99,7 +99,7 @@ describe("Testing an multi child each control flow", () => { function apply(array: string[]) { setList(array); - expect(div.innerHTML).toBe(array.join("") + "z"); + expect(div.innerHTML).toBe(`${array.join("")}z`); setList([n1, n2, n3, n4]); expect(div.innerHTML).toBe("abcdz"); } From fa32322d4d7814eb7edbba75f48e7854c0e72b87 Mon Sep 17 00:00:00 2001 From: Amin Yahyaabadi Date: Tue, 22 Jun 2021 01:46:24 -0500 Subject: [PATCH 4/5] fix: optimize SUSPENSE_REPLACE regex --- packages/solid/src/static/rendering.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/solid/src/static/rendering.ts b/packages/solid/src/static/rendering.ts index cc257a714..e7b4cbb1d 100644 --- a/packages/solid/src/static/rendering.ts +++ b/packages/solid/src/static/rendering.ts @@ -440,7 +440,7 @@ export function Suspense(props: { fallback: string; children: string }) { return sharedConfig.context!.async ? { t: `<#${id}#>` } : props.fallback; } -const SUSPENSE_REPLACE = /<#([0-9\.]+)\#>/; +const SUSPENSE_REPLACE = /<#([\d.]+)#>/; export function awaitSuspense(fn: () => any) { return new Promise(resolve => { const registry = new Set(); From 3e7d535697ba850856efff5d3af1238ca552d21f Mon Sep 17 00:00:00 2001 From: Amin Yahyaabadi Date: Tue, 22 Jun 2021 02:07:18 -0500 Subject: [PATCH 5/5] test: use consts/let instead of var/let --- packages/solid/test/mutable.spec.ts | 24 ++++---- packages/solid/test/signals.memo.spec.ts | 68 +++++++++++----------- packages/solid/test/state.spec.ts | 36 ++++++------ packages/solid/test/stateModifiers.spec.ts | 10 ++-- packages/solid/web/test/suspense.spec.tsx | 2 +- 5 files changed, 70 insertions(+), 70 deletions(-) diff --git a/packages/solid/test/mutable.spec.ts b/packages/solid/test/mutable.spec.ts index 6c743668d..6866ec544 100644 --- a/packages/solid/test/mutable.spec.ts +++ b/packages/solid/test/mutable.spec.ts @@ -95,7 +95,7 @@ describe("Simple update modes", () => { describe("Unwrapping Edge Cases", () => { test("Unwrap nested frozen state object", () => { - var state = createMutable({ + const state = createMutable({ data: Object.freeze({ user: { firstName: "John", lastName: "Snow" } }) }), s = unwrap({ ...state }); @@ -105,7 +105,7 @@ describe("Unwrapping Edge Cases", () => { expect(s.data.user[$RAW]).toBeUndefined(); }); test("Unwrap nested frozen array", () => { - var state = createMutable({ + const state = createMutable({ data: [{ user: { firstName: "John", lastName: "Snow" } }] }), s = unwrap({ data: state.data.slice(0) }); @@ -115,7 +115,7 @@ describe("Unwrapping Edge Cases", () => { expect(s.data[0].user[$RAW]).toBeUndefined(); }); test("Unwrap nested frozen state array", () => { - var state = createMutable({ + const state = createMutable({ data: Object.freeze([{ user: { firstName: "John", lastName: "Snow" } }]) }), s = unwrap({ ...state }); @@ -129,8 +129,8 @@ describe("Unwrapping Edge Cases", () => { describe("Tracking State changes", () => { test("Track a state change", () => { createRoot(() => { - var state = createMutable({ data: 2 }), - executionCount = 0; + const state = createMutable({ data: 2 }) + let executionCount = 0; expect.assertions(2); createComputed(() => { @@ -152,10 +152,10 @@ describe("Tracking State changes", () => { test("Track a nested state change", () => { createRoot(() => { - var state = createMutable({ + const state = createMutable({ user: { firstName: "John", lastName: "Smith" } - }), - executionCount = 0; + }) + let executionCount = 0; expect.assertions(2); createComputed(() => { @@ -178,7 +178,7 @@ describe("Tracking State changes", () => { describe("Handling functions in state", () => { test("Array Native Methods: Array.Filter", () => { createRoot(() => { - var state = createMutable({ list: [0, 1, 2] }), + const state = createMutable({ list: [0, 1, 2] }), getFiltered = createMemo(() => state.list.filter(i => i % 2)); expect(getFiltered()).toStrictEqual([1]); }); @@ -186,7 +186,7 @@ describe("Handling functions in state", () => { test("Track function change", () => { createRoot(() => { - var state = createMutable<{ fn: () => number }>({ + const state = createMutable<{ fn: () => number }>({ fn: () => 1 }), getValue = createMemo(() => state.fn()); @@ -199,7 +199,7 @@ describe("Handling functions in state", () => { describe("Setting state from Effects", () => { test("Setting state from signal", () => { createRoot(() => { - var [getData, setData] = createSignal("init"), + const [getData, setData] = createSignal("init"), state = createMutable({ data: "" }); createComputed(() => (state.data = getData())); setData("signal"); @@ -209,7 +209,7 @@ describe("Setting state from Effects", () => { test("Select Promise", done => { createRoot(async () => { - var p = new Promise(resolve => { + const p = new Promise(resolve => { setTimeout(resolve, 20, "promised"); }), state = createMutable({ data: "" }); diff --git a/packages/solid/test/signals.memo.spec.ts b/packages/solid/test/signals.memo.spec.ts index 0f4ad02e9..c0f14fb4c 100644 --- a/packages/solid/test/signals.memo.spec.ts +++ b/packages/solid/test/signals.memo.spec.ts @@ -4,9 +4,9 @@ describe("createMemo", () => { describe("executing propagating", () => { it("does not trigger downstream computations unless changed", () => { createRoot(() => { - let [s1, set] = createSignal(1, { equals: false }); + const [s1, set] = createSignal(1, { equals: false }); let order = ""; - let t1 = createMemo(() => { + const t1 = createMemo(() => { order += "t1"; return s1(); }); @@ -26,9 +26,9 @@ describe("createMemo", () => { it("applies updates to changed dependees in same order as createComputed", () => { createRoot(() => { - let [s1, set] = createSignal(0); + const [s1, set] = createSignal(0); let order = ""; - let t1 = createMemo(() => { + const t1 = createMemo(() => { order += "t1"; return s1() === 0; }); @@ -50,10 +50,10 @@ describe("createMemo", () => { it("updates downstream pending computations", () => { createRoot(() => { - let [s1, set] = createSignal(0); - let [s2] = createSignal(0); + const [s1, set] = createSignal(0); + const [s2] = createSignal(0); let order = ""; - let t1 = createMemo(() => { + const t1 = createMemo(() => { order += "t1"; return s1() === 0; }); @@ -77,11 +77,11 @@ describe("createMemo", () => { }); describe("with changing dependencies", () => { - var i: () => boolean, setI: (v: boolean) => void; - var t: () => number, setT: (v: number) => void; - var e: () => number, setE: (v: number) => void; - var fevals: number; - var f: () => number; + let i: () => boolean, setI: (v: boolean) => void; + let t: () => number, setT: (v: number) => void; + let e: () => number, setE: (v: number) => void; + let fevals: number; + let f: () => number; function init() { [i, setI] = createSignal(true); @@ -177,8 +177,8 @@ describe("createMemo", () => { describe("with intercepting computations", () => { it("does not update subsequent pending computations after stale invocations", () => { createRoot(() => { - let [s1, set1] = createSignal(1); - let [s2, set2] = createSignal(false); + const [s1, set1] = createSignal(1); + const [s2, set2] = createSignal(false); let count = 0; /* s1 @@ -189,12 +189,12 @@ describe("createMemo", () => { c3 [PN,PN,STL,void] */ - let t1 = createMemo(() => s1() > 0); - let t2 = createMemo(() => s1() > 0); - let c1 = createMemo(() => s1()); - let t3 = createMemo(() => { - let a = s1(); - let b = s2(); + const t1 = createMemo(() => s1() > 0); + const t2 = createMemo(() => s1() > 0); + const c1 = createMemo(() => s1()); + const t3 = createMemo(() => { + const a = s1(); + const b = s2(); return a && b; }); createComputed(() => { @@ -252,8 +252,8 @@ describe("createMemo", () => { it("evaluates nested trackings", () => { createRoot(() => { - let [s1, set1] = createSignal(1); - let [s2] = createSignal(1); + const [s1, set1] = createSignal(1); + const [s2] = createSignal(1); let count = 0; let c1: () => number; createMemo(() => { @@ -271,13 +271,13 @@ describe("createMemo", () => { it("propagates in topological order", () => { createRoot(() => { - let [s1, set] = createSignal(true); + const [s1, set] = createSignal(true); let order = ""; - let t1 = createMemo(() => { + const t1 = createMemo(() => { order += "t1"; return s1(); }); - let t2 = createMemo(() => { + const t2 = createMemo(() => { order += "t2"; return s1(); }); @@ -294,7 +294,7 @@ describe("createMemo", () => { it("does not evaluate dependencies with tracking sources that have not changed", () => { createRoot(() => { - let [s1, set] = createSignal(1); + const [s1, set] = createSignal(1); let order = ""; let c2: () => boolean; createComputed(() => { @@ -303,11 +303,11 @@ describe("createMemo", () => { c2(); } }); - let t1 = createMemo(() => { + const t1 = createMemo(() => { order += "t1"; return s1() < 3; }); - let t2 = createMemo(() => { + const t2 = createMemo(() => { order += "t2"; return t1(); }); @@ -326,17 +326,17 @@ describe("createMemo", () => { it("correctly marks downstream computations as stale on change", () => { createRoot(() => { - let [s1, set] = createSignal(1); + const [s1, set] = createSignal(1); let order = ""; - let t1 = createMemo(() => { + const t1 = createMemo(() => { order += "t1"; return s1(); }); - let c1 = createMemo(() => { + const c1 = createMemo(() => { order += "c1"; return t1(); }); - let c2 = createMemo(() => { + const c2 = createMemo(() => { order += "c2"; return c1(); }); @@ -354,7 +354,7 @@ describe("createMemo", () => { describe("with unending changes", () => { it("throws when continually setting a direct dependency", () => { createRoot(() => { - var [d, set] = createSignal(1); + const [d, set] = createSignal(1); expect(() => { createMemo(() => { @@ -367,7 +367,7 @@ describe("createMemo", () => { it("throws when continually setting an indirect dependency", () => { createRoot(() => { let i = 2; - var [d, set] = createSignal(1), + const [d, set] = createSignal(1), f1 = createMemo(() => d()), f2 = createMemo(() => f1()), f3 = createMemo(() => f2()); diff --git a/packages/solid/test/state.spec.ts b/packages/solid/test/state.spec.ts index efc24d2fa..8bd9e1e2d 100644 --- a/packages/solid/test/state.spec.ts +++ b/packages/solid/test/state.spec.ts @@ -153,7 +153,7 @@ describe("Array setState modes", () => { describe("Unwrapping Edge Cases", () => { test("Unwrap nested frozen state object", () => { - var [state] = createState({ + const [state] = createState({ data: Object.freeze({ user: { firstName: "John", lastName: "Snow" } }) }), s = unwrap({ ...state }); @@ -163,7 +163,7 @@ describe("Unwrapping Edge Cases", () => { expect(s.data.user[$RAW]).toBeUndefined(); }); test("Unwrap nested frozen array", () => { - var [state] = createState({ + const [state] = createState({ data: [{ user: { firstName: "John", lastName: "Snow" } }] }), s = unwrap({ data: state.data.slice(0) }); @@ -173,7 +173,7 @@ describe("Unwrapping Edge Cases", () => { expect(s.data[0].user[$RAW]).toBeUndefined(); }); test("Unwrap nested frozen state array", () => { - var [state] = createState({ + const [state] = createState({ data: Object.freeze([{ user: { firstName: "John", lastName: "Snow" } }]) }), s = unwrap({ ...state }); @@ -187,8 +187,8 @@ describe("Unwrapping Edge Cases", () => { describe("Tracking State changes", () => { test("Track a state change", () => { createRoot(() => { - var [state, setState] = createState({ data: 2 }), - executionCount = 0; + const [state, setState] = createState({ data: 2 }); + let executionCount = 0; expect.assertions(2); createComputed(() => { @@ -211,10 +211,10 @@ describe("Tracking State changes", () => { test("Track a nested state change", () => { createRoot(() => { - var [state, setState] = createState({ + const [state, setState] = createState({ user: { firstName: "John", lastName: "Smith" } - }), - executionCount = 0; + }); + let executionCount = 0; expect.assertions(2); createComputed(() => { @@ -235,8 +235,8 @@ describe("Tracking State changes", () => { test("Tracking Object key addition/removal", () => { createRoot(() => { - var [state, setState] = createState<{ obj: { item?: number } }>({ obj: {} }), - executionCount = 0; + const [state, setState] = createState<{ obj: { item?: number } }>({ obj: {} }); + let executionCount = 0; createComputed(on(() => state.obj, (v) => { if (executionCount === 0) expect(v.item).toBeUndefined(); @@ -264,7 +264,7 @@ describe("Tracking State changes", () => { describe("Handling functions in state", () => { test("Array Native Methods: Array.Filter", () => { createRoot(() => { - var [state] = createState({ list: [0, 1, 2] }), + const [state] = createState({ list: [0, 1, 2] }), getFiltered = createMemo(() => state.list.filter(i => i % 2)); expect(getFiltered()).toStrictEqual([1]); }); @@ -272,7 +272,7 @@ describe("Handling functions in state", () => { test("Track function change", () => { createRoot(() => { - var [state, setState] = createState<{ fn: () => number }>({ + const [state, setState] = createState<{ fn: () => number }>({ fn: () => 1 }), getValue = createMemo(() => state.fn()); @@ -285,7 +285,7 @@ describe("Handling functions in state", () => { describe("Setting state from Effects", () => { test("Setting state from signal", () => { createRoot(() => { - var [getData, setData] = createSignal("init"), + const [getData, setData] = createSignal("init"), [state, setState] = createState({ data: "" }); createComputed(() => setState("data", getData())); setData("signal"); @@ -295,10 +295,10 @@ describe("Setting state from Effects", () => { test("Select Promise", done => { createRoot(async () => { - var p = new Promise(resolve => { + const p = new Promise(resolve => { setTimeout(resolve, 20, "promised"); - }), - [state, setState] = createState({ data: "" }); + }); + const [state, setState] = createState({ data: "" }); p.then(v => setState("data", v)); await p; expect(state.data).toBe("promised"); @@ -333,7 +333,7 @@ describe("Array length", () => { const [state, setState] = createState<{ list: number[] }>({ list: [] }); let length; // isolate length tracking - let list = state.list; + const list = state.list; createRoot(() => { createComputed(() => { length = list.length; @@ -348,7 +348,7 @@ describe("Array length", () => { describe("State recursion", () => { test("there is no infinite loop", () => { - let x: { a: number; b: any } = { a: 1, b: undefined }; + const x: { a: number; b: any } = { a: 1, b: undefined }; x.b = x; const [state, setState] = createState(x); diff --git a/packages/solid/test/stateModifiers.spec.ts b/packages/solid/test/stateModifiers.spec.ts index accc2ed19..b6e69973d 100644 --- a/packages/solid/test/stateModifiers.spec.ts +++ b/packages/solid/test/stateModifiers.spec.ts @@ -2,7 +2,7 @@ import { createState, reconcile, produce, unwrap } from "../src"; describe("setState with reconcile", () => { test("Reconcile a simple object", () => { - var [state, setState] = createState({ data: 2, missing: "soon" }); + const [state, setState] = createState({ data: 2, missing: "soon" }); expect(state.data).toBe(2); expect(state.missing).toBe("soon"); setState(reconcile({ data: 5 })); @@ -11,7 +11,7 @@ describe("setState with reconcile", () => { }); test("Reconcile a simple object on a nested path", () => { - var [state, setState] = createState({ + const [state, setState] = createState({ data: { user: { firstName: "John", middleName: "", lastName: "Snow" } } }); expect(state.data.user.firstName).toBe("John"); @@ -23,7 +23,7 @@ describe("setState with reconcile", () => { }); test("Reconcile a simple object on a nested path with no prev state", () => { - var [state, setState] = createState<{ user?: { firstName: string; middleName: string } }>({}); + const [state, setState] = createState<{ user?: { firstName: string; middleName: string } }>({}); expect(state.user).toBeUndefined(); setState("user", reconcile({ firstName: "Jake", middleName: "R" })); expect(state.user!.firstName).toBe("Jake"); @@ -35,7 +35,7 @@ describe("setState with reconcile", () => { NED = { id: 2, firstName: "Ned", lastName: "Stark" }, BRANDON = { id: 3, firstName: "Brandon", lastName: "Start" }, ARYA = { id: 4, firstName: "Arya", lastName: "Start" }; - var [state, setState] = createState({ users: [JOHN, NED, BRANDON] }); + const [state, setState] = createState({ users: [JOHN, NED, BRANDON] }); expect(Object.is(unwrap(state.users[0]), JOHN)).toBe(true); expect(Object.is(unwrap(state.users[1]), NED)).toBe(true); expect(Object.is(unwrap(state.users[2]), BRANDON)).toBe(true); @@ -62,7 +62,7 @@ describe("setState with reconcile", () => { const JOHN = { id: 1, firstName: "John", lastName: "Snow" }, NED = { id: 2, firstName: "Ned", lastName: "Stark" }, BRANDON = { id: 3, firstName: "Brandon", lastName: "Start" }; - var [state, setState] = createState({ + const [state, setState] = createState({ users: [{ ...JOHN }, { ...NED }, { ...BRANDON }] }); expect(state.users[0].id).toBe(1); diff --git a/packages/solid/web/test/suspense.spec.tsx b/packages/solid/web/test/suspense.spec.tsx index 911278c9e..e2cf2d93f 100644 --- a/packages/solid/web/test/suspense.spec.tsx +++ b/packages/solid/web/test/suspense.spec.tsx @@ -9,7 +9,7 @@ describe("Testing Suspense", () => { [triggered, trigger] = createSignal(false); const LazyComponent = lazy(() => new Promise(r => resolvers.push(r))), ChildComponent = (props: { greeting: string }) => { - let [value] = createResource( + const [value] = createResource( () => triggered() && "child", () => new Promise(r => setTimeout(() => r("Jo"), 300)), { initialValue: "" }