Update tests for legacy build (#2746)
* move fast-build example into a test fixture for legacy build * update tests for legacy build
This commit is contained in:
parent
c9d84af6b1
commit
2906110c04
23 changed files with 48 additions and 79 deletions
|
@ -9,7 +9,6 @@
|
||||||
"@example/my-component": "0.0.1",
|
"@example/my-component": "0.0.1",
|
||||||
"@example/docs": "0.0.1",
|
"@example/docs": "0.0.1",
|
||||||
"@example/env-vars": "0.0.1",
|
"@example/env-vars": "0.0.1",
|
||||||
"@example/fast-build": "0.0.1",
|
|
||||||
"@example/framework-alpine": "0.0.1",
|
"@example/framework-alpine": "0.0.1",
|
||||||
"@example/framework-lit": "0.0.1",
|
"@example/framework-lit": "0.0.1",
|
||||||
"@example/framework-multiple": "0.0.1",
|
"@example/framework-multiple": "0.0.1",
|
||||||
|
|
|
@ -1,2 +0,0 @@
|
||||||
# Expose Astro dependencies for `pnpm` users
|
|
||||||
shamefully-hoist=true
|
|
|
@ -1,21 +0,0 @@
|
||||||
{
|
|
||||||
"name": "@example/fast-build",
|
|
||||||
"version": "0.0.1",
|
|
||||||
"private": true,
|
|
||||||
"scripts": {
|
|
||||||
"dev": "astro dev --experimental-static-build",
|
|
||||||
"start": "astro dev --experimental-static-build",
|
|
||||||
"build": "astro build --experimental-static-build",
|
|
||||||
"scan-build": "astro build",
|
|
||||||
"preview": "astro preview"
|
|
||||||
},
|
|
||||||
"devDependencies": {
|
|
||||||
"@astrojs/renderer-vue": "^0.4.0",
|
|
||||||
"@astrojs/renderer-preact": "^0.5.0",
|
|
||||||
"sass": "^1.49.8",
|
|
||||||
"astro": "^0.24.0-next.0",
|
|
||||||
"preact": "~10.6.5",
|
|
||||||
"unocss": "^0.15.5",
|
|
||||||
"vite-imagetools": "^4.0.1"
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,2 +0,0 @@
|
||||||
<div id="external-hoist"></div>
|
|
||||||
<script type="module" hoist src="/src/scripts/external-hoist"></script>
|
|
Binary file not shown.
Before Width: | Height: | Size: 12 KiB |
Binary file not shown.
Before Width: | Height: | Size: 14 KiB |
|
@ -117,7 +117,6 @@ function resolveFlags(flags: Partial<Flags>): CLIFlags {
|
||||||
// eslint-disable-next-line no-console
|
// eslint-disable-next-line no-console
|
||||||
console.warn(`Passing --experimental-static-build is no longer necessary and is now the default. The flag will be removed in a future version of Astro.`);
|
console.warn(`Passing --experimental-static-build is no longer necessary and is now the default. The flag will be removed in a future version of Astro.`);
|
||||||
}
|
}
|
||||||
|
|
||||||
return {
|
return {
|
||||||
projectRoot: typeof flags.projectRoot === 'string' ? flags.projectRoot : undefined,
|
projectRoot: typeof flags.projectRoot === 'string' ? flags.projectRoot : undefined,
|
||||||
site: typeof flags.site === 'string' ? flags.site : undefined,
|
site: typeof flags.site === 'string' ? flags.site : undefined,
|
||||||
|
@ -126,7 +125,6 @@ function resolveFlags(flags: Partial<Flags>): CLIFlags {
|
||||||
config: typeof flags.config === 'string' ? flags.config : undefined,
|
config: typeof flags.config === 'string' ? flags.config : undefined,
|
||||||
hostname: typeof flags.hostname === 'string' ? flags.hostname : undefined,
|
hostname: typeof flags.hostname === 'string' ? flags.hostname : undefined,
|
||||||
legacyBuild: typeof flags.legacyBuild === 'boolean' ? flags.legacyBuild : false,
|
legacyBuild: typeof flags.legacyBuild === 'boolean' ? flags.legacyBuild : false,
|
||||||
experimentalStaticBuild: typeof flags.experimentalStaticBuild === 'boolean' ? flags.experimentalStaticBuild : true,
|
|
||||||
experimentalSsr: typeof flags.experimentalSsr === 'boolean' ? flags.experimentalSsr : false,
|
experimentalSsr: typeof flags.experimentalSsr === 'boolean' ? flags.experimentalSsr : false,
|
||||||
drafts: typeof flags.drafts === 'boolean' ? flags.drafts : false,
|
drafts: typeof flags.drafts === 'boolean' ? flags.drafts : false,
|
||||||
};
|
};
|
||||||
|
@ -140,11 +138,10 @@ function mergeCLIFlags(astroConfig: AstroUserConfig, flags: CLIFlags) {
|
||||||
if (typeof flags.site === 'string') astroConfig.buildOptions.site = flags.site;
|
if (typeof flags.site === 'string') astroConfig.buildOptions.site = flags.site;
|
||||||
if (typeof flags.port === 'number') astroConfig.devOptions.port = flags.port;
|
if (typeof flags.port === 'number') astroConfig.devOptions.port = flags.port;
|
||||||
if (typeof flags.hostname === 'string') astroConfig.devOptions.hostname = flags.hostname;
|
if (typeof flags.hostname === 'string') astroConfig.devOptions.hostname = flags.hostname;
|
||||||
if (typeof flags.experimentalStaticBuild === 'boolean') astroConfig.buildOptions.experimentalStaticBuild = flags.experimentalStaticBuild;
|
if (typeof flags.legacyBuild === 'boolean') astroConfig.buildOptions.legacyBuild = flags.legacyBuild;
|
||||||
if (typeof flags.experimentalSsr === 'boolean') {
|
if (typeof flags.experimentalSsr === 'boolean') {
|
||||||
astroConfig.buildOptions.experimentalSsr = flags.experimentalSsr;
|
astroConfig.buildOptions.experimentalSsr = flags.experimentalSsr;
|
||||||
if (flags.experimentalSsr) {
|
if (flags.experimentalSsr) {
|
||||||
astroConfig.buildOptions.experimentalStaticBuild = true;
|
|
||||||
astroConfig.buildOptions.legacyBuild = false;
|
astroConfig.buildOptions.legacyBuild = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,9 +1,4 @@
|
||||||
import { imagetools } from 'vite-imagetools';
|
|
||||||
|
|
||||||
// @ts-check
|
// @ts-check
|
||||||
export default /** @type {import('astro').AstroUserConfig} */ ({
|
export default /** @type {import('astro').AstroUserConfig} */ ({
|
||||||
renderers: ['@astrojs/renderer-vue'],
|
renderers: ['@astrojs/renderer-vue'],
|
||||||
vite: {
|
|
||||||
plugins: [imagetools()],
|
|
||||||
},
|
|
||||||
});
|
});
|
10
packages/astro/test/fixtures/legacy-build/package.json
vendored
Normal file
10
packages/astro/test/fixtures/legacy-build/package.json
vendored
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
{
|
||||||
|
"name": "@astrojs/legacy-build",
|
||||||
|
"version": "0.0.0",
|
||||||
|
"private": true,
|
||||||
|
"dependencies": {
|
||||||
|
"@astrojs/renderer-vue": "^0.4.0",
|
||||||
|
"astro": "workspace:*",
|
||||||
|
"preact": "~10.6.5"
|
||||||
|
}
|
||||||
|
}
|
|
@ -2,9 +2,7 @@
|
||||||
import Greeting from '../components/Greeting.vue';
|
import Greeting from '../components/Greeting.vue';
|
||||||
|
|
||||||
export async function getStaticPaths() {
|
export async function getStaticPaths() {
|
||||||
const response = await fetch(`https://pokeapi.co/api/v2/pokemon?limit=2000`);
|
const allPokemon = [{name: 'Charmander'}, {name: 'Charmander'}, {name: 'Charizard'}];
|
||||||
const result = await response.json();
|
|
||||||
const allPokemon = result.results;
|
|
||||||
return allPokemon.map(pokemon => ({params: {pokemon: pokemon.name}, props: {pokemon}}));
|
return allPokemon.map(pokemon => ({params: {pokemon: pokemon.name}, props: {pokemon}}));
|
||||||
}
|
}
|
||||||
---
|
---
|
|
@ -1,11 +1,7 @@
|
||||||
---
|
---
|
||||||
import imgUrl from '../images/penguin.jpg';
|
|
||||||
import grayscaleUrl from '../images/random.jpg?grayscale=true';
|
|
||||||
import Greeting from '../components/Greeting.vue';
|
import Greeting from '../components/Greeting.vue';
|
||||||
import Counter from '../components/Counter.vue';
|
import Counter from '../components/Counter.vue';
|
||||||
// import { Code } from 'astro/components';
|
|
||||||
import InlineHoisted from '../components/InlineHoisted.astro';
|
import InlineHoisted from '../components/InlineHoisted.astro';
|
||||||
import ExternalHoisted from '../components/ExternalHoisted.astro';
|
|
||||||
---
|
---
|
||||||
|
|
||||||
<html>
|
<html>
|
||||||
|
@ -29,12 +25,6 @@ import ExternalHoisted from '../components/ExternalHoisted.astro';
|
||||||
</style>
|
</style>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<section>
|
|
||||||
<h1>Images</h1>
|
|
||||||
|
|
||||||
<h2>Imported in JS</h2>
|
|
||||||
<img src={imgUrl} />
|
|
||||||
</section>
|
|
||||||
|
|
||||||
<section>
|
<section>
|
||||||
<h1>Component CSS</h1>
|
<h1>Component CSS</h1>
|
||||||
|
@ -43,14 +33,10 @@ import ExternalHoisted from '../components/ExternalHoisted.astro';
|
||||||
|
|
||||||
<section>
|
<section>
|
||||||
<h1>ImageTools</h1>
|
<h1>ImageTools</h1>
|
||||||
<img src={grayscaleUrl} />
|
|
||||||
</section>
|
</section>
|
||||||
|
|
||||||
<section>
|
<section>
|
||||||
<h1>Astro components</h1>
|
<h1>Astro components</h1>
|
||||||
<!-- <Code lang="css" code={`body {
|
|
||||||
color: salmon;
|
|
||||||
}`} /> -->
|
|
||||||
</section>
|
</section>
|
||||||
|
|
||||||
<section>
|
<section>
|
||||||
|
@ -61,7 +47,6 @@ import ExternalHoisted from '../components/ExternalHoisted.astro';
|
||||||
<section>
|
<section>
|
||||||
<h1>Hoisted scripts</h1>
|
<h1>Hoisted scripts</h1>
|
||||||
<InlineHoisted />
|
<InlineHoisted />
|
||||||
<ExternalHoisted />
|
|
||||||
</section>
|
</section>
|
||||||
|
|
||||||
<section class="define-vars">
|
<section class="define-vars">
|
23
packages/astro/test/legacy-build.test.js
Normal file
23
packages/astro/test/legacy-build.test.js
Normal file
|
@ -0,0 +1,23 @@
|
||||||
|
import { expect } from 'chai';
|
||||||
|
import cheerio from 'cheerio';
|
||||||
|
import { loadFixture } from './test-utils.js';
|
||||||
|
|
||||||
|
describe('Legacy Build', () => {
|
||||||
|
let fixture;
|
||||||
|
|
||||||
|
before(async () => {
|
||||||
|
fixture = await loadFixture({
|
||||||
|
projectRoot: './fixtures/legacy-build/',
|
||||||
|
});
|
||||||
|
await fixture.build({buildOptions: {legacyBuild: true}});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('build', () => {
|
||||||
|
it('is successful', async () => {
|
||||||
|
const html = await fixture.readFile(`/index.html`);
|
||||||
|
const $ = cheerio.load(html);
|
||||||
|
expect($('title').text()).to.equal('Demo app');
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
});
|
|
@ -9,9 +9,7 @@ describe('Code component inside static build', () => {
|
||||||
fixture = await loadFixture({
|
fixture = await loadFixture({
|
||||||
projectRoot: './fixtures/static-build-code-component/',
|
projectRoot: './fixtures/static-build-code-component/',
|
||||||
renderers: [],
|
renderers: [],
|
||||||
buildOptions: {
|
buildOptions: {},
|
||||||
experimentalStaticBuild: true,
|
|
||||||
},
|
|
||||||
});
|
});
|
||||||
await fixture.build();
|
await fixture.build();
|
||||||
});
|
});
|
||||||
|
|
|
@ -13,9 +13,7 @@ describe('Static build - frameworks', () => {
|
||||||
fixture = await loadFixture({
|
fixture = await loadFixture({
|
||||||
projectRoot: './fixtures/static-build-frameworks/',
|
projectRoot: './fixtures/static-build-frameworks/',
|
||||||
renderers: ['@astrojs/renderer-preact', '@astrojs/renderer-react'],
|
renderers: ['@astrojs/renderer-preact', '@astrojs/renderer-react'],
|
||||||
buildOptions: {
|
buildOptions: {},
|
||||||
experimentalStaticBuild: true,
|
|
||||||
},
|
|
||||||
});
|
});
|
||||||
await fixture.build();
|
await fixture.build();
|
||||||
});
|
});
|
||||||
|
|
|
@ -14,7 +14,6 @@ describe("Static build - pageUrlFormat: 'file'", () => {
|
||||||
projectRoot: './fixtures/static-build-page-url-format/',
|
projectRoot: './fixtures/static-build-page-url-format/',
|
||||||
renderers: [],
|
renderers: [],
|
||||||
buildOptions: {
|
buildOptions: {
|
||||||
experimentalStaticBuild: true,
|
|
||||||
site: 'http://example.com/subpath/',
|
site: 'http://example.com/subpath/',
|
||||||
pageUrlFormat: 'file',
|
pageUrlFormat: 'file',
|
||||||
},
|
},
|
||||||
|
|
|
@ -14,7 +14,6 @@ describe('Static build', () => {
|
||||||
projectRoot: './fixtures/static build/',
|
projectRoot: './fixtures/static build/',
|
||||||
renderers: ['@astrojs/renderer-preact'],
|
renderers: ['@astrojs/renderer-preact'],
|
||||||
buildOptions: {
|
buildOptions: {
|
||||||
experimentalStaticBuild: true,
|
|
||||||
site: 'http://example.com/subpath/',
|
site: 'http://example.com/subpath/',
|
||||||
},
|
},
|
||||||
ssr: {
|
ssr: {
|
||||||
|
|
|
@ -105,24 +105,6 @@ importers:
|
||||||
devDependencies:
|
devDependencies:
|
||||||
astro: link:../../packages/astro
|
astro: link:../../packages/astro
|
||||||
|
|
||||||
examples/fast-build:
|
|
||||||
specifiers:
|
|
||||||
'@astrojs/renderer-preact': ^0.5.0
|
|
||||||
'@astrojs/renderer-vue': ^0.4.0
|
|
||||||
astro: ^0.24.0-next.0
|
|
||||||
preact: ~10.6.5
|
|
||||||
sass: ^1.49.8
|
|
||||||
unocss: ^0.15.5
|
|
||||||
vite-imagetools: ^4.0.1
|
|
||||||
devDependencies:
|
|
||||||
'@astrojs/renderer-preact': link:../../packages/renderers/renderer-preact
|
|
||||||
'@astrojs/renderer-vue': link:../../packages/renderers/renderer-vue
|
|
||||||
astro: link:../../packages/astro
|
|
||||||
preact: 10.6.6
|
|
||||||
sass: 1.49.9
|
|
||||||
unocss: 0.15.6
|
|
||||||
vite-imagetools: 4.0.3
|
|
||||||
|
|
||||||
examples/framework-alpine:
|
examples/framework-alpine:
|
||||||
specifiers:
|
specifiers:
|
||||||
astro: ^0.24.0-next.0
|
astro: ^0.24.0-next.0
|
||||||
|
@ -815,6 +797,16 @@ importers:
|
||||||
dependencies:
|
dependencies:
|
||||||
astro: link:../../..
|
astro: link:../../..
|
||||||
|
|
||||||
|
packages/astro/test/fixtures/legacy-build:
|
||||||
|
specifiers:
|
||||||
|
'@astrojs/renderer-vue': ^0.4.0
|
||||||
|
astro: workspace:*
|
||||||
|
preact: ~10.6.5
|
||||||
|
dependencies:
|
||||||
|
'@astrojs/renderer-vue': link:../../../../renderers/renderer-vue
|
||||||
|
astro: link:../../..
|
||||||
|
preact: 10.6.6
|
||||||
|
|
||||||
packages/astro/test/fixtures/lit-element:
|
packages/astro/test/fixtures/lit-element:
|
||||||
specifiers:
|
specifiers:
|
||||||
'@astrojs/renderer-lit': workspace:*
|
'@astrojs/renderer-lit': workspace:*
|
||||||
|
@ -8005,6 +7997,7 @@ packages:
|
||||||
|
|
||||||
/preact/10.6.6:
|
/preact/10.6.6:
|
||||||
resolution: {integrity: sha512-dgxpTFV2vs4vizwKohYKkk7g7rmp1wOOcfd4Tz3IB3Wi+ivZzsn/SpeKJhRENSE+n8sUfsAl4S3HiCVT923ABw==}
|
resolution: {integrity: sha512-dgxpTFV2vs4vizwKohYKkk7g7rmp1wOOcfd4Tz3IB3Wi+ivZzsn/SpeKJhRENSE+n8sUfsAl4S3HiCVT923ABw==}
|
||||||
|
dev: false
|
||||||
|
|
||||||
/prebuild-install/7.0.1:
|
/prebuild-install/7.0.1:
|
||||||
resolution: {integrity: sha512-QBSab31WqkyxpnMWQxubYAHR5S9B2+r81ucocew34Fkl98FhvKIF50jIJnNOBmAZfyNV7vE5T6gd3hTVWgY6tg==}
|
resolution: {integrity: sha512-QBSab31WqkyxpnMWQxubYAHR5S9B2+r81ucocew34Fkl98FhvKIF50jIJnNOBmAZfyNV7vE5T6gd3hTVWgY6tg==}
|
||||||
|
|
Loading…
Reference in a new issue