@dcl/sdk 7.4.4 → 7.4.5-8054791102.commit-f06a0a7

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/players/index.js CHANGED
@@ -15,9 +15,11 @@ function definePlayerHelper(engine) {
15
15
  for (const [entity, identity] of players) {
16
16
  if (!playerEntities.has(entity)) {
17
17
  playerEntities.set(entity, identity.address);
18
+ // Call onEnter callback
18
19
  if (onEnterSceneCb) {
19
20
  onEnterSceneCb(getPlayer({ userId: identity.address }));
20
21
  }
22
+ // Check for changes/remove callbacks
21
23
  AvatarBase.onChange(entity, (value) => {
22
24
  if (!value && onLeaveSceneCb && playerEntities.get(entity)) {
23
25
  onLeaveSceneCb(playerEntities.get(entity));
@@ -34,6 +36,9 @@ function definePlayerHelper(engine) {
34
36
  onLeaveScene(cb) {
35
37
  onLeaveSceneCb = cb;
36
38
  },
39
+ /**
40
+ * Returns the info of the player if it's in the scene.
41
+ */
37
42
  getPlayer(user) {
38
43
  function getEntity() {
39
44
  if (!user?.userId)
@@ -70,4 +75,4 @@ const players = definePlayerHelper(engine);
70
75
  const { getPlayer, onEnterScene, onLeaveScene } = players;
71
76
  export { getPlayer, onEnterScene, onLeaveScene };
72
77
  export default players;
73
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/players/index.ts"],"names":[],"mappings":"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","sourcesContent":["import { Entity, IEngine, TransformType, engine } from '@dcl/ecs'\nimport {\n  PlayerIdentityData as definePlayerIdenityData,\n  AvatarBase as defineAvatarBase,\n  AvatarEquippedData as defineAvatarEquippedData,\n  PBAvatarBase,\n  PBAvatarEquippedData,\n  Transform as defineTransform\n} from '@dcl/ecs/dist/components'\n\ntype GetPlayerDataReq = {\n  userId: string\n}\ntype GetPlayerDataRes = {\n  entity: Entity\n  name: string\n  isGuest: boolean\n  userId: string\n  avatar?: PBAvatarBase\n  wearables: PBAvatarEquippedData['wearableUrns']\n  emotes: PBAvatarEquippedData['emoteUrns']\n  position: TransformType['position'] | undefined\n}\n\nfunction definePlayerHelper(engine: IEngine) {\n  const Transform = defineTransform(engine)\n  const PlayerIdentityData = definePlayerIdenityData(engine)\n  const AvatarEquippedData = defineAvatarEquippedData(engine)\n  const AvatarBase = defineAvatarBase(engine)\n  const playerEntities = new Map<Entity, string>()\n  let onEnterSceneCb: ((player: GetPlayerDataRes) => void) | undefined = undefined\n  let onLeaveSceneCb: ((userId: string) => void) | undefined = undefined\n\n  engine.addSystem(() => {\n    const players = Array.from(engine.getEntitiesWith(PlayerIdentityData, AvatarBase))\n    if (players.length === playerEntities.size) return\n\n    for (const [entity, identity] of players) {\n      if (!playerEntities.has(entity)) {\n        playerEntities.set(entity, identity.address)\n\n        // Call onEnter callback\n        if (onEnterSceneCb) {\n          onEnterSceneCb(getPlayer({ userId: identity.address })!)\n        }\n\n        // Check for changes/remove callbacks\n        AvatarBase.onChange(entity, (value) => {\n          if (!value && onLeaveSceneCb && playerEntities.get(entity)) {\n            onLeaveSceneCb(playerEntities.get(entity)!)\n            playerEntities.delete(entity)\n          }\n        })\n      }\n    }\n  })\n\n  return {\n    onEnterScene(cb: (player: GetPlayerDataRes) => void) {\n      onEnterSceneCb = cb\n    },\n    onLeaveScene(cb: (userId: string) => void) {\n      onLeaveSceneCb = cb\n    },\n    /**\n     * Returns the info of the player if it's in the scene.\n     */\n    getPlayer(user?: GetPlayerDataReq): GetPlayerDataRes | null {\n      function getEntity() {\n        if (!user?.userId) return engine.PlayerEntity\n        for (const [entity, data] of engine.getEntitiesWith(PlayerIdentityData)) {\n          if (data.address === user.userId) {\n            return entity\n          }\n        }\n        return undefined\n      }\n\n      const userEntity = getEntity()\n      if (!userEntity) return null\n\n      const playerData = PlayerIdentityData.getOrNull(userEntity)\n      const avatarData = AvatarBase.getOrNull(userEntity)\n      const wearablesData = AvatarEquippedData.getOrNull(userEntity)\n\n      if (!playerData && !avatarData && !wearablesData) return null\n\n      return {\n        entity: userEntity,\n        name: avatarData?.name ?? '',\n        isGuest: !!playerData?.isGuest ?? false,\n        userId: playerData?.address ?? '',\n        avatar: avatarData ?? undefined,\n        wearables: wearablesData?.wearableUrns ?? [],\n        emotes: wearablesData?.emoteUrns ?? [],\n        position: Transform.getOrNull(userEntity)?.position\n      }\n    }\n  }\n}\n\nconst players = definePlayerHelper(engine)\nconst { getPlayer, onEnterScene, onLeaveScene } = players\n\nexport { getPlayer, onEnterScene, onLeaveScene }\nexport default players\n"]}
78
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/players/index.ts"],"names":[],"mappings":"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","sourcesContent":["import { Entity, IEngine, TransformType, engine } from '@dcl/ecs'\nimport {\n  PlayerIdentityData as definePlayerIdenityData,\n  AvatarBase as defineAvatarBase,\n  AvatarEquippedData as defineAvatarEquippedData,\n  PBAvatarBase,\n  PBAvatarEquippedData,\n  Transform as defineTransform\n} from '@dcl/ecs/dist/components'\n\ntype GetPlayerDataReq = {\n  userId: string\n}\ntype GetPlayerDataRes = {\n  entity: Entity\n  name: string\n  isGuest: boolean\n  userId: string\n  avatar?: PBAvatarBase\n  wearables: PBAvatarEquippedData['wearableUrns']\n  emotes: PBAvatarEquippedData['emoteUrns']\n  position: TransformType['position'] | undefined\n}\n\nfunction definePlayerHelper(engine: IEngine) {\n  const Transform = defineTransform(engine)\n  const PlayerIdentityData = definePlayerIdenityData(engine)\n  const AvatarEquippedData = defineAvatarEquippedData(engine)\n  const AvatarBase = defineAvatarBase(engine)\n  const playerEntities = new Map<Entity, string>()\n  let onEnterSceneCb: ((player: GetPlayerDataRes) => void) | undefined = undefined\n  let onLeaveSceneCb: ((userId: string) => void) | undefined = undefined\n\n  engine.addSystem(() => {\n    const players = Array.from(engine.getEntitiesWith(PlayerIdentityData, AvatarBase))\n    if (players.length === playerEntities.size) return\n\n    for (const [entity, identity] of players) {\n      if (!playerEntities.has(entity)) {\n        playerEntities.set(entity, identity.address)\n\n        // Call onEnter callback\n        if (onEnterSceneCb) {\n          onEnterSceneCb(getPlayer({ userId: identity.address })!)\n        }\n\n        // Check for changes/remove callbacks\n        AvatarBase.onChange(entity, (value) => {\n          if (!value && onLeaveSceneCb && playerEntities.get(entity)) {\n            onLeaveSceneCb(playerEntities.get(entity)!)\n            playerEntities.delete(entity)\n          }\n        })\n      }\n    }\n  })\n\n  return {\n    onEnterScene(cb: (player: GetPlayerDataRes) => void) {\n      onEnterSceneCb = cb\n    },\n    onLeaveScene(cb: (userId: string) => void) {\n      onLeaveSceneCb = cb\n    },\n    /**\n     * Returns the info of the player if it's in the scene.\n     */\n    getPlayer(user?: GetPlayerDataReq): GetPlayerDataRes | null {\n      function getEntity() {\n        if (!user?.userId) return engine.PlayerEntity\n        for (const [entity, data] of engine.getEntitiesWith(PlayerIdentityData)) {\n          if (data.address === user.userId) {\n            return entity\n          }\n        }\n        return undefined\n      }\n\n      const userEntity = getEntity()\n      if (!userEntity) return null\n\n      const playerData = PlayerIdentityData.getOrNull(userEntity)\n      const avatarData = AvatarBase.getOrNull(userEntity)\n      const wearablesData = AvatarEquippedData.getOrNull(userEntity)\n\n      if (!playerData && !avatarData && !wearablesData) return null\n\n      return {\n        entity: userEntity,\n        name: avatarData?.name ?? '',\n        isGuest: !!playerData?.isGuest ?? false,\n        userId: playerData?.address ?? '',\n        avatar: avatarData ?? undefined,\n        wearables: wearablesData?.wearableUrns ?? [],\n        emotes: wearablesData?.emoteUrns ?? [],\n        position: Transform.getOrNull(userEntity)?.position\n      }\n    }\n  }\n}\n\nconst players = definePlayerHelper(engine)\nconst { getPlayer, onEnterScene, onLeaveScene } = players\n\nexport { getPlayer, onEnterScene, onLeaveScene }\nexport default players\n"]}
package/react-ecs.d.ts CHANGED
@@ -1,3 +1,21 @@
1
+ /**
2
+ * The module react-ecs is exposed by the sdk in the /react-ecs path.
3
+ *
4
+ * UI components and semantics for the SDK 7.
5
+ *
6
+ * JSX & Flexbox is used due to its market adoption and availability of implementations and documentation and expertise.
7
+ * @example
8
+ * ```tsx
9
+ * import ReactEcs, { Label, ReactEcsRenderer } from '@dcl/sdk/react-ecs'
10
+ * const Ui = () => <Label value="SDK 7" />
11
+ * ReactEcsRenderer.setUiRenderer(ui)
12
+ * ```
13
+ *
14
+ *
15
+ * Go to the Function section to see all the UI Components.
16
+ * @module ReactEcs
17
+ *
18
+ */
1
19
  import ReactEcs from '@dcl/react-ecs';
2
20
  export * from '@dcl/react-ecs';
3
21
  export default ReactEcs;
package/react-ecs.js CHANGED
@@ -1,4 +1,22 @@
1
+ /**
2
+ * The module react-ecs is exposed by the sdk in the /react-ecs path.
3
+ *
4
+ * UI components and semantics for the SDK 7.
5
+ *
6
+ * JSX & Flexbox is used due to its market adoption and availability of implementations and documentation and expertise.
7
+ * @example
8
+ * ```tsx
9
+ * import ReactEcs, { Label, ReactEcsRenderer } from '@dcl/sdk/react-ecs'
10
+ * const Ui = () => <Label value="SDK 7" />
11
+ * ReactEcsRenderer.setUiRenderer(ui)
12
+ * ```
13
+ *
14
+ *
15
+ * Go to the Function section to see all the UI Components.
16
+ * @module ReactEcs
17
+ *
18
+ */
1
19
  import ReactEcs from '@dcl/react-ecs';
2
20
  export * from '@dcl/react-ecs';
3
21
  export default ReactEcs;
4
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVhY3QtZWNzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsic3JjL3JlYWN0LWVjcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFtQkEsT0FBTyxRQUFRLE1BQU0sZ0JBQWdCLENBQUE7QUFDckMsY0FBYyxnQkFBZ0IsQ0FBQTtBQUM5QixlQUFlLFFBQVEsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogVGhlIG1vZHVsZSByZWFjdC1lY3MgaXMgZXhwb3NlZCBieSB0aGUgc2RrIGluIHRoZSAvcmVhY3QtZWNzIHBhdGguXG4gKlxuICogVUkgY29tcG9uZW50cyBhbmQgc2VtYW50aWNzIGZvciB0aGUgU0RLIDcuXG4gKlxuICogSlNYICYgRmxleGJveCBpcyB1c2VkIGR1ZSB0byBpdHMgbWFya2V0IGFkb3B0aW9uIGFuZCBhdmFpbGFiaWxpdHkgb2YgaW1wbGVtZW50YXRpb25zIGFuZCBkb2N1bWVudGF0aW9uIGFuZCBleHBlcnRpc2UuXG4gKiBAZXhhbXBsZVxuICogYGBgdHN4XG4gKiBpbXBvcnQgUmVhY3RFY3MsIHsgTGFiZWwsIFJlYWN0RWNzUmVuZGVyZXIgfSBmcm9tICdAZGNsL3Nkay9yZWFjdC1lY3MnXG4gKiBjb25zdCBVaSA9ICgpID0+IDxMYWJlbCB2YWx1ZT1cIlNESyA3XCIgLz5cbiAqIFJlYWN0RWNzUmVuZGVyZXIuc2V0VWlSZW5kZXJlcih1aSlcbiAqIGBgYFxuICpcbiAqXG4gKiBHbyB0byB0aGUgRnVuY3Rpb24gc2VjdGlvbiB0byBzZWUgYWxsIHRoZSBVSSBDb21wb25lbnRzLlxuICogQG1vZHVsZSBSZWFjdEVjc1xuICpcbiAqL1xuXG5pbXBvcnQgUmVhY3RFY3MgZnJvbSAnQGRjbC9yZWFjdC1lY3MnXG5leHBvcnQgKiBmcm9tICdAZGNsL3JlYWN0LWVjcydcbmV4cG9ydCBkZWZhdWx0IFJlYWN0RWNzXG4iXX0=
22
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVhY3QtZWNzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsic3JjL3JlYWN0LWVjcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FpQkc7QUFFSCxPQUFPLFFBQVEsTUFBTSxnQkFBZ0IsQ0FBQTtBQUNyQyxjQUFjLGdCQUFnQixDQUFBO0FBQzlCLGVBQWUsUUFBUSxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBUaGUgbW9kdWxlIHJlYWN0LWVjcyBpcyBleHBvc2VkIGJ5IHRoZSBzZGsgaW4gdGhlIC9yZWFjdC1lY3MgcGF0aC5cbiAqXG4gKiBVSSBjb21wb25lbnRzIGFuZCBzZW1hbnRpY3MgZm9yIHRoZSBTREsgNy5cbiAqXG4gKiBKU1ggJiBGbGV4Ym94IGlzIHVzZWQgZHVlIHRvIGl0cyBtYXJrZXQgYWRvcHRpb24gYW5kIGF2YWlsYWJpbGl0eSBvZiBpbXBsZW1lbnRhdGlvbnMgYW5kIGRvY3VtZW50YXRpb24gYW5kIGV4cGVydGlzZS5cbiAqIEBleGFtcGxlXG4gKiBgYGB0c3hcbiAqIGltcG9ydCBSZWFjdEVjcywgeyBMYWJlbCwgUmVhY3RFY3NSZW5kZXJlciB9IGZyb20gJ0BkY2wvc2RrL3JlYWN0LWVjcydcbiAqIGNvbnN0IFVpID0gKCkgPT4gPExhYmVsIHZhbHVlPVwiU0RLIDdcIiAvPlxuICogUmVhY3RFY3NSZW5kZXJlci5zZXRVaVJlbmRlcmVyKHVpKVxuICogYGBgXG4gKlxuICpcbiAqIEdvIHRvIHRoZSBGdW5jdGlvbiBzZWN0aW9uIHRvIHNlZSBhbGwgdGhlIFVJIENvbXBvbmVudHMuXG4gKiBAbW9kdWxlIFJlYWN0RWNzXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdEVjcyBmcm9tICdAZGNsL3JlYWN0LWVjcydcbmV4cG9ydCAqIGZyb20gJ0BkY2wvcmVhY3QtZWNzJ1xuZXhwb3J0IGRlZmF1bHQgUmVhY3RFY3NcbiJdfQ==
@@ -18,6 +18,10 @@ import { sendAsync } from '~system/EthereumController'
18
18
  import { getEthereumProvider } from '../internal/provider'
19
19
  import { polyfillTextEncoder } from './text-encoder'
20
20
 
21
+ /**
22
+ * Etherum Provider
23
+ * @public
24
+ */
21
25
  export function createEthereumProvider() {
22
26
  polyfillTextEncoder()
23
27
  return getEthereumProvider(sendAsync)
@@ -2,6 +2,7 @@
2
2
  /**
3
3
  * A class serves as a medium between the observable and its observers
4
4
  * @deprecated This function is an inheritance of ECS6, it's here temporary for the feature parity, please read the news and docs to know how handle when it's removed
5
+ * @public
5
6
  */
6
7
  export class ObserverEventState {
7
8
  /**
@@ -61,6 +62,7 @@ export class ObserverEventState {
61
62
  /**
62
63
  * Represent an Observer registered to a given Observable object.
63
64
  * @deprecated This function is an inheritance of ECS6, it's here temporary for the feature parity, please read the news and docs to know how handle when it's removed
65
+ * @public
64
66
  */
65
67
  export class Observer<T> {
66
68
  /**
@@ -101,6 +103,7 @@ export class Observer<T> {
101
103
  * For instance you may have a given Observable that have four different types of notifications: Move (mask = 0x01), Stop (mask = 0x02), Turn Right (mask = 0X04), Turn Left (mask = 0X08).
102
104
  * A given observer can register itself with only Move and Stop (mask = 0x03), then it will only be notified when one of these two occurs and will never be for Turn Left/Right.
103
105
  *
106
+ * @public
104
107
  * @deprecated This function is an inheritance of ECS6, it's here temporary for the feature parity, please read the news and docs to know how handle when it's removed
105
108
  */
106
109
  export class Observable<T> {
package/testing/assert.js CHANGED
@@ -1,3 +1,4 @@
1
+ // VERBATIM COPY OF https://github.com/LemonPi/deep-close-to
1
2
  const pSlice = Array.prototype.slice;
2
3
  const floatEpsilon = 0.0000001;
3
4
  export function assertEquals(a, b, message = 'Values are not equal') {
@@ -14,11 +15,14 @@ export function assertComponentValue(entity, component, value) {
14
15
  }
15
16
  export function deepCloseTo(actual, expected, options = {}) {
16
17
  const opts = Object.assign({}, { comp: closeTo }, options);
18
+ // 7.1. All identical values are equivalent, as determined by ===.
17
19
  if (actual === expected) {
18
20
  return true;
19
21
  }
20
22
  else if (actual instanceof Date && expected instanceof Date) {
21
23
  return opts.comp(actual, expected);
24
+ // 7.3. Other pairs that do not both pass typeof value == 'object',
25
+ // equivalence is determined by ==.
22
26
  }
23
27
  else if (!actual || !expected || (typeof actual !== 'object' && typeof expected !== 'object')) {
24
28
  if (opts.strict) {
@@ -33,6 +37,12 @@ export function deepCloseTo(actual, expected, options = {}) {
33
37
  return actual === expected;
34
38
  }
35
39
  return opts.comp(actual, expected);
40
+ // 7.4. For all other Object pairs, including Array objects, equivalence is
41
+ // determined by having the same number of owned properties (as verified
42
+ // with Object.prototype.hasOwnProperty.call), the same set of keys
43
+ // (although not necessarily the same order), equivalent values for every
44
+ // corresponding key, and an identical 'prototype' property. Note: this
45
+ // accounts for both named and indexed properties on Arrays.
36
46
  }
37
47
  else {
38
48
  return objEquiv(actual, expected, opts);
@@ -55,8 +65,11 @@ function objEquiv(a, b, opts) {
55
65
  let i, key;
56
66
  if (isUndefinedOrNull(a) || isUndefinedOrNull(b))
57
67
  return false;
68
+ // an identical 'prototype' property.
58
69
  if (a.prototype !== b.prototype)
59
70
  return false;
71
+ //~~~I've managed to break Object.keys through screwy arguments passing.
72
+ // Converting to array solves the problem.
60
73
  if (isArguments(a)) {
61
74
  if (!isArguments(b)) {
62
75
  return false;
@@ -78,14 +91,20 @@ function objEquiv(a, b, opts) {
78
91
  try {
79
92
  const ka = Object.keys(a);
80
93
  const kb = Object.keys(b);
94
+ // having the same number of owned properties (keys incorporates
95
+ // hasOwnProperty)
81
96
  if (ka.length !== kb.length)
82
97
  return false;
98
+ //the same set of keys (although not necessarily the same order),
83
99
  ka.sort();
84
100
  kb.sort();
101
+ //~~~cheap key test
85
102
  for (i = ka.length - 1; i >= 0; i--) {
86
103
  if (ka[i] !== kb[i])
87
104
  return false;
88
105
  }
106
+ //equivalent values for every corresponding key, and
107
+ //~~~possibly expensive deep test
89
108
  for (i = ka.length - 1; i >= 0; i--) {
90
109
  key = ka[i];
91
110
  if (!deepCloseTo(a[key], b[key], opts))
@@ -93,6 +112,7 @@ function objEquiv(a, b, opts) {
93
112
  }
94
113
  }
95
114
  catch (e) {
115
+ //happens when one is a string literal and the other isn't
96
116
  return false;
97
117
  }
98
118
  return typeof a === typeof b;
@@ -103,4 +123,4 @@ function isArguments(object) {
103
123
  function closeTo(actual, expected, delta = floatEpsilon) {
104
124
  return Math.abs(actual - expected) < delta;
105
125
  }
106
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"assert.js","sourceRoot":"","sources":["../src/testing/assert.ts"],"names":[],"mappings":"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","sourcesContent":["// VERBATIM COPY OF https://github.com/LemonPi/deep-close-to\n\nimport type { Entity, LastWriteWinElementSetComponentDefinition } from '@dcl/ecs'\n\nconst pSlice = Array.prototype.slice\n\nconst floatEpsilon = 0.0000001\n\ntype Options = { strict: boolean; comp: typeof closeTo }\n\nexport function assertEquals(a: any, b: any, message: string = 'Values are not equal') {\n  if (!deepCloseTo(a, b)) throw new Error(`${message} - ${JSON.stringify(a)} != ${JSON.stringify(b)}`)\n}\n\nexport function assert(a: any, message: string = 'assertion failed') {\n  if (!a) throw new Error(message)\n}\n\nexport function assertComponentValue<T>(\n  entity: Entity,\n  component: LastWriteWinElementSetComponentDefinition<T>,\n  value: T\n) {\n  assert(component.has(entity), `The entity doesn't have a ${component.componentName} component`)\n  assertEquals(component.get(entity)!, value, `Invalid ${component.componentName} values`)\n}\n\nexport function deepCloseTo(actual: any, expected: any, options: Partial<Options> = {}): boolean {\n  const opts = Object.assign({}, { comp: closeTo }, options)\n  // 7.1. All identical values are equivalent, as determined by ===.\n  if (actual === expected) {\n    return true\n  } else if (actual instanceof Date && expected instanceof Date) {\n    return opts.comp!(actual, expected)\n\n    // 7.3. Other pairs that do not both pass typeof value == 'object',\n    // equivalence is determined by ==.\n  } else if (!actual || !expected || (typeof actual !== 'object' && typeof expected !== 'object')) {\n    if (opts.strict) {\n      if (!actual && !expected) {\n        return actual === expected\n      }\n\n      if (typeof actual !== typeof expected) {\n        return false\n      }\n    }\n    if (!actual && !expected) {\n      return actual === expected\n    }\n    return opts.comp!(actual, expected)\n\n    // 7.4. For all other Object pairs, including Array objects, equivalence is\n    // determined by having the same number of owned properties (as verified\n    // with Object.prototype.hasOwnProperty.call), the same set of keys\n    // (although not necessarily the same order), equivalent values for every\n    // corresponding key, and an identical 'prototype' property. Note: this\n    // accounts for both named and indexed properties on Arrays.\n  } else {\n    return objEquiv(actual, expected, opts as any)\n  }\n}\n\nfunction isUndefinedOrNull(value: any) {\n  return value === null || value === undefined\n}\n\nfunction isBuffer(x: any) {\n  if (!x || typeof x !== 'object' || typeof x.length !== 'number') return false\n  if (typeof x.copy !== 'function' || typeof x.slice !== 'function') {\n    return false\n  }\n  if (x.length > 0 && typeof x[0] !== 'number') return false\n  return true\n}\n\nfunction objEquiv(a: any, b: any, opts: Options) {\n  let i, key\n  if (isUndefinedOrNull(a) || isUndefinedOrNull(b)) return false\n  // an identical 'prototype' property.\n  if (a.prototype !== b.prototype) return false\n  //~~~I've managed to break Object.keys through screwy arguments passing.\n  //   Converting to array solves the problem.\n  if (isArguments(a)) {\n    if (!isArguments(b)) {\n      return false\n    }\n    return deepCloseTo(pSlice.call(a), pSlice.call(b), opts)\n  }\n  if (isBuffer(a)) {\n    if (!isBuffer(b)) {\n      return false\n    }\n    if (a.length !== b.length) return false\n    for (i = 0; i < a.length; i++) {\n      if (a[i] !== b[i]) return false\n    }\n    return true\n  }\n\n  try {\n    const ka = Object.keys(a)\n    const kb = Object.keys(b)\n\n    // having the same number of owned properties (keys incorporates\n    // hasOwnProperty)\n    if (ka.length !== kb.length) return false\n    //the same set of keys (although not necessarily the same order),\n    ka.sort()\n    kb.sort()\n    //~~~cheap key test\n    for (i = ka.length - 1; i >= 0; i--) {\n      if (ka[i] !== kb[i]) return false\n    }\n    //equivalent values for every corresponding key, and\n    //~~~possibly expensive deep test\n    for (i = ka.length - 1; i >= 0; i--) {\n      key = ka[i]\n      if (!deepCloseTo(a[key], b[key], opts)) return false\n    }\n  } catch (e) {\n    //happens when one is a string literal and the other isn't\n    return false\n  }\n\n  return typeof a === typeof b\n}\n\nfunction isArguments(object: any) {\n  return Object.prototype.toString.call(object) === '[object Arguments]'\n}\nfunction closeTo(actual: any, expected: any, delta: number = floatEpsilon) {\n  return Math.abs(actual - expected) < delta\n}\n"]}
126
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"assert.js","sourceRoot":"","sources":["../src/testing/assert.ts"],"names":[],"mappings":"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","sourcesContent":["// VERBATIM COPY OF https://github.com/LemonPi/deep-close-to\n\nimport type { Entity, LastWriteWinElementSetComponentDefinition } from '@dcl/ecs'\n\nconst pSlice = Array.prototype.slice\n\nconst floatEpsilon = 0.0000001\n\ntype Options = { strict: boolean; comp: typeof closeTo }\n\nexport function assertEquals(a: any, b: any, message: string = 'Values are not equal') {\n  if (!deepCloseTo(a, b)) throw new Error(`${message} - ${JSON.stringify(a)} != ${JSON.stringify(b)}`)\n}\n\nexport function assert(a: any, message: string = 'assertion failed') {\n  if (!a) throw new Error(message)\n}\n\nexport function assertComponentValue<T>(\n  entity: Entity,\n  component: LastWriteWinElementSetComponentDefinition<T>,\n  value: T\n) {\n  assert(component.has(entity), `The entity doesn't have a ${component.componentName} component`)\n  assertEquals(component.get(entity)!, value, `Invalid ${component.componentName} values`)\n}\n\nexport function deepCloseTo(actual: any, expected: any, options: Partial<Options> = {}): boolean {\n  const opts = Object.assign({}, { comp: closeTo }, options)\n  // 7.1. All identical values are equivalent, as determined by ===.\n  if (actual === expected) {\n    return true\n  } else if (actual instanceof Date && expected instanceof Date) {\n    return opts.comp!(actual, expected)\n\n    // 7.3. Other pairs that do not both pass typeof value == 'object',\n    // equivalence is determined by ==.\n  } else if (!actual || !expected || (typeof actual !== 'object' && typeof expected !== 'object')) {\n    if (opts.strict) {\n      if (!actual && !expected) {\n        return actual === expected\n      }\n\n      if (typeof actual !== typeof expected) {\n        return false\n      }\n    }\n    if (!actual && !expected) {\n      return actual === expected\n    }\n    return opts.comp!(actual, expected)\n\n    // 7.4. For all other Object pairs, including Array objects, equivalence is\n    // determined by having the same number of owned properties (as verified\n    // with Object.prototype.hasOwnProperty.call), the same set of keys\n    // (although not necessarily the same order), equivalent values for every\n    // corresponding key, and an identical 'prototype' property. Note: this\n    // accounts for both named and indexed properties on Arrays.\n  } else {\n    return objEquiv(actual, expected, opts as any)\n  }\n}\n\nfunction isUndefinedOrNull(value: any) {\n  return value === null || value === undefined\n}\n\nfunction isBuffer(x: any) {\n  if (!x || typeof x !== 'object' || typeof x.length !== 'number') return false\n  if (typeof x.copy !== 'function' || typeof x.slice !== 'function') {\n    return false\n  }\n  if (x.length > 0 && typeof x[0] !== 'number') return false\n  return true\n}\n\nfunction objEquiv(a: any, b: any, opts: Options) {\n  let i, key\n  if (isUndefinedOrNull(a) || isUndefinedOrNull(b)) return false\n  // an identical 'prototype' property.\n  if (a.prototype !== b.prototype) return false\n  //~~~I've managed to break Object.keys through screwy arguments passing.\n  //   Converting to array solves the problem.\n  if (isArguments(a)) {\n    if (!isArguments(b)) {\n      return false\n    }\n    return deepCloseTo(pSlice.call(a), pSlice.call(b), opts)\n  }\n  if (isBuffer(a)) {\n    if (!isBuffer(b)) {\n      return false\n    }\n    if (a.length !== b.length) return false\n    for (i = 0; i < a.length; i++) {\n      if (a[i] !== b[i]) return false\n    }\n    return true\n  }\n\n  try {\n    const ka = Object.keys(a)\n    const kb = Object.keys(b)\n\n    // having the same number of owned properties (keys incorporates\n    // hasOwnProperty)\n    if (ka.length !== kb.length) return false\n    //the same set of keys (although not necessarily the same order),\n    ka.sort()\n    kb.sort()\n    //~~~cheap key test\n    for (i = ka.length - 1; i >= 0; i--) {\n      if (ka[i] !== kb[i]) return false\n    }\n    //equivalent values for every corresponding key, and\n    //~~~possibly expensive deep test\n    for (i = ka.length - 1; i >= 0; i--) {\n      key = ka[i]\n      if (!deepCloseTo(a[key], b[key], opts)) return false\n    }\n  } catch (e) {\n    //happens when one is a string literal and the other isn't\n    return false\n  }\n\n  return typeof a === typeof b\n}\n\nfunction isArguments(object: any) {\n  return Object.prototype.toString.call(object) === '[object Arguments]'\n}\nfunction closeTo(actual: any, expected: any, delta: number = floatEpsilon) {\n  return Math.abs(actual - expected) < delta\n}\n"]}
@@ -1,2 +1,7 @@
1
1
  import { TestDefinitionFunction } from './types';
2
+ /**
3
+ * In development builds, this function serves as test runner for automated test scenarios
4
+ * if the runtime accepts the `~system/Testing` module
5
+ * @public
6
+ */
2
7
  export declare const test: TestDefinitionFunction;
package/testing/index.js CHANGED
@@ -1,10 +1,16 @@
1
1
  import { engine } from '@dcl/ecs';
2
2
  import { createTestRuntime } from './runtime';
3
- export const test = DEBUG ? createTestFunction() : () => { };
3
+ /**
4
+ * In development builds, this function serves as test runner for automated test scenarios
5
+ * if the runtime accepts the `~system/Testing` module
6
+ * @public
7
+ */
8
+ /* @__PURE__ */
9
+ export const test = DEBUG ? /* @__PURE__ */ createTestFunction() : /* @__PURE__ */ () => { };
4
10
  function createTestFunction() {
5
11
  let testingModule;
6
12
  try {
7
- testingModule = require('~system/Testing');
13
+ testingModule = /* @__PURE__ */ require('~system/Testing');
8
14
  }
9
15
  catch (err) {
10
16
  console.error(err);
@@ -27,4 +33,4 @@ function createTestFunction() {
27
33
  const runtime = createTestRuntime(testingModule, engine);
28
34
  return runtime.test;
29
35
  }
30
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvdGVzdGluZy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sVUFBVSxDQUFBO0FBQ2pDLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLFdBQVcsQ0FBQTtBQVc3QyxNQUFNLENBQUMsTUFBTSxJQUFJLEdBQTJCLEtBQUssQ0FBQyxDQUFDLENBQWlCLGtCQUFrQixFQUFFLENBQUMsQ0FBQyxDQUFpQixHQUFHLEVBQUUsR0FBRSxDQUFDLENBQUE7QUFFbkgsU0FBUyxrQkFBa0I7SUFDekIsSUFBSSxhQUE0QixDQUFBO0lBQ2hDLElBQUk7UUFDRixhQUFhLEdBQW1CLE9BQU8sQ0FBQyxpQkFBaUIsQ0FBQyxDQUFBO0tBQzNEO0lBQUMsT0FBTyxHQUFHLEVBQUU7UUFDWixPQUFPLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFBO1FBRWxCLE9BQU8sQ0FBQyxLQUFLLENBQUMsMEZBQTBGLENBQUMsQ0FBQTtRQUV6RyxhQUFhLEdBQUc7WUFDZCxLQUFLLENBQUMsYUFBYSxDQUFDLElBQUk7Z0JBQ3RCLE9BQU8sQ0FBQyxHQUFHLENBQUMsdUNBQXVDLEVBQUUsSUFBSSxDQUFDLENBQUE7Z0JBQzFELE9BQU8sRUFBRSxDQUFBO1lBQ1gsQ0FBQztZQUNELEtBQUssQ0FBQyxJQUFJLENBQUMsSUFBSTtnQkFDYixPQUFPLENBQUMsR0FBRyxDQUFDLGtDQUFrQyxFQUFFLElBQUksQ0FBQyxDQUFBO2dCQUNyRCxPQUFPLEVBQUUsQ0FBQTtZQUNYLENBQUM7WUFDRCxLQUFLLENBQUMsa0JBQWtCLENBQUMsU0FBUztnQkFDaEMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxnREFBZ0QsRUFBRSxTQUFTLENBQUMsQ0FBQTtnQkFDeEUsT0FBTyxFQUFFLENBQUE7WUFDWCxDQUFDO1NBQ0YsQ0FBQTtLQUNGO0lBRUQsTUFBTSxPQUFPLEdBQUcsaUJBQWlCLENBQUMsYUFBYSxFQUFFLE1BQU0sQ0FBQyxDQUFBO0lBQ3hELE9BQU8sT0FBTyxDQUFDLElBQUksQ0FBQTtBQUNyQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZW5naW5lIH0gZnJvbSAnQGRjbC9lY3MnXG5pbXBvcnQgeyBjcmVhdGVUZXN0UnVudGltZSB9IGZyb20gJy4vcnVudGltZSdcbmltcG9ydCB7IFRlc3REZWZpbml0aW9uRnVuY3Rpb24sIFRlc3RpbmdNb2R1bGUgfSBmcm9tICcuL3R5cGVzJ1xuXG5kZWNsYXJlIGxldCByZXF1aXJlOiBhbnlcblxuLyoqXG4gKiBJbiBkZXZlbG9wbWVudCBidWlsZHMsIHRoaXMgZnVuY3Rpb24gc2VydmVzIGFzIHRlc3QgcnVubmVyIGZvciBhdXRvbWF0ZWQgdGVzdCBzY2VuYXJpb3NcbiAqIGlmIHRoZSBydW50aW1lIGFjY2VwdHMgdGhlIGB+c3lzdGVtL1Rlc3RpbmdgIG1vZHVsZVxuICogQHB1YmxpY1xuICovXG4vKiBAX19QVVJFX18gKi9cbmV4cG9ydCBjb25zdCB0ZXN0OiBUZXN0RGVmaW5pdGlvbkZ1bmN0aW9uID0gREVCVUcgPyAvKiBAX19QVVJFX18gKi8gY3JlYXRlVGVzdEZ1bmN0aW9uKCkgOiAvKiBAX19QVVJFX18gKi8gKCkgPT4ge31cblxuZnVuY3Rpb24gY3JlYXRlVGVzdEZ1bmN0aW9uKCkge1xuICBsZXQgdGVzdGluZ01vZHVsZTogVGVzdGluZ01vZHVsZVxuICB0cnkge1xuICAgIHRlc3RpbmdNb2R1bGUgPSAvKiBAX19QVVJFX18gKi8gcmVxdWlyZSgnfnN5c3RlbS9UZXN0aW5nJylcbiAgfSBjYXRjaCAoZXJyKSB7XG4gICAgY29uc29sZS5lcnJvcihlcnIpXG5cbiAgICBjb25zb2xlLmVycm9yKGDwn5S08J+aqOKAvO+4jyBXQVJOSU5HOiBUaGUgdGVzdCBydW5uZXIgaXMgbm90IGF2YWlsYWJsZS4gVGhlIHRlc3QgcnVubmVyIHdpbGwgYmUgbW9ja2VkLiDigLzvuI/wn5qo8J+UtGApXG5cbiAgICB0ZXN0aW5nTW9kdWxlID0ge1xuICAgICAgYXN5bmMgbG9nVGVzdFJlc3VsdChkYXRhKSB7XG4gICAgICAgIGNvbnNvbGUubG9nKGDwn6eqIG1vY2tlZCAnfnN5c3RlbS9UZXN0aW5nJy5sb2dSZXN1bHRgLCBkYXRhKVxuICAgICAgICByZXR1cm4ge31cbiAgICAgIH0sXG4gICAgICBhc3luYyBwbGFuKGRhdGEpIHtcbiAgICAgICAgY29uc29sZS5sb2coYPCfp6ogbW9ja2VkICd+c3lzdGVtL1Rlc3RpbmcnLnBsYW5gLCBkYXRhKVxuICAgICAgICByZXR1cm4ge31cbiAgICAgIH0sXG4gICAgICBhc3luYyBzZXRDYW1lcmFUcmFuc2Zvcm0odHJhbnNmb3JtKSB7XG4gICAgICAgIGNvbnNvbGUubG9nKGDwn6eqIG1vY2tlZCAnfnN5c3RlbS9UZXN0aW5nJy5zZXRDYW1lcmFUcmFuc2Zvcm1gLCB0cmFuc2Zvcm0pXG4gICAgICAgIHJldHVybiB7fVxuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIGNvbnN0IHJ1bnRpbWUgPSBjcmVhdGVUZXN0UnVudGltZSh0ZXN0aW5nTW9kdWxlLCBlbmdpbmUpXG4gIHJldHVybiBydW50aW1lLnRlc3Rcbn1cbiJdfQ==
36
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvdGVzdGluZy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sVUFBVSxDQUFBO0FBQ2pDLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLFdBQVcsQ0FBQTtBQUs3Qzs7OztHQUlHO0FBQ0gsZUFBZTtBQUNmLE1BQU0sQ0FBQyxNQUFNLElBQUksR0FBMkIsS0FBSyxDQUFDLENBQUMsQ0FBQyxlQUFlLENBQUMsa0JBQWtCLEVBQUUsQ0FBQyxDQUFDLENBQUMsZUFBZSxDQUFDLEdBQUcsRUFBRSxHQUFFLENBQUMsQ0FBQTtBQUVuSCxTQUFTLGtCQUFrQjtJQUN6QixJQUFJLGFBQTRCLENBQUE7SUFDaEMsSUFBSTtRQUNGLGFBQWEsR0FBRyxlQUFlLENBQUMsT0FBTyxDQUFDLGlCQUFpQixDQUFDLENBQUE7S0FDM0Q7SUFBQyxPQUFPLEdBQUcsRUFBRTtRQUNaLE9BQU8sQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUE7UUFFbEIsT0FBTyxDQUFDLEtBQUssQ0FBQywwRkFBMEYsQ0FBQyxDQUFBO1FBRXpHLGFBQWEsR0FBRztZQUNkLEtBQUssQ0FBQyxhQUFhLENBQUMsSUFBSTtnQkFDdEIsT0FBTyxDQUFDLEdBQUcsQ0FBQyx1Q0FBdUMsRUFBRSxJQUFJLENBQUMsQ0FBQTtnQkFDMUQsT0FBTyxFQUFFLENBQUE7WUFDWCxDQUFDO1lBQ0QsS0FBSyxDQUFDLElBQUksQ0FBQyxJQUFJO2dCQUNiLE9BQU8sQ0FBQyxHQUFHLENBQUMsa0NBQWtDLEVBQUUsSUFBSSxDQUFDLENBQUE7Z0JBQ3JELE9BQU8sRUFBRSxDQUFBO1lBQ1gsQ0FBQztZQUNELEtBQUssQ0FBQyxrQkFBa0IsQ0FBQyxTQUFTO2dCQUNoQyxPQUFPLENBQUMsR0FBRyxDQUFDLGdEQUFnRCxFQUFFLFNBQVMsQ0FBQyxDQUFBO2dCQUN4RSxPQUFPLEVBQUUsQ0FBQTtZQUNYLENBQUM7U0FDRixDQUFBO0tBQ0Y7SUFFRCxNQUFNLE9BQU8sR0FBRyxpQkFBaUIsQ0FBQyxhQUFhLEVBQUUsTUFBTSxDQUFDLENBQUE7SUFDeEQsT0FBTyxPQUFPLENBQUMsSUFBSSxDQUFBO0FBQ3JCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBlbmdpbmUgfSBmcm9tICdAZGNsL2VjcydcbmltcG9ydCB7IGNyZWF0ZVRlc3RSdW50aW1lIH0gZnJvbSAnLi9ydW50aW1lJ1xuaW1wb3J0IHsgVGVzdERlZmluaXRpb25GdW5jdGlvbiwgVGVzdGluZ01vZHVsZSB9IGZyb20gJy4vdHlwZXMnXG5cbmRlY2xhcmUgbGV0IHJlcXVpcmU6IGFueVxuXG4vKipcbiAqIEluIGRldmVsb3BtZW50IGJ1aWxkcywgdGhpcyBmdW5jdGlvbiBzZXJ2ZXMgYXMgdGVzdCBydW5uZXIgZm9yIGF1dG9tYXRlZCB0ZXN0IHNjZW5hcmlvc1xuICogaWYgdGhlIHJ1bnRpbWUgYWNjZXB0cyB0aGUgYH5zeXN0ZW0vVGVzdGluZ2AgbW9kdWxlXG4gKiBAcHVibGljXG4gKi9cbi8qIEBfX1BVUkVfXyAqL1xuZXhwb3J0IGNvbnN0IHRlc3Q6IFRlc3REZWZpbml0aW9uRnVuY3Rpb24gPSBERUJVRyA/IC8qIEBfX1BVUkVfXyAqLyBjcmVhdGVUZXN0RnVuY3Rpb24oKSA6IC8qIEBfX1BVUkVfXyAqLyAoKSA9PiB7fVxuXG5mdW5jdGlvbiBjcmVhdGVUZXN0RnVuY3Rpb24oKSB7XG4gIGxldCB0ZXN0aW5nTW9kdWxlOiBUZXN0aW5nTW9kdWxlXG4gIHRyeSB7XG4gICAgdGVzdGluZ01vZHVsZSA9IC8qIEBfX1BVUkVfXyAqLyByZXF1aXJlKCd+c3lzdGVtL1Rlc3RpbmcnKVxuICB9IGNhdGNoIChlcnIpIHtcbiAgICBjb25zb2xlLmVycm9yKGVycilcblxuICAgIGNvbnNvbGUuZXJyb3IoYPCflLTwn5qo4oC877iPIFdBUk5JTkc6IFRoZSB0ZXN0IHJ1bm5lciBpcyBub3QgYXZhaWxhYmxlLiBUaGUgdGVzdCBydW5uZXIgd2lsbCBiZSBtb2NrZWQuIOKAvO+4j/Cfmqjwn5S0YClcblxuICAgIHRlc3RpbmdNb2R1bGUgPSB7XG4gICAgICBhc3luYyBsb2dUZXN0UmVzdWx0KGRhdGEpIHtcbiAgICAgICAgY29uc29sZS5sb2coYPCfp6ogbW9ja2VkICd+c3lzdGVtL1Rlc3RpbmcnLmxvZ1Jlc3VsdGAsIGRhdGEpXG4gICAgICAgIHJldHVybiB7fVxuICAgICAgfSxcbiAgICAgIGFzeW5jIHBsYW4oZGF0YSkge1xuICAgICAgICBjb25zb2xlLmxvZyhg8J+nqiBtb2NrZWQgJ35zeXN0ZW0vVGVzdGluZycucGxhbmAsIGRhdGEpXG4gICAgICAgIHJldHVybiB7fVxuICAgICAgfSxcbiAgICAgIGFzeW5jIHNldENhbWVyYVRyYW5zZm9ybSh0cmFuc2Zvcm0pIHtcbiAgICAgICAgY29uc29sZS5sb2coYPCfp6ogbW9ja2VkICd+c3lzdGVtL1Rlc3RpbmcnLnNldENhbWVyYVRyYW5zZm9ybWAsIHRyYW5zZm9ybSlcbiAgICAgICAgcmV0dXJuIHt9XG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgY29uc3QgcnVudGltZSA9IGNyZWF0ZVRlc3RSdW50aW1lKHRlc3RpbmdNb2R1bGUsIGVuZ2luZSlcbiAgcmV0dXJuIHJ1bnRpbWUudGVzdFxufVxuIl19
@@ -1,3 +1,6 @@
1
+ /**
2
+ * This module provides a createTestRuntime function that returns an object with a test function that can be used to define tests.
3
+ */
1
4
  import { IEngine } from '@dcl/ecs';
2
5
  import type { TestingModule, TestFunction } from './types';
3
6
  export declare function createTestRuntime(testingModule: TestingModule, engine: IEngine): {
@@ -1,24 +1,40 @@
1
+ /**
2
+ * This module provides a createTestRuntime function that returns an object with a test function that can be used to define tests.
3
+ */
1
4
  import { Transform } from '@dcl/ecs';
2
5
  import { assertEquals } from './assert';
6
+ // This function creates a test runtime that can be used to define and run tests.
7
+ // It takes a `TestingModule` instance (loaded from require('~system/Testing')) and an `IEngine` instance (from Decentraland's SDK).
8
+ // It returns an object with a `test` function that can be used to define tests.
9
+ /* @__PURE__ */
3
10
  export function createTestRuntime(testingModule, engine) {
11
+ // this flag ensures no tests are added asynchronously
4
12
  let runtimeFrozen = false;
5
13
  let currentFrameCounter = 0;
6
14
  let currentFrameTime = 0;
15
+ // array to hold the scheduled tests
7
16
  const scheduledTests = [];
17
+ // an array of promises that are resolved on the next frame (after the current frame is finished)
8
18
  const nextTickFuture = [];
19
+ // this function returns a promise that resolves on the next frame
9
20
  async function nextTick() {
10
21
  return new Promise((resolve) => {
11
22
  nextTickFuture.push(resolve);
12
23
  });
13
24
  }
25
+ // add a system to the engine that resolves all promises in the `nextTickFuture` array
14
26
  engine.addSystem(function TestingFrameworkCoroutineRunner(dt) {
15
27
  currentFrameCounter++;
16
28
  currentFrameTime += dt;
29
+ // resolve all nextTick futures.
17
30
  nextTickFuture.splice(0, nextTickFuture.length).forEach((_) => _(dt));
18
31
  });
32
+ // this function schedules a value to be processed on the next frame, the test runner will
33
+ // continue to run until it reaches a yield point
19
34
  function scheduleValue(value, env) {
20
35
  if (value && typeof value === 'object' && typeof value.then === 'function') {
21
36
  console.log('⏱️ yield promise');
37
+ // if the value is a promise, schedule it to be awaited after the current frame is finished
22
38
  nextTickFuture.push(async () => {
23
39
  try {
24
40
  scheduleValue(await value, env);
@@ -30,6 +46,7 @@ export function createTestRuntime(testingModule, engine) {
30
46
  }
31
47
  else if (typeof value === 'function') {
32
48
  console.log('⏱️ yield function');
49
+ // if the value is a function, schedule it to be called on the next frame
33
50
  nextTickFuture.push(() => {
34
51
  scheduleValue(value(), env);
35
52
  });
@@ -37,6 +54,7 @@ export function createTestRuntime(testingModule, engine) {
37
54
  }
38
55
  else if (typeof value === 'undefined' || value === null) {
39
56
  console.log('⏱️ yield');
57
+ // if the value is undefined or null, continue processing the generator the next frame
40
58
  nextTickFuture.push(() => {
41
59
  consumeGenerator(env);
42
60
  });
@@ -44,6 +62,7 @@ export function createTestRuntime(testingModule, engine) {
44
62
  else
45
63
  throw new Error(`Unexpected value from test generator: ${value}`);
46
64
  }
65
+ // this function processes a generator function by scheduling its values to be processed on the next frame
47
66
  function consumeGenerator(env) {
48
67
  try {
49
68
  const ret = env.generator.next();
@@ -58,17 +77,20 @@ export function createTestRuntime(testingModule, engine) {
58
77
  env.reject(err);
59
78
  }
60
79
  }
80
+ // this function schedules a test run on the next frame
61
81
  function scheduleNextRun() {
62
82
  if (scheduledTests.length) {
63
83
  nextTickFuture.push(runTests);
64
84
  }
65
85
  }
86
+ // this function runs the scheduled tests
66
87
  function runTests() {
67
88
  if (scheduledTests.length) {
68
89
  const entry = scheduledTests.shift();
69
90
  const initialFrame = currentFrameCounter;
70
91
  const startTime = currentFrameTime;
71
92
  let resolved = false;
93
+ // this function should be called only once. it makes the current test pass
72
94
  const resolve = () => {
73
95
  if (resolved)
74
96
  throw new Error('resolved twice');
@@ -139,12 +161,18 @@ export function createTestRuntime(testingModule, engine) {
139
161
  }
140
162
  }
141
163
  }
164
+ // schedule the test runner start for the next frame
142
165
  nextTickFuture.push(() => {
166
+ // once we run the next tick, the test runtime becomes frozen. that means no new
167
+ // test definitions are accepted
143
168
  runtimeFrozen = true;
144
169
  if (!scheduledTests.length)
145
170
  return;
171
+ // inform the test runner about the plans for this test run
146
172
  testingModule.plan({ tests: scheduledTests }).then(scheduleNextRun).catch(globalFail);
147
173
  });
174
+ // this is the function that is used to plan a test functionn
175
+ /* @__PURE__ */
148
176
  function test(name, fn) {
149
177
  if (runtimeFrozen)
150
178
  throw new Error("New tests can't be added at this stage.");
@@ -163,6 +191,7 @@ function isPromise(t) {
163
191
  return t && typeof t === 'object' && typeof t.then === 'function';
164
192
  }
165
193
  function globalFail(error) {
194
+ // for now, the failure is only writing to the console.error.
166
195
  console.error(error);
167
196
  }
168
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"runtime.js","sourceRoot":"","sources":["../src/testing/runtime.ts"],"names":[],"mappings":"AAIA,OAAO,EAAW,SAAS,EAAE,MAAM,UAAU,CAAA;AAC7C,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAA;AAOvC,MAAM,UAAU,iBAAiB,CAAC,aAA4B,EAAE,MAAe;IAU7E,IAAI,aAAa,GAAG,KAAK,CAAA;IAEzB,IAAI,mBAAmB,GAAG,CAAC,CAAA;IAC3B,IAAI,gBAAgB,GAAG,CAAC,CAAA;IAGxB,MAAM,cAAc,GAAoB,EAAE,CAAA;IAG1C,MAAM,cAAc,GAAgC,EAAE,CAAA;IAGtD,KAAK,UAAU,QAAQ;QACrB,OAAO,IAAI,OAAO,CAAS,CAAC,OAAO,EAAE,EAAE;YACrC,cAAc,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;QAC9B,CAAC,CAAC,CAAA;IACJ,CAAC;IAGD,MAAM,CAAC,SAAS,CAAC,SAAS,+BAA+B,CAAC,EAAE;QAC1D,mBAAmB,EAAE,CAAA;QACrB,gBAAgB,IAAI,EAAE,CAAA;QAEtB,cAAc,CAAC,MAAM,CAAC,CAAC,EAAE,cAAc,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAA;IACvE,CAAC,CAAC,CAAA;IAIF,SAAS,aAAa,CAAC,KAAU,EAAE,GAAsB;QACvD,IAAI,KAAK,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,OAAO,KAAK,CAAC,IAAI,KAAK,UAAU,EAAE;YAC1E,OAAO,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAA;YAE/B,cAAc,CAAC,IAAI,CAAC,KAAK,IAAI,EAAE;gBAC7B,IAAI;oBACF,aAAa,CAAC,MAAM,KAAK,EAAE,GAAG,CAAC,CAAA;iBAChC;gBAAC,OAAO,GAAG,EAAE;oBACZ,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAA;iBAChB;YACH,CAAC,CAAC,CAAA;SACH;aAAM,IAAI,OAAO,KAAK,KAAK,UAAU,EAAE;YACtC,OAAO,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAA;YAEhC,cAAc,CAAC,IAAI,CAAC,GAAG,EAAE;gBACvB,aAAa,CAAC,KAAK,EAAE,EAAE,GAAG,CAAC,CAAA;YAC7B,CAAC,CAAC,CAAA;YACF,OAAM;SACP;aAAM,IAAI,OAAO,KAAK,KAAK,WAAW,IAAI,KAAK,KAAK,IAAI,EAAE;YACzD,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,CAAA;YAEvB,cAAc,CAAC,IAAI,CAAC,GAAG,EAAE;gBACvB,gBAAgB,CAAC,GAAG,CAAC,CAAA;YACvB,CAAC,CAAC,CAAA;SACH;;YAAM,MAAM,IAAI,KAAK,CAAC,yCAAyC,KAAK,EAAE,CAAC,CAAA;IAC1E,CAAC;IAGD,SAAS,gBAAgB,CAAC,GAAsB;QAC9C,IAAI;YACF,MAAM,GAAG,GAAG,GAAG,CAAC,SAAS,CAAC,IAAI,EAAE,CAAA;YAChC,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE;gBACb,aAAa,CAAC,GAAG,CAAC,KAAK,EAAE,GAAG,CAAC,CAAA;aAC9B;iBAAM;gBACL,GAAG,CAAC,OAAO,EAAE,CAAA;aACd;SACF;QAAC,OAAO,GAAG,EAAE;YACZ,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAA;SAChB;IACH,CAAC;IAGD,SAAS,eAAe;QACtB,IAAI,cAAc,CAAC,MAAM,EAAE;YACzB,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;SAC9B;IACH,CAAC;IAGD,SAAS,QAAQ;QACf,IAAI,cAAc,CAAC,MAAM,EAAE;YACzB,MAAM,KAAK,GAAG,cAAc,CAAC,KAAK,EAAG,CAAA;YACrC,MAAM,YAAY,GAAG,mBAAmB,CAAA;YACxC,MAAM,SAAS,GAAG,gBAAgB,CAAA;YAElC,IAAI,QAAQ,GAAG,KAAK,CAAA;YAGpB,MAAM,OAAO,GAAG,GAAG,EAAE;gBACnB,IAAI,QAAQ;oBAAE,MAAM,IAAI,KAAK,CAAC,gBAAgB,CAAC,CAAA;gBAC/C,QAAQ,GAAG,IAAI,CAAA;gBAEf,OAAO,CAAC,GAAG,CAAC,kBAAkB,KAAK,CAAC,IAAI,EAAE,CAAC,CAAA;gBAE3C,aAAa;qBACV,aAAa,CAAC;oBACb,IAAI,EAAE,KAAK,CAAC,IAAI;oBAChB,EAAE,EAAE,IAAI;oBACR,WAAW,EAAE,mBAAmB,GAAG,YAAY;oBAC/C,SAAS,EAAE,gBAAgB,GAAG,SAAS;iBACxC,CAAC;qBACD,OAAO,CAAC,eAAe,CAAC,CAAA;YAC7B,CAAC,CAAA;YAED,MAAM,MAAM,GAAG,CAAC,GAAQ,EAAE,EAAE;gBAC1B,IAAI,QAAQ;oBAAE,MAAM,IAAI,KAAK,CAAC,gBAAgB,CAAC,CAAA;gBAC/C,QAAQ,GAAG,IAAI,CAAA;gBAEf,OAAO,CAAC,GAAG,CAAC,kBAAkB,KAAK,CAAC,IAAI,EAAE,CAAC,CAAA;gBAC3C,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;gBAElB,aAAa;qBACV,aAAa,CAAC;oBACb,IAAI,EAAE,KAAK,CAAC,IAAI;oBAChB,EAAE,EAAE,KAAK;oBACT,KAAK,EAAE,GAAG,CAAC,QAAQ,EAAE;oBACrB,KAAK,EAAE,GAAG,IAAI,OAAO,GAAG,KAAK,QAAQ,IAAI,GAAG,CAAC,KAAK;oBAClD,WAAW,EAAE,mBAAmB,GAAG,YAAY;oBAC/C,SAAS,EAAE,gBAAgB,GAAG,SAAS;iBACxC,CAAC;qBACD,OAAO,CAAC,eAAe,CAAC,CAAA;YAC7B,CAAC,CAAA;YAED,IAAI;gBACF,OAAO,CAAC,GAAG,CAAC,mBAAmB,KAAK,CAAC,IAAI,EAAE,CAAC,CAAA;gBAE5C,MAAM,WAAW,GAAgB;oBAC/B,KAAK,CAAC,kBAAkB,CAAC,SAAS;wBAChC,MAAM,aAAa,CAAC,kBAAkB,CAAC,SAAS,CAAC,CAAA;wBACjD,MAAM,QAAQ,EAAE,CAAA;wBAEhB,MAAM,kBAAkB,GAAG,MAAM,CAAC,YAAY,CAAC,SAAS,CAAC,WAAW,CAAqB,CAAA;wBACzF,MAAM,eAAe,GAAG,kBAAkB,CAAC,GAAG,CAAC,MAAM,CAAC,YAAY,CAAC,CAAA;wBAEnE,YAAY,CAAC,eAAe,CAAC,QAAQ,EAAE,SAAS,CAAC,QAAQ,EAAE,uBAAuB,CAAC,CAAA;wBACnF,YAAY,CAAC,eAAe,CAAC,QAAQ,EAAE,SAAS,CAAC,QAAQ,EAAE,uBAAuB,CAAC,CAAA;oBACrF,CAAC;iBACF,CAAA;gBAED,MAAM,WAAW,GAAG,KAAK,CAAC,EAAE,CAAC,WAAW,CAAC,CAAA;gBAEzC,IAAI,WAAW,IAAI,OAAO,WAAW,KAAK,QAAQ,EAAE;oBAClD,IAAI,WAAW,CAAC,WAAW,CAAC,EAAE;wBAC5B,MAAM,GAAG,GAAsB;4BAC7B,SAAS,EAAE,WAAW;4BACtB,OAAO,EAAE,WAAW;4BACpB,OAAO;4BACP,MAAM;yBACP,CAAA;wBACD,gBAAgB,CAAC,GAAG,CAAC,CAAA;qBACtB;yBAAM,IAAI,SAAS,CAAC,WAAW,CAAC,EAAE;wBACjC,WAAW,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,CAAA;qBACxC;yBAAM;wBACL,MAAM,IAAI,KAAK,CAAC,6BAA6B,WAAW,EAAE,CAAC,CAAA;qBAC5D;iBACF;qBAAM;oBACL,OAAO,EAAE,CAAA;iBACV;aACF;YAAC,OAAO,GAAQ,EAAE;gBACjB,MAAM,CAAC,GAAG,CAAC,CAAA;aACZ;SACF;IACH,CAAC;IAGD,cAAc,CAAC,IAAI,CAAC,GAAG,EAAE;QAGvB,aAAa,GAAG,IAAI,CAAA;QAEpB,IAAI,CAAC,cAAc,CAAC,MAAM;YAAE,OAAM;QAGlC,aAAa,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,cAAc,EAAE,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,KAAK,CAAC,UAAU,CAAC,CAAA;IACvF,CAAC,CAAC,CAAA;IAIF,SAAS,IAAI,CAAC,IAAY,EAAE,EAAgB;QAC1C,IAAI,aAAa;YAAE,MAAM,IAAI,KAAK,CAAC,yCAAyC,CAAC,CAAA;QAE7E,IAAI,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,CAAC;YAAE,MAAM,IAAI,KAAK,CAAC,kBAAkB,IAAI,iBAAiB,CAAC,CAAA;QAEzG,cAAc,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,IAAI,EAAE,CAAC,CAAA;IACnC,CAAC;IAED,OAAO;QACL,IAAI;KACL,CAAA;AACH,CAAC;AAED,SAAS,WAAW,CAAC,CAAM;IACzB,OAAO,CAAC,IAAI,OAAO,CAAC,KAAK,QAAQ,IAAI,OAAO,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,UAAU,CAAA;AAC/E,CAAC;AAED,SAAS,SAAS,CAAC,CAAM;IACvB,OAAO,CAAC,IAAI,OAAO,CAAC,KAAK,QAAQ,IAAI,OAAO,CAAC,CAAC,IAAI,KAAK,UAAU,CAAA;AACnE,CAAC;AAED,SAAS,UAAU,CAAC,KAAU;IAE5B,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAA;AACtB,CAAC","sourcesContent":["/**\n * This module provides a createTestRuntime function that returns an object with a test function that can be used to define tests.\n */\n\nimport { IEngine, Transform } from '@dcl/ecs'\nimport { assertEquals } from './assert'\nimport type { TestingModule, TestFunction, TestHelpers } from './types'\n\n// This function creates a test runtime that can be used to define and run tests.\n// It takes a `TestingModule` instance (loaded from require('~system/Testing')) and an `IEngine` instance (from Decentraland's SDK).\n// It returns an object with a `test` function that can be used to define tests.\n/* @__PURE__ */\nexport function createTestRuntime(testingModule: TestingModule, engine: IEngine) {\n  type TestPlanEntry = { name: string; fn: TestFunction }\n  type RunnerEnvironment = {\n    resolve: () => void\n    reject: (error: any) => void\n    helpers: TestHelpers\n    generator: Generator\n  }\n\n  // this flag ensures no tests are added asynchronously\n  let runtimeFrozen = false\n\n  let currentFrameCounter = 0\n  let currentFrameTime = 0\n\n  // array to hold the scheduled tests\n  const scheduledTests: TestPlanEntry[] = []\n\n  // an array of promises that are resolved on the next frame (after the current frame is finished)\n  const nextTickFuture: Array<(dt: number) => void> = []\n\n  // this function returns a promise that resolves on the next frame\n  async function nextTick() {\n    return new Promise<number>((resolve) => {\n      nextTickFuture.push(resolve)\n    })\n  }\n\n  // add a system to the engine that resolves all promises in the `nextTickFuture` array\n  engine.addSystem(function TestingFrameworkCoroutineRunner(dt) {\n    currentFrameCounter++\n    currentFrameTime += dt\n    // resolve all nextTick futures.\n    nextTickFuture.splice(0, nextTickFuture.length).forEach((_) => _(dt))\n  })\n\n  // this function schedules a value to be processed on the next frame, the test runner will\n  // continue to run until it reaches a yield point\n  function scheduleValue(value: any, env: RunnerEnvironment) {\n    if (value && typeof value === 'object' && typeof value.then === 'function') {\n      console.log('⏱️ yield promise')\n      // if the value is a promise, schedule it to be awaited after the current frame is finished\n      nextTickFuture.push(async () => {\n        try {\n          scheduleValue(await value, env)\n        } catch (err) {\n          env.reject(err)\n        }\n      })\n    } else if (typeof value === 'function') {\n      console.log('⏱️ yield function')\n      // if the value is a function, schedule it to be called on the next frame\n      nextTickFuture.push(() => {\n        scheduleValue(value(), env)\n      })\n      return\n    } else if (typeof value === 'undefined' || value === null) {\n      console.log('⏱️ yield')\n      // if the value is undefined or null, continue processing the generator the next frame\n      nextTickFuture.push(() => {\n        consumeGenerator(env)\n      })\n    } else throw new Error(`Unexpected value from test generator: ${value}`)\n  }\n\n  // this function processes a generator function by scheduling its values to be processed on the next frame\n  function consumeGenerator(env: RunnerEnvironment) {\n    try {\n      const ret = env.generator.next()\n      if (!ret.done) {\n        scheduleValue(ret.value, env)\n      } else {\n        env.resolve()\n      }\n    } catch (err) {\n      env.reject(err)\n    }\n  }\n\n  // this function schedules a test run on the next frame\n  function scheduleNextRun() {\n    if (scheduledTests.length) {\n      nextTickFuture.push(runTests)\n    }\n  }\n\n  // this function runs the scheduled tests\n  function runTests() {\n    if (scheduledTests.length) {\n      const entry = scheduledTests.shift()!\n      const initialFrame = currentFrameCounter\n      const startTime = currentFrameTime\n\n      let resolved = false\n\n      // this function should be called only once. it makes the current test pass\n      const resolve = () => {\n        if (resolved) throw new Error('resolved twice')\n        resolved = true\n\n        console.log(`🟢 Test passed ${entry.name}`)\n\n        testingModule\n          .logTestResult({\n            name: entry.name,\n            ok: true,\n            totalFrames: currentFrameCounter - initialFrame,\n            totalTime: currentFrameTime - startTime\n          })\n          .finally(scheduleNextRun)\n      }\n\n      const reject = (err: any) => {\n        if (resolved) throw new Error('resolved twice')\n        resolved = true\n\n        console.log(`🔴 Test failed ${entry.name}`)\n        console.error(err)\n\n        testingModule\n          .logTestResult({\n            name: entry.name,\n            ok: false,\n            error: err.toString(),\n            stack: err && typeof err === 'object' && err.stack,\n            totalFrames: currentFrameCounter - initialFrame,\n            totalTime: currentFrameTime - startTime\n          })\n          .finally(scheduleNextRun)\n      }\n\n      try {\n        console.log(`🧪 Running test ${entry.name}`)\n\n        const testHelpers: TestHelpers = {\n          async setCameraTransform(transform) {\n            await testingModule.setCameraTransform(transform)\n            await nextTick()\n\n            const TransformComponent = engine.getComponent(Transform.componentId) as typeof Transform\n            const actualTransform = TransformComponent.get(engine.CameraEntity)\n\n            assertEquals(actualTransform.position, transform.position, \"positions don't match\")\n            assertEquals(actualTransform.rotation, transform.rotation, \"rotations don't match\")\n          }\n        }\n\n        const returnValue = entry.fn(testHelpers)\n\n        if (returnValue && typeof returnValue === 'object') {\n          if (isGenerator(returnValue)) {\n            const env: RunnerEnvironment = {\n              generator: returnValue,\n              helpers: testHelpers,\n              resolve,\n              reject\n            }\n            consumeGenerator(env)\n          } else if (isPromise(returnValue)) {\n            returnValue.then(resolve).catch(reject)\n          } else {\n            throw new Error(`Unknown test result type: ${returnValue}`)\n          }\n        } else {\n          resolve()\n        }\n      } catch (err: any) {\n        reject(err)\n      }\n    }\n  }\n\n  // schedule the test runner start for the next frame\n  nextTickFuture.push(() => {\n    // once we run the next tick, the test runtime becomes frozen. that means no new\n    // test definitions are accepted\n    runtimeFrozen = true\n\n    if (!scheduledTests.length) return\n\n    // inform the test runner about the plans for this test run\n    testingModule.plan({ tests: scheduledTests }).then(scheduleNextRun).catch(globalFail)\n  })\n\n  // this is the function that is used to plan a test functionn\n  /* @__PURE__ */\n  function test(name: string, fn: TestFunction) {\n    if (runtimeFrozen) throw new Error(\"New tests can't be added at this stage.\")\n\n    if (scheduledTests.some(($) => $.name === name)) throw new Error(`Test with name ${name} already exists`)\n\n    scheduledTests.push({ fn, name })\n  }\n\n  return {\n    test\n  }\n}\n\nfunction isGenerator(t: any): t is Generator {\n  return t && typeof t === 'object' && typeof t[Symbol.iterator] === 'function'\n}\n\nfunction isPromise(t: any): t is Promise<unknown> {\n  return t && typeof t === 'object' && typeof t.then === 'function'\n}\n\nfunction globalFail(error: any) {\n  // for now, the failure is only writing to the console.error.\n  console.error(error)\n}\n"]}
197
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"runtime.js","sourceRoot":"","sources":["../src/testing/runtime.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * This module provides a createTestRuntime function that returns an object with a test function that can be used to define tests.\n */\n\nimport { IEngine, Transform } from '@dcl/ecs'\nimport { assertEquals } from './assert'\nimport type { TestingModule, TestFunction, TestHelpers } from './types'\n\n// This function creates a test runtime that can be used to define and run tests.\n// It takes a `TestingModule` instance (loaded from require('~system/Testing')) and an `IEngine` instance (from Decentraland's SDK).\n// It returns an object with a `test` function that can be used to define tests.\n/* @__PURE__ */\nexport function createTestRuntime(testingModule: TestingModule, engine: IEngine) {\n  type TestPlanEntry = { name: string; fn: TestFunction }\n  type RunnerEnvironment = {\n    resolve: () => void\n    reject: (error: any) => void\n    helpers: TestHelpers\n    generator: Generator\n  }\n\n  // this flag ensures no tests are added asynchronously\n  let runtimeFrozen = false\n\n  let currentFrameCounter = 0\n  let currentFrameTime = 0\n\n  // array to hold the scheduled tests\n  const scheduledTests: TestPlanEntry[] = []\n\n  // an array of promises that are resolved on the next frame (after the current frame is finished)\n  const nextTickFuture: Array<(dt: number) => void> = []\n\n  // this function returns a promise that resolves on the next frame\n  async function nextTick() {\n    return new Promise<number>((resolve) => {\n      nextTickFuture.push(resolve)\n    })\n  }\n\n  // add a system to the engine that resolves all promises in the `nextTickFuture` array\n  engine.addSystem(function TestingFrameworkCoroutineRunner(dt) {\n    currentFrameCounter++\n    currentFrameTime += dt\n    // resolve all nextTick futures.\n    nextTickFuture.splice(0, nextTickFuture.length).forEach((_) => _(dt))\n  })\n\n  // this function schedules a value to be processed on the next frame, the test runner will\n  // continue to run until it reaches a yield point\n  function scheduleValue(value: any, env: RunnerEnvironment) {\n    if (value && typeof value === 'object' && typeof value.then === 'function') {\n      console.log('⏱️ yield promise')\n      // if the value is a promise, schedule it to be awaited after the current frame is finished\n      nextTickFuture.push(async () => {\n        try {\n          scheduleValue(await value, env)\n        } catch (err) {\n          env.reject(err)\n        }\n      })\n    } else if (typeof value === 'function') {\n      console.log('⏱️ yield function')\n      // if the value is a function, schedule it to be called on the next frame\n      nextTickFuture.push(() => {\n        scheduleValue(value(), env)\n      })\n      return\n    } else if (typeof value === 'undefined' || value === null) {\n      console.log('⏱️ yield')\n      // if the value is undefined or null, continue processing the generator the next frame\n      nextTickFuture.push(() => {\n        consumeGenerator(env)\n      })\n    } else throw new Error(`Unexpected value from test generator: ${value}`)\n  }\n\n  // this function processes a generator function by scheduling its values to be processed on the next frame\n  function consumeGenerator(env: RunnerEnvironment) {\n    try {\n      const ret = env.generator.next()\n      if (!ret.done) {\n        scheduleValue(ret.value, env)\n      } else {\n        env.resolve()\n      }\n    } catch (err) {\n      env.reject(err)\n    }\n  }\n\n  // this function schedules a test run on the next frame\n  function scheduleNextRun() {\n    if (scheduledTests.length) {\n      nextTickFuture.push(runTests)\n    }\n  }\n\n  // this function runs the scheduled tests\n  function runTests() {\n    if (scheduledTests.length) {\n      const entry = scheduledTests.shift()!\n      const initialFrame = currentFrameCounter\n      const startTime = currentFrameTime\n\n      let resolved = false\n\n      // this function should be called only once. it makes the current test pass\n      const resolve = () => {\n        if (resolved) throw new Error('resolved twice')\n        resolved = true\n\n        console.log(`🟢 Test passed ${entry.name}`)\n\n        testingModule\n          .logTestResult({\n            name: entry.name,\n            ok: true,\n            totalFrames: currentFrameCounter - initialFrame,\n            totalTime: currentFrameTime - startTime\n          })\n          .finally(scheduleNextRun)\n      }\n\n      const reject = (err: any) => {\n        if (resolved) throw new Error('resolved twice')\n        resolved = true\n\n        console.log(`🔴 Test failed ${entry.name}`)\n        console.error(err)\n\n        testingModule\n          .logTestResult({\n            name: entry.name,\n            ok: false,\n            error: err.toString(),\n            stack: err && typeof err === 'object' && err.stack,\n            totalFrames: currentFrameCounter - initialFrame,\n            totalTime: currentFrameTime - startTime\n          })\n          .finally(scheduleNextRun)\n      }\n\n      try {\n        console.log(`🧪 Running test ${entry.name}`)\n\n        const testHelpers: TestHelpers = {\n          async setCameraTransform(transform) {\n            await testingModule.setCameraTransform(transform)\n            await nextTick()\n\n            const TransformComponent = engine.getComponent(Transform.componentId) as typeof Transform\n            const actualTransform = TransformComponent.get(engine.CameraEntity)\n\n            assertEquals(actualTransform.position, transform.position, \"positions don't match\")\n            assertEquals(actualTransform.rotation, transform.rotation, \"rotations don't match\")\n          }\n        }\n\n        const returnValue = entry.fn(testHelpers)\n\n        if (returnValue && typeof returnValue === 'object') {\n          if (isGenerator(returnValue)) {\n            const env: RunnerEnvironment = {\n              generator: returnValue,\n              helpers: testHelpers,\n              resolve,\n              reject\n            }\n            consumeGenerator(env)\n          } else if (isPromise(returnValue)) {\n            returnValue.then(resolve).catch(reject)\n          } else {\n            throw new Error(`Unknown test result type: ${returnValue}`)\n          }\n        } else {\n          resolve()\n        }\n      } catch (err: any) {\n        reject(err)\n      }\n    }\n  }\n\n  // schedule the test runner start for the next frame\n  nextTickFuture.push(() => {\n    // once we run the next tick, the test runtime becomes frozen. that means no new\n    // test definitions are accepted\n    runtimeFrozen = true\n\n    if (!scheduledTests.length) return\n\n    // inform the test runner about the plans for this test run\n    testingModule.plan({ tests: scheduledTests }).then(scheduleNextRun).catch(globalFail)\n  })\n\n  // this is the function that is used to plan a test functionn\n  /* @__PURE__ */\n  function test(name: string, fn: TestFunction) {\n    if (runtimeFrozen) throw new Error(\"New tests can't be added at this stage.\")\n\n    if (scheduledTests.some(($) => $.name === name)) throw new Error(`Test with name ${name} already exists`)\n\n    scheduledTests.push({ fn, name })\n  }\n\n  return {\n    test\n  }\n}\n\nfunction isGenerator(t: any): t is Generator {\n  return t && typeof t === 'object' && typeof t[Symbol.iterator] === 'function'\n}\n\nfunction isPromise(t: any): t is Promise<unknown> {\n  return t && typeof t === 'object' && typeof t.then === 'function'\n}\n\nfunction globalFail(error: any) {\n  // for now, the failure is only writing to the console.error.\n  console.error(error)\n}\n"]}
@@ -2,6 +2,11 @@
2
2
  import type { TransformType } from '@dcl/ecs';
3
3
  import type { logTestResult, plan, setCameraTransform } from '~system/Testing';
4
4
  export type TestHelpers = {
5
+ /**
6
+ * Instructs the renderer to set the camera transform to the provided argument.
7
+ * This function resolves the next frame and fails if the CameraTransform is not
8
+ * equal to the provided argument.
9
+ */
5
10
  setCameraTransform(transform: Pick<TransformType, 'position' | 'rotation'>): Promise<void>;
6
11
  };
7
12
  export type TestFunction = (helpers: TestHelpers) => Generator | Promise<any>;
package/tsconfig.json CHANGED
@@ -3,7 +3,8 @@
3
3
  "esModuleInterop": true,
4
4
  "declaration": true,
5
5
  "stripInternal": true,
6
- "outDir": "."
6
+ "outDir": ".",
7
+ "removeComments": false
7
8
  },
8
9
  "include": ["src"],
9
10
  "exclude": ["dist"],