@jscad/modeling 3.0.3-alpha.0 → 3.0.4-alpha.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +17 -0
- package/dist/jscad-modeling.es.js +2 -7
- package/dist/jscad-modeling.min.js +2 -7
- package/package.json +6 -7
- package/rollup.config.js +8 -4
- package/src/curves/bezier/arcLengthToT.js +1 -1
- package/src/curves/bezier/create.js +1 -1
- package/src/curves/bezier/index.js +7 -7
- package/src/curves/bezier/length.js +1 -1
- package/src/curves/bezier/lengths.js +2 -1
- package/src/curves/bezier/tangentAt.js +1 -1
- package/src/curves/bezier/valueAt.js +1 -1
- package/src/curves/index.js +3 -3
- package/src/geometries/geom2/applyTransforms.js +3 -1
- package/src/geometries/geom2/clone.js +5 -1
- package/src/geometries/geom2/create.js +4 -14
- package/src/geometries/geom2/fromSides.js +4 -2
- package/src/geometries/geom2/index.js +21 -5
- package/src/geometries/geom2/isA.js +5 -1
- package/src/geometries/geom2/reverse.js +4 -2
- package/src/geometries/geom2/toOutlines.js +2 -1
- package/src/geometries/geom2/toPoints.js +5 -2
- package/src/geometries/geom2/toSides.js +4 -3
- package/src/geometries/geom2/toString.js +3 -2
- package/src/geometries/geom2/transform.js +4 -2
- package/src/geometries/geom2/validate.js +6 -2
- package/src/geometries/geom3/clone.js +5 -1
- package/src/geometries/geom3/create.js +5 -19
- package/src/geometries/geom3/fromVertices.js +13 -1
- package/src/geometries/geom3/fromVerticesConvex.js +1 -1
- package/src/geometries/geom3/index.d.ts +1 -0
- package/src/geometries/geom3/index.js +26 -4
- package/src/geometries/geom3/invert.js +5 -1
- package/src/geometries/geom3/isA.js +5 -1
- package/src/geometries/geom3/isConvex.d.ts +3 -0
- package/src/geometries/geom3/isConvex.js +65 -0
- package/src/geometries/geom3/isConvex.test.js +44 -0
- package/src/geometries/geom3/toPolygons.js +4 -2
- package/src/geometries/geom3/toString.js +3 -2
- package/src/geometries/geom3/toVertices.js +8 -4
- package/src/geometries/geom3/transform.js +5 -2
- package/src/geometries/geom3/validate.js +6 -2
- package/src/geometries/index.js +9 -7
- package/src/geometries/path2/appendArc.js +7 -5
- package/src/geometries/path2/appendArc.test.js +11 -15
- package/src/geometries/path2/appendBezier.js +6 -4
- package/src/geometries/path2/appendPoints.js +4 -2
- package/src/geometries/path2/applyTransforms.js +3 -0
- package/src/geometries/path2/clone.js +5 -1
- package/src/geometries/path2/close.js +5 -1
- package/src/geometries/path2/concat.js +3 -2
- package/src/geometries/path2/create.js +4 -15
- package/src/geometries/path2/equals.js +12 -7
- package/src/geometries/path2/fromPoints.js +5 -3
- package/src/geometries/path2/index.js +21 -4
- package/src/geometries/path2/isA.js +5 -1
- package/src/geometries/path2/reverse.js +4 -2
- package/src/geometries/path2/toPoints.js +5 -3
- package/src/geometries/path2/toString.js +3 -2
- package/src/geometries/path2/transform.js +4 -2
- package/src/geometries/path2/validate.js +5 -1
- package/src/geometries/path3/applyTransforms.js +1 -1
- package/src/geometries/path3/close.js +4 -2
- package/src/geometries/path3/concat.js +2 -3
- package/src/geometries/path3/create.js +4 -20
- package/src/geometries/path3/equals.js +4 -2
- package/src/geometries/path3/fromVertices.js +2 -3
- package/src/geometries/path3/index.js +17 -1
- package/src/geometries/path3/isA.js +4 -2
- package/src/geometries/path3/reverse.js +2 -3
- package/src/geometries/path3/toString.js +2 -3
- package/src/geometries/path3/toVertices.js +2 -3
- package/src/geometries/path3/transform.js +2 -3
- package/src/geometries/path3/validate.js +6 -3
- package/src/geometries/poly2/arePointsInside.js +4 -1
- package/src/geometries/poly2/clone.js +4 -1
- package/src/geometries/poly2/create.js +2 -9
- package/src/geometries/poly2/index.js +16 -4
- package/src/geometries/poly2/isA.js +5 -1
- package/src/geometries/poly2/isConvex.js +5 -1
- package/src/geometries/poly2/isSimple.js +5 -1
- package/src/geometries/poly2/measureArea.js +4 -1
- package/src/geometries/poly2/measureBoundingBox.js +6 -1
- package/src/geometries/poly2/reverse.js +4 -1
- package/src/geometries/poly2/toPoints.js +6 -1
- package/src/geometries/poly2/toString.js +5 -1
- package/src/geometries/poly2/transform.js +5 -1
- package/src/geometries/poly2/validate.js +6 -2
- package/src/geometries/poly3/clone.js +4 -1
- package/src/geometries/poly3/create.js +3 -11
- package/src/geometries/poly3/fromVerticesAndPlane.js +3 -1
- package/src/geometries/poly3/index.js +19 -4
- package/src/geometries/poly3/invert.js +4 -1
- package/src/geometries/poly3/isA.js +5 -1
- package/src/geometries/poly3/isConvex.js +5 -1
- package/src/geometries/poly3/measureArea.js +5 -1
- package/src/geometries/poly3/measureBoundingBox.js +4 -1
- package/src/geometries/poly3/measureBoundingSphere.js +4 -3
- package/src/geometries/poly3/measureSignedVolume.js +6 -1
- package/src/geometries/poly3/plane.js +6 -0
- package/src/geometries/poly3/toString.js +5 -1
- package/src/geometries/poly3/toVertices.js +6 -1
- package/src/geometries/poly3/transform.js +5 -1
- package/src/geometries/poly3/validate.js +6 -2
- package/src/geometries/slice/calculatePlane.js +3 -3
- package/src/geometries/slice/clone.js +4 -1
- package/src/geometries/slice/create.js +5 -10
- package/src/geometries/slice/equals.js +5 -1
- package/src/geometries/slice/fromGeom2.js +1 -1
- package/src/geometries/slice/fromVertices.js +3 -3
- package/src/geometries/slice/index.js +19 -4
- package/src/geometries/slice/isA.js +5 -1
- package/src/geometries/slice/reverse.js +5 -2
- package/src/geometries/slice/toEdges.js +5 -3
- package/src/geometries/slice/toPolygons.js +5 -1
- package/src/geometries/slice/toString.js +5 -1
- package/src/geometries/slice/toVertices.js +5 -3
- package/src/geometries/slice/transform.js +4 -3
- package/src/geometries/slice/validate.js +3 -2
- package/src/index.d.ts +1 -0
- package/src/index.js +4 -0
- package/src/maths/constants.js +11 -7
- package/src/maths/index.js +2 -1
- package/src/maths/mat4/isOnlyTransformScale.js +1 -1
- package/src/operations/booleans/index.js +2 -0
- package/src/operations/booleans/intersect.js +0 -1
- package/src/operations/booleans/scission.js +0 -1
- package/src/operations/booleans/trees/splitLineSegmentByPlane.js +1 -4
- package/src/operations/booleans/trees/splitPolygonByPlane.test.js +138 -0
- package/src/operations/booleans/unionGeom3.test.js +35 -0
- package/src/operations/extrusions/extrudeFromSlices.js +15 -5
- package/src/operations/extrusions/extrudeRotate.js +2 -1
- package/src/operations/extrusions/extrudeRotate.test.js +34 -0
- package/src/operations/extrusions/extrudeWalls.test.js +60 -0
- package/src/operations/minkowski/index.d.ts +1 -0
- package/src/operations/minkowski/index.js +15 -0
- package/src/operations/minkowski/minkowskiSum.d.ts +4 -0
- package/src/operations/minkowski/minkowskiSum.js +223 -0
- package/src/operations/minkowski/minkowskiSum.test.js +199 -0
- package/src/operations/modifiers/reTesselateCoplanarPolygons.js +10 -3
- package/src/operations/modifiers/reTesselateCoplanarPolygons.test.js +36 -1
- package/src/operations/modifiers/retessellate.js +4 -2
- package/src/operations/modifiers/snap.test.js +24 -15
- package/src/operations/offsets/offsetGeom3.test.js +5 -7
- package/src/primitives/arc.js +2 -2
- package/src/primitives/arc.test.js +104 -113
- package/src/utils/flatten.js +1 -1
- package/src/utils/flatten.test.js +94 -0
|
@@ -13,205 +13,196 @@ test('arc (defaults)', (t) => {
|
|
|
13
13
|
const obs = path2.toPoints(geometry)
|
|
14
14
|
|
|
15
15
|
t.notThrows(() => path2.validate(geometry))
|
|
16
|
-
t.is(obs.length,
|
|
16
|
+
t.is(obs.length, 32)
|
|
17
17
|
})
|
|
18
18
|
|
|
19
19
|
test('arc (options)', (t) => {
|
|
20
20
|
// test center
|
|
21
21
|
let exp = [
|
|
22
22
|
[3, 2],
|
|
23
|
-
[2.
|
|
24
|
-
[2.
|
|
25
|
-
[2.
|
|
26
|
-
[2
|
|
27
|
-
[1.
|
|
28
|
-
[1.
|
|
29
|
-
[1.
|
|
30
|
-
[1
|
|
31
|
-
[1.
|
|
32
|
-
[1.
|
|
33
|
-
[1.
|
|
34
|
-
[
|
|
35
|
-
[2.
|
|
36
|
-
[2.
|
|
37
|
-
[2.
|
|
38
|
-
[2.9324722294043557, 1.6387583338128469]
|
|
23
|
+
[2.923879532511287, 2.3826834323650896],
|
|
24
|
+
[2.7071067811865475, 2.7071067811865475],
|
|
25
|
+
[2.3826834323650896, 2.923879532511287],
|
|
26
|
+
[2, 3],
|
|
27
|
+
[1.6173165676349104, 2.923879532511287],
|
|
28
|
+
[1.2928932188134525, 2.7071067811865475],
|
|
29
|
+
[1.0761204674887133, 2.38268343236509],
|
|
30
|
+
[1, 2],
|
|
31
|
+
[1.076120467488713, 1.6173165676349104],
|
|
32
|
+
[1.2928932188134523, 1.2928932188134525],
|
|
33
|
+
[1.6173165676349097, 1.0761204674887135],
|
|
34
|
+
[2, 1],
|
|
35
|
+
[2.38268343236509, 1.0761204674887135],
|
|
36
|
+
[2.7071067811865475, 1.2928932188134523],
|
|
37
|
+
[2.9238795325112865, 1.6173165676349095]
|
|
39
38
|
]
|
|
40
39
|
let geometry = arc({ center: [2, 2], segments: 16 })
|
|
41
40
|
let obs = path2.toPoints(geometry)
|
|
42
41
|
|
|
43
42
|
t.notThrows(() => path2.validate(geometry))
|
|
44
|
-
t.is(obs.length,
|
|
43
|
+
t.is(obs.length, 16)
|
|
45
44
|
t.true(comparePoints(obs, exp))
|
|
46
45
|
|
|
47
46
|
// test radius
|
|
48
47
|
exp = [
|
|
49
48
|
[2, 0],
|
|
50
|
-
[1.
|
|
51
|
-
[1.
|
|
52
|
-
[0.
|
|
53
|
-
[0
|
|
54
|
-
[-0.
|
|
55
|
-
[-1.
|
|
56
|
-
[-1.
|
|
57
|
-
[-
|
|
58
|
-
[-1.
|
|
59
|
-
[-1.
|
|
60
|
-
[-
|
|
61
|
-
[
|
|
62
|
-
[0.
|
|
63
|
-
[
|
|
64
|
-
[1.
|
|
65
|
-
[1.8649444588087116, -0.7224833323743061]
|
|
49
|
+
[1.8477590650225735, 0.7653668647301796],
|
|
50
|
+
[1.4142135623730951, 1.414213562373095],
|
|
51
|
+
[0.7653668647301797, 1.8477590650225735],
|
|
52
|
+
[0, 2],
|
|
53
|
+
[-0.7653668647301795, 1.8477590650225735],
|
|
54
|
+
[-1.414213562373095, 1.4142135623730951],
|
|
55
|
+
[-1.8477590650225735, 0.7653668647301798],
|
|
56
|
+
[-2, 0],
|
|
57
|
+
[-1.8477590650225737, -0.7653668647301793],
|
|
58
|
+
[-1.4142135623730954, -1.414213562373095],
|
|
59
|
+
[-0.7653668647301807, -1.847759065022573],
|
|
60
|
+
[0, -2],
|
|
61
|
+
[0.76536686473018, -1.8477590650225733],
|
|
62
|
+
[1.4142135623730947, -1.4142135623730954],
|
|
63
|
+
[1.847759065022573, -0.7653668647301808]
|
|
66
64
|
]
|
|
67
65
|
geometry = arc({ radius: 2, segments: 16 })
|
|
68
66
|
obs = path2.toPoints(geometry)
|
|
69
67
|
|
|
70
68
|
t.notThrows(() => path2.validate(geometry))
|
|
71
|
-
t.is(obs.length,
|
|
69
|
+
t.is(obs.length, 16)
|
|
72
70
|
t.true(comparePoints(obs, exp))
|
|
73
71
|
|
|
74
72
|
// test startAngle
|
|
75
73
|
exp = [
|
|
76
|
-
[
|
|
77
|
-
[-0.
|
|
78
|
-
[-0.
|
|
79
|
-
[-0.
|
|
80
|
-
[-
|
|
81
|
-
[-0.
|
|
82
|
-
[-0.
|
|
83
|
-
[-0.
|
|
84
|
-
[
|
|
85
|
-
[0.
|
|
86
|
-
[0.
|
|
87
|
-
[0.
|
|
88
|
-
[
|
|
89
|
-
[1, -2.4492935982947064e-16]
|
|
74
|
+
[0, 1],
|
|
75
|
+
[-0.3826834323650897, 0.9238795325112867],
|
|
76
|
+
[-0.7071067811865475, 0.7071067811865476],
|
|
77
|
+
[-0.9238795325112867, 0.3826834323650899],
|
|
78
|
+
[-1, 0],
|
|
79
|
+
[-0.9238795325112868, -0.38268343236508967],
|
|
80
|
+
[-0.7071067811865477, -0.7071067811865475],
|
|
81
|
+
[-0.38268343236509034, -0.9238795325112865],
|
|
82
|
+
[0, -1],
|
|
83
|
+
[0.38268343236509, -0.9238795325112866],
|
|
84
|
+
[0.7071067811865474, -0.7071067811865477],
|
|
85
|
+
[0.9238795325112865, -0.3826834323650904],
|
|
86
|
+
[1, 0]
|
|
90
87
|
]
|
|
91
88
|
geometry = arc({ startAngle: TAU / 4, segments: 16 })
|
|
92
89
|
obs = path2.toPoints(geometry)
|
|
93
90
|
|
|
94
91
|
t.notThrows(() => path2.validate(geometry))
|
|
95
|
-
t.is(obs.length,
|
|
92
|
+
t.is(obs.length, 13)
|
|
96
93
|
t.true(comparePoints(obs, exp))
|
|
97
94
|
|
|
98
95
|
// test endAngle
|
|
99
96
|
exp = [
|
|
100
97
|
[1, 0],
|
|
101
|
-
[0.
|
|
102
|
-
[0.
|
|
103
|
-
[0.
|
|
104
|
-
[0
|
|
105
|
-
[6.123233995736766e-17, 1]
|
|
98
|
+
[0.9238795325112867, 0.3826834323650898],
|
|
99
|
+
[0.7071067811865476, 0.7071067811865475],
|
|
100
|
+
[0.38268343236508984, 0.9238795325112867],
|
|
101
|
+
[0, 1]
|
|
106
102
|
]
|
|
107
103
|
geometry = arc({ endAngle: TAU / 4, segments: 16 })
|
|
108
104
|
obs = path2.toPoints(geometry)
|
|
109
105
|
|
|
110
106
|
t.notThrows(() => path2.validate(geometry))
|
|
111
|
-
t.is(obs.length,
|
|
107
|
+
t.is(obs.length, 5)
|
|
112
108
|
t.true(comparePoints(obs, exp))
|
|
113
109
|
|
|
114
110
|
// test makeTangent
|
|
115
111
|
exp = [
|
|
116
112
|
[1, 0],
|
|
117
|
-
[0.
|
|
118
|
-
[0.
|
|
119
|
-
[0.
|
|
120
|
-
[0.
|
|
121
|
-
[0.
|
|
122
|
-
[-0.
|
|
123
|
-
[-0.
|
|
124
|
-
[-0.
|
|
125
|
-
[-
|
|
126
|
-
[-0.
|
|
127
|
-
[-0.
|
|
128
|
-
[-0.
|
|
129
|
-
[-0.
|
|
130
|
-
[0.
|
|
131
|
-
[0.
|
|
132
|
-
[0.
|
|
133
|
-
[0.
|
|
134
|
-
[0.9957341762950345, -0.09226835946330197]
|
|
113
|
+
[0.9951847266721969, 0.0980171403295606],
|
|
114
|
+
[0.8876396204028539, 0.46053871095824],
|
|
115
|
+
[0.6531728429537769, 0.7572088465064846],
|
|
116
|
+
[0.325310292162263, 0.9456073253805213],
|
|
117
|
+
[-0.04906767432741801, 0.9987954562051724],
|
|
118
|
+
[-0.416429560097637, 0.9091679830905225],
|
|
119
|
+
[-0.7242470829514668, 0.689540544737067],
|
|
120
|
+
[-0.9285060804732155, 0.3713171939518377],
|
|
121
|
+
[-1, 0],
|
|
122
|
+
[-0.9285060804732156, -0.37131719395183743],
|
|
123
|
+
[-0.724247082951467, -0.6895405447370668],
|
|
124
|
+
[-0.4164295600976372, -0.9091679830905224],
|
|
125
|
+
[-0.04906767432741803, -0.9987954562051724],
|
|
126
|
+
[0.3253102921622629, -0.9456073253805213],
|
|
127
|
+
[0.6531728429537768, -0.7572088465064846],
|
|
128
|
+
[0.8876396204028539, -0.46053871095823995],
|
|
129
|
+
[0.9951847266721969, -0.0980171403295605]
|
|
135
130
|
]
|
|
136
131
|
geometry = arc({ makeTangent: true, segments: 16 })
|
|
137
132
|
obs = path2.toPoints(geometry)
|
|
138
133
|
|
|
139
134
|
t.notThrows(() => path2.validate(geometry))
|
|
140
|
-
t.is(obs.length,
|
|
135
|
+
t.is(obs.length, 18)
|
|
141
136
|
t.true(comparePoints(obs, exp))
|
|
142
137
|
|
|
143
138
|
// test segments
|
|
144
139
|
exp = [
|
|
145
140
|
[1, 0],
|
|
146
|
-
[0.
|
|
147
|
-
[0
|
|
148
|
-
[-0.
|
|
149
|
-
[-
|
|
150
|
-
[-0.
|
|
151
|
-
[
|
|
152
|
-
[0.
|
|
153
|
-
[0.7660444431189778, -0.6427876096865396]
|
|
141
|
+
[0.7071067811865476, 0.7071067811865475],
|
|
142
|
+
[0, 1],
|
|
143
|
+
[-0.7071067811865475, 0.7071067811865476],
|
|
144
|
+
[-1, 0],
|
|
145
|
+
[-0.7071067811865477, -0.7071067811865475],
|
|
146
|
+
[0, -1],
|
|
147
|
+
[0.7071067811865474, -0.7071067811865477]
|
|
154
148
|
]
|
|
155
149
|
geometry = arc({ segments: 8 })
|
|
156
150
|
obs = path2.toPoints(geometry)
|
|
157
151
|
|
|
158
152
|
t.notThrows(() => path2.validate(geometry))
|
|
159
|
-
t.is(obs.length,
|
|
153
|
+
t.is(obs.length, 8)
|
|
160
154
|
t.true(comparePoints(obs, exp))
|
|
161
155
|
})
|
|
162
156
|
|
|
163
157
|
test('arc (rotations)', (t) => {
|
|
164
158
|
let exp = [
|
|
165
|
-
[
|
|
166
|
-
[-0.
|
|
167
|
-
[-0.
|
|
168
|
-
[-0.
|
|
169
|
-
[-
|
|
170
|
-
[-1, 1.2246467991473532e-16]
|
|
159
|
+
[0, 1],
|
|
160
|
+
[-0.3826834323650897, 0.9238795325112867],
|
|
161
|
+
[-0.7071067811865475, 0.7071067811865476],
|
|
162
|
+
[-0.9238795325112867, 0.3826834323650899],
|
|
163
|
+
[-1, 0]
|
|
171
164
|
]
|
|
172
165
|
let geometry = arc({ startAngle: TAU / 4, endAngle: TAU / 2, segments: 16 })
|
|
173
166
|
let obs = path2.toPoints(geometry)
|
|
174
167
|
|
|
175
168
|
t.notThrows(() => path2.validate(geometry))
|
|
176
|
-
t.is(obs.length,
|
|
169
|
+
t.is(obs.length, 5)
|
|
177
170
|
t.true(comparePoints(obs, exp))
|
|
178
171
|
|
|
179
172
|
exp = [
|
|
180
|
-
[-1,
|
|
181
|
-
[-0.
|
|
182
|
-
[-0.
|
|
183
|
-
[-0.
|
|
184
|
-
[
|
|
185
|
-
[0.
|
|
186
|
-
[0.
|
|
187
|
-
[0.
|
|
188
|
-
[
|
|
189
|
-
[1, -2.4492935982947064e-16]
|
|
173
|
+
[-1, 0],
|
|
174
|
+
[-0.9238795325112868, -0.38268343236508967],
|
|
175
|
+
[-0.7071067811865477, -0.7071067811865475],
|
|
176
|
+
[-0.38268343236509034, -0.9238795325112865],
|
|
177
|
+
[0, -1],
|
|
178
|
+
[0.38268343236509, -0.9238795325112866],
|
|
179
|
+
[0.7071067811865474, -0.7071067811865477],
|
|
180
|
+
[0.9238795325112865, -0.3826834323650904],
|
|
181
|
+
[1, 0]
|
|
190
182
|
]
|
|
191
183
|
geometry = arc({ startAngle: TAU / 2, endAngle: TAU, segments: 16 })
|
|
192
184
|
obs = path2.toPoints(geometry)
|
|
193
185
|
|
|
194
186
|
t.notThrows(() => path2.validate(geometry))
|
|
195
|
-
t.is(obs.length,
|
|
187
|
+
t.is(obs.length, 9)
|
|
196
188
|
t.true(comparePoints(obs, exp))
|
|
197
189
|
|
|
198
190
|
exp = [
|
|
199
|
-
[
|
|
200
|
-
[0.
|
|
201
|
-
[0.
|
|
202
|
-
[0.
|
|
203
|
-
[
|
|
204
|
-
[0.
|
|
205
|
-
[0.
|
|
206
|
-
[0.
|
|
207
|
-
[0
|
|
208
|
-
[3.061616997868383e-16, 1]
|
|
191
|
+
[0, -1],
|
|
192
|
+
[0.38268343236509, -0.9238795325112866],
|
|
193
|
+
[0.7071067811865474, -0.7071067811865477],
|
|
194
|
+
[0.9238795325112865, -0.3826834323650904],
|
|
195
|
+
[1, 0],
|
|
196
|
+
[0.9238795325112867, 0.38268343236508995],
|
|
197
|
+
[0.7071067811865477, 0.7071067811865474],
|
|
198
|
+
[0.38268343236509045, 0.9238795325112865],
|
|
199
|
+
[0, 1]
|
|
209
200
|
]
|
|
210
201
|
geometry = arc({ startAngle: TAU * 0.75, endAngle: TAU / 4, segments: 16 })
|
|
211
202
|
obs = path2.toPoints(geometry)
|
|
212
203
|
|
|
213
204
|
t.notThrows(() => path2.validate(geometry))
|
|
214
|
-
t.is(obs.length,
|
|
205
|
+
t.is(obs.length, 9)
|
|
215
206
|
t.true(comparePoints(obs, exp))
|
|
216
207
|
|
|
217
208
|
exp = [[-1.8369701987210297e-16, -1]]
|
package/src/utils/flatten.js
CHANGED
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
import test from 'ava'
|
|
2
|
+
|
|
3
|
+
import { flatten } from './index.js'
|
|
4
|
+
|
|
5
|
+
test('flatten: test an empty array returns empty.', (t) => {
|
|
6
|
+
t.deepEqual(flatten([]), [])
|
|
7
|
+
})
|
|
8
|
+
|
|
9
|
+
test('flatten: test a flat array is unchanged.', (t) => {
|
|
10
|
+
t.deepEqual(flatten([1, 2, 3]), [1, 2, 3])
|
|
11
|
+
})
|
|
12
|
+
|
|
13
|
+
test('flatten: test single level nesting is flattened.', (t) => {
|
|
14
|
+
t.deepEqual(flatten([1, [2, 3], 4]), [1, 2, 3, 4])
|
|
15
|
+
t.deepEqual(flatten([[1, 2], [3, 4]]), [1, 2, 3, 4])
|
|
16
|
+
t.deepEqual(flatten([[1], [2], [3]]), [1, 2, 3])
|
|
17
|
+
})
|
|
18
|
+
|
|
19
|
+
test('flatten: test deep nesting is flattened.', (t) => {
|
|
20
|
+
t.deepEqual(flatten([1, [2, [3, [4]]]]), [1, 2, 3, 4])
|
|
21
|
+
t.deepEqual(flatten([[[[1]]]]), [1])
|
|
22
|
+
t.deepEqual(flatten([1, [2, [3, [4, [5]]]]]), [1, 2, 3, 4, 5])
|
|
23
|
+
})
|
|
24
|
+
|
|
25
|
+
test('flatten: test mixed nesting depths are flattened.', (t) => {
|
|
26
|
+
t.deepEqual(flatten([1, [2, 3], [[4, 5]], [[[6]]]]), [1, 2, 3, 4, 5, 6])
|
|
27
|
+
})
|
|
28
|
+
|
|
29
|
+
test('flatten: test empty nested arrays are removed.', (t) => {
|
|
30
|
+
t.deepEqual(flatten([[]]), [])
|
|
31
|
+
t.deepEqual(flatten([[], []]), [])
|
|
32
|
+
t.deepEqual(flatten([1, [], 2]), [1, 2])
|
|
33
|
+
t.deepEqual(flatten([[], [1], []]), [1])
|
|
34
|
+
})
|
|
35
|
+
|
|
36
|
+
test('flatten: test single element arrays are flattened.', (t) => {
|
|
37
|
+
t.deepEqual(flatten([1]), [1])
|
|
38
|
+
t.deepEqual(flatten([[1]]), [1])
|
|
39
|
+
t.deepEqual(flatten([[[1]]]), [1])
|
|
40
|
+
})
|
|
41
|
+
|
|
42
|
+
test('flatten: test element order is preserved.', (t) => {
|
|
43
|
+
t.deepEqual(flatten([1, [2, 3], 4, [5, 6]]), [1, 2, 3, 4, 5, 6])
|
|
44
|
+
t.deepEqual(flatten([[1, 2], 3, [4, [5, 6]]]), [1, 2, 3, 4, 5, 6])
|
|
45
|
+
})
|
|
46
|
+
|
|
47
|
+
test('flatten: test object references are preserved.', (t) => {
|
|
48
|
+
const obj1 = { id: 1 }
|
|
49
|
+
const obj2 = { id: 2 }
|
|
50
|
+
const obj3 = { id: 3 }
|
|
51
|
+
const result = flatten([obj1, [obj2, obj3]])
|
|
52
|
+
t.is(result[0], obj1)
|
|
53
|
+
t.is(result[1], obj2)
|
|
54
|
+
t.is(result[2], obj3)
|
|
55
|
+
})
|
|
56
|
+
|
|
57
|
+
test('flatten: test various types are preserved.', (t) => {
|
|
58
|
+
const obj = { a: 1 }
|
|
59
|
+
const fn = () => {}
|
|
60
|
+
t.deepEqual(flatten([1, 'string', null, undefined, true]), [1, 'string', null, undefined, true])
|
|
61
|
+
|
|
62
|
+
const result = flatten([obj, [fn]])
|
|
63
|
+
t.is(result[0], obj)
|
|
64
|
+
t.is(result[1], fn)
|
|
65
|
+
})
|
|
66
|
+
|
|
67
|
+
test('flatten: test large flat array is unchanged.', (t) => {
|
|
68
|
+
const large = []
|
|
69
|
+
for (let i = 0; i < 1000; i++) {
|
|
70
|
+
large.push(i)
|
|
71
|
+
}
|
|
72
|
+
const result = flatten(large)
|
|
73
|
+
t.is(result.length, 1000)
|
|
74
|
+
t.is(result[0], 0)
|
|
75
|
+
t.is(result[999], 999)
|
|
76
|
+
})
|
|
77
|
+
|
|
78
|
+
test('flatten: test large nested array is flattened.', (t) => {
|
|
79
|
+
const nested = []
|
|
80
|
+
for (let i = 0; i < 100; i++) {
|
|
81
|
+
nested.push([i * 10, i * 10 + 1, i * 10 + 2])
|
|
82
|
+
}
|
|
83
|
+
const result = flatten(nested)
|
|
84
|
+
t.is(result.length, 300)
|
|
85
|
+
t.is(result[0], 0)
|
|
86
|
+
t.is(result[3], 10)
|
|
87
|
+
})
|
|
88
|
+
|
|
89
|
+
test('flatten: test input array is not modified.', (t) => {
|
|
90
|
+
const input = [1, [2, 3], 4]
|
|
91
|
+
const inputCopy = JSON.stringify(input)
|
|
92
|
+
flatten(input)
|
|
93
|
+
t.is(JSON.stringify(input), inputCopy)
|
|
94
|
+
})
|