UNPKG

fabric

Version:

Object model for HTML5 canvas, and SVG-to-canvas parser. Backed by jsdom and node-canvas.

77 lines (65 loc) 2.23 kB
import type { PlaywrightTestConfig } from '@playwright/test'; import { readdirSync, rmSync, statSync } from 'node:fs'; import * as path from 'node:path'; import { build, watch } from 'rolldown'; import { makeRe } from 'micromatch'; const include = ['**/*.ts']; const exclude = ['**/*.spec.ts', '**/*.fixtures.ts']; const src = path.resolve(process.cwd(), 'e2e', 'tests'); const dist = path.resolve(process.cwd(), 'e2e', 'dist'); const includeRe = include.map((glob) => makeRe(glob)); const excludeRe = exclude.map((glob) => makeRe(glob)); const walkSync = (dir: string, callback: (file: string) => void) => { const files = readdirSync(dir); files.forEach((file) => { const filepath = path.resolve(dir, file); const stats = statSync(filepath); if (stats.isDirectory()) { walkSync(filepath, callback); } else if (stats.isFile()) { callback(filepath); } }); }; const shouldBuild = (file: string) => includeRe.some((re) => re.test(file)) && excludeRe.every((re) => !re.test(file)); const getRolldownOptions = (input: string[]) => ({ input, external: [/^fabric/, 'westures', 'canvas', /^node:/], transform: { target: 'chrome100' as const, }, output: { dir: dist, format: 'es' as const, preserveModules: true, preserveModulesRoot: src, entryFileNames: '[name].js', sanitizeFileName: (name: string) => name.replace(/[\0?*]/g, '_'), }, }); export default async (_config: PlaywrightTestConfig) => { const files: string[] = []; walkSync(src, (file) => files.push(file)); const input = files.filter((file) => shouldBuild(file)); rmSync(dist, { recursive: true, force: true }); await build(getRolldownOptions(input)); console.log( `Successfully compiled ${input.length} files from ${path.relative( process.cwd(), src, )} to ${path.relative(process.cwd(), dist)}`, ); // watch if (process.argv.includes('--ui')) { const watcher = watch(getRolldownOptions(input)); watcher.on('event', (event) => { if (event.code === 'BUNDLE_END') { console.log(`Rebuilt e2e tests in ${event.duration}ms`); event.result.close(); } }); process.once('exit', () => watcher.close()); } };