mirror of
https://github.com/microsoft/playwright.git
synced 2024-10-27 05:46:28 +03:00
feat(ct): allow clearing cached build and test transformations (#29410)
This commit is contained in:
parent
32a1d49729
commit
7f81c6e138
@ -26,11 +26,11 @@ import { source as injectedSource } from './generated/indexSource';
|
|||||||
import { createConfig, populateComponentsFromTests, resolveDirs, transformIndexFile } from './viteUtils';
|
import { createConfig, populateComponentsFromTests, resolveDirs, transformIndexFile } from './viteUtils';
|
||||||
import type { ComponentRegistry } from './viteUtils';
|
import type { ComponentRegistry } from './viteUtils';
|
||||||
|
|
||||||
export async function runDevServer(configFile: string, registerSourceFile: string, frameworkPluginFactory: () => Promise<any>) {
|
export async function loadConfig(configFile: string): Promise<FullConfigInternal | null> {
|
||||||
const configFileOrDirectory = configFile ? path.resolve(process.cwd(), configFile) : process.cwd();
|
const configFileOrDirectory = configFile ? path.resolve(process.cwd(), configFile) : process.cwd();
|
||||||
const resolvedConfigFile = resolveConfigFile(configFileOrDirectory);
|
const resolvedConfigFile = resolveConfigFile(configFileOrDirectory);
|
||||||
if (restartWithExperimentalTsEsm(resolvedConfigFile))
|
if (restartWithExperimentalTsEsm(resolvedConfigFile))
|
||||||
return;
|
return null;
|
||||||
|
|
||||||
const configLoader = new ConfigLoader();
|
const configLoader = new ConfigLoader();
|
||||||
let config: FullConfigInternal;
|
let config: FullConfigInternal;
|
||||||
@ -38,6 +38,13 @@ export async function runDevServer(configFile: string, registerSourceFile: strin
|
|||||||
config = await configLoader.loadConfigFile(resolvedConfigFile);
|
config = await configLoader.loadConfigFile(resolvedConfigFile);
|
||||||
else
|
else
|
||||||
config = await configLoader.loadEmptyConfig(configFileOrDirectory);
|
config = await configLoader.loadEmptyConfig(configFileOrDirectory);
|
||||||
|
return config;
|
||||||
|
}
|
||||||
|
|
||||||
|
export async function runDevServer(configFile: string, registerSourceFile: string, frameworkPluginFactory: () => Promise<any>) {
|
||||||
|
const config = await loadConfig(configFile);
|
||||||
|
if (!config)
|
||||||
|
return;
|
||||||
|
|
||||||
const runner = new Runner(config);
|
const runner = new Runner(config);
|
||||||
await runner.loadAllTests(true);
|
await runner.loadAllTests(true);
|
||||||
|
@ -16,8 +16,11 @@
|
|||||||
|
|
||||||
import type { Command } from 'playwright-core/lib/utilsBundle';
|
import type { Command } from 'playwright-core/lib/utilsBundle';
|
||||||
|
|
||||||
|
import fs from 'fs';
|
||||||
import { program } from 'playwright/lib/program';
|
import { program } from 'playwright/lib/program';
|
||||||
import { runDevServer } from './devServer';
|
import { loadConfig, runDevServer } from './devServer';
|
||||||
|
import { resolveDirs } from './viteUtils';
|
||||||
|
import { cacheDir } from 'playwright/lib/transform/compilationCache';
|
||||||
export { program } from 'playwright/lib/program';
|
export { program } from 'playwright/lib/program';
|
||||||
|
|
||||||
let registerSourceFile: string;
|
let registerSourceFile: string;
|
||||||
@ -31,10 +34,37 @@ export function initializePlugin(registerSource: string, factory: () => Promise<
|
|||||||
function addDevServerCommand(program: Command) {
|
function addDevServerCommand(program: Command) {
|
||||||
const command = program.command('dev-server');
|
const command = program.command('dev-server');
|
||||||
command.description('start dev server');
|
command.description('start dev server');
|
||||||
command.option('-c, --config <file>', `Configuration file. Can be used to specify additional configuration for the output report.`);
|
command.option('-c, --config <file>', `Configuration file.`);
|
||||||
command.action(options => {
|
command.action(options => {
|
||||||
runDevServer(options.config, registerSourceFile, frameworkPluginFactory);
|
runDevServer(options.config, registerSourceFile, frameworkPluginFactory);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function addClearCacheCommand(program: Command) {
|
||||||
|
const command = program.command('clear-caches');
|
||||||
|
command.description('clears build and test caches');
|
||||||
|
command.option('-c, --config <file>', `Configuration file.`);
|
||||||
|
command.action(async options => {
|
||||||
|
const configFile = options.config;
|
||||||
|
const config = await loadConfig(configFile);
|
||||||
|
if (!config)
|
||||||
|
return;
|
||||||
|
const { outDir } = await resolveDirs(config.configDir, config.config);
|
||||||
|
await removeFolder(outDir);
|
||||||
|
await removeFolder(cacheDir);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
async function removeFolder(folder: string) {
|
||||||
|
try {
|
||||||
|
if (!fs.existsSync(folder))
|
||||||
|
return;
|
||||||
|
// eslint-disable-next-line no-console
|
||||||
|
console.log(`Removing ${await fs.promises.realpath(folder)}`);
|
||||||
|
await fs.promises.rm(folder, { recursive: true, force: true });
|
||||||
|
} catch {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
addDevServerCommand(program);
|
addDevServerCommand(program);
|
||||||
|
addClearCacheCommand(program);
|
||||||
|
@ -47,7 +47,7 @@ type SerializedCompilationCache = {
|
|||||||
// - For workers-only dynamic imports or some cache problems, we will re-transpile files in
|
// - For workers-only dynamic imports or some cache problems, we will re-transpile files in
|
||||||
// each worker anew.
|
// each worker anew.
|
||||||
|
|
||||||
const cacheDir = process.env.PWTEST_CACHE_DIR || (() => {
|
export const cacheDir = process.env.PWTEST_CACHE_DIR || (() => {
|
||||||
if (process.platform === 'win32')
|
if (process.platform === 'win32')
|
||||||
return path.join(os.tmpdir(), `playwright-transform-cache`);
|
return path.join(os.tmpdir(), `playwright-transform-cache`);
|
||||||
// Use `geteuid()` instead of more natural `os.userInfo().username`
|
// Use `geteuid()` instead of more natural `os.userInfo().username`
|
||||||
|
Loading…
Reference in New Issue
Block a user