-
-
Notifications
You must be signed in to change notification settings - Fork 842
/
add-data.js
115 lines (98 loc) · 2.38 KB
/
add-data.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
"use strict"
import {measure} from "./measure"
import produce, {
setAutoFreeze,
setUseProxies,
enableAllPlugins
} from "../dist/immer.cjs.production.min.js"
import cloneDeep from "lodash.clonedeep"
import {fromJS} from "immutable"
import Seamless from "seamless-immutable"
import deepFreeze from "deep-freeze"
enableAllPlugins()
console.log("\n# add-data - loading large set of data\n")
const dataSet = require("./data.json")
const baseState = {
data: null
}
const frozenBazeState = deepFreeze(cloneDeep(baseState))
const immutableJsBaseState = fromJS(baseState)
const seamlessBaseState = Seamless.from(baseState)
const MAX = 10000
measure(
"just mutate",
() => ({draft: cloneDeep(baseState)}),
({draft}) => {
draft.data = dataSet
}
)
measure(
"just mutate, freeze",
() => ({draft: cloneDeep(baseState)}),
({draft}) => {
draft.data = dataSet
deepFreeze(draft)
}
)
measure("handcrafted reducer (no freeze)", () => {
const nextState = {
...baseState,
data: dataSet
}
})
measure("handcrafted reducer (with freeze)", () => {
const nextState = deepFreeze({
...baseState,
data: dataSet
})
})
measure("immutableJS", () => {
let state = immutableJsBaseState.withMutations(state => {
state.setIn(["data"], fromJS(dataSet))
})
})
measure("immutableJS + toJS", () => {
let state = immutableJsBaseState
.withMutations(state => {
state.setIn(["data"], fromJS(dataSet))
})
.toJS()
})
measure("seamless-immutable", () => {
seamlessBaseState.set("data", dataSet)
})
measure("seamless-immutable + asMutable", () => {
seamlessBaseState.set("data", dataSet).asMutable({deep: true})
})
measure("immer (proxy) - without autofreeze * " + MAX, () => {
setUseProxies(true)
setAutoFreeze(false)
for (let i = 0; i < MAX; i++)
produce(baseState, draft => {
draft.data = dataSet
})
})
measure("immer (proxy) - with autofreeze * " + MAX, () => {
setUseProxies(true)
setAutoFreeze(true)
for (let i = 0; i < MAX; i++)
produce(frozenBazeState, draft => {
draft.data = dataSet
})
})
measure("immer (es5) - without autofreeze * " + MAX, () => {
setUseProxies(false)
setAutoFreeze(false)
for (let i = 0; i < MAX; i++)
produce(baseState, draft => {
draft.data = dataSet
})
})
measure("immer (es5) - with autofreeze * " + MAX, () => {
setUseProxies(false)
setAutoFreeze(true)
for (let i = 0; i < MAX; i++)
produce(frozenBazeState, draft => {
draft.data = dataSet
})
})