chore: Wrapper Data Contract

This commit is contained in:
BluJ
2023-05-08 11:49:56 -06:00
parent bb59b96e64
commit aded4f6b3d
18 changed files with 265 additions and 187 deletions

View File

@@ -1,11 +1,13 @@
import { Effects } from "../types"
import { utils } from "../util"
import { createMainUtils, utils } from "../util"
import { createWrapperDataContract } from "../wrapperData/wrapperDataContract"
type WrapperType = {
config: {
someValue: "a" | "b"
}
}
const wrapperDataContract = createWrapperDataContract<WrapperType>()
const todo = <A>(): A => {
throw new Error("not implemented")
}
@@ -13,23 +15,23 @@ const noop = () => {}
describe("wrapperData", () => {
test("types", async () => {
;async () => {
utils<WrapperType>(todo<Effects>()).setOwnWrapperData("/config", {
utils(wrapperDataContract, todo<Effects>()).setOwnWrapperData("/config", {
someValue: "a",
})
utils<WrapperType>(todo<Effects>()).setOwnWrapperData(
utils(wrapperDataContract, todo<Effects>()).setOwnWrapperData(
"/config/someValue",
"b",
)
utils<WrapperType>(todo<Effects>()).setOwnWrapperData("", {
utils(wrapperDataContract, todo<Effects>()).setOwnWrapperData("", {
config: { someValue: "b" },
})
utils<WrapperType>(todo<Effects>()).setOwnWrapperData(
utils(wrapperDataContract, todo<Effects>()).setOwnWrapperData(
"/config/someValue",
// @ts-expect-error Type is wrong for the setting value
5,
)
utils<WrapperType>(todo<Effects>()).setOwnWrapperData(
utils(wrapperDataContract, todo<Effects>()).setOwnWrapperData(
// @ts-expect-error Path is wrong
"/config/someVae3lue",
"someValue",
@@ -50,47 +52,47 @@ describe("wrapperData", () => {
path: "/config/some2Value",
value: "a",
})
;(await utils<WrapperType, {}>(todo<Effects>())
;(await createMainUtils(wrapperDataContract, todo<Effects>())
.getOwnWrapperData("/config/someValue")
.const()) satisfies string
;(await utils<WrapperType, {}>(todo<Effects>())
;(await createMainUtils(wrapperDataContract, todo<Effects>())
.getOwnWrapperData("/config")
.const()) satisfies WrapperType["config"]
await utils<WrapperType, {}>(todo<Effects>())
await createMainUtils(wrapperDataContract, todo<Effects>())
// @ts-expect-error Path is wrong
.getOwnWrapperData("/config/somdsfeValue")
.const()
/// ----------------- ERRORS -----------------
utils<WrapperType>(todo<Effects>()).setOwnWrapperData("", {
utils(wrapperDataContract, todo<Effects>()).setOwnWrapperData("", {
// @ts-expect-error Type is wrong for the setting value
config: { someValue: "notInAOrB" },
})
utils<WrapperType>(todo<Effects>()).setOwnWrapperData(
utils(wrapperDataContract, todo<Effects>()).setOwnWrapperData(
"/config/someValue",
// @ts-expect-error Type is wrong for the setting value
"notInAOrB",
)
;(await utils<WrapperType>(todo<Effects>())
;(await utils(wrapperDataContract, todo<Effects>())
.getOwnWrapperData("/config/someValue")
// @ts-expect-error Const should normally not be callable
.const()) satisfies string
;(await utils<WrapperType>(todo<Effects>())
;(await utils(wrapperDataContract, todo<Effects>())
.getOwnWrapperData("/config")
// @ts-expect-error Const should normally not be callable
.const()) satisfies WrapperType["config"]
await utils<WrapperType>(todo<Effects>())
await utils(wrapperDataContract, todo<Effects>())
// @ts-expect-error Path is wrong
.getOwnWrapperData("/config/somdsfeValue")
// @ts-expect-error Const should normally not be callable
.const()
///
;(await utils<WrapperType>(todo<Effects>())
;(await utils(wrapperDataContract, todo<Effects>())
.getOwnWrapperData("/config/someValue")
// @ts-expect-error satisfies type is wrong
.const()) satisfies number
;(await utils<WrapperType, {}>(todo<Effects>())
;(await createMainUtils(wrapperDataContract, todo<Effects>())
// @ts-expect-error Path is wrong
.getOwnWrapperData("/config/")
.const()) satisfies WrapperType["config"]