Enable tests (#1773)

This commit is contained in:
Drew Powers 2021-11-09 10:06:25 -07:00 committed by GitHub
parent db215b902a
commit f22a5c45d8
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
6 changed files with 14 additions and 29 deletions

View file

@ -1,5 +1,5 @@
/** /**
* UNCOMMENT: when "window is not defined" error fixed in Vite * UNCOMMENT: fix "Error: Unable to render PersistentCounter because it is null!"
import { expect } from 'chai'; import { expect } from 'chai';
import cheerio from 'cheerio'; import cheerio from 'cheerio';
import { loadFixture } from './test-utils.js'; import { loadFixture } from './test-utils.js';
@ -11,7 +11,6 @@ before(async () => {
await fixture.build(); await fixture.build();
}); });
// TODO: fix "window is not defined" error in Vite
describe('Client only components', () => { describe('Client only components', () => {
it('Loads pages using client:only hydrator', async () => { it('Loads pages using client:only hydrator', async () => {
const html = await fixture.readFile('/index.html'); const html = await fixture.readFile('/index.html');

View file

@ -87,8 +87,7 @@ describe('Styles SSR', () => {
expect(wrapper).to.have.lengthOf(1); expect(wrapper).to.have.lengthOf(1);
}); });
// TODO: add dynamic class scoping in compiler it('Astro scoped styles', async () => {
it.skip('Astro scoped styles', async () => {
const html = await fixture.readFile('/index.html'); const html = await fixture.readFile('/index.html');
const $ = cheerio.load(html); const $ = cheerio.load(html);
@ -111,10 +110,13 @@ describe('Styles SSR', () => {
expect(el1.attr('class')).to.equal(`blue ${scopedClass}`); expect(el1.attr('class')).to.equal(`blue ${scopedClass}`);
expect(el2.attr('class')).to.equal(`visible ${scopedClass}`); expect(el2.attr('class')).to.equal(`visible ${scopedClass}`);
const css = $('style').text(); let css = '';
$('style').each((_, el) => {
css += $(el).html();
});
// test 4: CSS generates as expected // test 4: CSS generates as expected
expect(css.toString()).to.equal(`.blue.${scopedClass}{color:powderblue}.color\\:blue.${scopedClass}{color:powderblue}.visible.${scopedClass}{display:block}`); expect(css).to.include(`.blue.${scopedClass}{color:powderblue;}.color\\:blue.${scopedClass}{color:powderblue;}.visible.${scopedClass}{display:block;}`);
}); });
it('Astro scoped styles skipped without <style>', async () => { it('Astro scoped styles skipped without <style>', async () => {
@ -125,19 +127,10 @@ describe('Styles SSR', () => {
expect($('#no-scope').attr('class')).to.equal(undefined); expect($('#no-scope').attr('class')).to.equal(undefined);
}); });
// TODO: add behavior in compiler it('Astro scoped styles can be passed to child components', async () => {
it.skip('Astro scoped styles can be passed to child components', async () => {
const html = await fixture.readFile('/index.html'); const html = await fixture.readFile('/index.html');
const $ = cheerio.load(html); const $ = cheerio.load(html);
let scopedClass; expect($('#passed-in').attr('class')).to.match(/outer astro-[A-Z0-9]+ astro-[A-Z0-9]+/);
$('style')
.html()
.replace(/outer\.(astro-[A-Za-z0-9-]+)/, (match, p1) => {
scopedClass = p1;
return match;
});
expect($('#passed-in').attr('class')).to.equal(`outer ${scopedClass}`);
}); });
}); });

View file

@ -1,4 +1,3 @@
<script> <script>
import './logResize'; import './logResize';
@ -19,4 +18,3 @@
<pre>{ count }</pre> <pre>{ count }</pre>
<button on:click={add}>+</button> <button on:click={add}>+</button>
</div> </div>

View file

@ -1,3 +1,3 @@
window.addEventListener("resize", function() { window.addEventListener("resize", function() {
console.log("window resized"); console.log("window resized");
}); });

View file

@ -1,5 +1,3 @@
/**
* UNCOMMENT: add markdown support
import { expect } from 'chai'; import { expect } from 'chai';
import cheerio from 'cheerio'; import cheerio from 'cheerio';
import { loadFixture } from './test-utils.js'; import { loadFixture } from './test-utils.js';
@ -28,12 +26,9 @@ describe('Markdown tests', () => {
}); });
it('Can load a realworld markdown page with Astro', async () => { it('Can load a realworld markdown page with Astro', async () => {
const html = await fixture.fetch('/realworld/index.html'); const html = await fixture.readFile('/realworld/index.html');
const $ = cheerio.load(html); const $ = cheerio.load(html);
expect($('pre')).to.have.lengthOf(7); expect($('pre')).to.have.lengthOf(7);
}); });
}); });
*/
it.skip('is skipped', () => {});

View file

@ -39,7 +39,7 @@ describe('React Components', () => {
expect($('#pure')).to.have.lengthOf(1); expect($('#pure')).to.have.lengthOf(1);
}); });
// TODO: fix ocmpiler bug // TODO: fix compiler bug
it.skip('Includes reactroot on hydrating components', async () => { it.skip('Includes reactroot on hydrating components', async () => {
const html = await fixture.readFile('/index.html'); const html = await fixture.readFile('/index.html');
const $ = cheerio.load(html); const $ = cheerio.load(html);