0
Fork 0
mirror of https://github.com/withastro/astro.git synced 2025-01-06 22:10:10 -05:00

Disabling unreliable E2E test for further investigation (#3560)

* fixing reliability issue in component HMR tests

* fix: test change snuck into the last commit

* TEMP: logging to track down ubuntu CI failure

* disabling svelte test for now

* reverting unrelated .d.ts change
This commit is contained in:
Tony Sullivan 2022-06-10 18:18:11 +00:00 committed by GitHub
parent 6e8391365a
commit 99ee40ced0
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 54 additions and 22 deletions

View file

@ -1,7 +1,6 @@
<script> <script>
export let id; export let id;
let children;
let count = 0; let count = 0;
function add() { function add() {

View file

@ -1,5 +1,4 @@
import { test as base, expect } from '@playwright/test'; import { test as base, expect } from '@playwright/test';
import os from 'os';
import { loadFixture } from './test-utils.js'; import { loadFixture } from './test-utils.js';
const test = base.extend({ const test = base.extend({
@ -111,49 +110,83 @@ test.describe('Multiple frameworks', () => {
test('Page template', async ({ astro, page }) => { test('Page template', async ({ astro, page }) => {
await page.goto('/'); await page.goto('/');
// 1: updating the page template const slot = page.locator('#preact-counter + .counter-message');
const preactSlot = page.locator('#preact-counter + .counter-message'); await expect(slot, 'initial slot content').toHaveText('Hello Preact!');
await expect(preactSlot, 'initial slot content').toHaveText('Hello Preact!');
await astro.editFile('./src/pages/index.astro', (content) => await astro.editFile('./src/pages/index.astro', (content) =>
content.replace('Hello Preact!', 'Hello Preact, updated!') content.replace('Hello Preact!', 'Hello Preact, updated!')
); );
await expect(preactSlot, 'slot content updated').toHaveText('Hello Preact, updated!'); await expect(slot, 'slot content updated').toHaveText('Hello Preact, updated!');
}); });
test('React component', async ({ astro, page }) => { test('React component', async ({ astro, page }) => {
await page.goto('/'); await page.goto('/');
// Edit the react component const count = await page.locator('#react-counter pre');
await expect(count, 'initial count updated to 0').toHaveText('0');
await astro.editFile('./src/components/ReactCounter.jsx', (content) => await astro.editFile('./src/components/ReactCounter.jsx', (content) =>
content.replace('useState(0)', 'useState(5)') content.replace('useState(0)', 'useState(5)')
); );
const reactCount = await page.locator('#react-counter pre'); await expect(count, 'initial count updated to 5').toHaveText('5');
await expect(reactCount, 'initial count updated to 5').toHaveText('5');
}); });
// TODO: HMR works on Ubuntu, why is this specific test failing in CI? test('Preact component', async ({ astro, page }) => {
const it = os.platform() === 'linux' ? test.skip : test;
it('Svelte component', async ({ astro, page }) => {
await page.goto('/'); await page.goto('/');
// Edit the svelte component's style const count = await page.locator('#preact-counter pre');
const svelteCounter = page.locator('#svelte-counter'); await expect(count, 'initial count updated to 0').toHaveText('0');
await expect(svelteCounter, 'initial background is white').toHaveCSS(
'background-color', await astro.editFile('./src/components/PreactCounter.tsx', (content) =>
'rgb(255, 255, 255)' content.replace('useState(0)', 'useState(5)')
); );
await expect(count, 'initial count updated to 5').toHaveText('5');
});
test('Solid component', async ({ astro, page }) => {
await page.goto('/');
const count = await page.locator('#solid-counter pre');
await expect(count, 'initial count updated to 0').toHaveText('0');
await astro.editFile('./src/components/SolidCounter.tsx', (content) =>
content.replace('createSignal(0)', 'createSignal(5)')
);
await expect(count, 'initial count updated to 5').toHaveText('5');
});
// TODO: re-enable this test when #3559 is fixed
// https://github.com/withastro/astro/issues/3559
test.skip('Vue component', async ({ astro, page }) => {
await page.goto('/');
const count = await page.locator('#vue-counter pre');
await expect(count, 'initial count updated to 0').toHaveText('0');
await astro.editFile('./src/components/VueCounter.vue', (content) =>
content.replace('ref(0)', 'ref(5)')
);
await expect(count, 'initial count updated to 5').toHaveText('5');
});
// TODO: track down a reliability issue in this test
// It seems to lost connection to the vite server in CI
test.skip('Svelte component', async ({ astro, page }) => {
await page.goto('/');
const count = page.locator('#svelte-counter pre');
await expect(count, 'initial count is 0').toHaveText('0');
await astro.editFile('./src/components/SvelteCounter.svelte', (content) => await astro.editFile('./src/components/SvelteCounter.svelte', (content) =>
content.replace('background: white', 'background: rgb(230, 230, 230)') content.replace('let count = 0;', 'let count = 5;')
); );
await expect(svelteCounter, 'background color updated').toHaveCSS( await expect(count, 'initial count updated to 5').toHaveText('5');
'background-color',
'rgb(230, 230, 230)'
);
}); });
}); });
}); });