mirror of
https://github.com/withastro/astro.git
synced 2025-01-22 18:41:55 -05:00
d08ddaf5b9
* chore: `yarn` => `pnpm` * docs: `yarn` => `pnpm` * chore(ci): yarn => pnpm * chore(ci): update pnpm cache path * fix: add missing deps * fix: add missing deps * test: add package.json to all test fixtures * chore: improve hoisting behavior * chore: move turbo into package.json * chore: update npmrc * fix: add missing `debug` dependency * chore: remove prepare script * test: fix new tests * fix: fully resolve renderer paths and `astro/internal` path * chore: update lockfile * chore: remove log * fix: resolve renderers in vite-plugin-jsx * fix: prefer public-hoist-pattern to shamefully-hoist * chore: ignore @babel/core peer warning * chore: update dependencies * test: add autoprefixer as explicit dep * chore: update `.npmrc` file in examples * chore: update dependencies * fix: resolve renderer dependencies in static build * fix: static build renderer resolution * chore: fix smoke tests * chore: hoist autoprefixer * chore: update lockfile * attempt: use full file:// path on Windows * attempt: use astro/internal * attempt: optimize astro/internal * attempt: expose ./internal.js * chore: add missing package.json files * attempt: resolve astro/internal path * chore: tidy package.json * chore: update lockfile * chore: update deps * chore: update deps * chore: yarn -> pnpm * attempt: explicit /@fs urls * attempt: explicit /@fs urls * chore: update all examples for pnpm * chore: fix hoisting for with-vite-plugin-pwa * chore(ci): fix sharp install * chore: update with-vite-plugin-pwa example * fix: pin vite-plugin-pwa to 0.11.11 * fix: add workbox-window to vite-plugin-pwa deps * refactor: use pnpm update --recursive Co-authored-by: JuanM04 <me@juanm04.com> * chore: yarn => pnpm * chore: yarn => pnpm * fix: update smoke test to skip examples which don't work in static build * update lockfile * chore: update .npmrc files * chore: update lockfile * fix: smoke script * chore: update .npmrc file * fix: return to shamefully-hoist (shamefully) * chore: update lockfile * fix(smoke): ignore scripts for smoke tests * fix: update example to disable renderers * chore: bump version * chore(ci): fix smoke tests * attempt: disable --frozen-lockfile for smoke tests * chore: update smoke test * chore: fix rebase issue * chore: update lockfile * fix: smoke tests * fix(ci): run external smoke tests first * fix(ci): run syntax * chore: update lockfile * fix(ci): ensure submodules are up-to-date * fix(ci): ensure submodules are up-to-date * chore: update lockfile * chore: update for webapi * chore: silence node:* warnings * chore: update deps * fix(ci): persist generated webapi assets * fix(ci): webapi build script * chore(ci): remove custom node caching * chore: keep turbo.json * chore: update turbo, ignore create-astro * chore: update deps * fix(ci): test command * chore(ci): update test script Co-authored-by: JuanM04 <me@juanm04.com>
65 lines
1.7 KiB
JavaScript
65 lines
1.7 KiB
JavaScript
/** @file Remove all smoke tests and may remove extra smoke-test dependencies from `pnpm-lock.yaml`. */
|
|
|
|
// @ts-check
|
|
|
|
import { execa } from 'execa';
|
|
import { polyfill } from '@astrojs/webapi';
|
|
import { fileURLToPath } from 'node:url';
|
|
import { promises as fs } from 'node:fs';
|
|
|
|
polyfill(globalThis, { exclude: 'window document' });
|
|
|
|
/* Configuration
|
|
/* ========================================================================== */
|
|
|
|
/** URL directory containing this current script. */
|
|
const scriptDir = new URL('./', import.meta.url);
|
|
|
|
/** URL directory containing the entire project. */
|
|
const rootDir = new URL('../../', import.meta.url);
|
|
|
|
/* Application
|
|
/* ========================================================================== */
|
|
|
|
/** Runs all smoke tests. */
|
|
async function run() {
|
|
const dirs = await getChildDirectories(scriptDir);
|
|
|
|
if (dirs.length) {
|
|
console.log();
|
|
|
|
for (const dir of await getChildDirectories(scriptDir)) {
|
|
console.log('🤖', 'Removing', dir.pathname.split('/').at(-1));
|
|
|
|
fs.rm(dir, { force: true, recursive: true });
|
|
}
|
|
}
|
|
|
|
console.log();
|
|
|
|
console.log('🤖', 'Resetting', 'pnpm');
|
|
|
|
await execa('pnpm', ['install'], { cwd: fileURLToPath(rootDir), stdout: 'inherit', stderr: 'inherit' });
|
|
}
|
|
|
|
/* Functionality
|
|
/* ========================================================================== */
|
|
|
|
/** Returns all child directories of the given directory. */
|
|
const getChildDirectories = async (/** @type {URL} */ dir) => {
|
|
/** @type {URL[]} */
|
|
const dirs = [];
|
|
|
|
for await (const dirent of await fs.opendir(dir)) {
|
|
if (dirent.isDirectory()) {
|
|
dirs.push(new URL(dirent.name, dir));
|
|
}
|
|
}
|
|
|
|
return dirs;
|
|
};
|
|
|
|
/* Execution
|
|
/* -------------------------------------------------------------------------- */
|
|
|
|
run();
|