* feat: remove component framework selector * feat: update templates to use "basics" * feat: add "astro add" cli step * tests: astro add step * fix: reset env for pnpm tests * fix: update install step test * chore: remove "frameworks" step from tests * deps: remove node-fetch from create-astro * chore: changeset * fix: use "preferLocal" for astro add command * refactor: remove POSTPROCESS_FILES * feat: add --yes flag to simplify astro add * feat: bring back minimal option as "completely empty"
39 lines
1.2 KiB
JavaScript
39 lines
1.2 KiB
JavaScript
import { execa } from 'execa';
|
|
import { fileURLToPath } from 'url';
|
|
import { dirname } from 'path';
|
|
|
|
const __filename = fileURLToPath(import.meta.url);
|
|
export const testDir = dirname(__filename);
|
|
export const timeout = 5000;
|
|
|
|
const createAstroError = new Error(
|
|
'Timed out waiting for create-astro to respond with expected output.'
|
|
);
|
|
|
|
export function promiseWithTimeout(testFn) {
|
|
return new Promise((resolve, reject) => {
|
|
const timeoutEvent = setTimeout(() => {
|
|
reject(createAstroError);
|
|
}, timeout);
|
|
function resolver() {
|
|
clearTimeout(timeoutEvent);
|
|
resolve();
|
|
}
|
|
testFn(resolver);
|
|
});
|
|
}
|
|
|
|
export const PROMPT_MESSAGES = {
|
|
directory: 'Where would you like to create your app?',
|
|
template: 'Which app template would you like to use?',
|
|
install: (pkgManager) => `Would you like us to run "${pkgManager} install?"`,
|
|
astroAdd: (astroAddCommand = 'npx astro@latest add --yes') => `Run "${astroAddCommand}?" This lets you optionally add component frameworks (ex. React), CSS frameworks (ex. Tailwind), and more.`,
|
|
};
|
|
|
|
export function setup(args = []) {
|
|
const { stdout, stdin } = execa('../create-astro.mjs', args, { cwd: testDir });
|
|
return {
|
|
stdin,
|
|
stdout,
|
|
};
|
|
}
|