@dxos/echo 0.8.4-staging.ac66bdf99f → 0.9.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/LICENSE +102 -5
- package/README.md +7 -7
- package/dist/lib/neutral/Annotation.mjs +37 -6
- package/dist/lib/neutral/Database.mjs +6 -17
- package/dist/lib/neutral/Entity.mjs +31 -20
- package/dist/lib/neutral/Err.mjs +3 -3
- package/dist/lib/neutral/Feed.mjs +23 -19
- package/dist/lib/neutral/Filter.mjs +13 -15
- package/dist/lib/neutral/Format.mjs +23 -3
- package/dist/lib/neutral/JsonSchema.mjs +7 -8
- package/dist/lib/neutral/Key.mjs +9 -5
- package/dist/lib/neutral/Migration.mjs +11 -10
- package/dist/lib/neutral/Obj.mjs +29 -20
- package/dist/lib/neutral/Order.mjs +7 -3
- package/dist/lib/neutral/Query.mjs +17 -17
- package/dist/lib/neutral/QueryResult.mjs +1 -1
- package/dist/lib/neutral/Ref.mjs +10 -9
- package/dist/lib/neutral/Registry.mjs +14 -0
- package/dist/lib/neutral/Relation.mjs +28 -25
- package/dist/lib/neutral/Scope.mjs +12 -0
- package/dist/lib/neutral/Tag.mjs +17 -14
- package/dist/lib/neutral/Type.mjs +54 -26
- package/dist/lib/neutral/{chunk-OMUPQMLR.mjs → chunk-35INCYOE.mjs} +1 -1
- package/dist/lib/neutral/chunk-35INCYOE.mjs.map +7 -0
- package/dist/lib/neutral/chunk-3PBP4V4O.mjs +101 -0
- package/dist/lib/neutral/chunk-3PBP4V4O.mjs.map +7 -0
- package/dist/lib/neutral/chunk-4ZUHOTCG.mjs +184 -0
- package/dist/lib/neutral/chunk-4ZUHOTCG.mjs.map +7 -0
- package/dist/lib/neutral/chunk-5SMDBFVB.mjs +108 -0
- package/dist/lib/neutral/chunk-5SMDBFVB.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-OS35K56T.mjs → chunk-5SUJPHAE.mjs} +3 -3
- package/dist/lib/neutral/{chunk-OS35K56T.mjs.map → chunk-5SUJPHAE.mjs.map} +2 -2
- package/dist/lib/neutral/{chunk-GZQTCRJB.mjs → chunk-6M2Z6WBH.mjs} +22 -2
- package/dist/lib/neutral/chunk-6M2Z6WBH.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-V36VO5SS.mjs → chunk-6YDI3J37.mjs} +32 -40
- package/dist/lib/neutral/chunk-6YDI3J37.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-MOR5ERFM.mjs → chunk-7FPIAJIV.mjs} +701 -1256
- package/dist/lib/neutral/chunk-7FPIAJIV.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-ANHVGJI4.mjs → chunk-7LOUAPYZ.mjs} +9 -5
- package/dist/lib/neutral/chunk-7LOUAPYZ.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-JUXPFOEI.mjs → chunk-7PI7C4EF.mjs} +48 -88
- package/dist/lib/neutral/chunk-7PI7C4EF.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-UBEZSGXY.mjs → chunk-BBFJWWAV.mjs} +6 -6
- package/dist/lib/neutral/chunk-BBFJWWAV.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-UI6MWK5W.mjs → chunk-EVK6XBXO.mjs} +16 -2
- package/dist/lib/neutral/chunk-EVK6XBXO.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-7RO7CPBZ.mjs → chunk-IGK6FN65.mjs} +2 -2
- package/dist/lib/neutral/{chunk-HBUZJNZO.mjs → chunk-LWXVKPPW.mjs} +94 -99
- package/dist/lib/neutral/chunk-LWXVKPPW.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-BVOFLCVF.mjs → chunk-MZ7K3MLL.mjs} +9 -6
- package/dist/lib/neutral/chunk-MZ7K3MLL.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-TBKX6JQO.mjs → chunk-O6BH7EPN.mjs} +30 -3
- package/dist/lib/neutral/chunk-O6BH7EPN.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-EAMSSLZC.mjs → chunk-QQIYS74I.mjs} +83 -46
- package/dist/lib/neutral/chunk-QQIYS74I.mjs.map +7 -0
- package/dist/lib/neutral/chunk-R5W6DXR4.mjs +678 -0
- package/dist/lib/neutral/chunk-R5W6DXR4.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-WAK4DMFV.mjs → chunk-RIVWNMSF.mjs} +12 -7
- package/dist/lib/neutral/chunk-RIVWNMSF.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-T6W2LEZU.mjs → chunk-SBVFRTST.mjs} +73 -38
- package/dist/lib/neutral/chunk-SBVFRTST.mjs.map +7 -0
- package/dist/lib/neutral/chunk-T6E37YIP.mjs +251 -0
- package/dist/lib/neutral/chunk-T6E37YIP.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-DQYLD2RB.mjs → chunk-TFEWTY5A.mjs} +155 -129
- package/dist/lib/neutral/chunk-TFEWTY5A.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-B4BASU6W.mjs → chunk-TYGKCRMK.mjs} +85 -76
- package/dist/lib/neutral/chunk-TYGKCRMK.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-4OIBYSXE.mjs → chunk-UUP46KUQ.mjs} +78 -32
- package/dist/lib/neutral/chunk-UUP46KUQ.mjs.map +7 -0
- package/dist/lib/neutral/chunk-WISOH2XH.mjs +36 -0
- package/dist/lib/neutral/chunk-WISOH2XH.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-G3IQMKF7.mjs → chunk-WTQJHC75.mjs} +111 -112
- package/dist/lib/neutral/chunk-WTQJHC75.mjs.map +7 -0
- package/dist/lib/neutral/chunk-WU3GIANS.mjs +31 -0
- package/dist/lib/neutral/chunk-WU3GIANS.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-TU3GW67D.mjs → chunk-ZGNNFYHS.mjs} +40 -40
- package/dist/lib/neutral/chunk-ZGNNFYHS.mjs.map +7 -0
- package/dist/lib/neutral/index.mjs +47 -41
- package/dist/lib/neutral/internal/index.mjs +137 -72
- package/dist/lib/neutral/meta.json +1 -1
- package/dist/lib/neutral/testing/index.mjs +261 -178
- package/dist/lib/neutral/testing/index.mjs.map +4 -4
- package/dist/types/src/Annotation.d.ts +108 -4
- package/dist/types/src/Annotation.d.ts.map +1 -1
- package/dist/types/src/Annotation.test.d.ts +2 -0
- package/dist/types/src/Annotation.test.d.ts.map +1 -0
- package/dist/types/src/Collection.d.ts +2 -3
- package/dist/types/src/Collection.d.ts.map +1 -1
- package/dist/types/src/Database.d.ts +56 -49
- package/dist/types/src/Database.d.ts.map +1 -1
- package/dist/types/src/Dataset.d.ts +16 -6
- package/dist/types/src/Dataset.d.ts.map +1 -1
- package/dist/types/src/Entity.d.ts +101 -28
- package/dist/types/src/Entity.d.ts.map +1 -1
- package/dist/types/src/Err.d.ts +27 -27
- package/dist/types/src/Err.d.ts.map +1 -1
- package/dist/types/src/Feed.d.ts +66 -19
- package/dist/types/src/Feed.d.ts.map +1 -1
- package/dist/types/src/Filter.d.ts +38 -12
- package/dist/types/src/Filter.d.ts.map +1 -1
- package/dist/types/src/Format.d.ts +0 -2
- package/dist/types/src/Format.d.ts.map +1 -1
- package/dist/types/src/Hypergraph.d.ts +14 -9
- package/dist/types/src/Hypergraph.d.ts.map +1 -1
- package/dist/types/src/Json.d.ts +33 -0
- package/dist/types/src/Json.d.ts.map +1 -0
- package/dist/types/src/Json.test.d.ts +2 -0
- package/dist/types/src/Json.test.d.ts.map +1 -0
- package/dist/types/src/JsonSchema.d.ts +2 -2
- package/dist/types/src/JsonSchema.d.ts.map +1 -1
- package/dist/types/src/Key.d.ts +1 -1
- package/dist/types/src/Key.d.ts.map +1 -1
- package/dist/types/src/Migration.d.ts +26 -11
- package/dist/types/src/Migration.d.ts.map +1 -1
- package/dist/types/src/Obj.d.ts +104 -61
- package/dist/types/src/Obj.d.ts.map +1 -1
- package/dist/types/src/Order.d.ts +10 -0
- package/dist/types/src/Order.d.ts.map +1 -1
- package/dist/types/src/Query.d.ts +34 -12
- package/dist/types/src/Query.d.ts.map +1 -1
- package/dist/types/src/QueryResult.d.ts +21 -0
- package/dist/types/src/QueryResult.d.ts.map +1 -1
- package/dist/types/src/Ref.d.ts +15 -7
- package/dist/types/src/Ref.d.ts.map +1 -1
- package/dist/types/src/Registry.d.ts +131 -0
- package/dist/types/src/Registry.d.ts.map +1 -0
- package/dist/types/src/Relation.d.ts +73 -41
- package/dist/types/src/Relation.d.ts.map +1 -1
- package/dist/types/src/Scope.d.ts +35 -0
- package/dist/types/src/Scope.d.ts.map +1 -0
- package/dist/types/src/Tag.d.ts +21 -5
- package/dist/types/src/Tag.d.ts.map +1 -1
- package/dist/types/src/Type.d.ts +362 -95
- package/dist/types/src/Type.d.ts.map +1 -1
- package/dist/types/src/View.d.ts +9 -12
- package/dist/types/src/View.d.ts.map +1 -1
- package/dist/types/src/exemplars.test.d.ts +2 -0
- package/dist/types/src/exemplars.test.d.ts.map +1 -0
- package/dist/types/src/index.d.ts +4 -3
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/internal/Annotation/annotations.d.ts +79 -38
- package/dist/types/src/internal/Annotation/annotations.d.ts.map +1 -1
- package/dist/types/src/internal/Annotation/dictionary.d.ts +24 -0
- package/dist/types/src/internal/Annotation/dictionary.d.ts.map +1 -0
- package/dist/types/src/internal/Annotation/entity-dictionary.d.ts +14 -0
- package/dist/types/src/internal/Annotation/entity-dictionary.d.ts.map +1 -0
- package/dist/types/src/internal/Annotation/index.d.ts +4 -2
- package/dist/types/src/internal/Annotation/index.d.ts.map +1 -1
- package/dist/types/src/internal/Annotation/sorting.d.ts.map +1 -1
- package/dist/types/src/internal/Annotation/util.d.ts +14 -5
- package/dist/types/src/internal/Annotation/util.d.ts.map +1 -1
- package/dist/types/src/internal/Entity/api.d.ts +17 -3
- package/dist/types/src/internal/Entity/api.d.ts.map +1 -1
- package/dist/types/src/internal/Entity/entity.d.ts +72 -8
- package/dist/types/src/internal/Entity/entity.d.ts.map +1 -1
- package/dist/types/src/internal/Entity/guard.d.ts +10 -0
- package/dist/types/src/internal/Entity/guard.d.ts.map +1 -0
- package/dist/types/src/internal/Entity/index.d.ts +2 -0
- package/dist/types/src/internal/Entity/index.d.ts.map +1 -1
- package/dist/types/src/internal/Entity/model.d.ts +21 -17
- package/dist/types/src/internal/Entity/model.d.ts.map +1 -1
- package/dist/types/src/internal/Entity/object.d.ts +3 -3
- package/dist/types/src/internal/Entity/object.d.ts.map +1 -1
- package/dist/types/src/internal/Entity/relation.d.ts +30 -7
- package/dist/types/src/internal/Entity/relation.d.ts.map +1 -1
- package/dist/types/src/internal/Entity/type-kind.d.ts +24 -0
- package/dist/types/src/internal/Entity/type-kind.d.ts.map +1 -0
- package/dist/types/src/internal/Entity/type-uri.d.ts +24 -0
- package/dist/types/src/internal/Entity/type-uri.d.ts.map +1 -0
- package/dist/types/src/internal/Entity/version.d.ts.map +1 -1
- package/dist/types/src/internal/Format/date.d.ts.map +1 -1
- package/dist/types/src/internal/Format/format.d.ts +3 -2
- package/dist/types/src/internal/Format/format.d.ts.map +1 -1
- package/dist/types/src/internal/Format/index.d.ts +2 -2
- package/dist/types/src/internal/Format/index.d.ts.map +1 -1
- package/dist/types/src/internal/Format/number.d.ts.map +1 -1
- package/dist/types/src/internal/Format/object.d.ts +3 -1
- package/dist/types/src/internal/Format/object.d.ts.map +1 -1
- package/dist/types/src/internal/Format/types.d.ts.map +1 -1
- package/dist/types/src/internal/JsonSchema/json-schema-normalize.d.ts.map +1 -1
- package/dist/types/src/internal/JsonSchema/json-schema-type.d.ts +34 -34
- package/dist/types/src/internal/JsonSchema/json-schema-type.d.ts.map +1 -1
- package/dist/types/src/internal/JsonSchema/json-schema.d.ts +3 -2
- package/dist/types/src/internal/JsonSchema/json-schema.d.ts.map +1 -1
- package/dist/types/src/internal/Obj/atoms.d.ts +38 -0
- package/dist/types/src/internal/Obj/atoms.d.ts.map +1 -0
- package/dist/types/src/internal/Obj/clone.d.ts.map +1 -1
- package/dist/types/src/internal/Obj/common.d.ts.map +1 -1
- package/dist/types/src/internal/Obj/create-object.d.ts +12 -12
- package/dist/types/src/internal/Obj/create-object.d.ts.map +1 -1
- package/dist/types/src/internal/Obj/deleted.d.ts.map +1 -1
- package/dist/types/src/internal/Obj/index.d.ts +1 -1
- package/dist/types/src/internal/Obj/index.d.ts.map +1 -1
- package/dist/types/src/internal/Obj/json-serializer.d.ts +8 -8
- package/dist/types/src/internal/Obj/json-serializer.d.ts.map +1 -1
- package/dist/types/src/internal/Obj/set-value.d.ts +1 -1
- package/dist/types/src/internal/Obj/set-value.d.ts.map +1 -1
- package/dist/types/src/internal/Obj/snapshot.d.ts.map +1 -1
- package/dist/types/src/internal/Obj/typed-object.d.ts +1 -1
- package/dist/types/src/internal/Query/index.d.ts +2 -0
- package/dist/types/src/internal/Query/index.d.ts.map +1 -0
- package/dist/types/src/internal/{Query.d.ts → Query/pretty.d.ts} +1 -1
- package/dist/types/src/internal/Query/pretty.d.ts.map +1 -0
- package/dist/types/src/internal/Ref/atoms.d.ts +10 -0
- package/dist/types/src/internal/Ref/atoms.d.ts.map +1 -0
- package/dist/types/src/internal/Ref/ref-array.d.ts +2 -2
- package/dist/types/src/internal/Ref/ref.d.ts +50 -19
- package/dist/types/src/internal/Ref/ref.d.ts.map +1 -1
- package/dist/types/src/internal/Ref/utils.d.ts +8 -0
- package/dist/types/src/internal/Ref/utils.d.ts.map +1 -0
- package/dist/types/src/internal/Type/compose.d.ts.map +1 -1
- package/dist/types/src/internal/Type/index.d.ts +1 -2
- package/dist/types/src/internal/Type/index.d.ts.map +1 -1
- package/dist/types/src/internal/Type/manipulation.d.ts +0 -1
- package/dist/types/src/internal/Type/manipulation.d.ts.map +1 -1
- package/dist/types/src/internal/Type/type-schema.d.ts +52 -0
- package/dist/types/src/internal/Type/type-schema.d.ts.map +1 -0
- package/dist/types/src/internal/common/api/meta.d.ts +14 -11
- package/dist/types/src/internal/common/api/meta.d.ts.map +1 -1
- package/dist/types/src/internal/common/proxy/change-context.d.ts +1 -1
- package/dist/types/src/internal/common/proxy/change-context.d.ts.map +1 -1
- package/dist/types/src/internal/common/proxy/define-hidden-property.d.ts.map +1 -1
- package/dist/types/src/internal/common/proxy/errors.d.ts +1 -1
- package/dist/types/src/internal/common/proxy/errors.d.ts.map +1 -1
- package/dist/types/src/internal/common/proxy/event-batch.d.ts.map +1 -1
- package/dist/types/src/internal/common/proxy/json-serializer.d.ts.map +1 -1
- package/dist/types/src/internal/common/proxy/make-object.d.ts +11 -5
- package/dist/types/src/internal/common/proxy/make-object.d.ts.map +1 -1
- package/dist/types/src/internal/common/proxy/ownership.d.ts.map +1 -1
- package/dist/types/src/internal/common/proxy/proxy-utils.d.ts.map +1 -1
- package/dist/types/src/internal/common/proxy/reactive-array.d.ts +1 -1
- package/dist/types/src/internal/common/proxy/reactive.d.ts +1 -1
- package/dist/types/src/internal/common/proxy/reactive.d.ts.map +1 -1
- package/dist/types/src/internal/common/proxy/reactive.test.d.ts +2 -0
- package/dist/types/src/internal/common/proxy/reactive.test.d.ts.map +1 -0
- package/dist/types/src/internal/common/proxy/schema-validator.d.ts.map +1 -1
- package/dist/types/src/internal/common/proxy/typed-handler.d.ts +18 -2
- package/dist/types/src/internal/common/proxy/typed-handler.d.ts.map +1 -1
- package/dist/types/src/internal/common/types/base.d.ts +4 -4
- package/dist/types/src/internal/common/types/base.d.ts.map +1 -1
- package/dist/types/src/internal/common/types/entity.d.ts +62 -5
- package/dist/types/src/internal/common/types/entity.d.ts.map +1 -1
- package/dist/types/src/internal/common/types/index.d.ts +1 -1
- package/dist/types/src/internal/common/types/index.d.ts.map +1 -1
- package/dist/types/src/internal/common/types/meta.d.ts +33 -12
- package/dist/types/src/internal/common/types/meta.d.ts.map +1 -1
- package/dist/types/src/internal/common/types/model-symbols.d.ts +15 -4
- package/dist/types/src/internal/common/types/model-symbols.d.ts.map +1 -1
- package/dist/types/src/internal/common/types/typename.d.ts +7 -0
- package/dist/types/src/internal/common/types/typename.d.ts.map +1 -1
- package/dist/types/src/internal/common/types/version.d.ts +1 -1
- package/dist/types/src/internal/common/types/well-known-types.d.ts +11 -0
- package/dist/types/src/internal/common/types/well-known-types.d.ts.map +1 -0
- package/dist/types/src/internal/index.d.ts +2 -2
- package/dist/types/src/internal/index.d.ts.map +1 -1
- package/dist/types/src/testing/index.d.ts +1 -0
- package/dist/types/src/testing/index.d.ts.map +1 -1
- package/dist/types/src/testing/registry.d.ts +9 -0
- package/dist/types/src/testing/registry.d.ts.map +1 -0
- package/dist/types/src/testing/test-data.d.ts +8 -8
- package/dist/types/src/testing/test-data.d.ts.map +1 -1
- package/dist/types/src/testing/test-schema.d.ts +83 -89
- package/dist/types/src/testing/test-schema.d.ts.map +1 -1
- package/dist/types/src/testing/util.d.ts +5 -3
- package/dist/types/src/testing/util.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +26 -24
- package/src/Annotation.test.ts +439 -0
- package/src/Annotation.ts +158 -4
- package/src/Collection.ts +5 -9
- package/src/Database.ts +93 -100
- package/src/Dataset.ts +10 -2
- package/src/Entity.test.ts +116 -6
- package/src/Entity.ts +134 -32
- package/src/Err.ts +4 -4
- package/src/Feed.ts +92 -44
- package/src/Filter.ts +70 -40
- package/src/Format.ts +0 -4
- package/src/Hypergraph.ts +14 -9
- package/src/Json.test.ts +175 -0
- package/src/Json.ts +103 -0
- package/src/Key.ts +1 -1
- package/src/Migration.ts +39 -19
- package/src/Obj.test.ts +122 -20
- package/src/Obj.ts +168 -91
- package/src/Order.ts +22 -0
- package/src/Query.test.ts +183 -154
- package/src/Query.ts +172 -85
- package/src/QueryResult.ts +26 -0
- package/src/Ref.ts +22 -4
- package/src/Registry.ts +155 -0
- package/src/Relation.test.ts +10 -10
- package/src/Relation.ts +116 -69
- package/src/Scope.ts +50 -0
- package/src/Tag.md +88 -0
- package/src/Tag.ts +49 -6
- package/src/Type.test.ts +223 -18
- package/src/Type.ts +609 -131
- package/src/View.ts +14 -23
- package/src/exemplars.test.ts +21 -0
- package/src/index.ts +4 -4
- package/src/internal/Annotation/annotations.test.ts +31 -11
- package/src/internal/Annotation/annotations.ts +143 -111
- package/src/internal/Annotation/dictionary.ts +47 -0
- package/src/internal/Annotation/entity-dictionary.ts +74 -0
- package/src/internal/Annotation/index.ts +4 -2
- package/src/internal/Annotation/util.ts +17 -8
- package/src/internal/Entity/api.ts +54 -7
- package/src/internal/Entity/entity.ts +196 -47
- package/src/internal/Entity/guard.ts +26 -0
- package/src/internal/Entity/index.ts +2 -0
- package/src/internal/Entity/model.ts +38 -28
- package/src/internal/Entity/object.ts +21 -5
- package/src/internal/Entity/relation.ts +68 -34
- package/src/internal/Entity/type-kind.ts +75 -0
- package/src/internal/Entity/type-uri.ts +92 -0
- package/src/internal/Entity/util.ts +9 -9
- package/src/internal/Format/date.ts +0 -4
- package/src/internal/Format/format.test.ts +21 -0
- package/src/internal/Format/index.ts +2 -3
- package/src/internal/Format/object.ts +21 -4
- package/src/internal/Format/types.ts +1 -1
- package/src/internal/JsonSchema/annotations.ts +1 -1
- package/src/internal/JsonSchema/json-schema-type.ts +4 -4
- package/src/internal/JsonSchema/json-schema.test.ts +71 -145
- package/src/internal/JsonSchema/json-schema.ts +49 -35
- package/src/internal/Obj/atoms.ts +244 -0
- package/src/internal/Obj/clone.ts +9 -4
- package/src/internal/Obj/create-object.test.ts +12 -10
- package/src/internal/Obj/create-object.ts +68 -22
- package/src/internal/Obj/index.ts +1 -1
- package/src/internal/Obj/inspect.ts +5 -3
- package/src/internal/Obj/json-serializer.test.ts +101 -22
- package/src/internal/Obj/json-serializer.ts +89 -33
- package/src/internal/Obj/set-value.test.ts +22 -45
- package/src/internal/Obj/set-value.ts +12 -19
- package/src/internal/Obj/snapshot.ts +13 -4
- package/src/internal/Obj/typed-object.test.ts +9 -11
- package/src/internal/Obj/typed-object.ts +1 -1
- package/src/internal/Query/index.ts +5 -0
- package/src/internal/{Query.ts → Query/pretty.ts} +40 -12
- package/src/internal/Ref/atoms.ts +20 -0
- package/src/internal/Ref/ref-array.ts +3 -3
- package/src/internal/Ref/ref.test.ts +18 -27
- package/src/internal/Ref/ref.ts +137 -59
- package/src/internal/Ref/utils.ts +45 -0
- package/src/internal/Type/compose.test.ts +3 -1
- package/src/internal/Type/index.ts +1 -2
- package/src/internal/Type/manipulation.ts +0 -25
- package/src/internal/Type/type-schema.ts +60 -0
- package/src/internal/common/README.md +2 -2
- package/src/internal/common/api/meta.ts +19 -17
- package/src/internal/common/proxy/change-context.ts +1 -1
- package/src/internal/common/proxy/change.test.ts +91 -83
- package/src/internal/common/proxy/errors.ts +2 -2
- package/src/internal/common/proxy/handler.test.ts +1 -1
- package/src/internal/common/proxy/json-serializer.ts +27 -16
- package/src/internal/common/proxy/make-object.ts +44 -20
- package/src/internal/common/proxy/ownership.ts +2 -2
- package/src/internal/common/proxy/reactive-array.ts +1 -1
- package/src/internal/common/proxy/reactive.test.ts +54 -0
- package/src/internal/common/proxy/reactive.ts +11 -2
- package/src/internal/common/proxy/schema.test.ts +48 -86
- package/src/internal/common/proxy/typed-handler.test.ts +12 -11
- package/src/internal/common/proxy/typed-handler.ts +78 -16
- package/src/internal/common/proxy/typed-object.test.ts +16 -28
- package/src/internal/common/types/base.ts +4 -4
- package/src/internal/common/types/entity.ts +80 -1
- package/src/internal/common/types/index.ts +6 -1
- package/src/internal/common/types/meta.ts +62 -20
- package/src/internal/common/types/model-symbols.ts +24 -4
- package/src/internal/common/types/typename.ts +39 -3
- package/src/internal/common/types/well-known-types.ts +15 -0
- package/src/internal/index.ts +6 -4
- package/src/testing/api.test.ts +15 -9
- package/src/testing/index.ts +1 -0
- package/src/testing/registry.ts +44 -0
- package/src/testing/test-data.ts +159 -99
- package/src/testing/test-schema.ts +22 -58
- package/src/testing/util.ts +14 -11
- package/dist/lib/neutral/Extension.mjs +0 -18
- package/dist/lib/neutral/SchemaRegistry.mjs +0 -2
- package/dist/lib/neutral/chunk-2KHZ36F5.mjs +0 -361
- package/dist/lib/neutral/chunk-2KHZ36F5.mjs.map +0 -7
- package/dist/lib/neutral/chunk-4OIBYSXE.mjs.map +0 -7
- package/dist/lib/neutral/chunk-4P3IXBLT.mjs +0 -45
- package/dist/lib/neutral/chunk-4P3IXBLT.mjs.map +0 -7
- package/dist/lib/neutral/chunk-ANHVGJI4.mjs.map +0 -7
- package/dist/lib/neutral/chunk-B4BASU6W.mjs.map +0 -7
- package/dist/lib/neutral/chunk-BNCCGLJN.mjs +0 -7
- package/dist/lib/neutral/chunk-BNCCGLJN.mjs.map +0 -7
- package/dist/lib/neutral/chunk-BVOFLCVF.mjs.map +0 -7
- package/dist/lib/neutral/chunk-DQYLD2RB.mjs.map +0 -7
- package/dist/lib/neutral/chunk-EAMSSLZC.mjs.map +0 -7
- package/dist/lib/neutral/chunk-G3IQMKF7.mjs.map +0 -7
- package/dist/lib/neutral/chunk-GZQTCRJB.mjs.map +0 -7
- package/dist/lib/neutral/chunk-HBUZJNZO.mjs.map +0 -7
- package/dist/lib/neutral/chunk-JUXPFOEI.mjs.map +0 -7
- package/dist/lib/neutral/chunk-MOR5ERFM.mjs.map +0 -7
- package/dist/lib/neutral/chunk-OMUPQMLR.mjs.map +0 -7
- package/dist/lib/neutral/chunk-PHU22NLC.mjs +0 -136
- package/dist/lib/neutral/chunk-PHU22NLC.mjs.map +0 -7
- package/dist/lib/neutral/chunk-ROG4RXXL.mjs +0 -97
- package/dist/lib/neutral/chunk-ROG4RXXL.mjs.map +0 -7
- package/dist/lib/neutral/chunk-T6W2LEZU.mjs.map +0 -7
- package/dist/lib/neutral/chunk-TBKX6JQO.mjs.map +0 -7
- package/dist/lib/neutral/chunk-TU3GW67D.mjs.map +0 -7
- package/dist/lib/neutral/chunk-UBEZSGXY.mjs.map +0 -7
- package/dist/lib/neutral/chunk-UI6MWK5W.mjs.map +0 -7
- package/dist/lib/neutral/chunk-V36VO5SS.mjs.map +0 -7
- package/dist/lib/neutral/chunk-WAK4DMFV.mjs.map +0 -7
- package/dist/lib/neutral/chunk-YAHXAYOW.mjs +0 -56
- package/dist/lib/neutral/chunk-YAHXAYOW.mjs.map +0 -7
- package/dist/lib/neutral/chunk-YS6Q3XAD.mjs +0 -50
- package/dist/lib/neutral/chunk-YS6Q3XAD.mjs.map +0 -7
- package/dist/types/src/Extension.d.ts +0 -80
- package/dist/types/src/Extension.d.ts.map +0 -1
- package/dist/types/src/Extension.test.d.ts +0 -2
- package/dist/types/src/Extension.test.d.ts.map +0 -1
- package/dist/types/src/SchemaRegistry.d.ts +0 -84
- package/dist/types/src/SchemaRegistry.d.ts.map +0 -1
- package/dist/types/src/internal/Obj/ids.d.ts +0 -6
- package/dist/types/src/internal/Obj/ids.d.ts.map +0 -1
- package/dist/types/src/internal/Query.d.ts.map +0 -1
- package/dist/types/src/internal/Type/echo-schema.d.ts +0 -181
- package/dist/types/src/internal/Type/echo-schema.d.ts.map +0 -1
- package/dist/types/src/internal/Type/persistent-schema.d.ts +0 -20
- package/dist/types/src/internal/Type/persistent-schema.d.ts.map +0 -1
- package/src/Extension.test.ts +0 -235
- package/src/Extension.ts +0 -122
- package/src/SchemaRegistry.ts +0 -106
- package/src/internal/Obj/ids.ts +0 -12
- package/src/internal/Type/echo-schema.ts +0 -423
- package/src/internal/Type/persistent-schema.ts +0 -33
- /package/dist/lib/neutral/{Extension.mjs.map → Registry.mjs.map} +0 -0
- /package/dist/lib/neutral/{SchemaRegistry.mjs.map → Scope.mjs.map} +0 -0
- /package/dist/lib/neutral/{chunk-7RO7CPBZ.mjs.map → chunk-IGK6FN65.mjs.map} +0 -0
package/src/Type.test.ts
CHANGED
|
@@ -5,6 +5,10 @@
|
|
|
5
5
|
import * as Schema from 'effect/Schema';
|
|
6
6
|
import { describe, test } from 'vitest';
|
|
7
7
|
|
|
8
|
+
import { DXN, EntityId } from '@dxos/keys';
|
|
9
|
+
|
|
10
|
+
import * as Entity from './Entity';
|
|
11
|
+
import * as JsonSchema from './JsonSchema';
|
|
8
12
|
import * as Obj from './Obj';
|
|
9
13
|
import * as Relation from './Relation';
|
|
10
14
|
import { TestSchema } from './testing';
|
|
@@ -12,16 +16,9 @@ import * as Type from './Type';
|
|
|
12
16
|
|
|
13
17
|
describe('Type', () => {
|
|
14
18
|
describe('Obj.Unknown schema', () => {
|
|
15
|
-
test('has SchemaKindId for schema type checking', ({ expect }) => {
|
|
16
|
-
// Type.isObjectSchema uses SchemaKindId to check if a schema is an object schema.
|
|
17
|
-
expect(Type.isObjectSchema(Obj.Unknown)).toBe(true);
|
|
18
|
-
expect(Type.isObjectSchema(TestSchema.Person)).toBe(true);
|
|
19
|
-
expect(Type.isObjectSchema(Relation.Unknown)).toBe(false);
|
|
20
|
-
});
|
|
21
|
-
|
|
22
19
|
test('Schema.is validates structural compatibility only', ({ expect }) => {
|
|
23
|
-
// Schema.is does structural validation (has id field).
|
|
24
|
-
//
|
|
20
|
+
// Schema.is does structural validation (has id field). `Obj.Unknown` IS
|
|
21
|
+
// a raw Effect Schema (branded with EchoSchemaKind), so pass it directly.
|
|
25
22
|
expect(Schema.is(Obj.Unknown)({ id: 'plain-object' })).toBe(true);
|
|
26
23
|
const obj = Obj.make(TestSchema.Person, { name: 'Test' });
|
|
27
24
|
expect(Schema.is(Obj.Unknown)(obj)).toBe(true);
|
|
@@ -29,16 +26,9 @@ describe('Type', () => {
|
|
|
29
26
|
});
|
|
30
27
|
|
|
31
28
|
describe('Relation.Unknown schema', () => {
|
|
32
|
-
test('has SchemaKindId for schema type checking', ({ expect }) => {
|
|
33
|
-
// Type.isRelationSchema uses SchemaKindId to check if a schema is a relation schema.
|
|
34
|
-
expect(Type.isRelationSchema(Relation.Unknown)).toBe(true);
|
|
35
|
-
expect(Type.isRelationSchema(TestSchema.HasManager)).toBe(true);
|
|
36
|
-
expect(Type.isRelationSchema(Obj.Unknown)).toBe(false);
|
|
37
|
-
});
|
|
38
|
-
|
|
39
29
|
test('Schema.is validates structural compatibility only', ({ expect }) => {
|
|
40
|
-
// Schema.is does structural validation (has id field).
|
|
41
|
-
//
|
|
30
|
+
// Schema.is does structural validation (has id field). `Relation.Unknown`
|
|
31
|
+
// IS a raw Effect Schema (branded with EchoSchemaKind), so pass it directly.
|
|
42
32
|
expect(Schema.is(Relation.Unknown)({ id: 'plain-object' })).toBe(true);
|
|
43
33
|
const obj1 = Obj.make(TestSchema.Person, { name: 'Alice' });
|
|
44
34
|
const obj2 = Obj.make(TestSchema.Person, { name: 'Bob' });
|
|
@@ -49,4 +39,219 @@ describe('Type', () => {
|
|
|
49
39
|
expect(Schema.is(Relation.Unknown)(rel)).toBe(true);
|
|
50
40
|
});
|
|
51
41
|
});
|
|
42
|
+
|
|
43
|
+
describe('Type.Type meta-schema', () => {
|
|
44
|
+
test('Type.Type is branded as the type entity kind', ({ expect }) => {
|
|
45
|
+
// The Type.Type entity itself is an in-memory object (KindId=Object) that
|
|
46
|
+
// *declares* a type-kind schema (SchemaKindId=Type).
|
|
47
|
+
expect(Type.isTypeKind(Type.Type)).toBe(true);
|
|
48
|
+
expect(Type.isObject(Type.Type)).toBe(false);
|
|
49
|
+
expect(Type.isRelation(Type.Type)).toBe(false);
|
|
50
|
+
});
|
|
51
|
+
|
|
52
|
+
test('static object/relation types are not type-kind', ({ expect }) => {
|
|
53
|
+
expect(Type.isTypeKind(TestSchema.Person)).toBe(false);
|
|
54
|
+
expect(Type.isTypeKind(TestSchema.HasManager)).toBe(false);
|
|
55
|
+
});
|
|
56
|
+
|
|
57
|
+
test('Type.getMeta(Type.Type) reports key/version of the meta-schema', ({ expect }) => {
|
|
58
|
+
// `Type.getMeta` returns the entity's `EntityMeta`. For the static
|
|
59
|
+
// `Type.Type` meta-schema entity the key/version reflect its registry
|
|
60
|
+
// identity. The schema-kind brand is on `[SchemaKindId]`, not in meta.
|
|
61
|
+
const meta = Type.getMeta(Type.Type);
|
|
62
|
+
expect(meta.key).toBe('org.dxos.type.schema');
|
|
63
|
+
expect(meta.version).toBe('0.1.0');
|
|
64
|
+
expect(Type.isTypeKind(Type.Type)).toBe(true);
|
|
65
|
+
});
|
|
66
|
+
|
|
67
|
+
test('Type.getURI(Type.Type) returns the meta-schema DXN', ({ expect }) => {
|
|
68
|
+
expect(Type.getURI(Type.Type).toString()).toBe('dxn:org.dxos.type.schema:0.1.0');
|
|
69
|
+
});
|
|
70
|
+
});
|
|
71
|
+
|
|
72
|
+
describe('Type.makeObjectFromJsonSchema', () => {
|
|
73
|
+
test('creates an instance branded KindId=type', ({ expect }) => {
|
|
74
|
+
const entity = Type.makeObjectFromJsonSchema({
|
|
75
|
+
typename: 'com.example.type.test',
|
|
76
|
+
version: '0.1.0',
|
|
77
|
+
jsonSchema: JsonSchema.toJsonSchema(Schema.Struct({ field: Schema.Number })),
|
|
78
|
+
});
|
|
79
|
+
expect((entity as any)[Entity.KindId]).toBe(Entity.Kind.Type);
|
|
80
|
+
// `typename` / `version` are not direct fields on a persisted `Type.Type`;
|
|
81
|
+
// they live in `EntityMeta` (the canonical registry-provenance pair).
|
|
82
|
+
// Read them via the helpers (or `Type.getMeta`).
|
|
83
|
+
expect(Type.getTypename(entity)).toBe('com.example.type.test');
|
|
84
|
+
expect(Type.getVersion(entity)).toBe('0.1.0');
|
|
85
|
+
expect(entity.jsonSchema).toBeDefined();
|
|
86
|
+
});
|
|
87
|
+
|
|
88
|
+
test('defaults version to 0.0.0 for drafts', ({ expect }) => {
|
|
89
|
+
const draft = Type.makeObjectFromJsonSchema({
|
|
90
|
+
jsonSchema: JsonSchema.toJsonSchema(Schema.Struct({ field: Schema.String })),
|
|
91
|
+
});
|
|
92
|
+
// Drafts default version to `'0.0.0'` in `EntityMeta.version`; the
|
|
93
|
+
// typename (`EntityMeta.key`) is undefined until set.
|
|
94
|
+
expect(Type.getVersion(draft)).toBe('0.0.0');
|
|
95
|
+
const meta = Type.getMeta(draft);
|
|
96
|
+
expect(meta.key).toBeUndefined();
|
|
97
|
+
expect(meta.version).toBe('0.0.0');
|
|
98
|
+
});
|
|
99
|
+
|
|
100
|
+
test('assigns a stable id', ({ expect }) => {
|
|
101
|
+
const a = Type.makeObjectFromJsonSchema({ jsonSchema: JsonSchema.toJsonSchema(Schema.Struct({})) });
|
|
102
|
+
const b = Type.makeObjectFromJsonSchema({ jsonSchema: JsonSchema.toJsonSchema(Schema.Struct({})) });
|
|
103
|
+
expect(typeof a.id).toBe('string');
|
|
104
|
+
expect(a.id).not.toBe(b.id);
|
|
105
|
+
});
|
|
106
|
+
|
|
107
|
+
test('result satisfies isType', ({ expect }) => {
|
|
108
|
+
const entity = Type.makeObjectFromJsonSchema({
|
|
109
|
+
jsonSchema: JsonSchema.toJsonSchema(Schema.Struct({ field: Schema.Number })),
|
|
110
|
+
});
|
|
111
|
+
expect(Type.isType(entity)).toBe(true);
|
|
112
|
+
});
|
|
113
|
+
});
|
|
114
|
+
|
|
115
|
+
describe('Type.makeRelationFromJsonSchema', () => {
|
|
116
|
+
test('embeds source/target DXNs into jsonSchema', ({ expect }) => {
|
|
117
|
+
const entity = Type.makeRelationFromJsonSchema({
|
|
118
|
+
typename: 'com.example.type.testRel',
|
|
119
|
+
version: '0.1.0',
|
|
120
|
+
jsonSchema: JsonSchema.toJsonSchema(Schema.Struct({ note: Schema.String })),
|
|
121
|
+
source: TestSchema.Person,
|
|
122
|
+
target: TestSchema.Organization,
|
|
123
|
+
});
|
|
124
|
+
expect((entity as any)[Entity.KindId]).toBe(Entity.Kind.Type);
|
|
125
|
+
expect(entity.jsonSchema.entityKind).toBe(Entity.Kind.Relation);
|
|
126
|
+
expect((entity.jsonSchema as any).relationSource?.$ref).toBe(Type.getURI(TestSchema.Person).toString());
|
|
127
|
+
expect((entity.jsonSchema as any).relationTarget?.$ref).toBe(Type.getURI(TestSchema.Organization).toString());
|
|
128
|
+
});
|
|
129
|
+
|
|
130
|
+
test('accepts Obj.Unknown as source/target', ({ expect }) => {
|
|
131
|
+
const entity = Type.makeRelationFromJsonSchema({
|
|
132
|
+
jsonSchema: JsonSchema.toJsonSchema(Schema.Struct({})),
|
|
133
|
+
source: Obj.Unknown,
|
|
134
|
+
target: Obj.Unknown,
|
|
135
|
+
});
|
|
136
|
+
const unknownURI = 'dxn:org.dxos.schema.anyObject:0.0.0';
|
|
137
|
+
expect((entity.jsonSchema as any).relationSource?.$ref).toBe(unknownURI);
|
|
138
|
+
expect((entity.jsonSchema as any).relationTarget?.$ref).toBe(unknownURI);
|
|
139
|
+
});
|
|
140
|
+
|
|
141
|
+
test('defaults version to 0.0.0 for drafts', ({ expect }) => {
|
|
142
|
+
const draft = Type.makeRelationFromJsonSchema({
|
|
143
|
+
jsonSchema: JsonSchema.toJsonSchema(Schema.Struct({})),
|
|
144
|
+
source: TestSchema.Person,
|
|
145
|
+
target: TestSchema.Person,
|
|
146
|
+
});
|
|
147
|
+
expect(Type.getVersion(draft)).toBe('0.0.0');
|
|
148
|
+
const meta = Type.getMeta(draft);
|
|
149
|
+
expect(meta.key).toBeUndefined();
|
|
150
|
+
expect(meta.version).toBe('0.0.0');
|
|
151
|
+
});
|
|
152
|
+
});
|
|
153
|
+
|
|
154
|
+
describe('Obj/Relation/Entity.getType', () => {
|
|
155
|
+
test('Obj.getType returns the static type entity for instances of Type.makeObject', ({ expect }) => {
|
|
156
|
+
const person = Obj.make(TestSchema.Person, { name: 'Alice' });
|
|
157
|
+
expect(Obj.getType(person)).toBe(TestSchema.Person);
|
|
158
|
+
});
|
|
159
|
+
|
|
160
|
+
test('Relation.getType returns the static type entity for instances of Type.makeRelation', ({ expect }) => {
|
|
161
|
+
const a = Obj.make(TestSchema.Person, { name: 'A' });
|
|
162
|
+
const b = Obj.make(TestSchema.Person, { name: 'B' });
|
|
163
|
+
const rel = Relation.make(TestSchema.HasManager, {
|
|
164
|
+
[Relation.Source]: a,
|
|
165
|
+
[Relation.Target]: b,
|
|
166
|
+
});
|
|
167
|
+
expect(Relation.getType(rel)).toBe(TestSchema.HasManager);
|
|
168
|
+
});
|
|
169
|
+
|
|
170
|
+
test('Entity.getType narrows uniformly across object/relation instances', ({ expect }) => {
|
|
171
|
+
const person = Obj.make(TestSchema.Person, { name: 'A' });
|
|
172
|
+
const a = Obj.make(TestSchema.Person, { name: 'A' });
|
|
173
|
+
const b = Obj.make(TestSchema.Person, { name: 'B' });
|
|
174
|
+
const rel = Relation.make(TestSchema.HasManager, {
|
|
175
|
+
[Relation.Source]: a,
|
|
176
|
+
[Relation.Target]: b,
|
|
177
|
+
});
|
|
178
|
+
expect(Entity.getType(person)).toBe(TestSchema.Person);
|
|
179
|
+
expect(Entity.getType(rel)).toBe(TestSchema.HasManager);
|
|
180
|
+
});
|
|
181
|
+
});
|
|
182
|
+
|
|
183
|
+
describe('static type factories', () => {
|
|
184
|
+
test('Type.makeObject stamps schema-kind=object', ({ expect }) => {
|
|
185
|
+
expect((TestSchema.Person as any)['~@dxos/echo/SchemaKind']).toBe(Entity.Kind.Object);
|
|
186
|
+
expect(Type.isObject(TestSchema.Person)).toBe(true);
|
|
187
|
+
});
|
|
188
|
+
|
|
189
|
+
test('Type.makeRelation stamps schema-kind=relation', ({ expect }) => {
|
|
190
|
+
expect((TestSchema.HasManager as any)['~@dxos/echo/SchemaKind']).toBe(Entity.Kind.Relation);
|
|
191
|
+
expect(Type.isRelation(TestSchema.HasManager)).toBe(true);
|
|
192
|
+
});
|
|
193
|
+
|
|
194
|
+
test('Type.getURI returns the DXN for static types', ({ expect }) => {
|
|
195
|
+
expect(Type.getURI(TestSchema.Person).toString()).toBe('dxn:com.example.type.person:0.1.0');
|
|
196
|
+
expect(Type.getURI(TestSchema.HasManager).toString()).toBe('dxn:com.example.type.hasManager:0.1.0');
|
|
197
|
+
});
|
|
198
|
+
});
|
|
199
|
+
|
|
200
|
+
describe('deterministic id default', () => {
|
|
201
|
+
// The default id is `EntityId.deterministic(typename, version)` — required so that
|
|
202
|
+
// `Type.makeObject(...)` never calls `crypto.getRandomValues()` at module-evaluation
|
|
203
|
+
// time (forbidden by Cloudflare workerd in global scope).
|
|
204
|
+
const personDxn = DXN.make('com.example.type.deterministic.person', '0.1.0');
|
|
205
|
+
const worksForDxn = DXN.make('com.example.type.deterministic.worksFor', '0.1.0');
|
|
206
|
+
|
|
207
|
+
test('Type.makeObject with the same DXN twice yields entities with identical ids', ({ expect }) => {
|
|
208
|
+
const a = Schema.Struct({ name: Schema.String }).pipe(Type.makeObject(personDxn));
|
|
209
|
+
const b = Schema.Struct({ name: Schema.String }).pipe(Type.makeObject(personDxn));
|
|
210
|
+
expect(a.id).toBe(b.id);
|
|
211
|
+
expect(a.id).toBe(EntityId.deterministic('com.example.type.deterministic.person', '0.1.0'));
|
|
212
|
+
});
|
|
213
|
+
|
|
214
|
+
test('different versions produce different ids', ({ expect }) => {
|
|
215
|
+
const v1 = Schema.Struct({ name: Schema.String }).pipe(
|
|
216
|
+
Type.makeObject(DXN.make('com.example.type.deterministic.person', '0.1.0')),
|
|
217
|
+
);
|
|
218
|
+
const v2 = Schema.Struct({ name: Schema.String }).pipe(
|
|
219
|
+
Type.makeObject(DXN.make('com.example.type.deterministic.person', '0.2.0')),
|
|
220
|
+
);
|
|
221
|
+
expect(v1.id).not.toBe(v2.id);
|
|
222
|
+
});
|
|
223
|
+
|
|
224
|
+
test('Type.makeObject({ id }) override is honoured', ({ expect }) => {
|
|
225
|
+
const explicit = EntityId.random();
|
|
226
|
+
const entity = Schema.Struct({ name: Schema.String }).pipe(Type.makeObject(personDxn, { id: explicit }));
|
|
227
|
+
expect(entity.id).toBe(explicit);
|
|
228
|
+
// And the default still kicks in when no override is supplied.
|
|
229
|
+
const defaultEntity = Schema.Struct({ name: Schema.String }).pipe(Type.makeObject(personDxn));
|
|
230
|
+
expect(defaultEntity.id).not.toBe(explicit);
|
|
231
|
+
});
|
|
232
|
+
|
|
233
|
+
test('Type.makeRelation defaults id to deterministic(typename, version)', ({ expect }) => {
|
|
234
|
+
const a = Schema.Struct({ since: Schema.Number }).pipe(
|
|
235
|
+
Type.makeRelation({ dxn: worksForDxn, source: TestSchema.Person, target: TestSchema.Organization }),
|
|
236
|
+
);
|
|
237
|
+
const b = Schema.Struct({ since: Schema.Number }).pipe(
|
|
238
|
+
Type.makeRelation({ dxn: worksForDxn, source: TestSchema.Person, target: TestSchema.Organization }),
|
|
239
|
+
);
|
|
240
|
+
expect(a.id).toBe(b.id);
|
|
241
|
+
expect(a.id).toBe(EntityId.deterministic('com.example.type.deterministic.worksFor', '0.1.0'));
|
|
242
|
+
});
|
|
243
|
+
|
|
244
|
+
test('Type.makeRelation({ id }) override is honoured', ({ expect }) => {
|
|
245
|
+
const explicit = EntityId.random();
|
|
246
|
+
const entity = Schema.Struct({ since: Schema.Number }).pipe(
|
|
247
|
+
Type.makeRelation({
|
|
248
|
+
dxn: worksForDxn,
|
|
249
|
+
source: TestSchema.Person,
|
|
250
|
+
target: TestSchema.Organization,
|
|
251
|
+
id: explicit,
|
|
252
|
+
}),
|
|
253
|
+
);
|
|
254
|
+
expect(entity.id).toBe(explicit);
|
|
255
|
+
});
|
|
256
|
+
});
|
|
52
257
|
});
|