Skip to content

Commit

Permalink
Combine web-forms package Vite/Vitest configs
Browse files Browse the repository at this point in the history
This is consistent with all of the other Web Forms packages. This merges the Vitest config as-is, into the Vite config from getodk#184 with slight adjustments:

- Give a name to express intent of branching on mode === ‘demo’
- Set up branchy config options early, assign to single return object of all combined config

I think this makes it more clear what is conditional in the config, and why it should be conditional.

Note: this _mostly satisfies_ our Vue/non-Vue build story. I would like to consider aligning the Vue/non-Vue approach with the Solid/non-Solid approach (see: packages/xforms-engine/vite.config.ts, and the env flag set in packages/xforms-engine/package.json scripts).
  • Loading branch information
eyelidlessness authored and sadiqkhoja committed Sep 12, 2024
1 parent 09335b0 commit 34e097a
Show file tree
Hide file tree
Showing 2 changed files with 120 additions and 119 deletions.
159 changes: 120 additions & 39 deletions packages/web-forms/vite.config.ts
Original file line number Diff line number Diff line change
@@ -1,34 +1,101 @@
import { CollectionValues } from '@getodk/common/types/collections/CollectionValues';
import vue from '@vitejs/plugin-vue';
import vueJsx from '@vitejs/plugin-vue-jsx';
import { existsSync } from 'node:fs';
import { resolve } from 'node:path';
import { fileURLToPath, URL } from 'node:url';
import { resolve } from 'path';
import unpluginFonts from 'unplugin-fonts/vite';
import { defineConfig, UserConfig } from 'vite';
import type { LibraryOptions } from 'vite';
import cssInjectedByJsPlugin from 'vite-plugin-css-injected-by-js';
import { defineConfig } from 'vitest/config';

const bundleFonts = () =>
unpluginFonts({
fontsource: {
families: [
{
/**
* Name of the font family.
* Require the `@fontsource/roboto` package to be installed.
*/
name: 'Roboto',
/**
* Load only a subset of the font family.
*/
weights: [300],
},
],
},
});
const supportedBrowsers = new Set(['chromium', 'firefox', 'webkit'] as const);

type SupportedBrowser = CollectionValues<typeof supportedBrowsers>;

const isSupportedBrowser = (browserName: string): browserName is SupportedBrowser =>
supportedBrowsers.has(browserName as SupportedBrowser);

const BROWSER_NAME = (() => {
const envBrowserName = process.env.BROWSER_NAME;

if (envBrowserName == null) {
return null;
}

if (isSupportedBrowser(envBrowserName)) {
return envBrowserName;
}

throw new Error(`Unsupported browser: ${envBrowserName}`);
})();

const BROWSER_ENABLED = BROWSER_NAME != null;

const TEST_ENVIRONMENT = BROWSER_ENABLED ? 'node' : 'jsdom';

const globalSetup: string[] = [];

/**
* @todo this is (hopefully!) temporary. Adds a delay when testing in
* `webkit`, to help mitigate flakiness that seems to be rooted in
* first-run timing issues (where "first" = "no Vite cache"; the issue was
* much more consistently reproducible in a state where
* `node_modules/.vite` is not present).
*/
const webkitFlakinessMitigations =
BROWSER_NAME === 'webkit' && !existsSync('./node_modules/.vite/deps');

export default defineConfig((env) => {
const config: UserConfig = {
if (webkitFlakinessMitigations) {
globalSetup.push('./tests/globalSetup/mitigate-webkit-flakiness.ts');
}

export default defineConfig(({ mode }) => {
const isVueBundled = mode === 'demo';

let lib: LibraryOptions | undefined;
let external: string[];
let globals: Record<string, string>;

if (isVueBundled) {
external = [];
globals = {};
} else {
external = ['vue'];
globals = { vue: 'Vue' };

lib = {
formats: ['es'],
entry: resolve(__dirname, 'src/index.ts'),
name: 'OdkWebForms',
fileName: 'index',
};
}

return {
base: './',
plugins: [vue(), vueJsx(), cssInjectedByJsPlugin(), bundleFonts()],
plugins: [
vue(),
vueJsx(),
cssInjectedByJsPlugin(),
unpluginFonts({
fontsource: {
families: [
{
/**
* Name of the font family.
* Require the `@fontsource/roboto` package to be installed.
*/
name: 'Roboto',
/**
* Load only a subset of the font family.
*/
weights: [300],
},
],
},
}),
],
resolve: {
alias: {
'@': fileURLToPath(new URL('./src', import.meta.url)),
Expand All @@ -44,18 +111,11 @@ export default defineConfig((env) => {
},
build: {
target: 'esnext',
lib: {
formats: ['es'],
entry: resolve(__dirname, 'src/index.ts'),
name: 'OdkWebForms',
fileName: 'index',
},
lib,
rollupOptions: {
external: ['vue'],
external,
output: {
globals: {
vue: 'Vue',
},
globals,
},
},
},
Expand Down Expand Up @@ -87,12 +147,33 @@ export default defineConfig((env) => {
],
},
},
};
optimizeDeps: {
force: true,
},
test: {
browser: {
enabled: BROWSER_ENABLED,
name: BROWSER_NAME!,
provider: 'playwright',
fileParallelism: false,
headless: true,
screenshotFailures: false,
},
environment: TEST_ENVIRONMENT,
exclude: ['e2e/**'],
root: fileURLToPath(new URL('./', import.meta.url)),

if (env.mode === 'demo') {
const { lib, rollupOptions, ...build } = config.build!;
config.build = build;
}
/** @see {@link webkitFlakinessMitigations} */
globalSetup,

return config;
// Suppress the console error log about parsing CSS stylesheet
// This is an open issue of jsdom
// see primefaces/primevue#4512 and jsdom/jsdom#2177
onConsoleLog(log: string, type: 'stderr' | 'stdout'): false | void {
if (log.includes('Error: Could not parse CSS stylesheet') && type === 'stderr') {
return false;
}
},
},
};
});
80 changes: 0 additions & 80 deletions packages/web-forms/vitest.config.ts

This file was deleted.

0 comments on commit 34e097a

Please sign in to comment.