feat(shared): support Map and Set in toDisplayString
close #1067, close #1100
This commit is contained in:
107
packages/shared/__tests__/toDisplayString.spec.ts
Normal file
107
packages/shared/__tests__/toDisplayString.spec.ts
Normal file
@@ -0,0 +1,107 @@
|
||||
import { toDisplayString } from '../src'
|
||||
|
||||
describe('toDisplayString', () => {
|
||||
test('nullish values', () => {
|
||||
expect(toDisplayString(null)).toBe('')
|
||||
expect(toDisplayString(undefined)).toBe('')
|
||||
})
|
||||
|
||||
test('primitive values', () => {
|
||||
expect(toDisplayString(1)).toBe('1')
|
||||
expect(toDisplayString(true)).toBe('true')
|
||||
expect(toDisplayString(false)).toBe('false')
|
||||
expect(toDisplayString('hello')).toBe('hello')
|
||||
})
|
||||
|
||||
test('Object and Arrays', () => {
|
||||
const obj = { foo: 123 }
|
||||
expect(toDisplayString(obj)).toBe(JSON.stringify(obj, null, 2))
|
||||
const arr = [obj]
|
||||
expect(toDisplayString(arr)).toBe(JSON.stringify(arr, null, 2))
|
||||
})
|
||||
|
||||
test('native objects', () => {
|
||||
const div = document.createElement('div')
|
||||
expect(toDisplayString(div)).toBe(`"[object HTMLDivElement]"`)
|
||||
expect(toDisplayString({ div })).toMatchInlineSnapshot(`
|
||||
"{
|
||||
\\"div\\": \\"[object HTMLDivElement]\\"
|
||||
}"
|
||||
`)
|
||||
})
|
||||
|
||||
test('Map and Set', () => {
|
||||
const m = new Map<any, any>([
|
||||
[1, 'foo'],
|
||||
[{ baz: 1 }, { foo: 'bar', qux: 2 }]
|
||||
])
|
||||
const s = new Set<any>([1, { foo: 'bar' }, m])
|
||||
|
||||
expect(toDisplayString(m)).toMatchInlineSnapshot(`
|
||||
"{
|
||||
\\"Map(2)\\": {
|
||||
\\"1 =>\\": \\"foo\\",
|
||||
\\"[object Object] =>\\": {
|
||||
\\"foo\\": \\"bar\\",
|
||||
\\"qux\\": 2
|
||||
}
|
||||
}
|
||||
}"
|
||||
`)
|
||||
expect(toDisplayString(s)).toMatchInlineSnapshot(`
|
||||
"{
|
||||
\\"Set(3)\\": [
|
||||
1,
|
||||
{
|
||||
\\"foo\\": \\"bar\\"
|
||||
},
|
||||
{
|
||||
\\"Map(2)\\": {
|
||||
\\"1 =>\\": \\"foo\\",
|
||||
\\"[object Object] =>\\": {
|
||||
\\"foo\\": \\"bar\\",
|
||||
\\"qux\\": 2
|
||||
}
|
||||
}
|
||||
}
|
||||
]
|
||||
}"
|
||||
`)
|
||||
|
||||
expect(
|
||||
toDisplayString({
|
||||
m,
|
||||
s
|
||||
})
|
||||
).toMatchInlineSnapshot(`
|
||||
"{
|
||||
\\"m\\": {
|
||||
\\"Map(2)\\": {
|
||||
\\"1 =>\\": \\"foo\\",
|
||||
\\"[object Object] =>\\": {
|
||||
\\"foo\\": \\"bar\\",
|
||||
\\"qux\\": 2
|
||||
}
|
||||
}
|
||||
},
|
||||
\\"s\\": {
|
||||
\\"Set(3)\\": [
|
||||
1,
|
||||
{
|
||||
\\"foo\\": \\"bar\\"
|
||||
},
|
||||
{
|
||||
\\"Map(2)\\": {
|
||||
\\"1 =>\\": \\"foo\\",
|
||||
\\"[object Object] =>\\": {
|
||||
\\"foo\\": \\"bar\\",
|
||||
\\"qux\\": 2
|
||||
}
|
||||
}
|
||||
}
|
||||
]
|
||||
}
|
||||
}"
|
||||
`)
|
||||
})
|
||||
})
|
||||
Reference in New Issue
Block a user