@woosh/meep-engine 2.110.14 → 2.110.15

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.
Files changed (435) hide show
  1. package/package.json +4 -2
  2. package/editor/actions/concrete/ModifyPatchSampler2DAction.spec.js +0 -30
  3. package/src/core/IdPool.spec.js +0 -29
  4. package/src/core/UUID.spec.js +0 -8
  5. package/src/core/binary/32BitEncoder.spec.js +0 -11
  6. package/src/core/binary/Base64.spec.js +0 -14
  7. package/src/core/binary/BinaryBuffer.spec.js +0 -324
  8. package/src/core/binary/BitSet.spec.js +0 -468
  9. package/src/core/binary/EncodingBinaryBuffer.spec.js +0 -16
  10. package/src/core/binary/align_32.spec.js +0 -11
  11. package/src/core/binary/align_4.spec.js +0 -20
  12. package/src/core/binary/data_view/DataViewStructAccessor.spec.js +0 -20
  13. package/src/core/binary/de_interleave_2_bits.spec.js +0 -21
  14. package/src/core/binary/dec2hex.spec.js +0 -13
  15. package/src/core/binary/hex2dec.spec.js +0 -22
  16. package/src/core/binary/int32_to_binary_string.spec.js +0 -9
  17. package/src/core/binary/operations/bitCount.spec.js +0 -19
  18. package/src/core/binary/operations/ceilPowerOfTwo.spec.js +0 -17
  19. package/src/core/binary/reverse_bits_uint32.spec.js +0 -18
  20. package/src/core/binary/split_by_2.spec.js +0 -22
  21. package/src/core/binary/split_by_3.spec.js +0 -22
  22. package/src/core/binary/uint8_to_float.spec.js +0 -7
  23. package/src/core/bvh2/binary/2/BinaryUint32BVH.spec.js +0 -136
  24. package/src/core/bvh2/bvh3/BVH.spec.js +0 -361
  25. package/src/core/bvh2/bvh3/BvhClient.spec.js +0 -51
  26. package/src/core/bvh2/bvh3/ebvh_build_for_geometry_morton.spec.js +0 -60
  27. package/src/core/bvh2/bvh3/query/bvh_query_leaves_generic.spec.js +0 -22
  28. package/src/core/bvh2/bvh3/query/bvh_query_leaves_ray.spec.js +0 -64
  29. package/src/core/bvh2/bvh3/query/bvh_query_user_data_generic.spec.js +0 -29
  30. package/src/core/bvh2/bvh3/query/bvh_query_user_data_nearest_to_point.spec.js +0 -209
  31. package/src/core/bvh2/bvh3/query/compute_tight_near_far_clipping_planes.spec.js +0 -41
  32. package/src/core/cache/Cache.spec.js +0 -277
  33. package/src/core/cache/FrequencySketch.spec.js +0 -5
  34. package/src/core/cache/LoadingCache.spec.js +0 -120
  35. package/src/core/codegen/LineBuilder.spec.js +0 -41
  36. package/src/core/collection/CuckooFilter.spec.js +0 -111
  37. package/src/core/collection/RingBuffer.spec.js +0 -59
  38. package/src/core/collection/Stack.spec.js +0 -63
  39. package/src/core/collection/array/arrayPickBestElement.spec.js +0 -7
  40. package/src/core/collection/array/arraySetSortingDiff.spec.js +0 -74
  41. package/src/core/collection/array/array_contains_duplicates.spec.js +0 -14
  42. package/src/core/collection/array/array_copy.spec.js +0 -19
  43. package/src/core/collection/array/array_deduplicate.spec.js +0 -11
  44. package/src/core/collection/array/array_get_index_in_range.spec.js +0 -16
  45. package/src/core/collection/array/array_remove_first.spec.js +0 -39
  46. package/src/core/collection/array/array_shuffle.spec.js +0 -27
  47. package/src/core/collection/array/binarySearchHighIndex.spec.js +0 -51
  48. package/src/core/collection/array/isArrayEqual.spec.js +0 -25
  49. package/src/core/collection/array/typed/is_typed_array_equals.spec.js +0 -71
  50. package/src/core/collection/array/weightedRandomFromArray.spec.js +0 -22
  51. package/src/core/collection/heap/BinaryHeap.spec.js +0 -137
  52. package/src/core/collection/heap/Uint32Heap.spec.js +0 -172
  53. package/src/core/collection/list/List.spec.js +0 -438
  54. package/src/core/collection/list/ListForwarder.spec.js +0 -101
  55. package/src/core/collection/map/HashMap.spec.js +0 -291
  56. package/src/core/collection/queue/Deque.spec.js +0 -276
  57. package/src/core/collection/set/HashSet.spec.js +0 -39
  58. package/src/core/collection/set/compute_set_difference.spec.js +0 -45
  59. package/src/core/collection/set/compute_set_intersection.spec.js +0 -45
  60. package/src/core/collection/table/RowFirstTable.spec.js +0 -323
  61. package/src/core/collection/table/RowFirstTableSpec.spec.js +0 -49
  62. package/src/core/collection/table/bind/TableRecord.spec.js +0 -27
  63. package/src/core/color/Color.spec.js +0 -174
  64. package/src/core/color/YCbCr/YCbCr.spec.js +0 -16
  65. package/src/core/color/hex/hex2rgb.spec.js +0 -10
  66. package/src/core/color/hex/rgb2hex.spec.js +0 -13
  67. package/src/core/color/hsv/hsv2rgb.spec.js +0 -43
  68. package/src/core/color/kelvin/kelvin_to_rgb.spec.js +0 -61
  69. package/src/core/color/kelvin/rgb_to_kelvin.spec.js +0 -15
  70. package/src/core/color/oklab/Okhsv.spec.js +0 -17
  71. package/src/core/color/oklab/XYZ.spec.js +0 -17
  72. package/src/core/color/oklab/oklab_to_xyz.spec.js +0 -31
  73. package/src/core/color/oklab/xyz_to_oklab.spec.js +0 -31
  74. package/src/core/color/parse_color.spec.js +0 -18
  75. package/src/core/color/sRGB/sRGB.spec.js +0 -16
  76. package/src/core/color/xyz/XYZ.spec.js +0 -16
  77. package/src/core/events/signal/Signal.spec.js +0 -253
  78. package/src/core/events/signal/SignalBinding.spec.js +0 -58
  79. package/src/core/fsm/simple/SimpleStateMachine.spec.js +0 -107
  80. package/src/core/fsm/simple/SimpleStateMachineDescription.spec.js +0 -103
  81. package/src/core/function/extractFunctionBody.spec.js +0 -15
  82. package/src/core/geom/2d/Rectangle.spec.js +0 -62
  83. package/src/core/geom/2d/aabb/AABB2.spec.js +0 -153
  84. package/src/core/geom/2d/aabb/aabb2_compute_center_from_multiple.spec.js +0 -11
  85. package/src/core/geom/2d/aabb/aabb2_compute_overlap.spec.js +0 -56
  86. package/src/core/geom/2d/aabb/aabb2_contains.spec.js +0 -40
  87. package/src/core/geom/2d/aabb/aabb2_distance_to_point.spec.js +0 -17
  88. package/src/core/geom/2d/aabb/aabb2_intersects_ray.spec.js +0 -28
  89. package/src/core/geom/2d/aabb/aabb2_signed_distance_sqr_to_point.spec.js +0 -40
  90. package/src/core/geom/2d/bvh/BVH2D.spec.js +0 -359
  91. package/src/core/geom/2d/bvh/bvh2d_query_all_data_by_circle.spec.js +0 -89
  92. package/src/core/geom/2d/circle/circle_compute_circle_intersection.spec.js +0 -79
  93. package/src/core/geom/2d/compute_polygon_area_2d.spec.js +0 -10
  94. package/src/core/geom/2d/compute_triangle_area_2d.spec.js +0 -9
  95. package/src/core/geom/2d/convex-hull/convex_hull_jarvis_2d.spec.js +0 -33
  96. package/src/core/geom/2d/convex-hull/convex_hull_monotone_2d.spec.js +0 -33
  97. package/src/core/geom/2d/hash-grid/SpatialHashGrid.spec.js +0 -254
  98. package/src/core/geom/2d/hash-grid/shg_query_elements_circle.spec.js +0 -85
  99. package/src/core/geom/2d/hash-grid/shg_query_elements_line.spec.js +0 -102
  100. package/src/core/geom/2d/quad-tree/QuadTreeNode.spec.js +0 -235
  101. package/src/core/geom/2d/quad-tree/qt_match_data_by_circle.spec.js +0 -86
  102. package/src/core/geom/2d/quad-tree-binary/QuadTree.spec.js +0 -53
  103. package/src/core/geom/2d/r-tree/StaticR2Tree.spec.js +0 -62
  104. package/src/core/geom/2d/spline_bezier2_2d.spec.js +0 -16
  105. package/src/core/geom/2d/uv_map_circle_to_square.spec.js +0 -28
  106. package/src/core/geom/2d/uv_map_square_to_circle.spec.js +0 -30
  107. package/src/core/geom/3d/SurfacePoint3.spec.js +0 -116
  108. package/src/core/geom/3d/aabb/AABB3.spec.js +0 -257
  109. package/src/core/geom/3d/aabb/aabb3_array_intersects_point.spec.js +0 -48
  110. package/src/core/geom/3d/aabb/aabb3_build_corners.spec.js +0 -27
  111. package/src/core/geom/3d/aabb/aabb3_compute_distance_above_plane_max.spec.js +0 -8
  112. package/src/core/geom/3d/aabb/aabb3_compute_plane_side.spec.js +0 -25
  113. package/src/core/geom/3d/aabb/aabb3_corner_edge_mapping.spec.js +0 -39
  114. package/src/core/geom/3d/aabb/aabb3_edge_corner_mapping.spec.js +0 -32
  115. package/src/core/geom/3d/aabb/aabb3_expand_array.spec.js +0 -16
  116. package/src/core/geom/3d/aabb/aabb3_from_v3_array.spec.js +0 -32
  117. package/src/core/geom/3d/aabb/aabb3_intersects_aabb3.spec.js +0 -115
  118. package/src/core/geom/3d/aabb/aabb3_intersects_ray.spec.js +0 -161
  119. package/src/core/geom/3d/aabb/aabb3_matrix4_project.spec.js +0 -54
  120. package/src/core/geom/3d/aabb/aabb3_raycast.spec.js +0 -37
  121. package/src/core/geom/3d/aabb/aabb3_score_boxes_SAH.spec.js +0 -14
  122. package/src/core/geom/3d/cone/computeConePlaneSide.spec.js +0 -13
  123. package/src/core/geom/3d/cone/compute_bounding_cone_of_2_cones.spec.js +0 -95
  124. package/src/core/geom/3d/line/line3_compute_nearest_point_to_point.spec.js +0 -61
  125. package/src/core/geom/3d/mat4/MATRIX_4_IDENTITY.spec.js +0 -10
  126. package/src/core/geom/3d/mat4/m4_multiply.spec.js +0 -34
  127. package/src/core/geom/3d/mat4/m4_multiply_alphatensor.spec.js +0 -35
  128. package/src/core/geom/3d/morton/v3_morton_encode_transformed.spec.js +0 -20
  129. package/src/core/geom/3d/normal/hemioct/unit_hemioct.spec.js +0 -41
  130. package/src/core/geom/3d/normal/octahedron/encoding.spec.js +0 -54
  131. package/src/core/geom/3d/plane/plane3_projectPoint.spec.js +0 -54
  132. package/src/core/geom/3d/plane/plane3_slerp.spec.js +0 -209
  133. package/src/core/geom/3d/ray/ray3_array_compose.spec.js +0 -14
  134. package/src/core/geom/3d/shape/TransformedShape3D.spec.js +0 -55
  135. package/src/core/geom/3d/shape/UnitCubeShape3D.spec.js +0 -42
  136. package/src/core/geom/3d/sphere/harmonics/sh3_dering_optimize_positive.spec.js +0 -53
  137. package/src/core/geom/3d/sphere/harmonics/sh3_vector_accumulate.spec.js +0 -27
  138. package/src/core/geom/3d/sphere/sphere_intersects_point.spec.js +0 -134
  139. package/src/core/geom/3d/sphere/sphere_intersects_ray.spec.js +0 -60
  140. package/src/core/geom/3d/sphere/sphere_radius_sqr_from_v3_array_transformed.spec.js +0 -8
  141. package/src/core/geom/3d/tetrahedra/TetrahedralMesh.spec.js +0 -233
  142. package/src/core/geom/3d/tetrahedra/compute_bounding_simplex_3d.spec.js +0 -66
  143. package/src/core/geom/3d/tetrahedra/delaunay/compute_delaunay_tetrahedral_mesh.spec.js +0 -36
  144. package/src/core/geom/3d/tetrahedra/delaunay/tetrahedral_mesh_build_from_grid.spec.js +0 -61
  145. package/src/core/geom/3d/tetrahedra/delaunay/tetrahedral_mesh_compute_sub_determinant.spec.js +0 -30
  146. package/src/core/geom/3d/tetrahedra/tetrahedron_compute_signed_volume.spec.js +0 -24
  147. package/src/core/geom/3d/tetrahedra/tetrahedron_contains_point.spec.js +0 -66
  148. package/src/core/geom/3d/topology/simplify/collapseEdge.spec.js +0 -24
  149. package/src/core/geom/3d/topology/struct/TopoEdge.spec.js +0 -52
  150. package/src/core/geom/3d/topology/struct/TopoVertex.spec.js +0 -128
  151. package/src/core/geom/3d/topology/struct/binary/BinaryElementPool.spec.js +0 -36
  152. package/src/core/geom/3d/topology/struct/binary/BinaryTopology.spec.js +0 -16
  153. package/src/core/geom/3d/topology/struct/binary/io/bt_index_geometry_to_topology.spec.js +0 -84
  154. package/src/core/geom/3d/topology/struct/binary/query/bt_mesh_edge_has_vertex.spec.js +0 -15
  155. package/src/core/geom/3d/topology/struct/binary/query/bt_mesh_edge_other_vertex.spec.js +0 -16
  156. package/src/core/geom/3d/triangle/computeTriangleClosestPointToPointBarycentric.spec.js +0 -100
  157. package/src/core/geom/3d/triangle/computeTriangleRayIntersection.spec.js +0 -25
  158. package/src/core/geom/3d/triangle/computeTriangleRayIntersectionBarycentric.spec.js +0 -26
  159. package/src/core/geom/3d/v3_compute_triangle_normal.spec.js +0 -46
  160. package/src/core/geom/ConicRay.spec.js +0 -24
  161. package/src/core/geom/Quaternion.spec.js +0 -429
  162. package/src/core/geom/Vector1.spec.js +0 -74
  163. package/src/core/geom/Vector2.spec.js +0 -295
  164. package/src/core/geom/Vector3.spec.js +0 -285
  165. package/src/core/geom/Vector4.spec.js +0 -11
  166. package/src/core/geom/normalize_angle_rad.spec.js +0 -45
  167. package/src/core/geom/packing/computeBoundingSphereOfSpheres.spec.js +0 -24
  168. package/src/core/geom/packing/max-rect/MaxRectanglesPacker.spec.js +0 -60
  169. package/src/core/geom/packing/miniball/Miniball.spec.js +0 -35
  170. package/src/core/geom/packing/miniball/Subspan.spec.js +0 -51
  171. package/src/core/geom/random/randomPointOnBox.spec.js +0 -57
  172. package/src/core/geom/vec/vector_normalize.spec.js +0 -15
  173. package/src/core/geom/vec3/v3_angle_cos_between.spec.js +0 -124
  174. package/src/core/geom/vec3/v3_displace_in_direction.spec.js +0 -80
  175. package/src/core/geom/vec3/v3_distance_above_plane.spec.js +0 -40
  176. package/src/core/graph/Edge.spec.js +0 -85
  177. package/src/core/graph/SquareMatrix.spec.js +0 -102
  178. package/src/core/graph/coloring/colorizeGraphGreedy.spec.js +0 -26
  179. package/src/core/graph/convert_graph_to_dot_string.spec.js +0 -28
  180. package/src/core/graph/eigen/matrix_eigenvalues_in_place.spec.js +0 -57
  181. package/src/core/graph/graph_k_means_cluster.spec.js +0 -23
  182. package/src/core/graph/mn_graph_coarsen.spec.js +0 -45
  183. package/src/core/graph/v2/Graph.spec.js +0 -364
  184. package/src/core/json/resolvePath.spec.js +0 -14
  185. package/src/core/lang/reactive/compileReactiveExpression.spec.js +0 -169
  186. package/src/core/math/bessel_j0.spec.js +0 -43
  187. package/src/core/math/clamp.spec.js +0 -15
  188. package/src/core/math/computeGreatestCommonDivisor.spec.js +0 -9
  189. package/src/core/math/computeIsoscelesTriangleApexAngle.spec.js +0 -6
  190. package/src/core/math/computeWholeDivisorLow.spec.js +0 -9
  191. package/src/core/math/copysign.spec.js +0 -13
  192. package/src/core/math/epsilonEquals.spec.js +0 -17
  193. package/src/core/math/factorial.spec.js +0 -9
  194. package/src/core/math/fract.spec.js +0 -11
  195. package/src/core/math/hash/computeHashFloatArray.spec.js +0 -11
  196. package/src/core/math/hash/computeObjectHash.spec.js +0 -42
  197. package/src/core/math/hash/murmur3_32.spec.js +0 -8
  198. package/src/core/math/hash/squirrel3.spec.js +0 -16
  199. package/src/core/math/iabs.spec.js +0 -9
  200. package/src/core/math/interval/NumericInterval.spec.js +0 -89
  201. package/src/core/math/interval/isValueBetween.spec.js +0 -11
  202. package/src/core/math/interval/isValueBetweenInclusive.spec.js +0 -16
  203. package/src/core/math/interval/overlap1D.spec.js +0 -10
  204. package/src/core/math/inverseLerp.spec.js +0 -13
  205. package/src/core/math/isPowerOfTwo.spec.js +0 -9
  206. package/src/core/math/isqrt.spec.js +0 -9
  207. package/src/core/math/lerp.spec.js +0 -15
  208. package/src/core/math/linalg/solve_linear_system.spec.js +0 -70
  209. package/src/core/math/max.spec.js +0 -25
  210. package/src/core/math/max2.spec.js +0 -13
  211. package/src/core/math/max3.spec.js +0 -29
  212. package/src/core/math/min2.spec.js +0 -37
  213. package/src/core/math/min3.spec.js +0 -29
  214. package/src/core/math/newton_solver_1d.spec.js +0 -9
  215. package/src/core/math/nextOdd.spec.js +0 -9
  216. package/src/core/math/noise/create_simplex_noise_2d.spec.js +0 -21
  217. package/src/core/math/noise/sdnoise.spec.js +0 -87
  218. package/src/core/math/physics/irradiance/interpolate_irradiance_linear.spec.js +0 -20
  219. package/src/core/math/physics/irradiance/interpolate_irradiance_lograrithmic.spec.js +0 -18
  220. package/src/core/math/physics/irradiance/interpolate_irradiance_smith.spec.js +0 -20
  221. package/src/core/math/pingpong.spec.js +0 -11
  222. package/src/core/math/random/MersenneTwister.spec.js +0 -19
  223. package/src/core/math/random/randomFloatBetween.spec.js +0 -9
  224. package/src/core/math/random/randomGaussian.spec.js +0 -9
  225. package/src/core/math/random/randomIntegerBetween.spec.js +0 -8
  226. package/src/core/math/random/roundFair.spec.js +0 -12
  227. package/src/core/math/random/seededRandomMersenneTwister.spec.js +0 -10
  228. package/src/core/math/random/seededRandom_Mulberry32.spec.js +0 -19
  229. package/src/core/math/remap.spec.js +0 -15
  230. package/src/core/math/sign.spec.js +0 -13
  231. package/src/core/math/smoothStep.spec.js +0 -16
  232. package/src/core/math/smootherStep.spec.js +0 -16
  233. package/src/core/math/solveQuadratic.spec.js +0 -18
  234. package/src/core/math/spline/cubicCurve.spec.js +0 -13
  235. package/src/core/math/spline/makeCubicCurve.spec.js +0 -9
  236. package/src/core/math/spline/spline_bezier2.spec.js +0 -13
  237. package/src/core/math/spline/spline_bezier3_bounds.spec.js +0 -37
  238. package/src/core/math/spline/spline_hermite3.spec.js +0 -18
  239. package/src/core/math/spline/spline_hermite3_bounds.spec.js +0 -37
  240. package/src/core/math/statistics/computeSampleSize_Cochran.spec.js +0 -12
  241. package/src/core/math/statistics/computeStatisticalMean.spec.js +0 -9
  242. package/src/core/math/statistics/computeStatisticalPartialMedian.spec.js +0 -13
  243. package/src/core/math/statistics/computeStatisticalPercentile.spec.js +0 -11
  244. package/src/core/math/statistics/computeStatisticalVariance.spec.js +0 -10
  245. package/src/core/math/statistics/halton_sequence.spec.js +0 -40
  246. package/src/core/math/statistics/radical_inverse_VdC_base_2.spec.js +0 -9
  247. package/src/core/math/statistics/softmax.spec.js +0 -9
  248. package/src/core/model/BooleanVector3.spec.js +0 -51
  249. package/src/core/model/BoundedValue.spec.js +0 -17
  250. package/src/core/model/ModuleRegistry.spec.js +0 -31
  251. package/src/core/model/ObservedBoolean.spec.js +0 -81
  252. package/src/core/model/ObservedInteger.spec.js +0 -51
  253. package/src/core/model/node-graph/Connection.spec.js +0 -33
  254. package/src/core/model/node-graph/NodeGraph.spec.js +0 -107
  255. package/src/core/model/node-graph/node/NodeDescription.spec.js +0 -81
  256. package/src/core/model/node-graph/node/NodeInstance.spec.js +0 -82
  257. package/src/core/model/node-graph/node/NodeInstancePortReference.spec.js +0 -109
  258. package/src/core/model/node-graph/node/NodeRegistry.spec.js +0 -123
  259. package/src/core/model/node-graph/node/Port.spec.js +0 -102
  260. package/src/core/model/node-graph/type/DataType.spec.js +0 -47
  261. package/src/core/model/node-graph/type/ParametricDataType.spec.js +0 -63
  262. package/src/core/model/node-graph/visual/PortVisualData.spec.js +0 -16
  263. package/src/core/model/object/ObjectPoolFactory.spec.js +0 -54
  264. package/src/core/model/object/objectDeepEquals.spec.js +0 -54
  265. package/src/core/model/object/write_property.spec.js +0 -26
  266. package/src/core/model/reactive/evaluation/MultiPredicateEvaluator.spec.js +0 -158
  267. package/src/core/model/reactive/js/compileReactiveToJS.spec.js +0 -14
  268. package/src/core/model/reactive/model/logic/ReactiveAnd.spec.js +0 -51
  269. package/src/core/model/reactive/model/logic/ReactiveOr.spec.js +0 -53
  270. package/src/core/model/reactive/model/terminal/ReactiveReference.spec.js +0 -26
  271. package/src/core/model/reactive/trigger/BlackboardTrigger.spec.js +0 -24
  272. package/src/core/model/reactive/trigger/ReactiveTrigger.spec.js +0 -5
  273. package/src/core/model/stat/LinearModifier.spec.js +0 -96
  274. package/src/core/model/stat/Stat.spec.js +0 -111
  275. package/src/core/parser/simple/readHexToken.spec.js +0 -21
  276. package/src/core/parser/simple/readIdentifierToken.spec.js +0 -32
  277. package/src/core/parser/simple/readNumberToken.spec.js +0 -17
  278. package/src/core/parser/simple/readReferenceToken.spec.js +0 -18
  279. package/src/core/parser/simple/readStringToken.spec.js +0 -57
  280. package/src/core/parser/simple/readUnsignedIntegerToken.spec.js +0 -6
  281. package/src/core/path/computeFileExtension.spec.js +0 -13
  282. package/src/core/path/computePathBase.spec.js +0 -13
  283. package/src/core/path/computePathDirectory.spec.js +0 -8
  284. package/src/core/primitives/array/computeStridedIntegerArrayHash.spec.js +0 -28
  285. package/src/core/primitives/numbers/computeHashFloat.spec.js +0 -14
  286. package/src/core/primitives/numbers/number_compare_ascending.spec.js +0 -9
  287. package/src/core/primitives/numbers/number_compare_descending.spec.js +0 -9
  288. package/src/core/primitives/numbers/number_format_by_thousands.spec.js +0 -12
  289. package/src/core/primitives/numbers/number_pretty_print.spec.js +0 -19
  290. package/src/core/primitives/strings/compareStrings.spec.js +0 -12
  291. package/src/core/primitives/strings/computeStringHash.spec.js +0 -20
  292. package/src/core/primitives/strings/insert_after.spec.js +0 -16
  293. package/src/core/primitives/strings/insert_before.spec.js +0 -16
  294. package/src/core/primitives/strings/string_capitalize.spec.js +0 -13
  295. package/src/core/primitives/strings/string_compute_common_prefix.spec.js +0 -23
  296. package/src/core/primitives/strings/string_format_camel_to_kebab.spec.js +0 -8
  297. package/src/core/primitives/strings/string_jaro_winkler.spec.js +0 -39
  298. package/src/core/primitives/strings/string_strip_trailing.spec.js +0 -27
  299. package/src/core/process/PromiseWatcher.spec.js +0 -69
  300. package/src/core/process/executor/ConcurrentExecutor.spec.js +0 -135
  301. package/src/core/process/task/util/actionTask.spec.js +0 -14
  302. package/src/core/process/task/util/countTask.spec.js +0 -18
  303. package/src/core/process/undo/ActionProcessor.spec.js +0 -64
  304. package/src/engine/Clock.spec.js +0 -26
  305. package/src/engine/Engine.spec.js +0 -15
  306. package/src/engine/achievements/Achievement.spec.js +0 -21
  307. package/src/engine/animation/curve/AnimationCurve.spec.js +0 -248
  308. package/src/engine/animation/curve/Keyframe.spec.js +0 -42
  309. package/src/engine/animation/curve/animation_curve_optimize.spec.js +0 -50
  310. package/src/engine/animation/curve/compression/downsample_float_array_curve_by_error.spec.js +0 -47
  311. package/src/engine/animation/curve/compression/sample_animation_curve_to_float_array.spec.js +0 -29
  312. package/src/engine/animation/keyed2/AnimationTrackPlayback.spec.js +0 -94
  313. package/src/engine/asset/AssetDescription.spec.js +0 -27
  314. package/src/engine/asset/AssetManager.spec.js +0 -50
  315. package/src/engine/asset/loaders/image/png/PNG.spec.js +0 -5
  316. package/src/engine/asset/loaders/image/png/PNGReader.spec.js +0 -5
  317. package/src/engine/asset/loaders/image/png/crc.spec.js +0 -15
  318. package/src/engine/control/ControlContext.spec.js +0 -81
  319. package/src/engine/ecs/Entity.spec.js +0 -188
  320. package/src/engine/ecs/EntityBlueprint.spec.js +0 -52
  321. package/src/engine/ecs/EntityComponentDataset.spec.js +0 -895
  322. package/src/engine/ecs/EntityManager.spec.js +0 -210
  323. package/src/engine/ecs/EntityObserver.spec.js +0 -184
  324. package/src/engine/ecs/animation/Animation.spec.js +0 -22
  325. package/src/engine/ecs/animation/AnimationClip.spec.js +0 -5
  326. package/src/engine/ecs/components/Tag.spec.js +0 -47
  327. package/src/engine/ecs/dynamic_actions/rules/DynamicRuleDescriptionTable.spec.js +0 -126
  328. package/src/engine/ecs/fow/FogOfWar.spec.js +0 -13
  329. package/src/engine/ecs/guid/UUID.spec.js +0 -100
  330. package/src/engine/ecs/guid/UUIDSerializationAdapter.spec.js +0 -21
  331. package/src/engine/ecs/parent/EntityNode.spec.js +0 -104
  332. package/src/engine/ecs/renderable/Renderable.spec.js +0 -10
  333. package/src/engine/ecs/storage/binary/BinarySerializationRegistry.spec.js +0 -139
  334. package/src/engine/ecs/storage/binary/collection/BinaryCollectionSerialization.spec.js +0 -259
  335. package/src/engine/ecs/storage/binary/object/BinaryObjectSerializationAdapter.spec.js +0 -59
  336. package/src/engine/ecs/storage/binary/object/BinaryObjectSerializationAdapter2.spec.js +0 -123
  337. package/src/engine/ecs/terrain/ecs/Terrain.spec.js +0 -5
  338. package/src/engine/ecs/terrain/ecs/cling/ClingToTerrainSystem.spec.js +0 -38
  339. package/src/engine/ecs/terrain/overlay/TerrainOverlay.spec.js +0 -6
  340. package/src/engine/ecs/terrain/tiles/TerrainTile.spec.js +0 -25
  341. package/src/engine/ecs/tooltip/TooltipComponent.spec.js +0 -47
  342. package/src/engine/ecs/transform/Transform.spec.js +0 -310
  343. package/src/engine/ecs/transform/TransformSerializationAdapter.spec.js +0 -28
  344. package/src/engine/ecs/transform-attachment/TransformAttachment.spec.js +0 -103
  345. package/src/engine/graphics/ecs/animation/animator/graph/AnimationGraph.spec.js +0 -5
  346. package/src/engine/graphics/ecs/animation/animator/graph/definition/AnimationGraphDefinition.spec.js +0 -5
  347. package/src/engine/graphics/ecs/camera/topdown/TopDownCameraController.spec.js +0 -94
  348. package/src/engine/graphics/ecs/decal/v2/Decal.spec.js +0 -5
  349. package/src/engine/graphics/ecs/mesh-v2/ShadedGeometry.spec.js +0 -19
  350. package/src/engine/graphics/ecs/mesh-v2/aggregate/SGMesh.spec.js +0 -5
  351. package/src/engine/graphics/ecs/mesh-v2/render/adapters/SGCacheKey.spec.js +0 -79
  352. package/src/engine/graphics/ecs/path/tube/TubePathStyle.spec.js +0 -5
  353. package/src/engine/graphics/ecs/path/tube/build/build_geometry_catmullrom.spec.js +0 -32
  354. package/src/engine/graphics/geometry/MikkT/MikkTSpace.spec.js +0 -28
  355. package/src/engine/graphics/geometry/bvh/buffered/bvh32_from_unindexed_geometry.spec.js +0 -22
  356. package/src/engine/graphics/particles/particular/engine/MovingBoundingBox.spec.js +0 -70
  357. package/src/engine/graphics/particles/particular/engine/emitter/ParticleEmitter.spec.js +0 -47
  358. package/src/engine/graphics/particles/particular/engine/emitter/ParticleLayer.spec.js +0 -100
  359. package/src/engine/graphics/particles/particular/engine/emitter/ParticlePool.spec.js +0 -225
  360. package/src/engine/graphics/particles/particular/engine/parameter/ParameterLookupTable.spec.js +0 -215
  361. package/src/engine/graphics/particles/particular/engine/parameter/ParameterSet.spec.js +0 -75
  362. package/src/engine/graphics/particles/particular/group/ParticleGroup.spec.js +0 -270
  363. package/src/engine/graphics/render/buffer/slot/parameter/ProgramValueSlotParameter.spec.js +0 -21
  364. package/src/engine/graphics/render/forward_plus/LightManager.spec.js +0 -94
  365. package/src/engine/graphics/render/forward_plus/cluster/write_cluster_planes.spec.js +0 -79
  366. package/src/engine/graphics/render/visibility/IncrementalDeltaSet.spec.js +0 -102
  367. package/src/engine/graphics/texture/atlas/CachingTextureAtlas.spec.js +0 -78
  368. package/src/engine/graphics/texture/atlas/TextureAtlas.spec.js +0 -319
  369. package/src/engine/graphics/texture/sampler/HarmonicDiffusionGrid.spec.js +0 -99
  370. package/src/engine/graphics/texture/sampler/Sampler2D.spec.js +0 -224
  371. package/src/engine/graphics/texture/sampler/copy_Sampler2D_channel_data.spec.js +0 -90
  372. package/src/engine/graphics/texture/sampler/distance/computeSignedDistanceField_NaiveFlood.spec.js +0 -183
  373. package/src/engine/graphics/texture/sampler/distance/computeUnsignedDistanceField.spec.js +0 -183
  374. package/src/engine/graphics/texture/sampler/resize/sampler2d_scale.spec.js +0 -73
  375. package/src/engine/graphics/texture/sampler/resize/sampler2d_scale_down_lanczos.spec.js +0 -31
  376. package/src/engine/graphics/texture/sampler/resize/sampler2d_scale_down_linear.spec.js +0 -44
  377. package/src/engine/graphics/texture/sampler/resize/sampler2d_scale_down_mipmap.spec.js +0 -13
  378. package/src/engine/graphics/texture/sampler/resize/sampler2d_scale_up_linear.spec.js +0 -14
  379. package/src/engine/graphics/texture/sampler/sampler2d_channel_compute_max.spec.js +0 -40
  380. package/src/engine/graphics/texture/sampler/sampler2d_channel_compute_min_indices.spec.js +0 -15
  381. package/src/engine/graphics/texture/sampler/sampler2d_copy_with_margins.spec.js +0 -31
  382. package/src/engine/graphics/texture/sampler/sampler2d_to_data_url.spec.js +0 -10
  383. package/src/engine/graphics/texture/sampler/sampler2d_to_uint8_RGBA.spec.js +0 -52
  384. package/src/engine/graphics/texture/sampler/serialization/TextureBinaryBufferSerializer.spec.js +0 -38
  385. package/src/engine/graphics/three/expand_aabb_by_transformed_three_object.spec.js +0 -108
  386. package/src/engine/graphics/trail/x/RibbonX.spec.js +0 -5
  387. package/src/engine/grid/obstacle/GridObstacle.spec.js +0 -175
  388. package/src/engine/input/devices/InputDeviceSwitch.spec.js +0 -5
  389. package/src/engine/input/devices/KeyboardDevice.spec.js +0 -12
  390. package/src/engine/input/devices/PointerDevice.spec.js +0 -12
  391. package/src/engine/intelligence/behavior/Behavior.spec.js +0 -15
  392. package/src/engine/intelligence/behavior/SelectorBehavior.spec.js +0 -18
  393. package/src/engine/intelligence/behavior/behavior_to_dot.spec.js +0 -25
  394. package/src/engine/intelligence/behavior/composite/ParallelBehavior.spec.js +0 -166
  395. package/src/engine/intelligence/behavior/composite/SequenceBehavior.spec.js +0 -17
  396. package/src/engine/intelligence/behavior/decorator/RepeatBehavior.spec.js +0 -32
  397. package/src/engine/intelligence/behavior/ecs/BehaviorSystem.spec.js +0 -75
  398. package/src/engine/intelligence/behavior/util/ConditionBehavior.spec.js +0 -24
  399. package/src/engine/intelligence/blackboard/Blackboard.spec.js +0 -111
  400. package/src/engine/intelligence/blackboard/BlackboardSerializationAdapter.spec.js +0 -30
  401. package/src/engine/intelligence/blackboard/make_blackboard_proxy.spec.js +0 -23
  402. package/src/engine/intelligence/mcts/MonteCarlo.spec.js +0 -244
  403. package/src/engine/intelligence/mcts/StateNode.spec.js +0 -49
  404. package/src/engine/intelligence/optimization/RandomOptimizer.spec.js +0 -57
  405. package/src/engine/intelligence/resource/ResourceAllocationSolver.spec.js +0 -104
  406. package/src/engine/intelligence/resource/StrategicResourceAllocator.spec.js +0 -46
  407. package/src/engine/knowledge/database/StaticKnowledgeDataTable.spec.js +0 -26
  408. package/src/engine/knowledge/database/StaticKnowledgeDatabase.spec.js +0 -23
  409. package/src/engine/navigation/ecs/components/Path.spec.js +0 -195
  410. package/src/engine/navigation/ecs/path_following/PathFollower.spec.js +0 -27
  411. package/src/engine/navigation/grid/find_path_on_grid_astar.spec.js +0 -87
  412. package/src/engine/notify/NotificationLog.spec.js +0 -17
  413. package/src/engine/options/Option.spec.js +0 -69
  414. package/src/engine/options/OptionGroup.spec.js +0 -61
  415. package/src/engine/physics/gjk/expanding_polytope_algorithm.spec.js +0 -46
  416. package/src/engine/physics/inverse_kinematics/fabrik/fabrik3d_solve_primitive.spec.js +0 -43
  417. package/src/engine/plugin/EnginePlugin.spec.js +0 -5
  418. package/src/engine/reference/v2/Reference.spec.js +0 -44
  419. package/src/engine/scene/Scene.spec.js +0 -20
  420. package/src/engine/scene/SceneManager.spec.js +0 -131
  421. package/src/engine/sound/ecs/emitter/SoundEmitterSerializationAdapter.spec.js +0 -49
  422. package/src/engine/ui/tiles2d/TileGrid.spec.js +0 -20
  423. package/src/engine/ui/tiles2d/computeTileGridMove.spec.js +0 -54
  424. package/src/generation/automata/CaveGeneratorCellularAutomata.spec.js +0 -12
  425. package/src/generation/filtering/numeric/complex/CellFilterAngleToNormal.spec.js +0 -30
  426. package/src/generation/filtering/numeric/complex/CellFilterGaussianBlur.spec.js +0 -17
  427. package/src/generation/filtering/numeric/process/computeCellFilterGradient.spec.js +0 -288
  428. package/src/generation/grid/GridData.spec.js +0 -46
  429. package/src/generation/markers/actions/probability/MarkerNodeActionSelectWeighted.spec.js +0 -116
  430. package/src/generation/markers/transform/MarkerNodeTransformerYRotateByFilterGradient.spec.js +0 -106
  431. package/src/generation/placement/action/GridCellActionPlaceTags.spec.js +0 -21
  432. package/src/generation/rules/CellMatcherLayerBitMaskTest.spec.js +0 -22
  433. package/src/generation/rules/cell/GridPatternMatcher.spec.js +0 -285
  434. package/src/generation/theme/ThemeEngine.spec.js +0 -7
  435. package/src/view/tooltip/gml/TooltipParser.spec.js +0 -142
