feat(ct): allow clearing cached build and test transformations (#29410)

This commit is contained in:
Pavel Feldman 2024-02-08 10:24:01 -08:00 committed by GitHub
parent 32a1d49729
commit 7f81c6e138
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
3 changed files with 42 additions and 5 deletions

View File

@ -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);

View File

@ -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);

View File

@ -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`