@woosh/meep-engine 2.110.14 → 2.111.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/build/meep.cjs +442 -370
- package/build/meep.min.js +1 -1
- package/build/meep.module.js +442 -370
- package/editor/tools/v2/BlenderCameraOrientationGizmo.js +4 -2
- package/package.json +4 -2
- package/src/core/events/signal/Signal.d.ts.map +1 -1
- package/src/core/events/signal/Signal.js +289 -255
- package/src/core/events/signal/SignalHandler.d.ts +7 -2
- package/src/core/events/signal/SignalHandler.d.ts.map +1 -1
- package/src/core/events/signal/SignalHandler.js +12 -6
- package/src/core/events/signal/signal_handler_list_find.d.ts +8 -0
- package/src/core/events/signal/signal_handler_list_find.d.ts.map +1 -0
- package/src/core/events/signal/signal_handler_list_find.js +23 -0
- package/src/core/events/signal/signal_handler_list_last.d.ts +7 -0
- package/src/core/events/signal/signal_handler_list_last.d.ts.map +1 -0
- package/src/core/events/signal/signal_handler_list_last.js +14 -0
- package/src/core/events/signal/signal_handler_list_validate.d.ts +8 -0
- package/src/core/events/signal/signal_handler_list_validate.d.ts.map +1 -0
- package/src/core/events/signal/signal_handler_list_validate.js +29 -0
- package/src/engine/ecs/dynamic_actions/rules/DynamicRuleDescription.d.ts +2 -3
- package/src/engine/ecs/dynamic_actions/rules/DynamicRuleDescription.d.ts.map +1 -1
- package/src/engine/ecs/dynamic_actions/rules/DynamicRuleDescription.js +3 -3
- package/src/engine/graphics/ecs/camera/Camera.d.ts.map +1 -1
- package/src/engine/graphics/ecs/camera/Camera.js +2 -2
- package/src/engine/graphics/ecs/camera/CameraSystem.d.ts.map +1 -1
- package/src/engine/graphics/ecs/camera/CameraSystem.js +10 -2
- package/src/engine/graphics/ecs/camera/quaternion_invert_orientation.d.ts +7 -0
- package/src/engine/graphics/ecs/camera/quaternion_invert_orientation.d.ts.map +1 -0
- package/src/engine/graphics/ecs/camera/{InvertQuaternionOrientation.js → quaternion_invert_orientation.js} +6 -5
- package/editor/actions/concrete/ModifyPatchSampler2DAction.spec.js +0 -30
- package/src/core/IdPool.spec.js +0 -29
- package/src/core/UUID.spec.js +0 -8
- package/src/core/binary/32BitEncoder.spec.js +0 -11
- package/src/core/binary/Base64.spec.js +0 -14
- package/src/core/binary/BinaryBuffer.spec.js +0 -324
- package/src/core/binary/BitSet.spec.js +0 -468
- package/src/core/binary/EncodingBinaryBuffer.spec.js +0 -16
- package/src/core/binary/align_32.spec.js +0 -11
- package/src/core/binary/align_4.spec.js +0 -20
- package/src/core/binary/data_view/DataViewStructAccessor.spec.js +0 -20
- package/src/core/binary/de_interleave_2_bits.spec.js +0 -21
- package/src/core/binary/dec2hex.spec.js +0 -13
- package/src/core/binary/hex2dec.spec.js +0 -22
- package/src/core/binary/int32_to_binary_string.spec.js +0 -9
- package/src/core/binary/operations/bitCount.spec.js +0 -19
- package/src/core/binary/operations/ceilPowerOfTwo.spec.js +0 -17
- package/src/core/binary/reverse_bits_uint32.spec.js +0 -18
- package/src/core/binary/split_by_2.spec.js +0 -22
- package/src/core/binary/split_by_3.spec.js +0 -22
- package/src/core/binary/uint8_to_float.spec.js +0 -7
- package/src/core/bvh2/binary/2/BinaryUint32BVH.spec.js +0 -136
- package/src/core/bvh2/bvh3/BVH.spec.js +0 -361
- package/src/core/bvh2/bvh3/BvhClient.spec.js +0 -51
- package/src/core/bvh2/bvh3/ebvh_build_for_geometry_morton.spec.js +0 -60
- package/src/core/bvh2/bvh3/query/bvh_query_leaves_generic.spec.js +0 -22
- package/src/core/bvh2/bvh3/query/bvh_query_leaves_ray.spec.js +0 -64
- package/src/core/bvh2/bvh3/query/bvh_query_user_data_generic.spec.js +0 -29
- package/src/core/bvh2/bvh3/query/bvh_query_user_data_nearest_to_point.spec.js +0 -209
- package/src/core/bvh2/bvh3/query/compute_tight_near_far_clipping_planes.spec.js +0 -41
- package/src/core/cache/Cache.spec.js +0 -277
- package/src/core/cache/FrequencySketch.spec.js +0 -5
- package/src/core/cache/LoadingCache.spec.js +0 -120
- package/src/core/codegen/LineBuilder.spec.js +0 -41
- package/src/core/collection/CuckooFilter.spec.js +0 -111
- package/src/core/collection/RingBuffer.spec.js +0 -59
- package/src/core/collection/Stack.spec.js +0 -63
- package/src/core/collection/array/arrayPickBestElement.spec.js +0 -7
- package/src/core/collection/array/arraySetSortingDiff.spec.js +0 -74
- package/src/core/collection/array/array_contains_duplicates.spec.js +0 -14
- package/src/core/collection/array/array_copy.spec.js +0 -19
- package/src/core/collection/array/array_deduplicate.spec.js +0 -11
- package/src/core/collection/array/array_get_index_in_range.spec.js +0 -16
- package/src/core/collection/array/array_remove_first.spec.js +0 -39
- package/src/core/collection/array/array_shuffle.spec.js +0 -27
- package/src/core/collection/array/binarySearchHighIndex.spec.js +0 -51
- package/src/core/collection/array/isArrayEqual.spec.js +0 -25
- package/src/core/collection/array/typed/is_typed_array_equals.spec.js +0 -71
- package/src/core/collection/array/weightedRandomFromArray.spec.js +0 -22
- package/src/core/collection/heap/BinaryHeap.spec.js +0 -137
- package/src/core/collection/heap/Uint32Heap.spec.js +0 -172
- package/src/core/collection/list/List.spec.js +0 -438
- package/src/core/collection/list/ListForwarder.spec.js +0 -101
- package/src/core/collection/map/HashMap.spec.js +0 -291
- package/src/core/collection/queue/Deque.spec.js +0 -276
- package/src/core/collection/set/HashSet.spec.js +0 -39
- package/src/core/collection/set/compute_set_difference.spec.js +0 -45
- package/src/core/collection/set/compute_set_intersection.spec.js +0 -45
- package/src/core/collection/table/RowFirstTable.spec.js +0 -323
- package/src/core/collection/table/RowFirstTableSpec.spec.js +0 -49
- package/src/core/collection/table/bind/TableRecord.spec.js +0 -27
- package/src/core/color/Color.spec.js +0 -174
- package/src/core/color/YCbCr/YCbCr.spec.js +0 -16
- package/src/core/color/hex/hex2rgb.spec.js +0 -10
- package/src/core/color/hex/rgb2hex.spec.js +0 -13
- package/src/core/color/hsv/hsv2rgb.spec.js +0 -43
- package/src/core/color/kelvin/kelvin_to_rgb.spec.js +0 -61
- package/src/core/color/kelvin/rgb_to_kelvin.spec.js +0 -15
- package/src/core/color/oklab/Okhsv.spec.js +0 -17
- package/src/core/color/oklab/XYZ.spec.js +0 -17
- package/src/core/color/oklab/oklab_to_xyz.spec.js +0 -31
- package/src/core/color/oklab/xyz_to_oklab.spec.js +0 -31
- package/src/core/color/parse_color.spec.js +0 -18
- package/src/core/color/sRGB/sRGB.spec.js +0 -16
- package/src/core/color/xyz/XYZ.spec.js +0 -16
- package/src/core/events/signal/Signal.spec.js +0 -253
- package/src/core/events/signal/SignalBinding.spec.js +0 -58
- package/src/core/fsm/simple/SimpleStateMachine.spec.js +0 -107
- package/src/core/fsm/simple/SimpleStateMachineDescription.spec.js +0 -103
- package/src/core/function/extractFunctionBody.spec.js +0 -15
- package/src/core/geom/2d/Rectangle.spec.js +0 -62
- package/src/core/geom/2d/aabb/AABB2.spec.js +0 -153
- package/src/core/geom/2d/aabb/aabb2_compute_center_from_multiple.spec.js +0 -11
- package/src/core/geom/2d/aabb/aabb2_compute_overlap.spec.js +0 -56
- package/src/core/geom/2d/aabb/aabb2_contains.spec.js +0 -40
- package/src/core/geom/2d/aabb/aabb2_distance_to_point.spec.js +0 -17
- package/src/core/geom/2d/aabb/aabb2_intersects_ray.spec.js +0 -28
- package/src/core/geom/2d/aabb/aabb2_signed_distance_sqr_to_point.spec.js +0 -40
- package/src/core/geom/2d/bvh/BVH2D.spec.js +0 -359
- package/src/core/geom/2d/bvh/bvh2d_query_all_data_by_circle.spec.js +0 -89
- package/src/core/geom/2d/circle/circle_compute_circle_intersection.spec.js +0 -79
- package/src/core/geom/2d/compute_polygon_area_2d.spec.js +0 -10
- package/src/core/geom/2d/compute_triangle_area_2d.spec.js +0 -9
- package/src/core/geom/2d/convex-hull/convex_hull_jarvis_2d.spec.js +0 -33
- package/src/core/geom/2d/convex-hull/convex_hull_monotone_2d.spec.js +0 -33
- package/src/core/geom/2d/hash-grid/SpatialHashGrid.spec.js +0 -254
- package/src/core/geom/2d/hash-grid/shg_query_elements_circle.spec.js +0 -85
- package/src/core/geom/2d/hash-grid/shg_query_elements_line.spec.js +0 -102
- package/src/core/geom/2d/quad-tree/QuadTreeNode.spec.js +0 -235
- package/src/core/geom/2d/quad-tree/qt_match_data_by_circle.spec.js +0 -86
- package/src/core/geom/2d/quad-tree-binary/QuadTree.spec.js +0 -53
- package/src/core/geom/2d/r-tree/StaticR2Tree.spec.js +0 -62
- package/src/core/geom/2d/spline_bezier2_2d.spec.js +0 -16
- package/src/core/geom/2d/uv_map_circle_to_square.spec.js +0 -28
- package/src/core/geom/2d/uv_map_square_to_circle.spec.js +0 -30
- package/src/core/geom/3d/SurfacePoint3.spec.js +0 -116
- package/src/core/geom/3d/aabb/AABB3.spec.js +0 -257
- package/src/core/geom/3d/aabb/aabb3_array_intersects_point.spec.js +0 -48
- package/src/core/geom/3d/aabb/aabb3_build_corners.spec.js +0 -27
- package/src/core/geom/3d/aabb/aabb3_compute_distance_above_plane_max.spec.js +0 -8
- package/src/core/geom/3d/aabb/aabb3_compute_plane_side.spec.js +0 -25
- package/src/core/geom/3d/aabb/aabb3_corner_edge_mapping.spec.js +0 -39
- package/src/core/geom/3d/aabb/aabb3_edge_corner_mapping.spec.js +0 -32
- package/src/core/geom/3d/aabb/aabb3_expand_array.spec.js +0 -16
- package/src/core/geom/3d/aabb/aabb3_from_v3_array.spec.js +0 -32
- package/src/core/geom/3d/aabb/aabb3_intersects_aabb3.spec.js +0 -115
- package/src/core/geom/3d/aabb/aabb3_intersects_ray.spec.js +0 -161
- package/src/core/geom/3d/aabb/aabb3_matrix4_project.spec.js +0 -54
- package/src/core/geom/3d/aabb/aabb3_raycast.spec.js +0 -37
- package/src/core/geom/3d/aabb/aabb3_score_boxes_SAH.spec.js +0 -14
- package/src/core/geom/3d/cone/computeConePlaneSide.spec.js +0 -13
- package/src/core/geom/3d/cone/compute_bounding_cone_of_2_cones.spec.js +0 -95
- package/src/core/geom/3d/line/line3_compute_nearest_point_to_point.spec.js +0 -61
- package/src/core/geom/3d/mat4/MATRIX_4_IDENTITY.spec.js +0 -10
- package/src/core/geom/3d/mat4/m4_multiply.spec.js +0 -34
- package/src/core/geom/3d/mat4/m4_multiply_alphatensor.spec.js +0 -35
- package/src/core/geom/3d/morton/v3_morton_encode_transformed.spec.js +0 -20
- package/src/core/geom/3d/normal/hemioct/unit_hemioct.spec.js +0 -41
- package/src/core/geom/3d/normal/octahedron/encoding.spec.js +0 -54
- package/src/core/geom/3d/plane/plane3_projectPoint.spec.js +0 -54
- package/src/core/geom/3d/plane/plane3_slerp.spec.js +0 -209
- package/src/core/geom/3d/ray/ray3_array_compose.spec.js +0 -14
- package/src/core/geom/3d/shape/TransformedShape3D.spec.js +0 -55
- package/src/core/geom/3d/shape/UnitCubeShape3D.spec.js +0 -42
- package/src/core/geom/3d/sphere/harmonics/sh3_dering_optimize_positive.spec.js +0 -53
- package/src/core/geom/3d/sphere/harmonics/sh3_vector_accumulate.spec.js +0 -27
- package/src/core/geom/3d/sphere/sphere_intersects_point.spec.js +0 -134
- package/src/core/geom/3d/sphere/sphere_intersects_ray.spec.js +0 -60
- package/src/core/geom/3d/sphere/sphere_radius_sqr_from_v3_array_transformed.spec.js +0 -8
- package/src/core/geom/3d/tetrahedra/TetrahedralMesh.spec.js +0 -233
- package/src/core/geom/3d/tetrahedra/compute_bounding_simplex_3d.spec.js +0 -66
- package/src/core/geom/3d/tetrahedra/delaunay/compute_delaunay_tetrahedral_mesh.spec.js +0 -36
- package/src/core/geom/3d/tetrahedra/delaunay/tetrahedral_mesh_build_from_grid.spec.js +0 -61
- package/src/core/geom/3d/tetrahedra/delaunay/tetrahedral_mesh_compute_sub_determinant.spec.js +0 -30
- package/src/core/geom/3d/tetrahedra/tetrahedron_compute_signed_volume.spec.js +0 -24
- package/src/core/geom/3d/tetrahedra/tetrahedron_contains_point.spec.js +0 -66
- package/src/core/geom/3d/topology/simplify/collapseEdge.spec.js +0 -24
- package/src/core/geom/3d/topology/struct/TopoEdge.spec.js +0 -52
- package/src/core/geom/3d/topology/struct/TopoVertex.spec.js +0 -128
- package/src/core/geom/3d/topology/struct/binary/BinaryElementPool.spec.js +0 -36
- package/src/core/geom/3d/topology/struct/binary/BinaryTopology.spec.js +0 -16
- package/src/core/geom/3d/topology/struct/binary/io/bt_index_geometry_to_topology.spec.js +0 -84
- package/src/core/geom/3d/topology/struct/binary/query/bt_mesh_edge_has_vertex.spec.js +0 -15
- package/src/core/geom/3d/topology/struct/binary/query/bt_mesh_edge_other_vertex.spec.js +0 -16
- package/src/core/geom/3d/triangle/computeTriangleClosestPointToPointBarycentric.spec.js +0 -100
- package/src/core/geom/3d/triangle/computeTriangleRayIntersection.spec.js +0 -25
- package/src/core/geom/3d/triangle/computeTriangleRayIntersectionBarycentric.spec.js +0 -26
- package/src/core/geom/3d/v3_compute_triangle_normal.spec.js +0 -46
- package/src/core/geom/ConicRay.spec.js +0 -24
- package/src/core/geom/Quaternion.spec.js +0 -429
- package/src/core/geom/Vector1.spec.js +0 -74
- package/src/core/geom/Vector2.spec.js +0 -295
- package/src/core/geom/Vector3.spec.js +0 -285
- package/src/core/geom/Vector4.spec.js +0 -11
- package/src/core/geom/normalize_angle_rad.spec.js +0 -45
- package/src/core/geom/packing/computeBoundingSphereOfSpheres.spec.js +0 -24
- package/src/core/geom/packing/max-rect/MaxRectanglesPacker.spec.js +0 -60
- package/src/core/geom/packing/miniball/Miniball.spec.js +0 -35
- package/src/core/geom/packing/miniball/Subspan.spec.js +0 -51
- package/src/core/geom/random/randomPointOnBox.spec.js +0 -57
- package/src/core/geom/vec/vector_normalize.spec.js +0 -15
- package/src/core/geom/vec3/v3_angle_cos_between.spec.js +0 -124
- package/src/core/geom/vec3/v3_displace_in_direction.spec.js +0 -80
- package/src/core/geom/vec3/v3_distance_above_plane.spec.js +0 -40
- package/src/core/graph/Edge.spec.js +0 -85
- package/src/core/graph/SquareMatrix.spec.js +0 -102
- package/src/core/graph/coloring/colorizeGraphGreedy.spec.js +0 -26
- package/src/core/graph/convert_graph_to_dot_string.spec.js +0 -28
- package/src/core/graph/eigen/matrix_eigenvalues_in_place.spec.js +0 -57
- package/src/core/graph/graph_k_means_cluster.spec.js +0 -23
- package/src/core/graph/mn_graph_coarsen.spec.js +0 -45
- package/src/core/graph/v2/Graph.spec.js +0 -364
- package/src/core/json/resolvePath.spec.js +0 -14
- package/src/core/lang/reactive/compileReactiveExpression.spec.js +0 -169
- package/src/core/math/bessel_j0.spec.js +0 -43
- package/src/core/math/clamp.spec.js +0 -15
- package/src/core/math/computeGreatestCommonDivisor.spec.js +0 -9
- package/src/core/math/computeIsoscelesTriangleApexAngle.spec.js +0 -6
- package/src/core/math/computeWholeDivisorLow.spec.js +0 -9
- package/src/core/math/copysign.spec.js +0 -13
- package/src/core/math/epsilonEquals.spec.js +0 -17
- package/src/core/math/factorial.spec.js +0 -9
- package/src/core/math/fract.spec.js +0 -11
- package/src/core/math/hash/computeHashFloatArray.spec.js +0 -11
- package/src/core/math/hash/computeObjectHash.spec.js +0 -42
- package/src/core/math/hash/murmur3_32.spec.js +0 -8
- package/src/core/math/hash/squirrel3.spec.js +0 -16
- package/src/core/math/iabs.spec.js +0 -9
- package/src/core/math/interval/NumericInterval.spec.js +0 -89
- package/src/core/math/interval/isValueBetween.spec.js +0 -11
- package/src/core/math/interval/isValueBetweenInclusive.spec.js +0 -16
- package/src/core/math/interval/overlap1D.spec.js +0 -10
- package/src/core/math/inverseLerp.spec.js +0 -13
- package/src/core/math/isPowerOfTwo.spec.js +0 -9
- package/src/core/math/isqrt.spec.js +0 -9
- package/src/core/math/lerp.spec.js +0 -15
- package/src/core/math/linalg/solve_linear_system.spec.js +0 -70
- package/src/core/math/max.spec.js +0 -25
- package/src/core/math/max2.spec.js +0 -13
- package/src/core/math/max3.spec.js +0 -29
- package/src/core/math/min2.spec.js +0 -37
- package/src/core/math/min3.spec.js +0 -29
- package/src/core/math/newton_solver_1d.spec.js +0 -9
- package/src/core/math/nextOdd.spec.js +0 -9
- package/src/core/math/noise/create_simplex_noise_2d.spec.js +0 -21
- package/src/core/math/noise/sdnoise.spec.js +0 -87
- package/src/core/math/physics/irradiance/interpolate_irradiance_linear.spec.js +0 -20
- package/src/core/math/physics/irradiance/interpolate_irradiance_lograrithmic.spec.js +0 -18
- package/src/core/math/physics/irradiance/interpolate_irradiance_smith.spec.js +0 -20
- package/src/core/math/pingpong.spec.js +0 -11
- package/src/core/math/random/MersenneTwister.spec.js +0 -19
- package/src/core/math/random/randomFloatBetween.spec.js +0 -9
- package/src/core/math/random/randomGaussian.spec.js +0 -9
- package/src/core/math/random/randomIntegerBetween.spec.js +0 -8
- package/src/core/math/random/roundFair.spec.js +0 -12
- package/src/core/math/random/seededRandomMersenneTwister.spec.js +0 -10
- package/src/core/math/random/seededRandom_Mulberry32.spec.js +0 -19
- package/src/core/math/remap.spec.js +0 -15
- package/src/core/math/sign.spec.js +0 -13
- package/src/core/math/smoothStep.spec.js +0 -16
- package/src/core/math/smootherStep.spec.js +0 -16
- package/src/core/math/solveQuadratic.spec.js +0 -18
- package/src/core/math/spline/cubicCurve.spec.js +0 -13
- package/src/core/math/spline/makeCubicCurve.spec.js +0 -9
- package/src/core/math/spline/spline_bezier2.spec.js +0 -13
- package/src/core/math/spline/spline_bezier3_bounds.spec.js +0 -37
- package/src/core/math/spline/spline_hermite3.spec.js +0 -18
- package/src/core/math/spline/spline_hermite3_bounds.spec.js +0 -37
- package/src/core/math/statistics/computeSampleSize_Cochran.spec.js +0 -12
- package/src/core/math/statistics/computeStatisticalMean.spec.js +0 -9
- package/src/core/math/statistics/computeStatisticalPartialMedian.spec.js +0 -13
- package/src/core/math/statistics/computeStatisticalPercentile.spec.js +0 -11
- package/src/core/math/statistics/computeStatisticalVariance.spec.js +0 -10
- package/src/core/math/statistics/halton_sequence.spec.js +0 -40
- package/src/core/math/statistics/radical_inverse_VdC_base_2.spec.js +0 -9
- package/src/core/math/statistics/softmax.spec.js +0 -9
- package/src/core/model/BooleanVector3.spec.js +0 -51
- package/src/core/model/BoundedValue.spec.js +0 -17
- package/src/core/model/ModuleRegistry.spec.js +0 -31
- package/src/core/model/ObservedBoolean.spec.js +0 -81
- package/src/core/model/ObservedInteger.spec.js +0 -51
- package/src/core/model/node-graph/Connection.spec.js +0 -33
- package/src/core/model/node-graph/NodeGraph.spec.js +0 -107
- package/src/core/model/node-graph/node/NodeDescription.spec.js +0 -81
- package/src/core/model/node-graph/node/NodeInstance.spec.js +0 -82
- package/src/core/model/node-graph/node/NodeInstancePortReference.spec.js +0 -109
- package/src/core/model/node-graph/node/NodeRegistry.spec.js +0 -123
- package/src/core/model/node-graph/node/Port.spec.js +0 -102
- package/src/core/model/node-graph/type/DataType.spec.js +0 -47
- package/src/core/model/node-graph/type/ParametricDataType.spec.js +0 -63
- package/src/core/model/node-graph/visual/PortVisualData.spec.js +0 -16
- package/src/core/model/object/ObjectPoolFactory.spec.js +0 -54
- package/src/core/model/object/objectDeepEquals.spec.js +0 -54
- package/src/core/model/object/write_property.spec.js +0 -26
- package/src/core/model/reactive/evaluation/MultiPredicateEvaluator.spec.js +0 -158
- package/src/core/model/reactive/js/compileReactiveToJS.spec.js +0 -14
- package/src/core/model/reactive/model/logic/ReactiveAnd.spec.js +0 -51
- package/src/core/model/reactive/model/logic/ReactiveOr.spec.js +0 -53
- package/src/core/model/reactive/model/terminal/ReactiveReference.spec.js +0 -26
- package/src/core/model/reactive/trigger/BlackboardTrigger.spec.js +0 -24
- package/src/core/model/reactive/trigger/ReactiveTrigger.spec.js +0 -5
- package/src/core/model/stat/LinearModifier.spec.js +0 -96
- package/src/core/model/stat/Stat.spec.js +0 -111
- package/src/core/parser/simple/readHexToken.spec.js +0 -21
- package/src/core/parser/simple/readIdentifierToken.spec.js +0 -32
- package/src/core/parser/simple/readNumberToken.spec.js +0 -17
- package/src/core/parser/simple/readReferenceToken.spec.js +0 -18
- package/src/core/parser/simple/readStringToken.spec.js +0 -57
- package/src/core/parser/simple/readUnsignedIntegerToken.spec.js +0 -6
- package/src/core/path/computeFileExtension.spec.js +0 -13
- package/src/core/path/computePathBase.spec.js +0 -13
- package/src/core/path/computePathDirectory.spec.js +0 -8
- package/src/core/primitives/array/computeStridedIntegerArrayHash.spec.js +0 -28
- package/src/core/primitives/numbers/computeHashFloat.spec.js +0 -14
- package/src/core/primitives/numbers/number_compare_ascending.spec.js +0 -9
- package/src/core/primitives/numbers/number_compare_descending.spec.js +0 -9
- package/src/core/primitives/numbers/number_format_by_thousands.spec.js +0 -12
- package/src/core/primitives/numbers/number_pretty_print.spec.js +0 -19
- package/src/core/primitives/strings/compareStrings.spec.js +0 -12
- package/src/core/primitives/strings/computeStringHash.spec.js +0 -20
- package/src/core/primitives/strings/insert_after.spec.js +0 -16
- package/src/core/primitives/strings/insert_before.spec.js +0 -16
- package/src/core/primitives/strings/string_capitalize.spec.js +0 -13
- package/src/core/primitives/strings/string_compute_common_prefix.spec.js +0 -23
- package/src/core/primitives/strings/string_format_camel_to_kebab.spec.js +0 -8
- package/src/core/primitives/strings/string_jaro_winkler.spec.js +0 -39
- package/src/core/primitives/strings/string_strip_trailing.spec.js +0 -27
- package/src/core/process/PromiseWatcher.spec.js +0 -69
- package/src/core/process/executor/ConcurrentExecutor.spec.js +0 -135
- package/src/core/process/task/util/actionTask.spec.js +0 -14
- package/src/core/process/task/util/countTask.spec.js +0 -18
- package/src/core/process/undo/ActionProcessor.spec.js +0 -64
- package/src/engine/Clock.spec.js +0 -26
- package/src/engine/Engine.spec.js +0 -15
- package/src/engine/achievements/Achievement.spec.js +0 -21
- package/src/engine/animation/curve/AnimationCurve.spec.js +0 -248
- package/src/engine/animation/curve/Keyframe.spec.js +0 -42
- package/src/engine/animation/curve/animation_curve_optimize.spec.js +0 -50
- package/src/engine/animation/curve/compression/downsample_float_array_curve_by_error.spec.js +0 -47
- package/src/engine/animation/curve/compression/sample_animation_curve_to_float_array.spec.js +0 -29
- package/src/engine/animation/keyed2/AnimationTrackPlayback.spec.js +0 -94
- package/src/engine/asset/AssetDescription.spec.js +0 -27
- package/src/engine/asset/AssetManager.spec.js +0 -50
- package/src/engine/asset/loaders/image/png/PNG.spec.js +0 -5
- package/src/engine/asset/loaders/image/png/PNGReader.spec.js +0 -5
- package/src/engine/asset/loaders/image/png/crc.spec.js +0 -15
- package/src/engine/control/ControlContext.spec.js +0 -81
- package/src/engine/ecs/Entity.spec.js +0 -188
- package/src/engine/ecs/EntityBlueprint.spec.js +0 -52
- package/src/engine/ecs/EntityComponentDataset.spec.js +0 -895
- package/src/engine/ecs/EntityManager.spec.js +0 -210
- package/src/engine/ecs/EntityObserver.spec.js +0 -184
- package/src/engine/ecs/animation/Animation.spec.js +0 -22
- package/src/engine/ecs/animation/AnimationClip.spec.js +0 -5
- package/src/engine/ecs/components/Tag.spec.js +0 -47
- package/src/engine/ecs/dynamic_actions/rules/DynamicRuleDescriptionTable.spec.js +0 -126
- package/src/engine/ecs/fow/FogOfWar.spec.js +0 -13
- package/src/engine/ecs/guid/UUID.spec.js +0 -100
- package/src/engine/ecs/guid/UUIDSerializationAdapter.spec.js +0 -21
- package/src/engine/ecs/parent/EntityNode.spec.js +0 -104
- package/src/engine/ecs/renderable/Renderable.spec.js +0 -10
- package/src/engine/ecs/storage/binary/BinarySerializationRegistry.spec.js +0 -139
- package/src/engine/ecs/storage/binary/collection/BinaryCollectionSerialization.spec.js +0 -259
- package/src/engine/ecs/storage/binary/object/BinaryObjectSerializationAdapter.spec.js +0 -59
- package/src/engine/ecs/storage/binary/object/BinaryObjectSerializationAdapter2.spec.js +0 -123
- package/src/engine/ecs/terrain/ecs/Terrain.spec.js +0 -5
- package/src/engine/ecs/terrain/ecs/cling/ClingToTerrainSystem.spec.js +0 -38
- package/src/engine/ecs/terrain/overlay/TerrainOverlay.spec.js +0 -6
- package/src/engine/ecs/terrain/tiles/TerrainTile.spec.js +0 -25
- package/src/engine/ecs/tooltip/TooltipComponent.spec.js +0 -47
- package/src/engine/ecs/transform/Transform.spec.js +0 -310
- package/src/engine/ecs/transform/TransformSerializationAdapter.spec.js +0 -28
- package/src/engine/ecs/transform-attachment/TransformAttachment.spec.js +0 -103
- package/src/engine/graphics/ecs/animation/animator/graph/AnimationGraph.spec.js +0 -5
- package/src/engine/graphics/ecs/animation/animator/graph/definition/AnimationGraphDefinition.spec.js +0 -5
- package/src/engine/graphics/ecs/camera/InvertQuaternionOrientation.d.ts +0 -7
- package/src/engine/graphics/ecs/camera/InvertQuaternionOrientation.d.ts.map +0 -1
- package/src/engine/graphics/ecs/camera/topdown/TopDownCameraController.spec.js +0 -94
- package/src/engine/graphics/ecs/decal/v2/Decal.spec.js +0 -5
- package/src/engine/graphics/ecs/mesh-v2/ShadedGeometry.spec.js +0 -19
- package/src/engine/graphics/ecs/mesh-v2/aggregate/SGMesh.spec.js +0 -5
- package/src/engine/graphics/ecs/mesh-v2/render/adapters/SGCacheKey.spec.js +0 -79
- package/src/engine/graphics/ecs/path/tube/TubePathStyle.spec.js +0 -5
- package/src/engine/graphics/ecs/path/tube/build/build_geometry_catmullrom.spec.js +0 -32
- package/src/engine/graphics/geometry/MikkT/MikkTSpace.spec.js +0 -28
- package/src/engine/graphics/geometry/bvh/buffered/bvh32_from_unindexed_geometry.spec.js +0 -22
- package/src/engine/graphics/particles/particular/engine/MovingBoundingBox.spec.js +0 -70
- package/src/engine/graphics/particles/particular/engine/emitter/ParticleEmitter.spec.js +0 -47
- package/src/engine/graphics/particles/particular/engine/emitter/ParticleLayer.spec.js +0 -100
- package/src/engine/graphics/particles/particular/engine/emitter/ParticlePool.spec.js +0 -225
- package/src/engine/graphics/particles/particular/engine/parameter/ParameterLookupTable.spec.js +0 -215
- package/src/engine/graphics/particles/particular/engine/parameter/ParameterSet.spec.js +0 -75
- package/src/engine/graphics/particles/particular/group/ParticleGroup.spec.js +0 -270
- package/src/engine/graphics/render/buffer/slot/parameter/ProgramValueSlotParameter.spec.js +0 -21
- package/src/engine/graphics/render/forward_plus/LightManager.spec.js +0 -94
- package/src/engine/graphics/render/forward_plus/cluster/write_cluster_planes.spec.js +0 -79
- package/src/engine/graphics/render/visibility/IncrementalDeltaSet.spec.js +0 -102
- package/src/engine/graphics/texture/atlas/CachingTextureAtlas.spec.js +0 -78
- package/src/engine/graphics/texture/atlas/TextureAtlas.spec.js +0 -319
- package/src/engine/graphics/texture/sampler/HarmonicDiffusionGrid.spec.js +0 -99
- package/src/engine/graphics/texture/sampler/Sampler2D.spec.js +0 -224
- package/src/engine/graphics/texture/sampler/copy_Sampler2D_channel_data.spec.js +0 -90
- package/src/engine/graphics/texture/sampler/distance/computeSignedDistanceField_NaiveFlood.spec.js +0 -183
- package/src/engine/graphics/texture/sampler/distance/computeUnsignedDistanceField.spec.js +0 -183
- package/src/engine/graphics/texture/sampler/resize/sampler2d_scale.spec.js +0 -73
- package/src/engine/graphics/texture/sampler/resize/sampler2d_scale_down_lanczos.spec.js +0 -31
- package/src/engine/graphics/texture/sampler/resize/sampler2d_scale_down_linear.spec.js +0 -44
- package/src/engine/graphics/texture/sampler/resize/sampler2d_scale_down_mipmap.spec.js +0 -13
- package/src/engine/graphics/texture/sampler/resize/sampler2d_scale_up_linear.spec.js +0 -14
- package/src/engine/graphics/texture/sampler/sampler2d_channel_compute_max.spec.js +0 -40
- package/src/engine/graphics/texture/sampler/sampler2d_channel_compute_min_indices.spec.js +0 -15
- package/src/engine/graphics/texture/sampler/sampler2d_copy_with_margins.spec.js +0 -31
- package/src/engine/graphics/texture/sampler/sampler2d_to_data_url.spec.js +0 -10
- package/src/engine/graphics/texture/sampler/sampler2d_to_uint8_RGBA.spec.js +0 -52
- package/src/engine/graphics/texture/sampler/serialization/TextureBinaryBufferSerializer.spec.js +0 -38
- package/src/engine/graphics/three/expand_aabb_by_transformed_three_object.spec.js +0 -108
- package/src/engine/graphics/trail/x/RibbonX.spec.js +0 -5
- package/src/engine/grid/obstacle/GridObstacle.spec.js +0 -175
- package/src/engine/input/devices/InputDeviceSwitch.spec.js +0 -5
- package/src/engine/input/devices/KeyboardDevice.spec.js +0 -12
- package/src/engine/input/devices/PointerDevice.spec.js +0 -12
- package/src/engine/intelligence/behavior/Behavior.spec.js +0 -15
- package/src/engine/intelligence/behavior/SelectorBehavior.spec.js +0 -18
- package/src/engine/intelligence/behavior/behavior_to_dot.spec.js +0 -25
- package/src/engine/intelligence/behavior/composite/ParallelBehavior.spec.js +0 -166
- package/src/engine/intelligence/behavior/composite/SequenceBehavior.spec.js +0 -17
- package/src/engine/intelligence/behavior/decorator/RepeatBehavior.spec.js +0 -32
- package/src/engine/intelligence/behavior/ecs/BehaviorSystem.spec.js +0 -75
- package/src/engine/intelligence/behavior/util/ConditionBehavior.spec.js +0 -24
- package/src/engine/intelligence/blackboard/Blackboard.spec.js +0 -111
- package/src/engine/intelligence/blackboard/BlackboardSerializationAdapter.spec.js +0 -30
- package/src/engine/intelligence/blackboard/make_blackboard_proxy.spec.js +0 -23
- package/src/engine/intelligence/mcts/MonteCarlo.spec.js +0 -244
- package/src/engine/intelligence/mcts/StateNode.spec.js +0 -49
- package/src/engine/intelligence/optimization/RandomOptimizer.spec.js +0 -57
- package/src/engine/intelligence/resource/ResourceAllocationSolver.spec.js +0 -104
- package/src/engine/intelligence/resource/StrategicResourceAllocator.spec.js +0 -46
- package/src/engine/knowledge/database/StaticKnowledgeDataTable.spec.js +0 -26
- package/src/engine/knowledge/database/StaticKnowledgeDatabase.spec.js +0 -23
- package/src/engine/navigation/ecs/components/Path.spec.js +0 -195
- package/src/engine/navigation/ecs/path_following/PathFollower.spec.js +0 -27
- package/src/engine/navigation/grid/find_path_on_grid_astar.spec.js +0 -87
- package/src/engine/notify/NotificationLog.spec.js +0 -17
- package/src/engine/options/Option.spec.js +0 -69
- package/src/engine/options/OptionGroup.spec.js +0 -61
- package/src/engine/physics/gjk/expanding_polytope_algorithm.spec.js +0 -46
- package/src/engine/physics/inverse_kinematics/fabrik/fabrik3d_solve_primitive.spec.js +0 -43
- package/src/engine/plugin/EnginePlugin.spec.js +0 -5
- package/src/engine/reference/v2/Reference.spec.js +0 -44
- package/src/engine/scene/Scene.spec.js +0 -20
- package/src/engine/scene/SceneManager.spec.js +0 -131
- package/src/engine/sound/ecs/emitter/SoundEmitterSerializationAdapter.spec.js +0 -49
- package/src/engine/ui/tiles2d/TileGrid.spec.js +0 -20
- package/src/engine/ui/tiles2d/computeTileGridMove.spec.js +0 -54
- package/src/generation/automata/CaveGeneratorCellularAutomata.spec.js +0 -12
- package/src/generation/filtering/numeric/complex/CellFilterAngleToNormal.spec.js +0 -30
- package/src/generation/filtering/numeric/complex/CellFilterGaussianBlur.spec.js +0 -17
- package/src/generation/filtering/numeric/process/computeCellFilterGradient.spec.js +0 -288
- package/src/generation/grid/GridData.spec.js +0 -46
- package/src/generation/markers/actions/probability/MarkerNodeActionSelectWeighted.spec.js +0 -116
- package/src/generation/markers/transform/MarkerNodeTransformerYRotateByFilterGradient.spec.js +0 -106
- package/src/generation/placement/action/GridCellActionPlaceTags.spec.js +0 -21
- package/src/generation/rules/CellMatcherLayerBitMaskTest.spec.js +0 -22
- package/src/generation/rules/cell/GridPatternMatcher.spec.js +0 -285
- package/src/generation/theme/ThemeEngine.spec.js +0 -7
- package/src/view/tooltip/gml/TooltipParser.spec.js +0 -142
|
@@ -1,102 +0,0 @@
|
|
|
1
|
-
import { DataType } from "../type/DataType.js";
|
|
2
|
-
import { NodeRegistry } from "./NodeRegistry.js";
|
|
3
|
-
import { Port } from "./Port.js";
|
|
4
|
-
import { PortDirection } from "./PortDirection.js";
|
|
5
|
-
|
|
6
|
-
test("constructor does not throw", () => {
|
|
7
|
-
expect(() => new Port()).not.toThrow();
|
|
8
|
-
});
|
|
9
|
-
|
|
10
|
-
test("hash is consistent", () => {
|
|
11
|
-
const port = new Port();
|
|
12
|
-
|
|
13
|
-
expect(port.hash()).toEqual(port.hash());
|
|
14
|
-
});
|
|
15
|
-
|
|
16
|
-
test("hash is an unsigned integer", () => {
|
|
17
|
-
const port = new Port();
|
|
18
|
-
|
|
19
|
-
const hash = port.hash();
|
|
20
|
-
|
|
21
|
-
expect(typeof hash).toEqual("number");
|
|
22
|
-
expect(Number.isInteger(hash)).toEqual(true);
|
|
23
|
-
expect(hash).toBeGreaterThanOrEqual(0);
|
|
24
|
-
});
|
|
25
|
-
|
|
26
|
-
test("hash is different for different ports", () => {
|
|
27
|
-
|
|
28
|
-
const a = new Port();
|
|
29
|
-
const b = new Port();
|
|
30
|
-
|
|
31
|
-
expect(a.hash()).not.toEqual(b.hash());
|
|
32
|
-
});
|
|
33
|
-
|
|
34
|
-
test("equality works as intended", () => {
|
|
35
|
-
const a = new Port();
|
|
36
|
-
|
|
37
|
-
expect(a.equals(a)).toEqual(true);
|
|
38
|
-
|
|
39
|
-
const b = new Port();
|
|
40
|
-
|
|
41
|
-
expect(b.equals(a)).toEqual(false);
|
|
42
|
-
|
|
43
|
-
b.id = a.id;
|
|
44
|
-
|
|
45
|
-
expect(b.equals(a)).toEqual(true);
|
|
46
|
-
|
|
47
|
-
});
|
|
48
|
-
|
|
49
|
-
test("toString on newly crated instance produces a valid string", () => {
|
|
50
|
-
const port = new Port();
|
|
51
|
-
|
|
52
|
-
const s = port.toString();
|
|
53
|
-
|
|
54
|
-
expect(typeof s).toBe('string');
|
|
55
|
-
expect(s.trim().length).toBeGreaterThan(0); // non-empty
|
|
56
|
-
});
|
|
57
|
-
|
|
58
|
-
test("fromJSON", () => {
|
|
59
|
-
|
|
60
|
-
const registry = new NodeRegistry();
|
|
61
|
-
|
|
62
|
-
registry.addType(DataType.from(7, "t"));
|
|
63
|
-
|
|
64
|
-
const port = new Port();
|
|
65
|
-
|
|
66
|
-
port.fromJSON({
|
|
67
|
-
id: 3,
|
|
68
|
-
name: "x",
|
|
69
|
-
direction: "In",
|
|
70
|
-
dataType: {
|
|
71
|
-
id: 7,
|
|
72
|
-
name: "t"
|
|
73
|
-
}
|
|
74
|
-
}, registry);
|
|
75
|
-
|
|
76
|
-
expect(port.id).toEqual(3);
|
|
77
|
-
expect(port.name).toEqual("x");
|
|
78
|
-
expect(port.direction).toEqual(PortDirection.In);
|
|
79
|
-
expect(port.dataType.id).toEqual(7);
|
|
80
|
-
expect(port.dataType.name).toEqual("t");
|
|
81
|
-
});
|
|
82
|
-
|
|
83
|
-
test("toJSON", () => {
|
|
84
|
-
|
|
85
|
-
const port = new Port();
|
|
86
|
-
|
|
87
|
-
port.id = 3;
|
|
88
|
-
port.name = "x";
|
|
89
|
-
port.direction = PortDirection.Out;
|
|
90
|
-
port.dataType = DataType.from(7, "t");
|
|
91
|
-
|
|
92
|
-
expect(port.toJSON()).toEqual({
|
|
93
|
-
id: 3,
|
|
94
|
-
name: "x",
|
|
95
|
-
direction: "Out",
|
|
96
|
-
dataType: {
|
|
97
|
-
id: 7,
|
|
98
|
-
name: "t"
|
|
99
|
-
}
|
|
100
|
-
});
|
|
101
|
-
|
|
102
|
-
});
|
|
@@ -1,47 +0,0 @@
|
|
|
1
|
-
import { DataType } from "./DataType.js";
|
|
2
|
-
|
|
3
|
-
test('to/from json', () => {
|
|
4
|
-
const a = DataType.from(7, 'kitty');
|
|
5
|
-
|
|
6
|
-
const b = new DataType();
|
|
7
|
-
|
|
8
|
-
b.fromJSON(a.toJSON());
|
|
9
|
-
|
|
10
|
-
expect(b.id).toBe(a.id);
|
|
11
|
-
expect(b.name).toBe(a.name);
|
|
12
|
-
|
|
13
|
-
});
|
|
14
|
-
|
|
15
|
-
test('equals', () => {
|
|
16
|
-
const a = DataType.from(7, 'kitty');
|
|
17
|
-
const b = DataType.from(7, 'kitty');
|
|
18
|
-
const c = DataType.from(7, 'fluffy');
|
|
19
|
-
const d = DataType.from(9, 'kitty');
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
expect(a.equals(b)).toBe(true);
|
|
23
|
-
|
|
24
|
-
expect(a.equals(c)).toBe(false);
|
|
25
|
-
expect(a.equals(d)).toBe(false);
|
|
26
|
-
|
|
27
|
-
expect(c.equals(d)).toBe(false);
|
|
28
|
-
});
|
|
29
|
-
|
|
30
|
-
test("hash", () => {
|
|
31
|
-
|
|
32
|
-
const a = DataType.from(7, 'kitty');
|
|
33
|
-
const b = DataType.from(7, 'kitty');
|
|
34
|
-
|
|
35
|
-
expect(a.hash()).toEqual(a.hash()); //stability
|
|
36
|
-
expect(typeof a.hash()).toBe("number");
|
|
37
|
-
expect(Number.isInteger(a.hash())).toBe(true);
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
expect(a.hash()).toEqual(b.hash());
|
|
41
|
-
});
|
|
42
|
-
|
|
43
|
-
test("toString", () => {
|
|
44
|
-
const type = DataType.from(7, 'kitty');
|
|
45
|
-
|
|
46
|
-
expect(typeof type.toString()).toBe("string");
|
|
47
|
-
});
|
|
@@ -1,63 +0,0 @@
|
|
|
1
|
-
import { DataType } from "./DataType.js";
|
|
2
|
-
import { ParametricDataType } from "./ParametricDataType.js";
|
|
3
|
-
|
|
4
|
-
test("to/from json", () => {
|
|
5
|
-
|
|
6
|
-
const t = ParametricDataType.from(1, "x", [
|
|
7
|
-
DataType.from(7, "a")
|
|
8
|
-
]);
|
|
9
|
-
|
|
10
|
-
const json = t.toJSON();
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
const actual = new ParametricDataType();
|
|
14
|
-
|
|
15
|
-
actual.fromJSON(json);
|
|
16
|
-
|
|
17
|
-
expect(actual.id).toEqual(1);
|
|
18
|
-
expect(actual.name).toEqual("x");
|
|
19
|
-
expect(actual.parameters.length).toEqual(1);
|
|
20
|
-
expect(actual.parameters[0].id).toEqual(7);
|
|
21
|
-
expect(actual.parameters[0].name).toEqual("a");
|
|
22
|
-
expect(actual.parameters[0]).toBeInstanceOf(DataType);
|
|
23
|
-
});
|
|
24
|
-
|
|
25
|
-
test("equals", () => {
|
|
26
|
-
|
|
27
|
-
expect(
|
|
28
|
-
ParametricDataType.from(1, "x", [
|
|
29
|
-
DataType.from(7, "a")
|
|
30
|
-
]).equals(ParametricDataType.from(1, "x", [
|
|
31
|
-
DataType.from(7, "a")
|
|
32
|
-
]))
|
|
33
|
-
).toBe(true);
|
|
34
|
-
|
|
35
|
-
const t = ParametricDataType.from(1, "x");
|
|
36
|
-
|
|
37
|
-
expect(t.equals(t)).toBe(true);
|
|
38
|
-
|
|
39
|
-
expect(ParametricDataType.from(1, "x").equals(ParametricDataType.from(7, "x"))).toBe(false);
|
|
40
|
-
expect(ParametricDataType.from(1, "x").equals(ParametricDataType.from(1, "y"))).toBe(false);
|
|
41
|
-
|
|
42
|
-
expect(
|
|
43
|
-
ParametricDataType.from(1, "x", [
|
|
44
|
-
DataType.from(7, "a")
|
|
45
|
-
]).equals(ParametricDataType.from(1, "x", [
|
|
46
|
-
DataType.from(11, "a")
|
|
47
|
-
]))
|
|
48
|
-
).toBe(false);
|
|
49
|
-
|
|
50
|
-
expect(
|
|
51
|
-
ParametricDataType.from(1, "x", [
|
|
52
|
-
DataType.from(7, "a")
|
|
53
|
-
]).equals(ParametricDataType.from(1, "x", [
|
|
54
|
-
DataType.from(7, "b")
|
|
55
|
-
]))
|
|
56
|
-
).toBe(false);
|
|
57
|
-
|
|
58
|
-
expect(
|
|
59
|
-
ParametricDataType.from(1, "x", [
|
|
60
|
-
DataType.from(7, "a")
|
|
61
|
-
]).equals(ParametricDataType.from(1, "x"))
|
|
62
|
-
).toBe(false);
|
|
63
|
-
});
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
import { PortVisualData } from "./PortVisualData.js";
|
|
2
|
-
|
|
3
|
-
test("to/from JSON serialization", () => {
|
|
4
|
-
const a = new PortVisualData();
|
|
5
|
-
|
|
6
|
-
const b = new PortVisualData();
|
|
7
|
-
|
|
8
|
-
a.id = 7;
|
|
9
|
-
a.position.set(3, 11);
|
|
10
|
-
|
|
11
|
-
b.fromJSON(a.toJSON());
|
|
12
|
-
|
|
13
|
-
expect(b.id).toBe(7);
|
|
14
|
-
expect(b.position.x).toBe(3);
|
|
15
|
-
expect(b.position.y).toBe(11);
|
|
16
|
-
});
|
|
@@ -1,54 +0,0 @@
|
|
|
1
|
-
import { ObjectPoolFactory } from "./ObjectPoolFactory.js";
|
|
2
|
-
|
|
3
|
-
function create() {
|
|
4
|
-
return {};
|
|
5
|
-
}
|
|
6
|
-
|
|
7
|
-
function destroy() {
|
|
8
|
-
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
function reset() {
|
|
12
|
-
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
test("Reuses objects", () => {
|
|
16
|
-
const sut = new ObjectPoolFactory(create, destroy, reset);
|
|
17
|
-
|
|
18
|
-
const a = sut.create();
|
|
19
|
-
|
|
20
|
-
sut.release(a);
|
|
21
|
-
|
|
22
|
-
const b = sut.create();
|
|
23
|
-
|
|
24
|
-
//must be the same object
|
|
25
|
-
expect(a).toBe(b);
|
|
26
|
-
});
|
|
27
|
-
|
|
28
|
-
test("maxSize is respected", () => {
|
|
29
|
-
|
|
30
|
-
const sut = new ObjectPoolFactory(create, destroy, reset);
|
|
31
|
-
|
|
32
|
-
sut.maxSize = 2;
|
|
33
|
-
|
|
34
|
-
const a = sut.create();
|
|
35
|
-
const b = sut.create();
|
|
36
|
-
const c = sut.create();
|
|
37
|
-
|
|
38
|
-
sut.release(a);
|
|
39
|
-
sut.release(b);
|
|
40
|
-
//this one is beyond pool capacity
|
|
41
|
-
sut.release(c);
|
|
42
|
-
|
|
43
|
-
const x = sut.create();
|
|
44
|
-
const y = sut.create();
|
|
45
|
-
const z = sut.create();
|
|
46
|
-
|
|
47
|
-
expect(x === a || x === b).toBeTruthy();
|
|
48
|
-
expect(x).not.toBe(c);
|
|
49
|
-
|
|
50
|
-
expect(y === a || y === b).toBeTruthy();
|
|
51
|
-
expect(y).not.toBe(c);
|
|
52
|
-
|
|
53
|
-
expect(z).not.toBe(c);
|
|
54
|
-
});
|
|
@@ -1,54 +0,0 @@
|
|
|
1
|
-
import { objectDeepEquals } from "./objectDeepEquals.js";
|
|
2
|
-
|
|
3
|
-
test('objectDeepEquals', () => {
|
|
4
|
-
expect(objectDeepEquals({}, {})).toBe(true);
|
|
5
|
-
expect(objectDeepEquals({ a: 1 }, { a: 1 })).toBe(true);
|
|
6
|
-
expect(objectDeepEquals({ a: 1 }, { a: 2 })).toBe(false);
|
|
7
|
-
expect(objectDeepEquals({ a: 2 }, { a: 1 })).toBe(false);
|
|
8
|
-
|
|
9
|
-
expect(objectDeepEquals({ a: 1, b: "cat" }, { a: 1, b: "cat" })).toBe(true);
|
|
10
|
-
|
|
11
|
-
expect(objectDeepEquals({ a: 1, b: "cat" }, { a: 1 })).toBe(false);
|
|
12
|
-
|
|
13
|
-
expect(objectDeepEquals({ a: 1 }, { a: 1, b: "cat" })).toBe(false);
|
|
14
|
-
});
|
|
15
|
-
|
|
16
|
-
test("null values", () => {
|
|
17
|
-
expect(objectDeepEquals(null, null)).toBe(true);
|
|
18
|
-
expect(objectDeepEquals(null, {})).toBe(false);
|
|
19
|
-
expect(objectDeepEquals({}, null)).toBe(false);
|
|
20
|
-
});
|
|
21
|
-
|
|
22
|
-
test("same-type primitives", () => {
|
|
23
|
-
expect(objectDeepEquals(1, 1)).toBe(true);
|
|
24
|
-
expect(objectDeepEquals(-1, 1)).toBe(false);
|
|
25
|
-
expect(objectDeepEquals(-1, -1)).toBe(true);
|
|
26
|
-
expect(objectDeepEquals(-1, -3)).toBe(false);
|
|
27
|
-
|
|
28
|
-
expect(objectDeepEquals("cat", "cat")).toBe(true);
|
|
29
|
-
expect(objectDeepEquals("cat", "")).toBe(false);
|
|
30
|
-
expect(objectDeepEquals("", "cat")).toBe(false);
|
|
31
|
-
expect(objectDeepEquals("sat", "cat")).toBe(false);
|
|
32
|
-
expect(objectDeepEquals("cat", "sat")).toBe(false);
|
|
33
|
-
|
|
34
|
-
expect(objectDeepEquals(true, false)).toBe(false);
|
|
35
|
-
expect(objectDeepEquals(false, true)).toBe(false);
|
|
36
|
-
expect(objectDeepEquals(true, true)).toBe(true);
|
|
37
|
-
expect(objectDeepEquals(false, false)).toBe(true);
|
|
38
|
-
|
|
39
|
-
expect(objectDeepEquals(undefined, undefined)).toBe(true);
|
|
40
|
-
});
|
|
41
|
-
|
|
42
|
-
test("mixed primitives", () => {
|
|
43
|
-
expect(objectDeepEquals(1, undefined)).toBe(false);
|
|
44
|
-
expect(objectDeepEquals(undefined, 1)).toBe(false);
|
|
45
|
-
|
|
46
|
-
expect(objectDeepEquals("cat", 1)).toBe(false);
|
|
47
|
-
expect(objectDeepEquals(1, "cat")).toBe(false);
|
|
48
|
-
|
|
49
|
-
expect(objectDeepEquals(1, true)).toBe(false);
|
|
50
|
-
expect(objectDeepEquals(true, 1)).toBe(false);
|
|
51
|
-
|
|
52
|
-
expect(objectDeepEquals("cat", undefined)).toBe(false);
|
|
53
|
-
expect(objectDeepEquals(undefined, "cat")).toBe(false);
|
|
54
|
-
});
|
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
import { write_property } from "./write_property.js";
|
|
2
|
-
|
|
3
|
-
test("write via setter method", () => {
|
|
4
|
-
|
|
5
|
-
let value = 1;
|
|
6
|
-
|
|
7
|
-
const thing = {
|
|
8
|
-
setValue(v) {
|
|
9
|
-
value = v
|
|
10
|
-
}
|
|
11
|
-
}
|
|
12
|
-
|
|
13
|
-
write_property(thing, ['value'], 0, 1, 31);
|
|
14
|
-
|
|
15
|
-
expect(value).toEqual(31);
|
|
16
|
-
});
|
|
17
|
-
test("write via property accessor", () => {
|
|
18
|
-
|
|
19
|
-
const thing = {
|
|
20
|
-
value: 1
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
write_property(thing, ['value'], 0, 1, 31);
|
|
24
|
-
|
|
25
|
-
expect(thing.value).toEqual(31);
|
|
26
|
-
});
|
|
@@ -1,158 +0,0 @@
|
|
|
1
|
-
import { seededRandom } from "../../../math/random/seededRandom.js";
|
|
2
|
-
import DataType from "../../../parser/simple/DataType.js";
|
|
3
|
-
import { ReactiveLiteralBoolean } from "../model/terminal/ReactiveLiteralBoolean.js";
|
|
4
|
-
import { ReactiveLiteralNumber } from "../model/terminal/ReactiveLiteralNumber.js";
|
|
5
|
-
import { ReactiveLiteralString } from "../model/terminal/ReactiveLiteralString.js";
|
|
6
|
-
import { ReactiveReference } from "../model/terminal/ReactiveReference.js";
|
|
7
|
-
import { createRandomReactiveExpression } from "../model/util/createRandomReactiveExpression.js";
|
|
8
|
-
import { MultiPredicateEvaluator } from "./MultiPredicateEvaluator.js";
|
|
9
|
-
import { randomFromArray } from "../../../math/random/randomFromArray.js";
|
|
10
|
-
import { randomFloatBetween } from "../../../math/random/randomFloatBetween.js";
|
|
11
|
-
import { randomIntegerBetween } from "../../../math/random/randomIntegerBetween.js";
|
|
12
|
-
import { ReactiveEquals } from "../model/comparative/ReactiveEquals.js";
|
|
13
|
-
|
|
14
|
-
test('constructor does not throw', () => {
|
|
15
|
-
expect(() => new MultiPredicateEvaluator()).not.toThrow();
|
|
16
|
-
});
|
|
17
|
-
|
|
18
|
-
test('build empty', () => {
|
|
19
|
-
const processor = new MultiPredicateEvaluator();
|
|
20
|
-
|
|
21
|
-
expect(() => processor.build([])).not.toThrow();
|
|
22
|
-
});
|
|
23
|
-
|
|
24
|
-
test('match against empty list of predicates', () => {
|
|
25
|
-
|
|
26
|
-
const processor = new MultiPredicateEvaluator();
|
|
27
|
-
processor.build([]);
|
|
28
|
-
|
|
29
|
-
processor.initialize({});
|
|
30
|
-
|
|
31
|
-
expect(processor.next()).toBeUndefined();
|
|
32
|
-
});
|
|
33
|
-
|
|
34
|
-
test('match against one predicate', () => {
|
|
35
|
-
|
|
36
|
-
const processor = new MultiPredicateEvaluator();
|
|
37
|
-
|
|
38
|
-
const predicate = ReactiveEquals.from(new ReactiveReference('a'), ReactiveLiteralNumber.from(7));
|
|
39
|
-
|
|
40
|
-
processor.build([predicate]);
|
|
41
|
-
|
|
42
|
-
processor.initialize({ a: 1 });
|
|
43
|
-
|
|
44
|
-
expect(processor.next()).toBeUndefined();
|
|
45
|
-
|
|
46
|
-
processor.finalize();
|
|
47
|
-
processor.initialize({ a: 7 });
|
|
48
|
-
|
|
49
|
-
expect(processor.next()).toBe(predicate);
|
|
50
|
-
expect(processor.next()).toBeUndefined();
|
|
51
|
-
|
|
52
|
-
});
|
|
53
|
-
|
|
54
|
-
test.skip('performance', () => {
|
|
55
|
-
const random = seededRandom(12319);
|
|
56
|
-
|
|
57
|
-
const names = [];
|
|
58
|
-
|
|
59
|
-
const NAME_COUNT = 100;
|
|
60
|
-
for (let i = 0; i < NAME_COUNT; i++) {
|
|
61
|
-
names.push(`n${i}`);
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
const references = names.map(n => {
|
|
65
|
-
const ref = new ReactiveReference(n);
|
|
66
|
-
|
|
67
|
-
ref.dataType = DataType.Number;
|
|
68
|
-
|
|
69
|
-
return ref;
|
|
70
|
-
});
|
|
71
|
-
|
|
72
|
-
const literals = [];
|
|
73
|
-
|
|
74
|
-
for (let i = 0; i < 5; i++) {
|
|
75
|
-
literals.push(ReactiveLiteralNumber.from(randomFloatBetween(random, -10, 10)));
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
for (let i = 0; i < 5; i++) {
|
|
79
|
-
literals.push(ReactiveLiteralString.from(`string-${i}`));
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
literals.push(ReactiveLiteralBoolean.from(true));
|
|
83
|
-
literals.push(ReactiveLiteralBoolean.from(false));
|
|
84
|
-
|
|
85
|
-
const terminals = references.concat(literals);
|
|
86
|
-
|
|
87
|
-
const expressions = [];
|
|
88
|
-
|
|
89
|
-
const EXPRESSION_COUNT = 5000;
|
|
90
|
-
for (let i = 0; i < EXPRESSION_COUNT; i++) {
|
|
91
|
-
|
|
92
|
-
let exp;
|
|
93
|
-
|
|
94
|
-
do {
|
|
95
|
-
exp = createRandomReactiveExpression(random, terminals, randomIntegerBetween(random, 3, 15));
|
|
96
|
-
} while (exp.dataType !== DataType.Boolean);
|
|
97
|
-
|
|
98
|
-
expressions.push(exp);
|
|
99
|
-
|
|
100
|
-
}
|
|
101
|
-
const contexts = [];
|
|
102
|
-
|
|
103
|
-
const CONTEXT_COUNT = 5000;
|
|
104
|
-
|
|
105
|
-
for (let i = 0; i < CONTEXT_COUNT; i++) {
|
|
106
|
-
const v = {};
|
|
107
|
-
|
|
108
|
-
for (let j = 0; j < NAME_COUNT; j++) {
|
|
109
|
-
const roll = random();
|
|
110
|
-
|
|
111
|
-
if (roll < 0.03) {
|
|
112
|
-
continue;
|
|
113
|
-
}
|
|
114
|
-
|
|
115
|
-
const name = names[j];
|
|
116
|
-
|
|
117
|
-
v[name] = randomIntegerBetween(random, -10, 10);
|
|
118
|
-
}
|
|
119
|
-
|
|
120
|
-
contexts[i] = v;
|
|
121
|
-
}
|
|
122
|
-
|
|
123
|
-
const evaluator = new MultiPredicateEvaluator(exp => exp.computeTreeSize());
|
|
124
|
-
|
|
125
|
-
evaluator.build(expressions);
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
function cycle(context) {
|
|
129
|
-
evaluator.initialize(context);
|
|
130
|
-
evaluator.next();
|
|
131
|
-
evaluator.finalize();
|
|
132
|
-
}
|
|
133
|
-
|
|
134
|
-
const prewarm_random = seededRandom(63);
|
|
135
|
-
|
|
136
|
-
// pre-warm code
|
|
137
|
-
for (let i = 0; i < 10; i++) {
|
|
138
|
-
|
|
139
|
-
const context = randomFromArray(prewarm_random, contexts);
|
|
140
|
-
|
|
141
|
-
cycle(context);
|
|
142
|
-
}
|
|
143
|
-
|
|
144
|
-
const t0 = performance.now();
|
|
145
|
-
|
|
146
|
-
for (let i = 0; i < CONTEXT_COUNT; i++) {
|
|
147
|
-
const context = contexts[i];
|
|
148
|
-
|
|
149
|
-
cycle(context);
|
|
150
|
-
}
|
|
151
|
-
|
|
152
|
-
const overall_time = (performance.now() - t0) / 1000;
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
const overall_time_ps = overall_time * 1e12;
|
|
156
|
-
|
|
157
|
-
console.log(`Time per expression: ${Math.round(overall_time_ps / (CONTEXT_COUNT * EXPRESSION_COUNT))}ps(picoseconds)`);
|
|
158
|
-
});
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import { compileReactiveToJS } from "./compileReactiveToJS.js";
|
|
2
|
-
import { ReactiveLiteralBoolean } from "../model/terminal/ReactiveLiteralBoolean.js";
|
|
3
|
-
import { ReactiveLiteralNumber } from "../model/terminal/ReactiveLiteralNumber.js";
|
|
4
|
-
import { ReactiveLiteralString } from "../model/terminal/ReactiveLiteralString.js";
|
|
5
|
-
|
|
6
|
-
test("literal expressions", () => {
|
|
7
|
-
|
|
8
|
-
expect(compileReactiveToJS(ReactiveLiteralBoolean.from(true))).toEqual("true");
|
|
9
|
-
|
|
10
|
-
expect(compileReactiveToJS(ReactiveLiteralNumber.from(13.1))).toEqual("13.1");
|
|
11
|
-
|
|
12
|
-
expect(compileReactiveToJS(ReactiveLiteralString.from("a"))).toEqual("'a'");
|
|
13
|
-
|
|
14
|
-
});
|
|
@@ -1,51 +0,0 @@
|
|
|
1
|
-
import { ReactiveLiteralBoolean } from "../terminal/ReactiveLiteralBoolean.js";
|
|
2
|
-
import { ReactiveAnd } from "./ReactiveAnd.js";
|
|
3
|
-
|
|
4
|
-
test('copy method does not modify the sources', () => {
|
|
5
|
-
|
|
6
|
-
const b0 = ReactiveLiteralBoolean.from(false);
|
|
7
|
-
const b1 = ReactiveLiteralBoolean.from(true);
|
|
8
|
-
|
|
9
|
-
const a = new ReactiveAnd();
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
a.connect(b0, b1);
|
|
13
|
-
|
|
14
|
-
const b = new ReactiveAnd();
|
|
15
|
-
|
|
16
|
-
b.copy(a);
|
|
17
|
-
|
|
18
|
-
expect(b0.getValue()).toBe(false);
|
|
19
|
-
expect(b1.getValue()).toBe(true);
|
|
20
|
-
|
|
21
|
-
});
|
|
22
|
-
|
|
23
|
-
test("equals", () => {
|
|
24
|
-
|
|
25
|
-
const a = ReactiveAnd.from(ReactiveLiteralBoolean.from(true), ReactiveLiteralBoolean.from(true));
|
|
26
|
-
const b = ReactiveAnd.from(ReactiveLiteralBoolean.from(true), ReactiveLiteralBoolean.from(true));
|
|
27
|
-
const c = ReactiveAnd.from(ReactiveLiteralBoolean.from(true), ReactiveLiteralBoolean.from(false));
|
|
28
|
-
const d = ReactiveAnd.from(ReactiveLiteralBoolean.from(false), ReactiveLiteralBoolean.from(true));
|
|
29
|
-
|
|
30
|
-
expect(a.equals(b)).toBe(true);
|
|
31
|
-
expect(a.equals(c)).toBe(false);
|
|
32
|
-
expect(a.equals(d)).toBe(false);
|
|
33
|
-
|
|
34
|
-
expect(a.equals(ReactiveLiteralBoolean.from(true))).toBe(false);
|
|
35
|
-
});
|
|
36
|
-
|
|
37
|
-
test("evaluate", () => {
|
|
38
|
-
const a = ReactiveAnd.from(ReactiveLiteralBoolean.from(true), ReactiveLiteralBoolean.from(true));
|
|
39
|
-
const b = ReactiveAnd.from(ReactiveLiteralBoolean.from(true), ReactiveLiteralBoolean.from(false));
|
|
40
|
-
|
|
41
|
-
expect(a.evaluate({})).toBe(true);
|
|
42
|
-
expect(b.evaluate({})).toBe(false);
|
|
43
|
-
});
|
|
44
|
-
|
|
45
|
-
test("clone", () => {
|
|
46
|
-
const source = ReactiveAnd.from(ReactiveLiteralBoolean.from(true), ReactiveLiteralBoolean.from(false));
|
|
47
|
-
|
|
48
|
-
const clone = source.clone();
|
|
49
|
-
|
|
50
|
-
expect(clone.equals(source)).toBe(true);
|
|
51
|
-
});
|
|
@@ -1,53 +0,0 @@
|
|
|
1
|
-
import { ReactiveLiteralBoolean } from "../terminal/ReactiveLiteralBoolean.js";
|
|
2
|
-
import { ReactiveOr } from "./ReactiveOr.js";
|
|
3
|
-
|
|
4
|
-
test('copy method does not modify the sources', () => {
|
|
5
|
-
|
|
6
|
-
const b0 = ReactiveLiteralBoolean.from(false);
|
|
7
|
-
const b1 = ReactiveLiteralBoolean.from(true);
|
|
8
|
-
|
|
9
|
-
const a = new ReactiveOr();
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
a.connect(b0, b1);
|
|
13
|
-
|
|
14
|
-
const b = new ReactiveOr();
|
|
15
|
-
|
|
16
|
-
b.copy(a);
|
|
17
|
-
|
|
18
|
-
expect(b0.getValue()).toBe(false);
|
|
19
|
-
expect(b1.getValue()).toBe(true);
|
|
20
|
-
|
|
21
|
-
});
|
|
22
|
-
|
|
23
|
-
test("equals", () => {
|
|
24
|
-
|
|
25
|
-
const a = ReactiveOr.from(ReactiveLiteralBoolean.from(true), ReactiveLiteralBoolean.from(true));
|
|
26
|
-
const b = ReactiveOr.from(ReactiveLiteralBoolean.from(true), ReactiveLiteralBoolean.from(true));
|
|
27
|
-
const c = ReactiveOr.from(ReactiveLiteralBoolean.from(true), ReactiveLiteralBoolean.from(false));
|
|
28
|
-
const d = ReactiveOr.from(ReactiveLiteralBoolean.from(false), ReactiveLiteralBoolean.from(true));
|
|
29
|
-
|
|
30
|
-
expect(a.equals(b)).toBe(true);
|
|
31
|
-
expect(a.equals(c)).toBe(false);
|
|
32
|
-
expect(a.equals(d)).toBe(false);
|
|
33
|
-
|
|
34
|
-
expect(a.equals(ReactiveLiteralBoolean.from(true))).toBe(false);
|
|
35
|
-
});
|
|
36
|
-
|
|
37
|
-
test("evaluate", () => {
|
|
38
|
-
const a = ReactiveOr.from(ReactiveLiteralBoolean.from(true), ReactiveLiteralBoolean.from(true));
|
|
39
|
-
const b = ReactiveOr.from(ReactiveLiteralBoolean.from(true), ReactiveLiteralBoolean.from(false));
|
|
40
|
-
const c = ReactiveOr.from(ReactiveLiteralBoolean.from(false), ReactiveLiteralBoolean.from(false));
|
|
41
|
-
|
|
42
|
-
expect(a.evaluate({})).toBe(true);
|
|
43
|
-
expect(b.evaluate({})).toBe(true);
|
|
44
|
-
expect(c.evaluate({})).toBe(false);
|
|
45
|
-
});
|
|
46
|
-
|
|
47
|
-
test("clone", () => {
|
|
48
|
-
const source = ReactiveOr.from(ReactiveLiteralBoolean.from(true), ReactiveLiteralBoolean.from(false));
|
|
49
|
-
|
|
50
|
-
const clone = source.clone();
|
|
51
|
-
|
|
52
|
-
expect(clone.equals(source)).toBe(true);
|
|
53
|
-
});
|
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
import { jest } from "@jest/globals";
|
|
2
|
-
import ObservedBoolean from "../../../ObservedBoolean.js";
|
|
3
|
-
import { ReactiveReference } from "./ReactiveReference.js";
|
|
4
|
-
|
|
5
|
-
test('onChange dispatch', () => {
|
|
6
|
-
const ref = new ReactiveReference('x');
|
|
7
|
-
|
|
8
|
-
const b = new ObservedBoolean(false);
|
|
9
|
-
|
|
10
|
-
ref.connect(b);
|
|
11
|
-
|
|
12
|
-
const handler = jest.fn();
|
|
13
|
-
|
|
14
|
-
ref.onChanged.add(handler);
|
|
15
|
-
|
|
16
|
-
expect(handler).not.toHaveBeenCalled();
|
|
17
|
-
|
|
18
|
-
b.set(false);
|
|
19
|
-
|
|
20
|
-
expect(handler).not.toHaveBeenCalled();
|
|
21
|
-
|
|
22
|
-
b.set(true);
|
|
23
|
-
|
|
24
|
-
expect(handler).toHaveBeenCalledTimes(1);
|
|
25
|
-
expect(handler).toHaveBeenLastCalledWith(true, false);
|
|
26
|
-
});
|
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
import { BlackboardTrigger } from "./BlackboardTrigger.js";
|
|
2
|
-
import { Blackboard } from "../../../../engine/intelligence/blackboard/Blackboard.js";
|
|
3
|
-
|
|
4
|
-
test("constructor does not throw", () => {
|
|
5
|
-
expect(() => new BlackboardTrigger()).not.toThrow();
|
|
6
|
-
});
|
|
7
|
-
|
|
8
|
-
test("numeric equality", () => {
|
|
9
|
-
|
|
10
|
-
const trigger = new BlackboardTrigger();
|
|
11
|
-
trigger.code = "a == 7";
|
|
12
|
-
|
|
13
|
-
const bb = Blackboard.fromJSON({
|
|
14
|
-
a: 7
|
|
15
|
-
});
|
|
16
|
-
|
|
17
|
-
trigger.link(bb);
|
|
18
|
-
|
|
19
|
-
expect(trigger.getExpression().getValue()).toBe(true);
|
|
20
|
-
|
|
21
|
-
bb.acquireNumber("a").set(1);
|
|
22
|
-
|
|
23
|
-
expect(trigger.getExpression().getValue()).toBe(false);
|
|
24
|
-
});
|