@@ -1,29 +0,0 @@
1
- import { BVH } from "../BVH.js";
2
- import { bvh_query_user_data_generic } from "./bvh_query_user_data_generic.js";
3
- import { BVHQueryAny } from "./BVHQueryAny.js";
4
-
5
- test("all-accepting query", () => {
6
- const bvh = new BVH();
7
-
8
- const leaf_a = bvh.allocate_node();
9
- const leaf_b = bvh.allocate_node();
10
-
11
- bvh.node_set_user_data(leaf_a, 7);
12
- bvh.node_set_user_data(leaf_b, 13);
13
-
14
- bvh.insert_leaf(leaf_a);
15
- bvh.insert_leaf(leaf_b);
16
-
17
- const result = [];
18
-
19
- const count = bvh_query_user_data_generic(
20
- result, 1,
21
- bvh, bvh.root,
22
- BVHQueryAny.INSTANCE
23
- );
24
-
25
- expect(count).toBe(2);
26
- expect(result).toContain(7);
27
- expect(result).toContain(13);
28
-
29
- });
@@ -1,209 +0,0 @@
1
- import { aabb3_unsigned_distance_sqr_to_point } from "../../../geom/3d/aabb/aabb3_unsigned_distance_sqr_to_point.js";
2
- import { randomFloatBetween } from "../../../math/random/randomFloatBetween.js";
3
- import { seededRandom } from "../../../math/random/seededRandom.js";
4
- import { BVH } from "../BVH.js";
5
- import { bvh_query_user_data_nearest_to_point } from "./bvh_query_user_data_nearest_to_point.js";
6
-
7
- /**
8
- *
9
- * @param {number[]} boxes
10
- * @return {BVH}
11
- */
12
- function makeBvh(...boxes) {
13
- const r = new BVH();
14
-
15
- for (let i = 0; i < boxes.length; i++) {
16
- const box = boxes[i];
17
-
18
- const node = r.allocate_node();
19
-
20
- r.node_set_aabb(node, box);
21
- r.node_set_user_data(node, i);
22
-
23
- r.insert_leaf(node);
24
- }
25
-
26
- return r;
27
- }
28
-
29
- test('no data, infinite distance', () => {
30
- const bvh = makeBvh();
31
-
32
- const result = bvh_query_user_data_nearest_to_point(bvh, 0, 0, 0, Infinity);
33
-
34
- expect(result).toBe(-1);
35
- });
36
-
37
- test('single point, distance too short', () => {
38
- const bvh = makeBvh([1, 0, 0, 1, 0, 0]);
39
-
40
- const result = bvh_query_user_data_nearest_to_point(bvh, 0, 0, 0, 0.5);
41
-
42
- expect(result).toBe(-1);
43
- });
44
-
45
- test('single point, distance sufficient', () => {
46
- const bvh = makeBvh([1, 0, 0, 1, 0, 0]);
47
-
48
- const result = bvh_query_user_data_nearest_to_point(bvh, 0, 0, 0, 1.5);
49
-
50
- expect(result).not.toBe(-1);
51
- });
52
-
53
- test('two point, distance sufficient to one', () => {
54
- const bvh = makeBvh(
55
- [1, 0, 0, 1, 0, 0],
56
- [2, 0, 0, 2, 0, 0],
57
- );
58
-
59
- const result = bvh_query_user_data_nearest_to_point(bvh, 0, 0, 0, 1.5);
60
-
61
- expect(result).toBe(0);
62
- });
63
-
64
- test('two point, distance sufficient to both', () => {
65
- const bvh = makeBvh(
66
- [1, 0, 0, 1, 0, 0],
67
- [2, 0, 0, 2, 0, 0],
68
- );
69
-
70
- const result = bvh_query_user_data_nearest_to_point(bvh, 0, 0, 0, 2.5);
71
-
72
- expect(result).toBe(0);
73
- });
74
-
75
-
76
- test.skip("performance, 1M random boxes, 10k queries", () => {
77
-
78
- const random = seededRandom(1);
79
-
80
- const bvh = new BVH();
81
-
82
- const min_bound = -1000;
83
- const max_bound = 1000;
84
-
85
- const OBJECT_COUNT = 1000000;
86
-
87
- for (let i = 0; i < OBJECT_COUNT; i++) {
88
- const node = bvh.allocate_node();
89
-
90
- bvh.node_set_user_data(node, i);
91
-
92
- const x = randomFloatBetween(random, min_bound, max_bound);
93
- const y = randomFloatBetween(random, min_bound, max_bound);
94
- const z = randomFloatBetween(random, min_bound, max_bound);
95
-
96
- const extents = randomFloatBetween(random, 1, 50);
97
-
98
- const x0 = x - extents;
99
- const y0 = y - extents;
100
- const z0 = z - extents;
101
-
102
- const x1 = x + extents;
103
- const y1 = y + extents;
104
- const z1 = z + extents;
105
-
106
- bvh.node_set_aabb_primitive(
107
- node,
108
- x0, y0, z0,
109
- x1, y1, z1
110
- );
111
-
112
- bvh.insert_leaf(node);
113
- }
114
-
115
- const SAMPLE_POINT_COUNT = 10000;
116
-
117
- const t0 = performance.now();
118
-
119
- for (let i = 0; i < SAMPLE_POINT_COUNT; i++) {
120
-
121
- const x = randomFloatBetween(random, min_bound, max_bound);
122
- const y = randomFloatBetween(random, min_bound, max_bound);
123
- const z = randomFloatBetween(random, min_bound, max_bound);
124
-
125
- bvh_query_user_data_nearest_to_point(
126
- bvh, x, y, z
127
- );
128
- }
129
-
130
- const t1 = performance.now();
131
-
132
- const duration = (t1 - t0);
133
-
134
- console.log(`${duration / SAMPLE_POINT_COUNT}ms/query`);
135
- });
136
-
137
- test.skip('naive search, 1m random boxes, 10k queries', () => {
138
-
139
- const random = seededRandom(1);
140
-
141
- const OBJECT_COUNT = 1000000;
142
-
143
- const boxes = new Float32Array(OBJECT_COUNT * 6);
144
-
145
- const min_bound = -1000;
146
- const max_bound = 1000;
147
-
148
- const extents = 25;
149
-
150
- for (let i = 0; i < OBJECT_COUNT; i++) {
151
- const address = i * 6;
152
-
153
- const x = randomFloatBetween(random, min_bound, max_bound);
154
- const y = randomFloatBetween(random, min_bound, max_bound);
155
- const z = randomFloatBetween(random, min_bound, max_bound);
156
-
157
- boxes[address] = x - extents;
158
- boxes[address + 1] = y - extents;
159
- boxes[address + 2] = z - extents;
160
-
161
- boxes[address + 3] = x + extents;
162
- boxes[address + 4] = y + extents;
163
- boxes[address + 5] = z + extents;
164
-
165
- }
166
-
167
- function naive_query(boxes, count, x, y, z) {
168
- let best_distance_sqr = Infinity;
169
- let best_index = 0;
170
-
171
- const limit = count * 6;
172
-
173
- for (let i = 0; i < limit; i += 6) {
174
- const distance_sqr = aabb3_unsigned_distance_sqr_to_point(
175
- boxes[i], boxes[i + 1], boxes[i + 2],
176
- boxes[i + 3], boxes[i + 4], boxes[i + 5],
177
-
178
- x, y, z
179
- )
180
-
181
- if (distance_sqr < best_distance_sqr) {
182
- best_index = i;
183
- best_distance_sqr = distance_sqr;
184
- }
185
- }
186
-
187
- return best_index;
188
- }
189
-
190
- const SAMPLE_POINT_COUNT = 10000;
191
-
192
- const t0 = performance.now();
193
-
194
- for (let i = 0; i < SAMPLE_POINT_COUNT; i++) {
195
-
196
- const x = randomFloatBetween(random, min_bound, max_bound);
197
- const y = randomFloatBetween(random, min_bound, max_bound);
198
- const z = randomFloatBetween(random, min_bound, max_bound);
199
-
200
- naive_query(boxes, OBJECT_COUNT, x, y, z);
201
- }
202
-
203
- const t1 = performance.now();
204
-
205
- const duration = (t1 - t0);
206
-
207
- console.log(`${duration / SAMPLE_POINT_COUNT}ms/query`);
208
-
209
- });
@@ -1,41 +0,0 @@
1
- import { BVH } from "../BVH.js";
2
- import { compute_tight_near_far_clipping_planes } from "./compute_tight_near_far_clipping_planes.js";
3
-
4
-
5
- function orthographic_frustum(left, right, up, down, near, far) {
6
- return new Float32Array([
7
- 1, 0, 0, right,
8
- -1, 0, 0, -left,
9
- 0, 1, 0, down,
10
- 0, -1, 0, -up,
11
- 0, 0, 1, far,
12
- 0, 0, -1, -near
13
- ]);
14
- }
15
-
16
- test('Empty does not throw', () => {
17
- const bvh = new BVH();
18
-
19
- const res = [];
20
-
21
- const frustum = new Float32Array(24);
22
-
23
- compute_tight_near_far_clipping_planes(res, 0, 0b000011, bvh, frustum);
24
- });
25
-
26
- test.skip('Axis-aligned, orthographic tight fit around a single small node', () => {
27
- const frustum = orthographic_frustum(-1, 1, -1, 1, -1, 1);
28
-
29
- const bvh = new BVH();
30
-
31
- const leaf = bvh.allocate_node();
32
- bvh.node_set_aabb(leaf, [-0.1, -0.1, -0.1, 0.1, 0.1, 0.1]);
33
- bvh.insert_leaf(leaf);
34
-
35
- const res = [];
36
-
37
- compute_tight_near_far_clipping_planes(res, 0, 0b000011, bvh, frustum);
38
-
39
- expect(res[4 * 4 + 3]).toBeCloseTo(0.1);
40
- expect(res[4 * 5 + 3]).toBeCloseTo(0.1);
41
- });
@@ -1,277 +0,0 @@
1
- import { jest } from "@jest/globals";
2
- import { returnOne } from "../function/returnOne.js";
3
- import { Cache } from "./Cache.js";
4
-
5
- test("constructor doesn't throw", () => {
6
- new Cache({});
7
- });
8
-
9
- test("elements beyond capacity are evicted", () => {
10
-
11
- const cache = new Cache({ maxWeight: 3 });
12
-
13
- cache.put(1, 1);
14
- cache.put(2, 2);
15
- cache.put(4, 4);
16
- cache.put(5, 5);
17
-
18
- expect(cache.size()).toBe(3);
19
-
20
- });
21
-
22
- test("trying to insert an element into the cache that's larger than the cache capacity should result in the item not being inserted", () => {
23
- const cache = new Cache({
24
- maxWeight: 1,
25
- keyWeigher(key) {
26
- return key;
27
- }
28
- });
29
-
30
- cache.put(2, "hello");
31
-
32
- expect(cache.contains(2)).toBe(false);
33
- });
34
-
35
- test("Recently accessed element should not be targeted for eviction where possible", () => {
36
- const cache = new Cache();
37
-
38
- cache.put(2, "hello");
39
- cache.put(7, "world");
40
-
41
- cache.get(2);
42
-
43
- cache.evictOne();
44
-
45
- expect(cache.has(2)).toBe(true);
46
- });
47
-
48
- test("removeListener is called when element is evicted", () => {
49
-
50
- const removeListener = jest.fn();
51
-
52
- const cache = new Cache({ maxWeight: 1 });
53
- cache.onRemoved.add(removeListener);
54
-
55
- cache.put(1, 7);
56
-
57
- expect(removeListener).not.toHaveBeenCalled();
58
-
59
- cache.put(2, 9);
60
-
61
- expect(removeListener).toHaveBeenCalledTimes(1);
62
- expect(removeListener).toHaveBeenCalledWith(1, 7);
63
- });
64
-
65
- test("new cache is empty", () => {
66
- const cache = new Cache();
67
-
68
- expect(cache.size()).toBe(0);
69
- });
70
-
71
- test("cache.drop() doesn't invoke removeListener", () => {
72
- const removeListener = jest.fn();
73
-
74
- const cache = new Cache();
75
- cache.onRemoved.add(removeListener);
76
-
77
- cache.put(1, 1);
78
-
79
- cache.drop();
80
-
81
- expect(removeListener).not.toHaveBeenCalled();
82
- });
83
-
84
- test("cache is emptied by cache.drop()", () => {
85
- const cache = new Cache();
86
-
87
- cache.put(1, 2);
88
-
89
- cache.drop();
90
-
91
- expect(cache.size()).toBe(0);
92
- });
93
-
94
- test("store and retrieve the same item", () => {
95
-
96
- const cache = new Cache();
97
-
98
- cache.put("a", "b");
99
-
100
- expect(cache.get("a")).toBe("b");
101
-
102
- cache.put("c", "d");
103
-
104
- expect(cache.get("c")).toBe("d");
105
- });
106
-
107
- test("remove method", () => {
108
- const cache = new Cache();
109
-
110
- expect(cache.remove("a")).toBe(false);
111
-
112
- cache.put("a", "b");
113
-
114
- expect(cache.remove("a")).toBe(true);
115
-
116
- expect(cache.size()).toBe(0);
117
- expect(cache.get("a")).toBe(null);
118
-
119
- });
120
-
121
- test("replacing element with the same key", () => {
122
- const cache = new Cache();
123
-
124
- cache.put("a", "b");
125
- cache.put("a", "c");
126
-
127
- expect(cache.get("a")).toBe("c");
128
- });
129
-
130
- test("getOrCompute", () => {
131
-
132
- const cache = new Cache();
133
-
134
- const tokens = [1, 3, 5];
135
-
136
- const compute = () => tokens.shift();
137
-
138
- expect(cache.getOrCompute("x", compute)).toBe(1);
139
-
140
- expect(cache.get("x")).toBe(1);
141
-
142
- expect(cache.getOrCompute("x", compute)).toBe(1);
143
-
144
- expect(cache.getOrCompute("y", compute)).toBe(3);
145
-
146
- expect(cache.get("y")).toBe(3);
147
-
148
- expect(cache.getOrCompute("y", compute)).toBe(3);
149
-
150
- })
151
-
152
- test("clear on empty does not throw", () => {
153
-
154
- const cache = new Cache();
155
-
156
- cache.clear();
157
-
158
- });
159
-
160
- test("clear with a single entry", () => {
161
-
162
- const cache = new Cache();
163
-
164
- cache.set("x", 1);
165
-
166
- expect(cache.contains("x")).toBe(true);
167
-
168
- cache.clear();
169
-
170
- expect(cache.contains("x")).toBe(false);
171
-
172
- });
173
-
174
- test("calling 'evictOne' on empty cache should return false", () => {
175
- const cache = new Cache();
176
-
177
- expect(cache.evictOne()).toBe(false);
178
- });
179
-
180
- test("recomputeWeight", () => {
181
- const cache = new Cache({
182
- valueWeigher: () => 3,
183
- keyWeigher: returnOne
184
- });
185
-
186
- cache.set(1, 1);
187
-
188
- expect(cache.weight).toBe(4);
189
-
190
- cache.recomputeWeight();
191
-
192
- expect(cache.weight).toBe(4);
193
- });
194
-
195
- test("updateElementWeight", () => {
196
- class Record {
197
- weight = 0;
198
-
199
- constructor(v) {
200
- this.weight = v;
201
- }
202
- }
203
-
204
- /**
205
- *
206
- * @type {Cache<string, Record>}
207
- */
208
- const cache = new Cache({
209
- valueWeigher: (v) => v.weight,
210
- });
211
-
212
- const record_a = new Record(7);
213
- const record_b = new Record(11);
214
-
215
- cache.set("a", record_a);
216
- cache.set("b", record_b);
217
-
218
- expect(cache.weight).toBe(18);
219
-
220
- record_a.weight = 3;
221
-
222
- cache.updateElementWeight("a");
223
-
224
- expect(cache.weight).toBe(14);
225
-
226
- record_b.weight = 13;
227
-
228
- cache.updateElementWeight("b");
229
-
230
- expect(cache.weight).toBe(16);
231
- });
232
-
233
- test("silentRemove should not notify", () => {
234
-
235
- const cache = new Cache();
236
-
237
- cache.set("x", 1);
238
-
239
- const mock = jest.fn();
240
-
241
- cache.onRemoved.add(mock);
242
-
243
- cache.silentRemove("x");
244
-
245
- expect(cache.contains('x')).toBe(false);
246
-
247
- expect(mock).not.toHaveBeenCalled();
248
- });
249
-
250
- test("setting maxWeight will drop data and update weight", () => {
251
-
252
- const cache = new Cache();
253
-
254
- cache.set("a", 1);
255
- cache.set("b", 2);
256
- cache.set("c", 3);
257
-
258
- expect(cache.weight).toEqual(3);
259
-
260
- cache.maxWeight = 1;
261
-
262
- expect(cache.maxWeight).toEqual(1);
263
- expect(cache.weight).toEqual(1);
264
- });
265
-
266
- test("setting maxWeight to 0 will empty out cache", () => {
267
-
268
- const cache = new Cache();
269
-
270
- cache.set("a", 1);
271
- cache.set("b", 2);
272
-
273
- cache.maxWeight = 0;
274
-
275
- expect(cache.size()).toBe(0);
276
-
277
- });
@@ -1,5 +0,0 @@
1
- import { FrequencySketch } from "./FrequencySketch.js";
2
-
3
- test("constructor does not throw", () => {
4
- expect(() => new FrequencySketch()).not.toThrow();
5
- });
@@ -1,120 +0,0 @@
1
- import { LoadingCache } from "./LoadingCache.js";
2
-
3
- jest.useFakeTimers();
4
-
5
- test("successful load", () => {
6
- const cache = new LoadingCache({
7
- async load(key) {
8
- return 17;
9
- }
10
- });
11
-
12
- expect( cache.get(1)).resolves.toEqual(17);
13
- });
14
-
15
- test("when loader throws an exception, we should get a failed promise", () => {
16
- const cache = new LoadingCache({
17
- load(key) {
18
- throw "Designed Thrown Thing";
19
- }
20
- });
21
-
22
- const promise = cache.get("a");
23
-
24
- expect(promise).rejects.toEqual("Designed Thrown Thing");
25
- });
26
-
27
- test("record reuse", async () => {
28
- const load = jest.fn(async () => 17);
29
-
30
- const cache = new LoadingCache({
31
- load
32
- });
33
-
34
- await expect(cache.get(1)).resolves.toEqual(17);
35
- await expect(cache.get(1)).resolves.toEqual(17);
36
-
37
- expect(load).toHaveBeenCalledTimes(1);
38
- });
39
-
40
- test("timeout reload reuse", async () => {
41
-
42
- const values = [3, 5, 11];
43
-
44
- const load = jest.fn(async () => values.pop());
45
-
46
- const cache = new LoadingCache({
47
- load,
48
- timeToLive: 0.00000001
49
- });
50
-
51
- const request_1 = await cache.get(1);
52
- expect(request_1).toEqual(11);
53
-
54
- jest.advanceTimersByTime(1);
55
-
56
- const request_2 = await cache.get(1);
57
- expect(request_2).toEqual(5);
58
-
59
- jest.advanceTimersByTime(1);
60
-
61
- const request_3 = await cache.get(1);
62
- expect(request_3).toEqual(3);
63
- });
64
-
65
- test("eviction", async () => {
66
-
67
- /**
68
- *
69
- * @type {LoadingCache<number, number>}
70
- */
71
- const cache = new LoadingCache({
72
- valueWeigher(num) {
73
- return num;
74
- },
75
- load: async () => {
76
- return 2;
77
- },
78
- maxWeight: 6,
79
- });
80
-
81
- await cache.get(1);
82
- await cache.get(2);
83
- await cache.get(3);
84
-
85
- expect(cache.contains(1)).toBe(true);
86
- expect(cache.contains(2)).toBe(true);
87
- expect(cache.contains(3)).toBe(true);
88
-
89
- await cache.get(4);
90
-
91
- expect(cache.contains(1)).toBe(false);
92
- expect(cache.contains(2)).toBe(true);
93
- expect(cache.contains(3)).toBe(true);
94
- expect(cache.contains(4)).toBe(true);
95
-
96
- });
97
-
98
- test("insert element directly", async () => {
99
-
100
- const cache = new LoadingCache({
101
- load: async () => 3
102
- });
103
-
104
- cache.put("x", 1);
105
-
106
- expect(await cache.get("x")).toEqual(1);
107
- });
108
-
109
- test("clear", async () => {
110
-
111
- const cache = new LoadingCache({
112
- load: async () => 3
113
- });
114
-
115
- cache.put("x", 1);
116
-
117
- cache.clear();
118
-
119
- expect(await cache.get("x")).toEqual(3);
120
- });