From 7ef36744019ef28df85e44b48593e374b862189b Mon Sep 17 00:00:00 2001 From: Enderson Maia Date: Mon, 14 Oct 2024 17:00:30 -0300 Subject: [PATCH 1/4] fixup! feat(cli): build based on configuration implement typed errors for config module --- apps/cli/src/config.ts | 96 ++++++++++++++++++++++++++++++------ apps/cli/test/config.test.ts | 91 +++++++++++++++++++++++++++++----- 2 files changed, 161 insertions(+), 26 deletions(-) diff --git a/apps/cli/src/config.ts b/apps/cli/src/config.ts index 9f58420c..86c5d4f7 100644 --- a/apps/cli/src/config.ts +++ b/apps/cli/src/config.ts @@ -3,6 +3,72 @@ import os from "os"; import { extname } from "path"; import { TomlPrimitive, parse as parseToml } from "smol-toml"; +/** + * Typed Errors + */ +export class InvalidBuilderError extends Error { + constructor(builder: any) { + super(`Invalid builder: ${builder}`); + this.name = "InvalidBuilder"; + } +} + +export class InvalidDriveFormatError extends Error { + constructor(format: any) { + super(`Invalid drive format: ${format}`); + this.name = "InvalidDriveFormatError"; + } +} + +export class InvalidEmptyDriveFormatError extends Error { + constructor(format: any) { + super(`Invalid empty drive format: ${format}`); + this.name = "InvalidEmptyDriveFormatError"; + } +} + +export class InvalidStringValueError extends Error { + constructor(value: any) { + super(`Invalid string value: ${value}`); + this.name = "InvalidStringValueError"; + } +} + +export class InvalidBooleanValueError extends Error { + constructor(value: any) { + super(`Invalid boolean value: ${value}`); + this.name = "InvalidBooleanValueError"; + } +} + +export class InvalidNumberValueError extends Error { + constructor(value: any) { + super(`Invalid number value: ${value}`); + this.name = "InvalidNumberValueError"; + } +} + +export class InvalidBytesValueError extends Error { + constructor(value: any) { + super(`Invalid bytes value: ${value}`); + this.name = "InvalidBytesValueError"; + } +} + +export class RequiredFieldError extends Error { + constructor(key: string) { + super(`Missing required field: ${key}`); + this.name = "RequiredFieldError"; + } +} + +export class InvalidStringArrayError extends Error { + constructor() { + super(`Invalid string array`); + this.name = "InvalidStringArrayError"; + } +} + /** * Configuration for drives of a Cartesi Machine. A drive may already exist or be built by a builder */ @@ -141,7 +207,7 @@ const parseBoolean = (value: TomlPrimitive, defaultValue: boolean): boolean => { } else if (typeof value === "boolean") { return value; } - throw new Error(`Invalid boolean value: ${value}`); + throw new InvalidBooleanValueError(value); }; const parseOptionalBoolean = (value: TomlPrimitive): boolean | undefined => { @@ -150,7 +216,7 @@ const parseOptionalBoolean = (value: TomlPrimitive): boolean | undefined => { } else if (typeof value === "boolean") { return value; } - throw new Error(`Invalid boolean value: ${value}`); + throw new InvalidBooleanValueError(value); }; const parseString = (value: TomlPrimitive, defaultValue: string): string => { @@ -159,7 +225,7 @@ const parseString = (value: TomlPrimitive, defaultValue: string): string => { } else if (typeof value === "string") { return value; } - throw new Error(`Invalid string value: ${value}`); + throw new InvalidStringValueError(value); }; const parseStringArray = (value: TomlPrimitive): string[] => { @@ -172,19 +238,19 @@ const parseStringArray = (value: TomlPrimitive): string[] => { if (typeof v === "string") { return v; } - throw new Error(`Invalid string value: ${v}`); + throw new InvalidStringValueError(v); }); } - throw new Error(`Invalid string array value: ${value}`); + throw new InvalidStringArrayError(); }; const parseRequiredString = (value: TomlPrimitive, key: string): string => { if (value === undefined) { - throw new Error(`Missing required value: ${key}`); + throw new RequiredFieldError(key); } else if (typeof value === "string") { return value; } - throw new Error(`Invalid string value: ${value}`); + throw new InvalidStringValueError(value); }; const parseOptionalString = (value: TomlPrimitive): string | undefined => { @@ -193,7 +259,7 @@ const parseOptionalString = (value: TomlPrimitive): string | undefined => { } else if (typeof value === "string") { return value; } - throw new Error(`Invalid string value: ${value}`); + throw new InvalidStringValueError(value); }; const parseOptionalStringBoolean = ( @@ -206,7 +272,7 @@ const parseOptionalStringBoolean = ( } else if (typeof value === "boolean") { return value; } - throw new Error(`Invalid string value: ${value}`); + throw new InvalidStringValueError(value); }; const parseOptionalNumber = (value: TomlPrimitive): bigint | undefined => { @@ -217,7 +283,7 @@ const parseOptionalNumber = (value: TomlPrimitive): bigint | undefined => { } else if (typeof value === "number") { return BigInt(value); } - throw new Error(`Invalid number value: ${value}`); + throw new InvalidNumberValueError(value); }; const parseBytes = (value: TomlPrimitive, defaultValue: number): number => { @@ -228,7 +294,7 @@ const parseBytes = (value: TomlPrimitive, defaultValue: number): number => { } else if (typeof value === "number" || typeof value === "string") { return bytes.parse(value); } - throw new Error(`Invalid bytes value: ${value}`); + throw new InvalidBytesValueError(value); }; const parseBuilder = (value: TomlPrimitive): Builder => { @@ -248,7 +314,7 @@ const parseBuilder = (value: TomlPrimitive): Builder => { return "tar"; } } - throw new Error(`Invalid builder: ${value}`); + throw new InvalidBuilderError(value as string); }; const parseFormat = (value: TomlPrimitive): DriveFormat => { @@ -262,7 +328,7 @@ const parseFormat = (value: TomlPrimitive): DriveFormat => { return "sqfs"; } } - throw new Error(`Invalid format: ${value}`); + throw new InvalidDriveFormatError(value as string); }; const parseEmptyFormat = (value: TomlPrimitive): "ext2" | "raw" => { @@ -276,7 +342,7 @@ const parseEmptyFormat = (value: TomlPrimitive): "ext2" | "raw" => { return "raw"; } } - throw new Error(`Invalid format: ${value}`); + throw new InvalidEmptyDriveFormatError(value as string); }; const parseMachine = (value: TomlPrimitive): MachineConfig => { @@ -313,7 +379,7 @@ export const getDriveFormat = (filename: string): DriveFormat => { case ".sqfs": return "sqfs"; default: - throw new Error(`Invalid drive format: ${extension}`); + throw new InvalidDriveFormatError(extension); } }; diff --git a/apps/cli/test/config.test.ts b/apps/cli/test/config.test.ts index 6d4fbcd5..7ddb0a79 100644 --- a/apps/cli/test/config.test.ts +++ b/apps/cli/test/config.test.ts @@ -1,5 +1,15 @@ import { describe, expect, it } from "vitest"; -import { defaultConfig, defaultMachineConfig, parse } from "../src/config.js"; +import { + defaultConfig, + defaultMachineConfig, + InvalidBooleanValueError, + InvalidBuilderError, + InvalidDriveFormatError, + InvalidEmptyDriveFormatError, + InvalidStringValueError, + parse, + RequiredFieldError, +} from "../src/config.js"; describe("config", () => { it("default config", () => { @@ -41,47 +51,106 @@ shared = true`); it("invalid drive: invalid builder", () => { expect(() => parse('[drives.root]\nbuilder = "invalid"')).toThrowError( - "Invalid builder: invalid", + new InvalidBuilderError("invalid"), ); expect(() => parse("[drives.root]\nbuilder = true")).toThrowError( - "Invalid builder: true", + new InvalidBuilderError(true), ); expect(() => parse("[drives.root]\nbuilder = 10")).toThrowError( - "Invalid builder: 10", + new InvalidBuilderError(10), ); expect(() => parse("[drives.root]\nbuilder = {}")).toThrowError( - "Invalid builder: [object Object]", + new InvalidBuilderError({}), ); }); it("invalid drive: invalid format", () => { expect(() => parse('[drives.root]\nformat = "invalid"')).toThrowError( - "Invalid format: invalid", + new InvalidDriveFormatError("invalid"), ); expect(() => parse("[drives.root]\nformat = true")).toThrowError( - "Invalid format: true", + new InvalidDriveFormatError(true), ); expect(() => parse("[drives.root]\nformat = 10")).toThrowError( - "Invalid format: 10", + new InvalidDriveFormatError(10), ); expect(() => parse("[drives.root]\nformat = {}")).toThrowError( - "Invalid format: [object Object]", + new InvalidDriveFormatError({}), + ); + }); + + it("invalid drive: invalid extension", () => { + const builderNone = ` + [drives.none] + builder = "none" + filename = "./games/doom.xyzfs" + mount = "/usr/local/games/doom" + `; + expect(() => parse(builderNone)).toThrowError( + new InvalidDriveFormatError(".xyzfs"), ); }); it("invalid drive: invalid mount", () => { expect(() => parse("[drives.data]\nmount = 42")).toThrowError( - "Invalid string value: 42", + new InvalidStringValueError(42), + ); + }); + + it("invalid empty drive: invalid fomat", () => { + expect(() => + parse("[drives.data]\nbuilder = 'empty'\nformat = 42"), + ).toThrowError(new InvalidEmptyDriveFormatError(42)); + }); + + it("invalid boolean value", () => { + expect(() => parse("[machine]\nno-rollup = 42")).toThrowError( + new InvalidBooleanValueError(42), + ); + }); + + it("invalid string value", () => { + const invalidTarDrive = ` + [drives.data] + builder = "tar" + filename = 42 # invalid + format = "ext2" + `; + expect(() => parse(invalidTarDrive)).toThrowError( + new InvalidStringValueError(42), + ); + }); + + it("required field", () => { + const invalidDirectoryDrive = ` + [drives.data] + builder = "directory" + # directory = '' # required + `; + expect(() => parse(invalidDirectoryDrive)).toThrowError( + new RequiredFieldError("directory"), //XXX: how to know which field was required ); }); it("machine-config", () => { - expect(parse("[machine]\nno-rollup = true")).toEqual({ + const config = ` + [machine] + no-rollup = true + `; + expect(parse(config)).toEqual({ ...defaultConfig(), machine: { ...defaultMachineConfig(), noRollup: true, }, }); + + const invalidConfig = ` + ${config} + bootargs = ["no4lvl", "quiet", false] + `; + expect(() => parse(invalidConfig)).toThrowError( + new InvalidStringValueError(false), + ); }); }); From fd365907b234a59eee06db0963458f1f1288b20e Mon Sep 17 00:00:00 2001 From: Enderson Maia Date: Mon, 14 Oct 2024 17:11:15 -0300 Subject: [PATCH 2/4] ci(cli): enable vitest --- .github/workflows/cli.yaml | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/.github/workflows/cli.yaml b/.github/workflows/cli.yaml index b0189809..651a67d9 100644 --- a/.github/workflows/cli.yaml +++ b/.github/workflows/cli.yaml @@ -47,6 +47,10 @@ jobs: - name: Install dependencies run: pnpm install + - name: Test + working-directory: ./apps/cli + run: pnpm test run + - name: Build run: pnpm build --filter @cartesi/cli From 30516fe9ed30afd57265efbff32e5be69385ad4d Mon Sep 17 00:00:00 2001 From: Enderson Maia Date: Tue, 15 Oct 2024 08:41:05 -0300 Subject: [PATCH 3/4] fixup! feat(cli): build based on configuration use string instead of any --- apps/cli/src/config.ts | 32 ++++++++++++++++---------------- apps/cli/test/config.test.ts | 24 +++++++++++++----------- 2 files changed, 29 insertions(+), 27 deletions(-) diff --git a/apps/cli/src/config.ts b/apps/cli/src/config.ts index 86c5d4f7..41dd4dff 100644 --- a/apps/cli/src/config.ts +++ b/apps/cli/src/config.ts @@ -7,49 +7,49 @@ import { TomlPrimitive, parse as parseToml } from "smol-toml"; * Typed Errors */ export class InvalidBuilderError extends Error { - constructor(builder: any) { + constructor(builder: string) { super(`Invalid builder: ${builder}`); this.name = "InvalidBuilder"; } } export class InvalidDriveFormatError extends Error { - constructor(format: any) { + constructor(format: string) { super(`Invalid drive format: ${format}`); this.name = "InvalidDriveFormatError"; } } export class InvalidEmptyDriveFormatError extends Error { - constructor(format: any) { + constructor(format: string) { super(`Invalid empty drive format: ${format}`); this.name = "InvalidEmptyDriveFormatError"; } } export class InvalidStringValueError extends Error { - constructor(value: any) { + constructor(value: string) { super(`Invalid string value: ${value}`); this.name = "InvalidStringValueError"; } } export class InvalidBooleanValueError extends Error { - constructor(value: any) { + constructor(value: string) { super(`Invalid boolean value: ${value}`); this.name = "InvalidBooleanValueError"; } } export class InvalidNumberValueError extends Error { - constructor(value: any) { + constructor(value: string) { super(`Invalid number value: ${value}`); this.name = "InvalidNumberValueError"; } } export class InvalidBytesValueError extends Error { - constructor(value: any) { + constructor(value: string) { super(`Invalid bytes value: ${value}`); this.name = "InvalidBytesValueError"; } @@ -207,7 +207,7 @@ const parseBoolean = (value: TomlPrimitive, defaultValue: boolean): boolean => { } else if (typeof value === "boolean") { return value; } - throw new InvalidBooleanValueError(value); + throw new InvalidBooleanValueError(value as string); }; const parseOptionalBoolean = (value: TomlPrimitive): boolean | undefined => { @@ -216,7 +216,7 @@ const parseOptionalBoolean = (value: TomlPrimitive): boolean | undefined => { } else if (typeof value === "boolean") { return value; } - throw new InvalidBooleanValueError(value); + throw new InvalidBooleanValueError(value as string); }; const parseString = (value: TomlPrimitive, defaultValue: string): string => { @@ -225,7 +225,7 @@ const parseString = (value: TomlPrimitive, defaultValue: string): string => { } else if (typeof value === "string") { return value; } - throw new InvalidStringValueError(value); + throw new InvalidStringValueError(value as unknown as string); }; const parseStringArray = (value: TomlPrimitive): string[] => { @@ -238,7 +238,7 @@ const parseStringArray = (value: TomlPrimitive): string[] => { if (typeof v === "string") { return v; } - throw new InvalidStringValueError(v); + throw new InvalidStringValueError(v as unknown as string); }); } throw new InvalidStringArrayError(); @@ -250,7 +250,7 @@ const parseRequiredString = (value: TomlPrimitive, key: string): string => { } else if (typeof value === "string") { return value; } - throw new InvalidStringValueError(value); + throw new InvalidStringValueError(value as unknown as string); }; const parseOptionalString = (value: TomlPrimitive): string | undefined => { @@ -259,7 +259,7 @@ const parseOptionalString = (value: TomlPrimitive): string | undefined => { } else if (typeof value === "string") { return value; } - throw new InvalidStringValueError(value); + throw new InvalidStringValueError(value as unknown as string); }; const parseOptionalStringBoolean = ( @@ -272,7 +272,7 @@ const parseOptionalStringBoolean = ( } else if (typeof value === "boolean") { return value; } - throw new InvalidStringValueError(value); + throw new InvalidStringValueError(value as unknown as string); }; const parseOptionalNumber = (value: TomlPrimitive): bigint | undefined => { @@ -283,7 +283,7 @@ const parseOptionalNumber = (value: TomlPrimitive): bigint | undefined => { } else if (typeof value === "number") { return BigInt(value); } - throw new InvalidNumberValueError(value); + throw new InvalidNumberValueError(value as string); }; const parseBytes = (value: TomlPrimitive, defaultValue: number): number => { @@ -294,7 +294,7 @@ const parseBytes = (value: TomlPrimitive, defaultValue: number): number => { } else if (typeof value === "number" || typeof value === "string") { return bytes.parse(value); } - throw new InvalidBytesValueError(value); + throw new InvalidBytesValueError(value as unknown as string); }; const parseBuilder = (value: TomlPrimitive): Builder => { diff --git a/apps/cli/test/config.test.ts b/apps/cli/test/config.test.ts index 7ddb0a79..0af0836d 100644 --- a/apps/cli/test/config.test.ts +++ b/apps/cli/test/config.test.ts @@ -54,13 +54,13 @@ shared = true`); new InvalidBuilderError("invalid"), ); expect(() => parse("[drives.root]\nbuilder = true")).toThrowError( - new InvalidBuilderError(true), + new InvalidBuilderError(true as unknown as string), ); expect(() => parse("[drives.root]\nbuilder = 10")).toThrowError( - new InvalidBuilderError(10), + new InvalidBuilderError(10 as unknown as string), ); expect(() => parse("[drives.root]\nbuilder = {}")).toThrowError( - new InvalidBuilderError({}), + new InvalidBuilderError({} as unknown as string), ); }); @@ -69,13 +69,13 @@ shared = true`); new InvalidDriveFormatError("invalid"), ); expect(() => parse("[drives.root]\nformat = true")).toThrowError( - new InvalidDriveFormatError(true), + new InvalidDriveFormatError(true as unknown as string), ); expect(() => parse("[drives.root]\nformat = 10")).toThrowError( - new InvalidDriveFormatError(10), + new InvalidDriveFormatError(10 as unknown as string), ); expect(() => parse("[drives.root]\nformat = {}")).toThrowError( - new InvalidDriveFormatError({}), + new InvalidDriveFormatError({} as unknown as string), ); }); @@ -93,19 +93,21 @@ shared = true`); it("invalid drive: invalid mount", () => { expect(() => parse("[drives.data]\nmount = 42")).toThrowError( - new InvalidStringValueError(42), + new InvalidStringValueError(42 as unknown as string), ); }); it("invalid empty drive: invalid fomat", () => { expect(() => parse("[drives.data]\nbuilder = 'empty'\nformat = 42"), - ).toThrowError(new InvalidEmptyDriveFormatError(42)); + ).toThrowError( + new InvalidEmptyDriveFormatError(42 as unknown as string), + ); }); it("invalid boolean value", () => { expect(() => parse("[machine]\nno-rollup = 42")).toThrowError( - new InvalidBooleanValueError(42), + new InvalidBooleanValueError(42 as unknown as string), ); }); @@ -117,7 +119,7 @@ shared = true`); format = "ext2" `; expect(() => parse(invalidTarDrive)).toThrowError( - new InvalidStringValueError(42), + new InvalidStringValueError(42 as unknown as string), ); }); @@ -150,7 +152,7 @@ shared = true`); bootargs = ["no4lvl", "quiet", false] `; expect(() => parse(invalidConfig)).toThrowError( - new InvalidStringValueError(false), + new InvalidStringValueError(false as unknown as string), ); }); }); From cf7a6ddfb3d6398c86ca7a477d0d22ed941199c0 Mon Sep 17 00:00:00 2001 From: Danilo Tuler Date: Tue, 15 Oct 2024 09:15:56 -0400 Subject: [PATCH 4/4] fixup! feat(cli): build based on configuration fix typing --- apps/cli/src/config.ts | 40 ++++++++++++++++++------------------ apps/cli/test/config.test.ts | 24 ++++++++++------------ 2 files changed, 31 insertions(+), 33 deletions(-) diff --git a/apps/cli/src/config.ts b/apps/cli/src/config.ts index 41dd4dff..ba1c2622 100644 --- a/apps/cli/src/config.ts +++ b/apps/cli/src/config.ts @@ -7,56 +7,56 @@ import { TomlPrimitive, parse as parseToml } from "smol-toml"; * Typed Errors */ export class InvalidBuilderError extends Error { - constructor(builder: string) { + constructor(builder: TomlPrimitive) { super(`Invalid builder: ${builder}`); this.name = "InvalidBuilder"; } } export class InvalidDriveFormatError extends Error { - constructor(format: string) { + constructor(format: TomlPrimitive) { super(`Invalid drive format: ${format}`); this.name = "InvalidDriveFormatError"; } } export class InvalidEmptyDriveFormatError extends Error { - constructor(format: string) { + constructor(format: TomlPrimitive) { super(`Invalid empty drive format: ${format}`); this.name = "InvalidEmptyDriveFormatError"; } } export class InvalidStringValueError extends Error { - constructor(value: string) { + constructor(value: TomlPrimitive) { super(`Invalid string value: ${value}`); this.name = "InvalidStringValueError"; } } export class InvalidBooleanValueError extends Error { - constructor(value: string) { + constructor(value: TomlPrimitive) { super(`Invalid boolean value: ${value}`); this.name = "InvalidBooleanValueError"; } } export class InvalidNumberValueError extends Error { - constructor(value: string) { + constructor(value: TomlPrimitive) { super(`Invalid number value: ${value}`); this.name = "InvalidNumberValueError"; } } export class InvalidBytesValueError extends Error { - constructor(value: string) { + constructor(value: TomlPrimitive) { super(`Invalid bytes value: ${value}`); this.name = "InvalidBytesValueError"; } } export class RequiredFieldError extends Error { - constructor(key: string) { + constructor(key: TomlPrimitive) { super(`Missing required field: ${key}`); this.name = "RequiredFieldError"; } @@ -207,7 +207,7 @@ const parseBoolean = (value: TomlPrimitive, defaultValue: boolean): boolean => { } else if (typeof value === "boolean") { return value; } - throw new InvalidBooleanValueError(value as string); + throw new InvalidBooleanValueError(value); }; const parseOptionalBoolean = (value: TomlPrimitive): boolean | undefined => { @@ -216,7 +216,7 @@ const parseOptionalBoolean = (value: TomlPrimitive): boolean | undefined => { } else if (typeof value === "boolean") { return value; } - throw new InvalidBooleanValueError(value as string); + throw new InvalidBooleanValueError(value); }; const parseString = (value: TomlPrimitive, defaultValue: string): string => { @@ -225,7 +225,7 @@ const parseString = (value: TomlPrimitive, defaultValue: string): string => { } else if (typeof value === "string") { return value; } - throw new InvalidStringValueError(value as unknown as string); + throw new InvalidStringValueError(value); }; const parseStringArray = (value: TomlPrimitive): string[] => { @@ -238,7 +238,7 @@ const parseStringArray = (value: TomlPrimitive): string[] => { if (typeof v === "string") { return v; } - throw new InvalidStringValueError(v as unknown as string); + throw new InvalidStringValueError(v); }); } throw new InvalidStringArrayError(); @@ -250,7 +250,7 @@ const parseRequiredString = (value: TomlPrimitive, key: string): string => { } else if (typeof value === "string") { return value; } - throw new InvalidStringValueError(value as unknown as string); + throw new InvalidStringValueError(value); }; const parseOptionalString = (value: TomlPrimitive): string | undefined => { @@ -259,7 +259,7 @@ const parseOptionalString = (value: TomlPrimitive): string | undefined => { } else if (typeof value === "string") { return value; } - throw new InvalidStringValueError(value as unknown as string); + throw new InvalidStringValueError(value); }; const parseOptionalStringBoolean = ( @@ -272,7 +272,7 @@ const parseOptionalStringBoolean = ( } else if (typeof value === "boolean") { return value; } - throw new InvalidStringValueError(value as unknown as string); + throw new InvalidStringValueError(value); }; const parseOptionalNumber = (value: TomlPrimitive): bigint | undefined => { @@ -283,7 +283,7 @@ const parseOptionalNumber = (value: TomlPrimitive): bigint | undefined => { } else if (typeof value === "number") { return BigInt(value); } - throw new InvalidNumberValueError(value as string); + throw new InvalidNumberValueError(value); }; const parseBytes = (value: TomlPrimitive, defaultValue: number): number => { @@ -294,7 +294,7 @@ const parseBytes = (value: TomlPrimitive, defaultValue: number): number => { } else if (typeof value === "number" || typeof value === "string") { return bytes.parse(value); } - throw new InvalidBytesValueError(value as unknown as string); + throw new InvalidBytesValueError(value); }; const parseBuilder = (value: TomlPrimitive): Builder => { @@ -314,7 +314,7 @@ const parseBuilder = (value: TomlPrimitive): Builder => { return "tar"; } } - throw new InvalidBuilderError(value as string); + throw new InvalidBuilderError(value); }; const parseFormat = (value: TomlPrimitive): DriveFormat => { @@ -328,7 +328,7 @@ const parseFormat = (value: TomlPrimitive): DriveFormat => { return "sqfs"; } } - throw new InvalidDriveFormatError(value as string); + throw new InvalidDriveFormatError(value); }; const parseEmptyFormat = (value: TomlPrimitive): "ext2" | "raw" => { @@ -342,7 +342,7 @@ const parseEmptyFormat = (value: TomlPrimitive): "ext2" | "raw" => { return "raw"; } } - throw new InvalidEmptyDriveFormatError(value as string); + throw new InvalidEmptyDriveFormatError(value); }; const parseMachine = (value: TomlPrimitive): MachineConfig => { diff --git a/apps/cli/test/config.test.ts b/apps/cli/test/config.test.ts index 0af0836d..7ddb0a79 100644 --- a/apps/cli/test/config.test.ts +++ b/apps/cli/test/config.test.ts @@ -54,13 +54,13 @@ shared = true`); new InvalidBuilderError("invalid"), ); expect(() => parse("[drives.root]\nbuilder = true")).toThrowError( - new InvalidBuilderError(true as unknown as string), + new InvalidBuilderError(true), ); expect(() => parse("[drives.root]\nbuilder = 10")).toThrowError( - new InvalidBuilderError(10 as unknown as string), + new InvalidBuilderError(10), ); expect(() => parse("[drives.root]\nbuilder = {}")).toThrowError( - new InvalidBuilderError({} as unknown as string), + new InvalidBuilderError({}), ); }); @@ -69,13 +69,13 @@ shared = true`); new InvalidDriveFormatError("invalid"), ); expect(() => parse("[drives.root]\nformat = true")).toThrowError( - new InvalidDriveFormatError(true as unknown as string), + new InvalidDriveFormatError(true), ); expect(() => parse("[drives.root]\nformat = 10")).toThrowError( - new InvalidDriveFormatError(10 as unknown as string), + new InvalidDriveFormatError(10), ); expect(() => parse("[drives.root]\nformat = {}")).toThrowError( - new InvalidDriveFormatError({} as unknown as string), + new InvalidDriveFormatError({}), ); }); @@ -93,21 +93,19 @@ shared = true`); it("invalid drive: invalid mount", () => { expect(() => parse("[drives.data]\nmount = 42")).toThrowError( - new InvalidStringValueError(42 as unknown as string), + new InvalidStringValueError(42), ); }); it("invalid empty drive: invalid fomat", () => { expect(() => parse("[drives.data]\nbuilder = 'empty'\nformat = 42"), - ).toThrowError( - new InvalidEmptyDriveFormatError(42 as unknown as string), - ); + ).toThrowError(new InvalidEmptyDriveFormatError(42)); }); it("invalid boolean value", () => { expect(() => parse("[machine]\nno-rollup = 42")).toThrowError( - new InvalidBooleanValueError(42 as unknown as string), + new InvalidBooleanValueError(42), ); }); @@ -119,7 +117,7 @@ shared = true`); format = "ext2" `; expect(() => parse(invalidTarDrive)).toThrowError( - new InvalidStringValueError(42 as unknown as string), + new InvalidStringValueError(42), ); }); @@ -152,7 +150,7 @@ shared = true`); bootargs = ["no4lvl", "quiet", false] `; expect(() => parse(invalidConfig)).toThrowError( - new InvalidStringValueError(false as unknown as string), + new InvalidStringValueError(false), ); }); });