From f8aa239277b3bb90be175189a3064254f6ef7fce Mon Sep 17 00:00:00 2001 From: David Anson Date: Tue, 26 Sep 2023 22:05:56 -0700 Subject: [PATCH] Convert JSON schema validation to use @hyperjump/json-schema, validate against specific schema version, newly validate schema definitions. --- package.json | 4 +- test/markdownlint-cli2-test.js | 67 +++++++++++++++++++++++++++++----- 2 files changed, 59 insertions(+), 12 deletions(-) diff --git a/package.json b/package.json index ac9127dc..bc63db02 100644 --- a/package.json +++ b/package.json @@ -86,6 +86,7 @@ "eslint-plugin-n": "16.1.0", "eslint-plugin-unicorn": "48.0.1", "execa": "8.0.1", + "@hyperjump/json-schema": "1.6.0", "markdown-it-emoji": "2.0.2", "markdown-it-for-inline": "0.1.1", "markdownlint-cli2-formatter-codequality": "0.0.4", @@ -95,8 +96,7 @@ "markdownlint-cli2-formatter-sarif": "0.0.1", "markdownlint-cli2-formatter-summarize": "0.0.6", "markdownlint-rule-titlecase": "0.1.0", - "npm-run-all": "4.1.5", - "tv4": "1.3.0" + "npm-run-all": "4.1.5" }, "keywords": [ "markdown", diff --git a/test/markdownlint-cli2-test.js b/test/markdownlint-cli2-test.js index 6e2f824d..9c81b0b8 100644 --- a/test/markdownlint-cli2-test.js +++ b/test/markdownlint-cli2-test.js @@ -5,10 +5,21 @@ const fs = require("node:fs/promises"); const path = require("node:path"); const test = require("ava").default; -const tv4 = require("tv4"); const { "main": markdownlintCli2 } = require("../markdownlint-cli2.js"); const FsMock = require("./fs-mock"); +const jsonSchemaVersion = "http://json-schema.org/draft-07/schema#"; +// eslint-disable-next-line max-len +const markdownlintConfigSchemaUri = "https://raw.githubusercontent.com/DavidAnson/markdownlint-cli2/main/schema/markdownlint-config-schema.json"; +const markdownlintConfigSchemaDefinition = + require("../schema/markdownlint-config-schema.json"); +// @ts-ignore +markdownlintConfigSchemaDefinition.$schema = jsonSchemaVersion; +// eslint-disable-next-line max-len +const markdownlintCli2ConfigSchemaUri = "https://raw.githubusercontent.com/DavidAnson/markdownlint-cli2/main/schema/markdownlint-cli2-config-schema.json"; +const markdownlintCli2ConfigSchemaDefinition = + require("../schema/markdownlint-cli2-config-schema.json"); + const outputFormatterLengthIs = (t, length) => (options) => { const { results } = options; t.is(Object.keys(results).length, length, JSON.stringify(results, null, 2)); @@ -57,8 +68,23 @@ test("README files", (t) => { }); test("validateMarkdownlintConfigSchema", async (t) => { - t.plan(23); - const schema = require("../schema/markdownlint-config-schema.json"); + t.plan(24); + + // Validate schema + const { addSchema, validate } = + // eslint-disable-next-line n/file-extension-in-import + await import("@hyperjump/json-schema/draft-07"); + const schemaResult = await validate( + jsonSchemaVersion, + markdownlintConfigSchemaDefinition, + "BASIC" + ); + t.true(schemaResult.valid); + + // Validate instances + // @ts-ignore + addSchema(markdownlintConfigSchemaDefinition, markdownlintConfigSchemaUri); + const validateConfigSchema = await validate(markdownlintConfigSchemaUri); const { "default": stripJsonComments } = await import("strip-json-comments"); const { globby } = await import("globby"); const files = await globby( @@ -76,17 +102,37 @@ test("validateMarkdownlintConfigSchema", async (t) => { return Promise.all(files.map(async (file) => { const content = await fs.readFile(file, "utf8"); const json = JSON.parse(stripJsonComments(content)); + const instanceResult = validateConfigSchema(json, "BASIC"); t.true( - // @ts-ignore - tv4.validate(json, schema), - `${file}\n${JSON.stringify(tv4.error, null, 2)}` + instanceResult.valid, + `${file}\n${JSON.stringify(instanceResult, null, 2)}` ); })); }); test("validateMarkdownlintCli2ConfigSchema", async (t) => { - t.plan(81); - const schema = require("../schema/markdownlint-cli2-config-schema.json"); + t.plan(82); + + // Validate schema + const { addSchema, validate } = + // eslint-disable-next-line n/file-extension-in-import + await import("@hyperjump/json-schema/draft-07"); + const schemaResult = await validate( + jsonSchemaVersion, + markdownlintCli2ConfigSchemaDefinition, + "BASIC" + ); + t.true(schemaResult.valid); + + // Validate instances + // @ts-ignore + addSchema(markdownlintConfigSchemaDefinition, markdownlintConfigSchemaUri); + addSchema( + // @ts-ignore + markdownlintCli2ConfigSchemaDefinition, + markdownlintCli2ConfigSchemaUri + ); + const validateConfigSchema = await validate(markdownlintCli2ConfigSchemaUri); const { "default": stripJsonComments } = await import("strip-json-comments"); const { globby } = await import("globby"); const files = await globby( @@ -105,9 +151,10 @@ test("validateMarkdownlintCli2ConfigSchema", async (t) => { return Promise.all(files.map(async (file) => { const content = await fs.readFile(file, "utf8"); const json = JSON.parse(stripJsonComments(content)); + const instanceResult = validateConfigSchema(json, "BASIC"); t.true( - tv4.validate(json, schema), - `${file}\n${JSON.stringify(tv4.error, null, 2)}` + instanceResult.valid, + `${file}\n${JSON.stringify(instanceResult, null, 2)}` ); })); });