astro/packages/astro/test/astro-slots.test.js
Matthew Phillips 518e8f7e25
Allow passing promises to set:html (#4819)
* Allow passing promises to set:html

* Adding a changeset
2022-09-20 13:13:21 -04:00

155 lines
4.6 KiB
JavaScript

import { expect } from 'chai';
import * as cheerio from 'cheerio';
import { loadFixture } from './test-utils.js';
describe('Slots', () => {
let fixture;
before(async () => {
fixture = await loadFixture({ root: './fixtures/astro-slots/' });
await fixture.build();
});
it('Basic named slots work', async () => {
const html = await fixture.readFile('/index.html');
const $ = cheerio.load(html);
expect($('#a').text().trim()).to.equal('A');
expect($('#b').text().trim()).to.equal('B');
expect($('#c').text().trim()).to.equal('C');
expect($('#default').text().trim()).to.equal('Default');
});
it('Dynamic named slots work', async () => {
const html = await fixture.readFile('/dynamic/index.html');
const $ = cheerio.load(html);
expect($('#a').text().trim()).to.equal('A');
expect($('#b').text().trim()).to.equal('B');
expect($('#c').text().trim()).to.equal('C');
expect($('#default').text().trim()).to.equal('Default');
});
it('Conditional named slots work', async () => {
const html = await fixture.readFile('/conditional/index.html');
const $ = cheerio.load(html);
expect($('#a').text().trim()).to.equal('A');
expect($('#b').text().trim()).to.equal('B');
expect($('#c').text().trim()).to.equal('C');
expect($('#default').text().trim()).to.equal('Default');
});
it('Slots render fallback content by default', async () => {
const html = await fixture.readFile('/fallback/index.html');
const $ = cheerio.load(html);
expect($('#default')).to.have.lengthOf(1);
});
it('Slots override fallback content', async () => {
const html = await fixture.readFile('/fallback-override/index.html');
const $ = cheerio.load(html);
expect($('#override')).to.have.lengthOf(1);
});
it('Slots work with multiple elements', async () => {
const html = await fixture.readFile('/multiple/index.html');
const $ = cheerio.load(html);
expect($('#a').text().trim()).to.equal('ABC');
});
it('Slots work on Components', async () => {
const html = await fixture.readFile('/component/index.html');
const $ = cheerio.load(html);
// test 1: #a renders
expect($('#a')).to.have.lengthOf(1);
// test 2: Slotted component into #a
expect($('#a').children('astro-component')).to.have.lengthOf(1);
// test 3: Slotted component into default slot
expect($('#default').children('astro-component')).to.have.lengthOf(1);
});
it('Slots API work on Components', async () => {
// IDs will exist whether the slots are filled or not
{
const html = await fixture.readFile('/slottedapi-default/index.html');
const $ = cheerio.load(html);
expect($('#a')).to.have.lengthOf(1);
expect($('#b')).to.have.lengthOf(1);
expect($('#c')).to.have.lengthOf(1);
expect($('#default')).to.have.lengthOf(1);
}
// IDs will not exist because the slots are not filled
{
const html = await fixture.readFile('/slottedapi-empty/index.html');
const $ = cheerio.load(html);
expect($('#a')).to.have.lengthOf(0);
expect($('#b')).to.have.lengthOf(0);
expect($('#c')).to.have.lengthOf(0);
expect($('#default')).to.have.lengthOf(0);
}
// IDs will exist because the slots are filled
{
const html = await fixture.readFile('/slottedapi-filled/index.html');
const $ = cheerio.load(html);
expect($('#a')).to.have.lengthOf(1);
expect($('#b')).to.have.lengthOf(1);
expect($('#c')).to.have.lengthOf(1);
expect($('#default')).to.have.lengthOf(0); // the default slot is not filled
}
// Default ID will exist because the default slot is filled
{
const html = await fixture.readFile('/slottedapi-default-filled/index.html');
const $ = cheerio.load(html);
expect($('#a')).to.have.lengthOf(0);
expect($('#b')).to.have.lengthOf(0);
expect($('#c')).to.have.lengthOf(0);
expect($('#default')).to.have.lengthOf(1); // the default slot is filled
}
});
it('Slots.render() API', async () => {
// Simple imperative slot render
{
const html = await fixture.readFile('/slottedapi-render/index.html');
const $ = cheerio.load(html);
expect($('#render')).to.have.lengthOf(1);
expect($('#render').text()).to.equal('render');
}
// Child function render without args
{
const html = await fixture.readFile('/slottedapi-render/index.html');
const $ = cheerio.load(html);
expect($('#render-fn')).to.have.lengthOf(1);
expect($('#render-fn').text()).to.equal('render-fn');
}
// Child function render with args
{
const html = await fixture.readFile('/slottedapi-render/index.html');
const $ = cheerio.load(html);
expect($('#render-args')).to.have.lengthOf(1);
expect($('#render-args span')).to.have.lengthOf(1);
expect($('#render-args').text()).to.equal('render-args');
}
});
});