@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/testing/api.test.ts
CHANGED
|
@@ -13,16 +13,22 @@ import { TestSchema } from './test-schema';
|
|
|
13
13
|
describe('Experimental API review', () => {
|
|
14
14
|
test('type checks', ({ expect }) => {
|
|
15
15
|
const contact = Obj.make(TestSchema.Person, { name: 'Test' });
|
|
16
|
-
const
|
|
17
|
-
|
|
18
|
-
expect(Type.
|
|
19
|
-
expect(Type.getTypename(
|
|
20
|
-
expect(Type.getVersion(
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
16
|
+
const type = Obj.getType(contact) ?? raise(new Error('No type found'));
|
|
17
|
+
|
|
18
|
+
expect(Type.getTypename(type)).to.eq(Type.getTypename(TestSchema.Person));
|
|
19
|
+
expect(Type.getTypename(type)).to.eq('com.example.type.person');
|
|
20
|
+
expect(Type.getVersion(type)).to.eq('0.1.0');
|
|
21
|
+
// `Type.getMeta` returns `EntityMeta` (`{ keys, tags?, key?, version? }`) —
|
|
22
|
+
// the same shape `Obj.getMeta` and `Relation.getMeta` return. The
|
|
23
|
+
// schema-kind brand lives on `[SchemaKindId]`, not in meta.
|
|
24
|
+
expect(Type.getMeta(type)).to.deep.eq({
|
|
25
|
+
keys: [],
|
|
26
|
+
tags: [],
|
|
27
|
+
annotations: {},
|
|
28
|
+
key: 'com.example.type.person',
|
|
24
29
|
version: '0.1.0',
|
|
25
30
|
});
|
|
31
|
+
expect(Type.isObject(type)).to.be.true;
|
|
26
32
|
});
|
|
27
33
|
|
|
28
34
|
test('instance checks', ({ expect }) => {
|
|
@@ -32,7 +38,7 @@ describe('Experimental API review', () => {
|
|
|
32
38
|
employer: Ref.make(organization),
|
|
33
39
|
});
|
|
34
40
|
|
|
35
|
-
expect(Schema.is(TestSchema.Person)(contact)).to.be.true;
|
|
41
|
+
expect(Schema.is(Type.getSchema(TestSchema.Person))(contact)).to.be.true;
|
|
36
42
|
expect(Obj.instanceOf(TestSchema.Person, contact)).to.be.true;
|
|
37
43
|
expect(Obj.instanceOf(TestSchema.Organization, organization)).to.be.true;
|
|
38
44
|
|
package/src/testing/index.ts
CHANGED
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2026 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import * as Atom from '@effect-atom/atom/Atom';
|
|
6
|
+
import * as Layer from 'effect/Layer';
|
|
7
|
+
|
|
8
|
+
import { Event } from '@dxos/async';
|
|
9
|
+
|
|
10
|
+
import * as Registry from '../Registry';
|
|
11
|
+
|
|
12
|
+
/**
|
|
13
|
+
* Noop `Registry.Service` layer for testing — always returns empty query results.
|
|
14
|
+
* Use this in test layer stacks that require `Registry.Service` but don't need
|
|
15
|
+
* actual registry contents.
|
|
16
|
+
*/
|
|
17
|
+
export const registryLayerNoop: Layer.Layer<Registry.Service> = Layer.succeed(Registry.Service, {
|
|
18
|
+
[Registry.TypeId]: Registry.TypeId,
|
|
19
|
+
id: 'noop-registry',
|
|
20
|
+
changed: new Event<void>(),
|
|
21
|
+
local: [],
|
|
22
|
+
add: () => {},
|
|
23
|
+
remove: () => false,
|
|
24
|
+
clear: () => {},
|
|
25
|
+
get: () => undefined,
|
|
26
|
+
getByURI: () => undefined,
|
|
27
|
+
list: () => [],
|
|
28
|
+
// QueryFn is an overloaded interface — a single generic function cannot satisfy both overload
|
|
29
|
+
// signatures without a cast. This is the intentional type-system boundary.
|
|
30
|
+
query: ((_queryOrFilter: unknown) => ({
|
|
31
|
+
results: [],
|
|
32
|
+
entries: [],
|
|
33
|
+
run: async () => [],
|
|
34
|
+
runEntries: async () => [],
|
|
35
|
+
runSync: () => [],
|
|
36
|
+
runSyncEntries: () => [],
|
|
37
|
+
first: async (): Promise<never> => {
|
|
38
|
+
throw new Error('registryLayerNoop: registry is empty');
|
|
39
|
+
},
|
|
40
|
+
firstOrUndefined: async () => undefined,
|
|
41
|
+
subscribe: () => () => {},
|
|
42
|
+
atom: Atom.make((): never[] => []),
|
|
43
|
+
})) as Registry.Registry['query'],
|
|
44
|
+
} satisfies Registry.Registry);
|
package/src/testing/test-data.ts
CHANGED
|
@@ -2,128 +2,188 @@
|
|
|
2
2
|
// Copyright 2025 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
|
-
import { DatabaseDirectory,
|
|
6
|
-
import {
|
|
5
|
+
import { DatabaseDirectory, EntityStructure } from '@dxos/echo-protocol';
|
|
6
|
+
import { EID, EntityId, PublicKey } from '@dxos/keys';
|
|
7
7
|
|
|
8
8
|
import { Type } from '../index';
|
|
9
9
|
import { TestSchema } from './test-schema';
|
|
10
10
|
|
|
11
|
-
|
|
11
|
+
// Lazy init: Cloudflare workers disallow non-determinism at module scope (e.g. random keys).
|
|
12
|
+
let cachedSpaceKeyHex: string | undefined;
|
|
13
|
+
const getSpaceKeyHex = (): string => {
|
|
14
|
+
if (cachedSpaceKeyHex === undefined) {
|
|
15
|
+
cachedSpaceKeyHex = PublicKey.random().toHex();
|
|
16
|
+
}
|
|
17
|
+
return cachedSpaceKeyHex;
|
|
18
|
+
};
|
|
19
|
+
|
|
20
|
+
let cachedPeopleAlice: DatabaseDirectory | undefined;
|
|
21
|
+
let cachedPeopleBob: DatabaseDirectory | undefined;
|
|
22
|
+
let cachedOrgsDxos: DatabaseDirectory | undefined;
|
|
23
|
+
let cachedOrgsCyberdyne: DatabaseDirectory | undefined;
|
|
24
|
+
let cachedWorksFredCyberdyne: DatabaseDirectory | undefined;
|
|
25
|
+
let cachedWorksAliceAperture: DatabaseDirectory | undefined;
|
|
26
|
+
let cachedTasksTask1: DatabaseDirectory | undefined;
|
|
27
|
+
let cachedTasksTask2: DatabaseDirectory | undefined;
|
|
12
28
|
|
|
13
29
|
// TODO(burdon): Use Obj.make.
|
|
14
30
|
|
|
15
31
|
export const PEOPLE = {
|
|
16
|
-
alice: DatabaseDirectory
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
32
|
+
get alice(): DatabaseDirectory {
|
|
33
|
+
if (cachedPeopleAlice === undefined) {
|
|
34
|
+
cachedPeopleAlice = DatabaseDirectory.make({
|
|
35
|
+
spaceKey: getSpaceKeyHex(),
|
|
36
|
+
objects: {
|
|
37
|
+
[EntityId.random()]: EntityStructure.makeObject({
|
|
38
|
+
type: Type.getURI(TestSchema.Person)!,
|
|
39
|
+
data: {
|
|
40
|
+
name: 'Alice',
|
|
41
|
+
},
|
|
42
|
+
}),
|
|
23
43
|
},
|
|
24
|
-
})
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
return cachedPeopleAlice;
|
|
47
|
+
},
|
|
48
|
+
|
|
49
|
+
get bob(): DatabaseDirectory {
|
|
50
|
+
if (cachedPeopleBob === undefined) {
|
|
51
|
+
cachedPeopleBob = DatabaseDirectory.make({
|
|
52
|
+
spaceKey: getSpaceKeyHex(),
|
|
53
|
+
objects: {
|
|
54
|
+
[EntityId.random()]: EntityStructure.makeObject({
|
|
55
|
+
type: Type.getURI(TestSchema.Person)!,
|
|
56
|
+
data: {
|
|
57
|
+
name: 'Bob',
|
|
58
|
+
},
|
|
59
|
+
}),
|
|
34
60
|
},
|
|
35
|
-
})
|
|
36
|
-
}
|
|
37
|
-
|
|
61
|
+
});
|
|
62
|
+
}
|
|
63
|
+
return cachedPeopleBob;
|
|
64
|
+
},
|
|
38
65
|
};
|
|
39
66
|
|
|
40
67
|
export const ORGS = {
|
|
41
|
-
dxos: DatabaseDirectory
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
68
|
+
get dxos(): DatabaseDirectory {
|
|
69
|
+
if (cachedOrgsDxos === undefined) {
|
|
70
|
+
cachedOrgsDxos = DatabaseDirectory.make({
|
|
71
|
+
spaceKey: getSpaceKeyHex(),
|
|
72
|
+
objects: {
|
|
73
|
+
[EntityId.random()]: EntityStructure.makeObject({
|
|
74
|
+
type: Type.getURI(TestSchema.Organization)!,
|
|
75
|
+
data: {
|
|
76
|
+
name: 'DXOS',
|
|
77
|
+
founded: '2023',
|
|
78
|
+
},
|
|
79
|
+
}),
|
|
49
80
|
},
|
|
50
|
-
})
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
81
|
+
});
|
|
82
|
+
}
|
|
83
|
+
return cachedOrgsDxos;
|
|
84
|
+
},
|
|
85
|
+
|
|
86
|
+
get cyberdyne(): DatabaseDirectory {
|
|
87
|
+
if (cachedOrgsCyberdyne === undefined) {
|
|
88
|
+
cachedOrgsCyberdyne = DatabaseDirectory.make({
|
|
89
|
+
spaceKey: getSpaceKeyHex(),
|
|
90
|
+
objects: {
|
|
91
|
+
[EntityId.random()]: EntityStructure.makeObject({
|
|
92
|
+
type: Type.getURI(TestSchema.Organization)!,
|
|
93
|
+
data: {
|
|
94
|
+
name: 'Cyberdyne Systems',
|
|
95
|
+
founded: '1984',
|
|
96
|
+
},
|
|
97
|
+
}),
|
|
61
98
|
},
|
|
62
|
-
})
|
|
63
|
-
}
|
|
64
|
-
|
|
99
|
+
});
|
|
100
|
+
}
|
|
101
|
+
return cachedOrgsCyberdyne;
|
|
102
|
+
},
|
|
65
103
|
};
|
|
66
104
|
|
|
67
105
|
export const WORKS_FOR = {
|
|
68
|
-
fredWorksForCyberdyne: DatabaseDirectory
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
106
|
+
get fredWorksForCyberdyne(): DatabaseDirectory {
|
|
107
|
+
if (cachedWorksFredCyberdyne === undefined) {
|
|
108
|
+
cachedWorksFredCyberdyne = DatabaseDirectory.make({
|
|
109
|
+
spaceKey: getSpaceKeyHex(),
|
|
110
|
+
objects: {
|
|
111
|
+
[EntityId.random()]: EntityStructure.makeRelation({
|
|
112
|
+
type: Type.getURI(TestSchema.EmployedBy)!,
|
|
113
|
+
source: { '/': EID.make({ entityId: Object.keys(PEOPLE.bob.objects!)[0] }) },
|
|
114
|
+
target: { '/': EID.make({ entityId: Object.keys(ORGS.cyberdyne.objects!)[0] }) },
|
|
115
|
+
data: {
|
|
116
|
+
since: '2020',
|
|
117
|
+
position: 'Engineer',
|
|
118
|
+
},
|
|
119
|
+
}),
|
|
78
120
|
},
|
|
79
|
-
})
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
121
|
+
});
|
|
122
|
+
}
|
|
123
|
+
return cachedWorksFredCyberdyne;
|
|
124
|
+
},
|
|
125
|
+
|
|
126
|
+
get aliceWorksForAperture(): DatabaseDirectory {
|
|
127
|
+
if (cachedWorksAliceAperture === undefined) {
|
|
128
|
+
cachedWorksAliceAperture = DatabaseDirectory.make({
|
|
129
|
+
spaceKey: getSpaceKeyHex(),
|
|
130
|
+
objects: {
|
|
131
|
+
[EntityId.random()]: EntityStructure.makeRelation({
|
|
132
|
+
type: Type.getURI(TestSchema.EmployedBy)!,
|
|
133
|
+
source: { '/': EID.make({ entityId: Object.keys(PEOPLE.alice.objects!)[0] }) },
|
|
134
|
+
target: { '/': EID.make({ entityId: Object.keys(ORGS.dxos.objects!)[0] }) },
|
|
135
|
+
data: {
|
|
136
|
+
since: '2018',
|
|
137
|
+
position: 'Research Scientist',
|
|
138
|
+
},
|
|
139
|
+
}),
|
|
92
140
|
},
|
|
93
|
-
})
|
|
94
|
-
}
|
|
95
|
-
|
|
141
|
+
});
|
|
142
|
+
}
|
|
143
|
+
return cachedWorksAliceAperture;
|
|
144
|
+
},
|
|
96
145
|
};
|
|
97
146
|
|
|
98
147
|
export const TASKS = {
|
|
99
|
-
task1: DatabaseDirectory
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
148
|
+
get task1(): DatabaseDirectory {
|
|
149
|
+
if (cachedTasksTask1 === undefined) {
|
|
150
|
+
cachedTasksTask1 = DatabaseDirectory.make({
|
|
151
|
+
spaceKey: getSpaceKeyHex(),
|
|
152
|
+
objects: {
|
|
153
|
+
[EntityId.random()]: EntityStructure.makeObject({
|
|
154
|
+
type: Type.getURI(TestSchema.Task)!,
|
|
155
|
+
data: {
|
|
156
|
+
title: 'Complete project documentation',
|
|
157
|
+
description: 'Write comprehensive documentation for the new system',
|
|
158
|
+
status: 'in-progress',
|
|
159
|
+
dueDate: '2023-12-31',
|
|
160
|
+
assignee: { '/': EID.make({ entityId: Object.keys(PEOPLE.bob.objects!)[0] }) },
|
|
161
|
+
},
|
|
162
|
+
}),
|
|
110
163
|
},
|
|
111
|
-
})
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
164
|
+
});
|
|
165
|
+
}
|
|
166
|
+
return cachedTasksTask1;
|
|
167
|
+
},
|
|
168
|
+
|
|
169
|
+
get task2(): DatabaseDirectory {
|
|
170
|
+
if (cachedTasksTask2 === undefined) {
|
|
171
|
+
cachedTasksTask2 = DatabaseDirectory.make({
|
|
172
|
+
spaceKey: getSpaceKeyHex(),
|
|
173
|
+
objects: {
|
|
174
|
+
[EntityId.random()]: EntityStructure.makeObject({
|
|
175
|
+
type: Type.getURI(TestSchema.Task)!,
|
|
176
|
+
data: {
|
|
177
|
+
title: 'Run experiments',
|
|
178
|
+
description: 'Conduct series of experiments on the portal device',
|
|
179
|
+
status: 'pending',
|
|
180
|
+
dueDate: '2023-11-15',
|
|
181
|
+
assignee: { '/': EID.make({ entityId: Object.keys(PEOPLE.alice.objects!)[0] }) },
|
|
182
|
+
},
|
|
183
|
+
}),
|
|
125
184
|
},
|
|
126
|
-
})
|
|
127
|
-
}
|
|
128
|
-
|
|
185
|
+
});
|
|
186
|
+
}
|
|
187
|
+
return cachedTasksTask2;
|
|
188
|
+
},
|
|
129
189
|
};
|
|
@@ -4,6 +4,8 @@
|
|
|
4
4
|
|
|
5
5
|
import * as Schema from 'effect/Schema';
|
|
6
6
|
|
|
7
|
+
import { DXN } from '@dxos/keys';
|
|
8
|
+
|
|
7
9
|
import * as Obj from '../Obj';
|
|
8
10
|
import * as Ref from '../Ref';
|
|
9
11
|
import * as Type from '../Type';
|
|
@@ -18,13 +20,10 @@ export namespace TestSchema {
|
|
|
18
20
|
* This is the test variant with example.com namespace.
|
|
19
21
|
*/
|
|
20
22
|
export const Expando = Schema.Struct({}, { key: Schema.String, value: Schema.Any }).pipe(
|
|
21
|
-
Type.
|
|
22
|
-
typename: 'com.example.type.expando',
|
|
23
|
-
version: '0.1.0',
|
|
24
|
-
}),
|
|
23
|
+
Type.makeObject(DXN.make('com.example.type.expando', '0.1.0')),
|
|
25
24
|
);
|
|
26
25
|
|
|
27
|
-
export
|
|
26
|
+
export type Expando = Type.InstanceType<typeof Expando>;
|
|
28
27
|
|
|
29
28
|
//
|
|
30
29
|
// Example
|
|
@@ -63,15 +62,10 @@ export namespace TestSchema {
|
|
|
63
62
|
export interface ExampleSchema extends Schema.Schema.Type<typeof ExampleSchema> {}
|
|
64
63
|
|
|
65
64
|
/** @deprecated Use another test schema or create a specific local test schema. */
|
|
66
|
-
export const Example = ExampleSchema.pipe(
|
|
67
|
-
Type.object({
|
|
68
|
-
typename: 'com.example.type.example',
|
|
69
|
-
version: '0.1.0',
|
|
70
|
-
}),
|
|
71
|
-
);
|
|
65
|
+
export const Example = ExampleSchema.pipe(Type.makeObject(DXN.make('com.example.type.example', '0.1.0')));
|
|
72
66
|
|
|
73
67
|
/** @deprecated Use another test schema or create a specific local test schema. */
|
|
74
|
-
export interface Example extends
|
|
68
|
+
export interface Example extends Type.InstanceType<typeof Example> {}
|
|
75
69
|
|
|
76
70
|
//
|
|
77
71
|
// Message
|
|
@@ -87,14 +81,9 @@ export namespace TestSchema {
|
|
|
87
81
|
),
|
|
88
82
|
});
|
|
89
83
|
|
|
90
|
-
export const Message = MessageStruct.pipe(
|
|
91
|
-
Type.object({
|
|
92
|
-
typename: 'com.example.type.message',
|
|
93
|
-
version: '0.1.0',
|
|
94
|
-
}),
|
|
95
|
-
);
|
|
84
|
+
export const Message = MessageStruct.pipe(Type.makeObject(DXN.make('com.example.type.message', '0.1.0')));
|
|
96
85
|
|
|
97
|
-
export
|
|
86
|
+
export type Message = Type.InstanceType<typeof Message>;
|
|
98
87
|
|
|
99
88
|
//
|
|
100
89
|
// Organization
|
|
@@ -108,14 +97,9 @@ export namespace TestSchema {
|
|
|
108
97
|
value: Schema.String,
|
|
109
98
|
}),
|
|
110
99
|
),
|
|
111
|
-
}).pipe(
|
|
112
|
-
Type.object({
|
|
113
|
-
typename: 'com.example.type.organization',
|
|
114
|
-
version: '0.1.0',
|
|
115
|
-
}),
|
|
116
|
-
);
|
|
100
|
+
}).pipe(Type.makeObject(DXN.make('com.example.type.organization', '0.1.0')));
|
|
117
101
|
|
|
118
|
-
export
|
|
102
|
+
export type Organization = Type.InstanceType<typeof Organization>;
|
|
119
103
|
|
|
120
104
|
//
|
|
121
105
|
// Person
|
|
@@ -141,15 +125,9 @@ export namespace TestSchema {
|
|
|
141
125
|
label: Schema.String,
|
|
142
126
|
value: Schema.String,
|
|
143
127
|
}).pipe(Schema.Array, Schema.optional),
|
|
144
|
-
}).pipe(
|
|
145
|
-
Schema.partial,
|
|
146
|
-
Type.object({
|
|
147
|
-
typename: 'com.example.type.person',
|
|
148
|
-
version: '0.1.0',
|
|
149
|
-
}),
|
|
150
|
-
);
|
|
128
|
+
}).pipe(Schema.partial, Type.makeObject(DXN.make('com.example.type.person', '0.1.0')));
|
|
151
129
|
|
|
152
|
-
export interface Person extends
|
|
130
|
+
export interface Person extends Type.InstanceType<typeof Person> {}
|
|
153
131
|
|
|
154
132
|
//
|
|
155
133
|
// Task
|
|
@@ -163,30 +141,23 @@ export namespace TestSchema {
|
|
|
163
141
|
previous: Schema.optional(Schema.suspend((): Ref.RefSchema<Task> => Ref.Ref(Task))),
|
|
164
142
|
subTasks: Schema.optional(Schema.Array(Schema.suspend((): Ref.RefSchema<Task> => Ref.Ref(Task)))),
|
|
165
143
|
description: Schema.optional(Schema.String),
|
|
166
|
-
}).pipe(
|
|
167
|
-
Schema.partial,
|
|
168
|
-
Type.object({
|
|
169
|
-
typename: 'com.example.type.task',
|
|
170
|
-
version: '0.1.0',
|
|
171
|
-
}),
|
|
172
|
-
);
|
|
144
|
+
}).pipe(Schema.partial, Type.makeObject(DXN.make('com.example.type.task', '0.1.0')));
|
|
173
145
|
|
|
174
|
-
export interface Task extends
|
|
146
|
+
export interface Task extends Type.InstanceType<typeof Task> {}
|
|
175
147
|
|
|
176
148
|
//
|
|
177
149
|
// HasManager
|
|
178
150
|
//
|
|
179
151
|
|
|
180
152
|
export const HasManager = Schema.Struct({}).pipe(
|
|
181
|
-
Type.
|
|
182
|
-
|
|
183
|
-
version: '0.1.0',
|
|
153
|
+
Type.makeRelation({
|
|
154
|
+
dxn: DXN.make('com.example.type.hasManager', '0.1.0'),
|
|
184
155
|
source: Person,
|
|
185
156
|
target: Person,
|
|
186
157
|
}),
|
|
187
158
|
);
|
|
188
159
|
|
|
189
|
-
export
|
|
160
|
+
export type HasManager = Type.InstanceType<typeof HasManager>;
|
|
190
161
|
|
|
191
162
|
//
|
|
192
163
|
// EmployedBy
|
|
@@ -196,15 +167,14 @@ export namespace TestSchema {
|
|
|
196
167
|
role: Schema.String,
|
|
197
168
|
since: Schema.optional(Schema.String),
|
|
198
169
|
}).pipe(
|
|
199
|
-
Type.
|
|
200
|
-
|
|
201
|
-
version: '0.1.0',
|
|
170
|
+
Type.makeRelation({
|
|
171
|
+
dxn: DXN.make('com.example.type.employedBy', '0.1.0'),
|
|
202
172
|
source: Person,
|
|
203
173
|
target: Organization,
|
|
204
174
|
}),
|
|
205
175
|
);
|
|
206
176
|
|
|
207
|
-
export
|
|
177
|
+
export type EmployedBy = Type.InstanceType<typeof EmployedBy>;
|
|
208
178
|
|
|
209
179
|
//
|
|
210
180
|
// RecordType
|
|
@@ -228,13 +198,7 @@ export namespace TestSchema {
|
|
|
228
198
|
}),
|
|
229
199
|
),
|
|
230
200
|
),
|
|
231
|
-
}).pipe(
|
|
232
|
-
Schema.partial,
|
|
233
|
-
Type.object({
|
|
234
|
-
typename: 'com.example.type.container',
|
|
235
|
-
version: '0.1.0',
|
|
236
|
-
}),
|
|
237
|
-
);
|
|
201
|
+
}).pipe(Schema.partial, Type.makeObject(DXN.make('com.example.type.container', '0.1.0')));
|
|
238
202
|
|
|
239
|
-
export
|
|
203
|
+
export type Container = Type.InstanceType<typeof Container>;
|
|
240
204
|
}
|
package/src/testing/util.ts
CHANGED
|
@@ -8,24 +8,27 @@ import type * as SchemaAST from 'effect/SchemaAST';
|
|
|
8
8
|
import { assertArgument } from '@dxos/invariant';
|
|
9
9
|
import { deepMapValues } from '@dxos/util';
|
|
10
10
|
|
|
11
|
-
import {
|
|
11
|
+
import { TypeSchema, getSchemaTypename, getStaticTypeSchema, makeObject, subscribe, toJsonSchema } from '../internal';
|
|
12
|
+
import type * as Type from '../Type';
|
|
12
13
|
|
|
13
14
|
/**
|
|
14
|
-
* Create
|
|
15
|
+
* Create an in-memory `Type.Type` entity (a `TypeSchema` object) for tests.
|
|
16
|
+
* Accepts a raw Effect Schema. Pass `Type.getSchema(entity)` to convert a
|
|
17
|
+
* `Type.Type` entity to its underlying source schema first.
|
|
15
18
|
*/
|
|
16
19
|
// TODO(dmaretskyi): Should be replaced by registration of typed object.
|
|
17
|
-
export const createEchoSchema = (schema: Schema.Schema.AnyNoContext, version = '0.1.0'):
|
|
20
|
+
export const createEchoSchema = (schema: Schema.Schema.AnyNoContext, version = '0.1.0'): Type.Type => {
|
|
18
21
|
const jsonSchema = toJsonSchema(schema);
|
|
19
22
|
const typename = getSchemaTypename(schema);
|
|
20
23
|
assertArgument(typename, 'typename', 'Schema does not have a typename.');
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
24
|
+
// typename/version are routed via EntityMeta (the canonical registry-provenance
|
|
25
|
+
// pair); they're no longer data fields on `TypeSchema`.
|
|
26
|
+
return makeObject(
|
|
27
|
+
getStaticTypeSchema(TypeSchema) as any,
|
|
28
|
+
{ jsonSchema },
|
|
29
|
+
{ keys: [], key: typename, version },
|
|
30
|
+
TypeSchema,
|
|
31
|
+
) as unknown as Type.Type;
|
|
29
32
|
};
|
|
30
33
|
|
|
31
34
|
/**
|