From 281a4f40330f0dfb5cf4f13f9e2c2332c12d4841 Mon Sep 17 00:00:00 2001 From: Evan Hahn Date: Thu, 12 Dec 2024 19:52:27 +0000 Subject: [PATCH] test: assert that generated data is valid This beefs up our tests for `generate` by making sure that they pass `@comapeo/schema`'s `validate` function. --- test/generate.test.js | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/test/generate.test.js b/test/generate.test.js index e7db4ad..6954244 100644 --- a/test/generate.test.js +++ b/test/generate.test.js @@ -1,8 +1,9 @@ -import { encode } from '@comapeo/schema' +import { encode, validate, valueOf } from '@comapeo/schema' +import assert from 'node:assert/strict' import test from 'node:test' import { generate, listSchemas } from '../index.js' -test('generates encodable data', { concurrency: true }, async (t) => { +test('generates valid data', { concurrency: true }, async (t) => { const COUNT = 1000 const schemaNames = Object.keys(listSchemas()) @@ -11,6 +12,7 @@ test('generates encodable data', { concurrency: true }, async (t) => { if (schemaName === 'coreOwnership') continue await t.test(schemaName, () => { for (const doc of generate(schemaName, { count: COUNT })) { + assert(validate(schemaName, valueOf(doc)), 'doc is valid') // This should not throw. encode(doc) } @@ -19,6 +21,7 @@ test('generates encodable data', { concurrency: true }, async (t) => { await t.test('coreOwnership', () => { for (const doc of generate('coreOwnership', { count: COUNT })) { + assert(validate('coreOwnership', doc), 'doc is valid') // This should not throw. encode({ ...doc,