0
Fork 0
mirror of https://github.com/withastro/astro.git synced 2025-01-06 22:10:10 -05:00
astro/packages/integrations/mdx/test/remark-imgattr.test.js
2024-01-31 08:37:34 +00:00

49 lines
1.3 KiB
JavaScript

import { describe, it, before, after } from 'node:test';
import * as assert from 'node:assert/strict';
import * as cheerio from 'cheerio';
import { loadFixture } from '../../../astro/test/test-utils.js';
const FIXTURE_ROOT = new URL('./fixtures/image-remark-imgattr/', import.meta.url);
describe('Testing remark plugins for image processing', () => {
/** @type {import('./test-utils').Fixture} */
let fixture;
describe('start dev server', () => {
/** @type {import('./test-utils').DevServer} */
let devServer;
before(async () => {
fixture = await loadFixture({
root: FIXTURE_ROOT,
});
devServer = await fixture.startDevServer();
});
after(async () => {
await devServer.stop();
});
describe('Test image attributes can be added by remark plugins', () => {
let $;
before(async () => {
let res = await fixture.fetch('/');
let html = await res.text();
$ = cheerio.load(html);
});
it('<img> has correct attributes', async () => {
let $img = $('img');
assert.equal($img.attr('id'), 'test');
assert.equal($img.attr('sizes'), '(min-width: 600px) 600w, 300w');
assert.ok($img.attr('srcset'));
});
it('<img> was processed properly', async () => {
let $img = $('img');
assert.equal(new URL($img.attr('src'), 'http://example.com').searchParams.get('w'), '300');
});
});
});
});