2024-01-31 09:58:44 -05:00
|
|
|
import * as assert from 'node:assert/strict';
|
2024-02-21 09:08:19 -05:00
|
|
|
import { before, describe, it } from 'node:test';
|
2023-10-27 07:11:46 -05:00
|
|
|
import { parseHTML } from 'linkedom';
|
2024-02-21 09:08:19 -05:00
|
|
|
import { loadFixture } from './test-utils.js';
|
2023-10-27 07:11:46 -05:00
|
|
|
describe('Basics', () => {
|
|
|
|
/** @type {import('./test-utils').Fixture} */
|
|
|
|
let fixture;
|
|
|
|
|
|
|
|
before(async () => {
|
|
|
|
fixture = await loadFixture({
|
|
|
|
root: './fixtures/basics/',
|
|
|
|
});
|
|
|
|
await fixture.build();
|
|
|
|
});
|
|
|
|
|
|
|
|
it('Slots are added without the slot attribute', async () => {
|
|
|
|
const data = await fixture.readFile('/index.html');
|
|
|
|
const { document } = parseHTML(data);
|
|
|
|
const bar = document.querySelector('#foo');
|
|
|
|
|
2024-01-31 09:58:44 -05:00
|
|
|
assert.notEqual(bar, undefined);
|
|
|
|
assert.equal(bar.getAttribute('slot'), null);
|
2023-10-27 07:11:46 -05:00
|
|
|
});
|
2024-03-14 03:54:05 -05:00
|
|
|
|
|
|
|
it('Can show images from public', async () => {
|
|
|
|
const data = await fixture.readFile('/public/index.html');
|
|
|
|
const { document } = parseHTML(data);
|
|
|
|
const img = document.querySelector('img');
|
|
|
|
|
|
|
|
assert.notEqual(img, undefined);
|
|
|
|
assert.equal(img.getAttribute('src'), '/light_walrus.avif');
|
|
|
|
});
|
2024-10-03 13:52:11 -05:00
|
|
|
|
|
|
|
it('Should generate unique ids when using useId()', async () => {
|
|
|
|
const data = await fixture.readFile('/index.html');
|
|
|
|
const { document } = parseHTML(data);
|
|
|
|
|
|
|
|
const els = document.querySelectorAll('.vue-use-id');
|
|
|
|
assert.equal(els.length, 2);
|
|
|
|
assert.notEqual(els[0].getAttribute('id'), els[1].getAttribute('id'));
|
|
|
|
});
|
2023-10-27 07:11:46 -05:00
|
|
|
});
|