mirror of
https://github.com/pmndrs/zustand.git
synced 2025-12-08 19:45:52 +00:00
237 lines
5.7 KiB
TypeScript
237 lines
5.7 KiB
TypeScript
import { describe, expect, it } from 'vitest'
|
|
import { shallow } from 'zustand/shallow'
|
|
|
|
describe('shallow', () => {
|
|
it('compares primitive values', () => {
|
|
expect(shallow(true, true)).toBe(true)
|
|
expect(shallow(true, false)).toBe(false)
|
|
|
|
expect(shallow(1, 1)).toBe(true)
|
|
expect(shallow(1, 2)).toBe(false)
|
|
|
|
expect(shallow('zustand', 'zustand')).toBe(true)
|
|
expect(shallow('zustand', 'redux')).toBe(false)
|
|
})
|
|
|
|
it('compares objects', () => {
|
|
expect(shallow({ foo: 'bar', asd: 123 }, { foo: 'bar', asd: 123 })).toBe(
|
|
true,
|
|
)
|
|
|
|
expect(
|
|
shallow({ foo: 'bar', asd: 123 }, { foo: 'bar', foobar: true }),
|
|
).toBe(false)
|
|
|
|
expect(
|
|
shallow({ foo: 'bar', asd: 123 }, { foo: 'bar', asd: 123, foobar: true }),
|
|
).toBe(false)
|
|
})
|
|
|
|
it('compares arrays', () => {
|
|
expect(shallow([1, 2, 3], [1, 2, 3])).toBe(true)
|
|
|
|
expect(shallow([1, 2, 3], [2, 3, 4])).toBe(false)
|
|
|
|
expect(
|
|
shallow([{ foo: 'bar' }, { asd: 123 }], [{ foo: 'bar' }, { asd: 123 }]),
|
|
).toBe(false)
|
|
|
|
expect(shallow([{ foo: 'bar' }], [{ foo: 'bar', asd: 123 }])).toBe(false)
|
|
|
|
expect(shallow([1, 2, 3], [2, 3, 1])).toBe(false)
|
|
})
|
|
|
|
it('compares Maps', () => {
|
|
expect(
|
|
shallow(
|
|
new Map<string, unknown>([
|
|
['foo', 'bar'],
|
|
['asd', 123],
|
|
]),
|
|
new Map<string, unknown>([
|
|
['foo', 'bar'],
|
|
['asd', 123],
|
|
]),
|
|
),
|
|
).toBe(true)
|
|
|
|
expect(
|
|
shallow(
|
|
new Map<string, unknown>([
|
|
['foo', 'bar'],
|
|
['asd', 123],
|
|
]),
|
|
new Map<string, unknown>([
|
|
['asd', 123],
|
|
['foo', 'bar'],
|
|
]),
|
|
),
|
|
).toBe(true)
|
|
|
|
expect(
|
|
shallow(
|
|
new Map<string, unknown>([
|
|
['foo', 'bar'],
|
|
['asd', 123],
|
|
]),
|
|
new Map<string, unknown>([
|
|
['foo', 'bar'],
|
|
['foobar', true],
|
|
]),
|
|
),
|
|
).toBe(false)
|
|
|
|
expect(
|
|
shallow(
|
|
new Map<string, unknown>([
|
|
['foo', 'bar'],
|
|
['asd', 123],
|
|
]),
|
|
new Map<string, unknown>([
|
|
['foo', 'bar'],
|
|
['asd', 123],
|
|
['foobar', true],
|
|
]),
|
|
),
|
|
).toBe(false)
|
|
|
|
const obj = {}
|
|
const obj2 = {}
|
|
expect(
|
|
shallow(
|
|
new Map<object, unknown>([[obj, 'foo']]),
|
|
new Map<object, unknown>([[obj2, 'foo']]),
|
|
),
|
|
).toBe(false)
|
|
})
|
|
|
|
it('compares Sets', () => {
|
|
expect(shallow(new Set(['bar', 123]), new Set(['bar', 123]))).toBe(true)
|
|
|
|
expect(shallow(new Set(['bar', 123]), new Set([123, 'bar']))).toBe(true)
|
|
|
|
expect(shallow(new Set(['bar', 123]), new Set(['bar', 2]))).toBe(false)
|
|
|
|
expect(shallow(new Set(['bar', 123]), new Set(['bar', 123, true]))).toBe(
|
|
false,
|
|
)
|
|
|
|
const obj = {}
|
|
const obj2 = {}
|
|
expect(shallow(new Set([obj]), new Set([obj]))).toBe(true)
|
|
expect(shallow(new Set([obj]), new Set([obj2]))).toBe(false)
|
|
expect(shallow(new Set([obj]), new Set([obj, obj2]))).toBe(false)
|
|
expect(shallow(new Set([obj]), new Set([obj2, obj]))).toBe(false)
|
|
|
|
expect(shallow(['bar', 123] as never, new Set(['bar', 123]))).toBe(false)
|
|
})
|
|
|
|
it('compares functions', () => {
|
|
function firstFnCompare() {
|
|
return { foo: 'bar' }
|
|
}
|
|
|
|
function secondFnCompare() {
|
|
return { foo: 'bar' }
|
|
}
|
|
|
|
expect(shallow(firstFnCompare, firstFnCompare)).toBe(true)
|
|
|
|
expect(shallow(secondFnCompare, secondFnCompare)).toBe(true)
|
|
|
|
expect(shallow(firstFnCompare, secondFnCompare)).toBe(false)
|
|
})
|
|
|
|
it('compares URLSearchParams', () => {
|
|
expect(
|
|
shallow(new URLSearchParams({ a: 'a' }), new URLSearchParams({ a: 'a' })),
|
|
).toBe(true)
|
|
expect(
|
|
shallow(new URLSearchParams({ a: 'a' }), new URLSearchParams({ a: 'b' })),
|
|
).toBe(false)
|
|
expect(
|
|
shallow(new URLSearchParams({ a: 'a' }), new URLSearchParams({ b: 'b' })),
|
|
).toBe(false)
|
|
expect(
|
|
shallow(
|
|
new URLSearchParams({ a: 'a' }),
|
|
new URLSearchParams({ a: 'a', b: 'b' }),
|
|
),
|
|
).toBe(false)
|
|
expect(
|
|
shallow(
|
|
new URLSearchParams({ b: 'b', a: 'a' }),
|
|
new URLSearchParams({ a: 'a', b: 'b' }),
|
|
),
|
|
).toBe(true)
|
|
})
|
|
|
|
it('should work with nested arrays (#2794)', () => {
|
|
const arr = [1, 2]
|
|
expect(shallow([arr, 1], [arr, 1])).toBe(true)
|
|
})
|
|
|
|
it('should work with undefined (#3204)', () => {
|
|
expect(shallow({ a: undefined }, { b: 1 })).toBe(false)
|
|
})
|
|
})
|
|
|
|
describe('mixed cases', () => {
|
|
const obj = { 0: 'foo', 1: 'bar' }
|
|
const arr = ['foo', 'bar']
|
|
const set = new Set(['foo', 'bar'])
|
|
const map = new Map([
|
|
[0, 'foo'],
|
|
[1, 'bar'],
|
|
])
|
|
|
|
it('compares different data structures', () => {
|
|
expect(shallow<unknown>(obj, arr)).toBe(false)
|
|
expect(shallow<unknown>(obj, set)).toBe(false)
|
|
expect(shallow<unknown>(obj, map)).toBe(false)
|
|
expect(shallow<unknown>(arr, set)).toBe(false)
|
|
expect(shallow<unknown>(arr, map)).toBe(false)
|
|
expect(shallow<unknown>(set, map)).toBe(false)
|
|
})
|
|
})
|
|
|
|
describe('generators', () => {
|
|
it('pure iterable', () => {
|
|
function* gen() {
|
|
yield 1
|
|
yield 2
|
|
}
|
|
expect(Symbol.iterator in gen()).toBe(true)
|
|
expect(shallow(gen(), gen())).toBe(true)
|
|
})
|
|
|
|
it('pure iterable with different values returns false', () => {
|
|
const iterableA = {
|
|
[Symbol.iterator]: function* (): Generator<number> {
|
|
yield 1
|
|
yield 2
|
|
},
|
|
}
|
|
|
|
const iterableB = {
|
|
[Symbol.iterator]: function* (): Generator<number> {
|
|
yield 1
|
|
yield 3
|
|
},
|
|
}
|
|
|
|
expect(shallow(iterableA, iterableB)).toBe(false)
|
|
})
|
|
})
|
|
|
|
describe('unsupported cases', () => {
|
|
it('date', () => {
|
|
expect(
|
|
shallow(
|
|
new Date('2022-07-19T00:00:00.000Z'),
|
|
new Date('2022-07-20T00:00:00.000Z'),
|
|
),
|
|
).not.toBe(false)
|
|
})
|
|
})
|