From 068c5d3cf76dcf25fe1a9468b9f5e8291f1bbeee Mon Sep 17 00:00:00 2001 From: Gautam Singh <5769869+gautamsi@users.noreply.github.com> Date: Wed, 24 Jul 2024 21:07:10 -0500 Subject: [PATCH] fix test due to injected id field --- packages/core/src/admin-ui/templates/index.ts | 7 +++---- packages/core/src/lib/createSystem.ts | 2 +- packages/core/src/lib/defaults.ts | 4 ++-- packages/core/src/types/next-fields.ts | 2 +- tests/cli-tests/__snapshots__/artifacts.test.ts.snap | 2 +- 5 files changed, 8 insertions(+), 9 deletions(-) diff --git a/packages/core/src/admin-ui/templates/index.ts b/packages/core/src/admin-ui/templates/index.ts index 18412959f6f..b75c8c83d07 100644 --- a/packages/core/src/admin-ui/templates/index.ts +++ b/packages/core/src/admin-ui/templates/index.ts @@ -1,8 +1,6 @@ import * as Path from 'path' import { type GraphQLSchema } from 'graphql' -import { - type ResolvedKeystoneConfig -} from '../../types' +import { type ResolvedKeystoneConfig } from '../../types' import { type AdminMetaRootVal } from '../../lib/create-admin-meta' import { appTemplate } from './app' import { homeTemplate } from './home' @@ -14,7 +12,8 @@ import { nextConfigTemplate } from './next-config' const pkgDir = Path.dirname(require.resolve('@keystone-6/core/package.json')) -export function writeAdminFiles (config: ResolvedKeystoneConfig, +export function writeAdminFiles ( + config: ResolvedKeystoneConfig, graphQLSchema: GraphQLSchema, adminMeta: AdminMetaRootVal, configFileExists: boolean diff --git a/packages/core/src/lib/createSystem.ts b/packages/core/src/lib/createSystem.ts index 5a6f42f1893..87771800e3d 100644 --- a/packages/core/src/lib/createSystem.ts +++ b/packages/core/src/lib/createSystem.ts @@ -201,7 +201,7 @@ function formatUrl (provider: ResolvedKeystoneConfig['db']['provider'], url: str } export function createSystem (config_: KeystoneConfig | ResolvedKeystoneConfig) { - const config = resolveDefaults(config_ as KeystoneConfig) + const config = resolveDefaults(config_ as KeystoneConfig, true) const lists = initialiseLists(config) const adminMeta = createAdminMeta(config, lists) const graphQLSchema = createGraphQLSchema(config, lists, adminMeta, false) diff --git a/packages/core/src/lib/defaults.ts b/packages/core/src/lib/defaults.ts index 2772e902c00..d3caa91db4c 100644 --- a/packages/core/src/lib/defaults.ts +++ b/packages/core/src/lib/defaults.ts @@ -76,7 +76,7 @@ function defaultIsAccessAllowed ({ session, sessionStrategy }: KeystoneContext) export async function noop () {} function identity (x: T) { return x } -export function resolveDefaults (config: KeystoneConfig): ResolvedKeystoneConfig { +export function resolveDefaults (config: KeystoneConfig, injectIdField = false): ResolvedKeystoneConfig { if (!['postgresql', 'sqlite', 'mysql'].includes(config.db.provider)) { throw new TypeError(`"db.provider" only supports "sqlite", "postgresql" or "mysql"`) } @@ -126,7 +126,7 @@ export function resolveDefaults (config: schemaPath: config.graphql?.schemaPath ?? 'schema.graphql', extendGraphqlSchema: config.graphql?.extendGraphqlSchema ?? ((s) => s), }, - lists: injectDefaults(config, defaultIdField), + lists: injectIdField ? injectDefaults(config, defaultIdField) : config.lists, server: { maxFileSize: 200 * 1024 * 1024, // 200 MiB extendExpressApp: config.server?.extendExpressApp ?? noop, diff --git a/packages/core/src/types/next-fields.ts b/packages/core/src/types/next-fields.ts index fa3cadc1b8d..ab0bf683b5a 100644 --- a/packages/core/src/types/next-fields.ts +++ b/packages/core/src/types/next-fields.ts @@ -1,5 +1,5 @@ import Decimal from 'decimal.js' -import { graphql } from '..' +import { graphql } from './schema' import { type BaseListTypeInfo } from './type-info' import { type CommonFieldConfig } from './config' import { type DatabaseProvider } from './core' diff --git a/tests/cli-tests/__snapshots__/artifacts.test.ts.snap b/tests/cli-tests/__snapshots__/artifacts.test.ts.snap index 2b31990428e..2702901fbad 100644 --- a/tests/cli-tests/__snapshots__/artifacts.test.ts.snap +++ b/tests/cli-tests/__snapshots__/artifacts.test.ts.snap @@ -151,7 +151,7 @@ export declare namespace Lists { } } export type Context = import('@keystone-6/core/types').KeystoneContext> -export type Config = import('@keystone-6/core/types').KeystoneConfig> +export type Config = import('@keystone-6/core/types').ResolvedKeystoneConfig> export type TypeInfo = { lists: {