From 2eed4123f595205681e2edb1f7a1aa2e008c0405 Mon Sep 17 00:00:00 2001 From: bluwy Date: Tue, 4 Jul 2023 17:23:18 +0800 Subject: [PATCH] Prevent importing integration test-utils --- .../test/units/config/config-server.test.js | 4 ++-- packages/astro/test/units/config/format.test.js | 3 +-- .../dev/collections-mixed-content-errors.test.js | 3 +-- .../units/dev/collections-renderentry.test.js | 4 ++-- packages/astro/test/units/dev/hydration.test.js | 9 ++------- packages/astro/test/units/dev/restart.test.js | 8 ++++++-- .../astro/test/units/render/components.test.js | 9 ++------- packages/astro/test/units/render/head.test.js | 6 +----- packages/astro/test/units/render/jsx.test.js | 9 +-------- .../test/units/routing/route-matching.test.js | 3 +-- packages/astro/test/units/test-utils.js | 16 +++++++++++++++- .../vite-plugin-astro-server/request.test.js | 9 +++------ 12 files changed, 37 insertions(+), 46 deletions(-) diff --git a/packages/astro/test/units/config/config-server.test.js b/packages/astro/test/units/config/config-server.test.js index 881122321c60..11efbab7a69c 100644 --- a/packages/astro/test/units/config/config-server.test.js +++ b/packages/astro/test/units/config/config-server.test.js @@ -1,6 +1,6 @@ import { expect } from 'chai'; import { fileURLToPath } from 'url'; -import { defaultLogging as logging } from '../../test-utils.js'; +import { defaultLogging } from '../test-utils.js'; import { openConfig } from '../../../dist/core/config/index.js'; const cwd = fileURLToPath(new URL('../../fixtures/config-host/', import.meta.url)); @@ -11,7 +11,7 @@ describe('config.server', () => { cwd: flags.root || cwd, flags, cmd: 'dev', - logging, + logging: defaultLogging, }); } diff --git a/packages/astro/test/units/config/format.test.js b/packages/astro/test/units/config/format.test.js index 602c19cc374c..5dce2da4459a 100644 --- a/packages/astro/test/units/config/format.test.js +++ b/packages/astro/test/units/config/format.test.js @@ -2,8 +2,7 @@ import { expect } from 'chai'; import { runInContainer } from '../../../dist/core/dev/index.js'; import { openConfig, createSettings } from '../../../dist/core/config/index.js'; -import { createFs } from '../test-utils.js'; -import { defaultLogging } from '../../test-utils.js'; +import { createFs, defaultLogging } from '../test-utils.js'; const root = new URL('../../fixtures/tailwindcss-ts/', import.meta.url); diff --git a/packages/astro/test/units/dev/collections-mixed-content-errors.test.js b/packages/astro/test/units/dev/collections-mixed-content-errors.test.js index 64fb1c296f41..ae54953bdfb4 100644 --- a/packages/astro/test/units/dev/collections-mixed-content-errors.test.js +++ b/packages/astro/test/units/dev/collections-mixed-content-errors.test.js @@ -3,8 +3,7 @@ import { fileURLToPath } from 'url'; import { validateConfig } from '../../../dist/core/config/config.js'; import { createSettings } from '../../../dist/core/config/index.js'; import { sync as _sync } from '../../../dist/core/sync/index.js'; -import { defaultLogging } from '../../test-utils.js'; -import { createFsWithFallback } from '../test-utils.js'; +import { createFsWithFallback, defaultLogging } from '../test-utils.js'; const root = new URL('../../fixtures/content-mixed-errors/', import.meta.url); const logging = defaultLogging; diff --git a/packages/astro/test/units/dev/collections-renderentry.test.js b/packages/astro/test/units/dev/collections-renderentry.test.js index d44f65af4eb0..3daebeb11450 100644 --- a/packages/astro/test/units/dev/collections-renderentry.test.js +++ b/packages/astro/test/units/dev/collections-renderentry.test.js @@ -1,15 +1,15 @@ import { expect } from 'chai'; import * as cheerio from 'cheerio'; +import os from 'os'; import { runInContainer } from '../../../dist/core/dev/index.js'; import { createFsWithFallback, createRequestAndResponse } from '../test-utils.js'; -import { isWindows } from '../../test-utils.js'; import mdx from '../../../../integrations/mdx/dist/index.js'; import { attachContentServerListeners } from '../../../dist/content/server-listeners.js'; const root = new URL('../../fixtures/content/', import.meta.url); -const describe = isWindows ? global.describe.skip : global.describe; +const describe = os.platform() === 'win32' ? global.describe.skip : global.describe; async function runInContainerWithContentListeners(params, callback) { return await runInContainer(params, async (container) => { diff --git a/packages/astro/test/units/dev/hydration.test.js b/packages/astro/test/units/dev/hydration.test.js index 0a176b4db0fe..7285f5e71c37 100644 --- a/packages/astro/test/units/dev/hydration.test.js +++ b/packages/astro/test/units/dev/hydration.test.js @@ -1,9 +1,8 @@ import { expect } from 'chai'; import { runInContainer } from '../../../dist/core/dev/index.js'; -import { createFs, createRequestAndResponse } from '../test-utils.js'; +import { createFs, createRequestAndResponse, silentLogging } from '../test-utils.js'; import svelte from '../../../../integrations/svelte/dist/index.js'; -import { defaultLogging } from '../../test-utils.js'; const root = new URL('../../fixtures/alias/', import.meta.url); @@ -33,11 +32,7 @@ describe('dev container', () => { { fs, root, - logging: { - ...defaultLogging, - // Error is expected in this test - level: 'silent', - }, + logging: silentLogging, userConfig: { integrations: [svelte()], }, diff --git a/packages/astro/test/units/dev/restart.test.js b/packages/astro/test/units/dev/restart.test.js index 5c8c4a37c393..e1d391ef04ad 100644 --- a/packages/astro/test/units/dev/restart.test.js +++ b/packages/astro/test/units/dev/restart.test.js @@ -7,9 +7,13 @@ import { isStarted, startContainer, } from '../../../dist/core/dev/index.js'; -import { createFs, createRequestAndResponse, triggerFSEvent } from '../test-utils.js'; +import { + createFs, + createRequestAndResponse, + defaultLogging, + triggerFSEvent, +} from '../test-utils.js'; import { createSettings, openConfig } from '../../../dist/core/config/index.js'; -import { defaultLogging } from '../../test-utils.js'; const root = new URL('../../fixtures/alias/', import.meta.url); diff --git a/packages/astro/test/units/render/components.test.js b/packages/astro/test/units/render/components.test.js index 6b13c25623e6..38f9e1062582 100644 --- a/packages/astro/test/units/render/components.test.js +++ b/packages/astro/test/units/render/components.test.js @@ -2,9 +2,8 @@ import { expect } from 'chai'; import * as cheerio from 'cheerio'; import { runInContainer } from '../../../dist/core/dev/index.js'; -import { createFs, createRequestAndResponse } from '../test-utils.js'; +import { createFs, createRequestAndResponse, silentLogging } from '../test-utils.js'; import svelte from '../../../../integrations/svelte/dist/index.js'; -import { defaultLogging } from '../../test-utils.js'; const root = new URL('../../fixtures/alias/', import.meta.url); @@ -33,11 +32,7 @@ describe('core/render components', () => { { fs, root, - logging: { - ...defaultLogging, - // Error is expected in this test - level: 'silent', - }, + logging: silentLogging, userConfig: { integrations: [svelte()], }, diff --git a/packages/astro/test/units/render/head.test.js b/packages/astro/test/units/render/head.test.js index 705718e2d3d4..ef6ef0b92228 100644 --- a/packages/astro/test/units/render/head.test.js +++ b/packages/astro/test/units/render/head.test.js @@ -10,7 +10,6 @@ import { Fragment, } from '../../../dist/runtime/server/index.js'; import { createRenderContext, renderPage } from '../../../dist/core/render/index.js'; -import { defaultLogging as logging } from '../../test-utils.js'; import { createBasicEnvironment } from '../test-utils.js'; import * as cheerio from 'cheerio'; @@ -20,10 +19,7 @@ describe('core/render', () => { describe('Injected head contents', () => { let env; before(async () => { - env = createBasicEnvironment({ - logging, - renderers: [], - }); + env = createBasicEnvironment(); }); it('Multi-level layouts and head injection, with explicit head', async () => { diff --git a/packages/astro/test/units/render/jsx.test.js b/packages/astro/test/units/render/jsx.test.js index ed011ccb04de..46058cbff85e 100644 --- a/packages/astro/test/units/render/jsx.test.js +++ b/packages/astro/test/units/render/jsx.test.js @@ -6,14 +6,8 @@ import { renderSlot, } from '../../../dist/runtime/server/index.js'; import { jsx } from '../../../dist/jsx-runtime/index.js'; -import { - createBasicEnvironment, - createRenderContext, - renderPage, - loadRenderer, -} from '../../../dist/core/render/index.js'; +import { createRenderContext, renderPage, loadRenderer } from '../../../dist/core/render/index.js'; import { createAstroJSXComponent, renderer as jsxRenderer } from '../../../dist/jsx/index.js'; -import { defaultLogging as logging } from '../../test-utils.js'; import { createBasicEnvironment } from '../test-utils.js'; const createAstroModule = (AstroComponent) => ({ default: AstroComponent }); @@ -24,7 +18,6 @@ describe('core/render', () => { let env; before(async () => { env = createBasicEnvironment({ - logging, renderers: [await loadJSXRenderer()], }); }); diff --git a/packages/astro/test/units/routing/route-matching.test.js b/packages/astro/test/units/routing/route-matching.test.js index fca2064ea0e4..1c4e178d8bae 100644 --- a/packages/astro/test/units/routing/route-matching.test.js +++ b/packages/astro/test/units/routing/route-matching.test.js @@ -1,8 +1,7 @@ // @ts-check -import { createFs, createRequestAndResponse } from '../test-utils.js'; +import { createFs, createRequestAndResponse, defaultLogging } from '../test-utils.js'; import { createRouteManifest, matchAllRoutes } from '../../../dist/core/routing/index.js'; import { fileURLToPath } from 'url'; -import { defaultLogging } from '../../test-utils.js'; import { createViteLoader } from '../../../dist/core/module-loader/vite.js'; import { createDevelopmentEnvironment } from '../../../dist/core/render/dev/environment.js'; import { expect } from 'chai'; diff --git a/packages/astro/test/units/test-utils.js b/packages/astro/test/units/test-utils.js index ce3a265b3c46..a18d42de8be3 100644 --- a/packages/astro/test/units/test-utils.js +++ b/packages/astro/test/units/test-utils.js @@ -8,6 +8,19 @@ import { unixify } from './correct-path.js'; import { getDefaultClientDirectives } from '../../dist/core/client-directive/index.js'; import { createEnvironment } from '../../dist/core/render/index.js'; import { RouteCache } from '../../dist/core/render/route-cache.js'; +import { nodeLogDestination } from '../../dist/core/logger/node.js'; + +/** @type {import('../../src/core/logger/core').LogOptions} */ +export const defaultLogging = { + dest: nodeLogDestination, + level: 'error', +}; + +/** @type {import('../../src/core/logger/core').LogOptions} */ +export const silentLogging = { + dest: nodeLogDestination, + level: 'error', +}; class VirtualVolume extends Volume { #root = ''; @@ -159,7 +172,7 @@ export const createAstroModule = (AstroComponent) => ({ default: AstroComponent * @param {Partial} options * @returns {import('../../src/core/render/environment.js').Environment} */ -export function createBasicEnvironment(options) { +export function createBasicEnvironment(options = {}) { const mode = options.mode ?? 'development'; return createEnvironment({ ...options, @@ -171,6 +184,7 @@ export function createBasicEnvironment(options) { clientDirectives: getDefaultClientDirectives(), resolve: options.resolve ?? ((s) => Promise.resolve(s)), routeCache: new RouteCache(options.logging, mode), + logging: options.logging ?? defaultLogging, ssr: options.ssr ?? true, streaming: options.streaming ?? true, }); diff --git a/packages/astro/test/units/vite-plugin-astro-server/request.test.js b/packages/astro/test/units/vite-plugin-astro-server/request.test.js index a0202454d9d2..67d99c1776b6 100644 --- a/packages/astro/test/units/vite-plugin-astro-server/request.test.js +++ b/packages/astro/test/units/vite-plugin-astro-server/request.test.js @@ -5,19 +5,16 @@ import { createLoader } from '../../../dist/core/module-loader/index.js'; import { createRouteManifest } from '../../../dist/core/routing/index.js'; import { createComponent, render } from '../../../dist/runtime/server/index.js'; import { createController, handleRequest } from '../../../dist/vite-plugin-astro-server/index.js'; -import { defaultLogging as logging } from '../../test-utils.js'; import { createAstroModule, createBasicEnvironment, createFs, createRequestAndResponse, + defaultLogging, } from '../test-utils.js'; async function createDevEnvironment(overrides = {}) { - const env = createBasicEnvironment({ - logging, - renderers: [], - }); + const env = createBasicEnvironment(); env.settings = await createDefaultDevSettings({}, '/'); env.settings.renderers = []; env.loader = createLoader(); @@ -52,7 +49,7 @@ describe('vite-plugin-astro-server', () => { fsMod: fs, settings: env.settings, }, - logging + defaultLogging ); try {