From 0e5ebf1ae3cb079ad6232a3424bf19f2db539cec Mon Sep 17 00:00:00 2001 From: ymc9 <104139426+ymc9@users.noreply.github.com> Date: Fri, 13 Dec 2024 08:08:33 +0800 Subject: [PATCH 1/3] chore: exclude IDE packages from regular build --- .github/workflows/build-test.yml | 2 +- package.json | 3 ++- 2 files changed, 3 insertions(+), 2 deletions(-) diff --git a/.github/workflows/build-test.yml b/.github/workflows/build-test.yml index 717cf03b8..54868c57b 100644 --- a/.github/workflows/build-test.yml +++ b/.github/workflows/build-test.yml @@ -86,7 +86,7 @@ jobs: gradle-home-cache-cleanup: true - name: Build - run: DEFAULT_NPM_TAG=latest pnpm run build + run: DEFAULT_NPM_TAG=latest pnpm run build-ci - name: Lint run: pnpm lint diff --git a/package.json b/package.json index c4834d97b..8e55c4ed3 100644 --- a/package.json +++ b/package.json @@ -3,7 +3,8 @@ "version": "2.10.0", "description": "", "scripts": { - "build": "pnpm -r build", + "build": "pnpm -r --filter=\"!./packages/ide/*\" build", + "build-ci": "pnpm -r build", "lint": "pnpm -r lint", "test": "pnpm -r --parallel run test --silent --forceExit", "test-ci": "pnpm -r --parallel run --filter=\"./packages/**\" test --silent --forceExit", From 871e9b7e9d50767c289ab96a5876a4b67bb4a764 Mon Sep 17 00:00:00 2001 From: ymc9 <104139426+ymc9@users.noreply.github.com> Date: Fri, 13 Dec 2024 08:43:33 +0800 Subject: [PATCH 2/3] fix zod version issue --- packages/plugins/openapi/package.json | 2 +- packages/plugins/trpc/package.json | 6 ++++-- .../plugins/trpc/tests/projects/nuxt-trpc-v10/package.json | 2 +- .../plugins/trpc/tests/projects/nuxt-trpc-v11/package.json | 2 +- .../plugins/trpc/tests/projects/t3-trpc-v10/package.json | 2 +- .../plugins/trpc/tests/projects/t3-trpc-v11/package.json | 2 +- script/test-scaffold.ts | 2 +- 7 files changed, 10 insertions(+), 8 deletions(-) diff --git a/packages/plugins/openapi/package.json b/packages/plugins/openapi/package.json index 9c9c4da71..307403477 100644 --- a/packages/plugins/openapi/package.json +++ b/packages/plugins/openapi/package.json @@ -36,7 +36,7 @@ "ts-pattern": "^4.3.0", "upper-case-first": "^2.0.2", "yaml": "^2.2.2", - "zod": "^3.22.4", + "zod": "^3.22.4", "zod-validation-error": "^1.5.0" }, "devDependencies": { diff --git a/packages/plugins/trpc/package.json b/packages/plugins/trpc/package.json index 304ec2ac1..858e71521 100644 --- a/packages/plugins/trpc/package.json +++ b/packages/plugins/trpc/package.json @@ -31,8 +31,10 @@ "lower-case-first": "^2.0.2", "ts-morph": "^16.0.0", "tslib": "^2.4.1", - "upper-case-first": "^2.0.2", - "zod": "^3.22.4" + "upper-case-first": "^2.0.2" + }, + "peerDependencies": { + "zod": "^3.22.4" }, "devDependencies": { "@trpc/next": "^10.32.0", diff --git a/packages/plugins/trpc/tests/projects/nuxt-trpc-v10/package.json b/packages/plugins/trpc/tests/projects/nuxt-trpc-v10/package.json index 9a89c1e8b..387a37f37 100644 --- a/packages/plugins/trpc/tests/projects/nuxt-trpc-v10/package.json +++ b/packages/plugins/trpc/tests/projects/nuxt-trpc-v10/package.json @@ -17,7 +17,7 @@ "trpc-nuxt": "^0.10.22", "vue": "latest", "vue-router": "latest", - "zod": "^3.23.8" + "zod": "^3.22.4" }, "devDependencies": { "esbuild": "^0.24.0", diff --git a/packages/plugins/trpc/tests/projects/nuxt-trpc-v11/package.json b/packages/plugins/trpc/tests/projects/nuxt-trpc-v11/package.json index 68a65a4ca..38b9e2919 100644 --- a/packages/plugins/trpc/tests/projects/nuxt-trpc-v11/package.json +++ b/packages/plugins/trpc/tests/projects/nuxt-trpc-v11/package.json @@ -17,7 +17,7 @@ "trpc-nuxt": "^0.11.0-beta.1", "vue": "latest", "vue-router": "latest", - "zod": "^3.23.8" + "zod": "^3.22.4" }, "devDependencies": { "esbuild": "^0.24.0", diff --git a/packages/plugins/trpc/tests/projects/t3-trpc-v10/package.json b/packages/plugins/trpc/tests/projects/t3-trpc-v10/package.json index e26114fee..ad9203091 100644 --- a/packages/plugins/trpc/tests/projects/t3-trpc-v10/package.json +++ b/packages/plugins/trpc/tests/projects/t3-trpc-v10/package.json @@ -24,7 +24,7 @@ "react": "18.2.0", "react-dom": "18.2.0", "superjson": "^2.2.1", - "zod": "^3.22.4" + "zod": "^3.22.4" }, "devDependencies": { "@types/eslint": "^8.44.7", diff --git a/packages/plugins/trpc/tests/projects/t3-trpc-v11/package.json b/packages/plugins/trpc/tests/projects/t3-trpc-v11/package.json index 410d6c2a2..01117d261 100644 --- a/packages/plugins/trpc/tests/projects/t3-trpc-v11/package.json +++ b/packages/plugins/trpc/tests/projects/t3-trpc-v11/package.json @@ -28,7 +28,7 @@ "react-dom": "^18.3.1", "server-only": "^0.0.1", "superjson": "^2.2.1", - "zod": "^3.23.3" + "zod": "^3.22.4" }, "devDependencies": { "@types/eslint": "^8.56.10", diff --git a/script/test-scaffold.ts b/script/test-scaffold.ts index fdc82d952..5904a67c7 100644 --- a/script/test-scaffold.ts +++ b/script/test-scaffold.ts @@ -19,6 +19,6 @@ function run(cmd: string) { } run('npm init -y'); -run('npm i --no-audit --no-fund typescript prisma@6.0.x @prisma/client@6.0.x zod decimal.js @types/node'); +run('npm i --no-audit --no-fund typescript prisma@6.0.x @prisma/client@6.0.x zod@^3.22.4 decimal.js @types/node'); console.log('Test scaffold setup complete.'); From 9a24d17db210df1e7509d0875cc86e6ef23ca0fc Mon Sep 17 00:00:00 2001 From: ymc9 <104139426+ymc9@users.noreply.github.com> Date: Fri, 13 Dec 2024 09:14:58 +0800 Subject: [PATCH 3/3] fix zod version issue --- packages/runtime/src/zod-utils.ts | 14 +++++++++----- 1 file changed, 9 insertions(+), 5 deletions(-) diff --git a/packages/runtime/src/zod-utils.ts b/packages/runtime/src/zod-utils.ts index 47fa5a011..1ebaf9cdc 100644 --- a/packages/runtime/src/zod-utils.ts +++ b/packages/runtime/src/zod-utils.ts @@ -9,10 +9,12 @@ import { z as Z } from 'zod'; * accidentally matching a less-ideal schema candidate. * * The helper uses a custom schema to find the candidate that results in the fewest unrecognized keys when parsing the data. + * + * The function uses `any` for parameter and return type to be compatible with various zod versions. */ -export function smartUnion(z: typeof Z, candidates: Z.ZodSchema[]) { +export function smartUnion(z: any, candidates: any[]): any { // strip `z.lazy` - const processedCandidates = candidates.map((candidate) => unwrapLazy(z, candidate)); + const processedCandidates: Z.ZodSchema[] = candidates.map((candidate) => unwrapLazy(z, candidate)); if (processedCandidates.some((c) => !(c instanceof z.ZodObject || c instanceof z.ZodArray))) { // fall back to plain union if not all candidates are objects or arrays @@ -22,11 +24,13 @@ export function smartUnion(z: typeof Z, candidates: Z.ZodSchema[]) { let resultData: any; return z - .custom((data) => { + .custom((data: any) => { if (Array.isArray(data)) { const { data: result, success } = smartArrayUnion( z, - processedCandidates.filter((c) => c instanceof z.ZodArray), + processedCandidates.filter((c) => c instanceof z.ZodArray) as Array< + Z.ZodArray> + >, data ); if (success) { @@ -36,7 +40,7 @@ export function smartUnion(z: typeof Z, candidates: Z.ZodSchema[]) { } else { const { data: result, success } = smartObjectUnion( z, - processedCandidates.filter((c) => c instanceof z.ZodObject), + processedCandidates.filter((c) => c instanceof z.ZodObject) as Z.ZodObject[], data ); if (success) {