2022-07-20 16:45:05 -04:00
|
|
|
import { expect } from 'chai';
|
|
|
|
import * as cheerio from 'cheerio';
|
|
|
|
import { loadFixture } from './test-utils.js';
|
|
|
|
|
|
|
|
describe('Astro Markdown Shiki', () => {
|
|
|
|
describe('Render shiki', () => {
|
|
|
|
let fixture;
|
|
|
|
|
|
|
|
before(async () => {
|
|
|
|
fixture = await loadFixture({ root: './fixtures/astro-markdown-shiki/normal/' });
|
|
|
|
await fixture.build();
|
|
|
|
});
|
|
|
|
|
|
|
|
it('Can render Astro <Markdown> with shiki', async () => {
|
|
|
|
const html = await fixture.readFile('/astro/index.html');
|
|
|
|
const $ = cheerio.load(html);
|
|
|
|
|
|
|
|
// There should be no HTML from Prism
|
|
|
|
expect($('.token')).to.have.lengthOf(0);
|
|
|
|
|
|
|
|
expect($('pre')).to.have.lengthOf(2);
|
|
|
|
|
|
|
|
expect($('span.line')).to.have.lengthOf(2);
|
|
|
|
expect($('span.line').get(0).children).to.have.lengthOf(1);
|
|
|
|
expect($('span.line').get(1).children).to.have.lengthOf(5);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('Themes', () => {
|
|
|
|
describe('Integrated theme', async () => {
|
|
|
|
let fixture;
|
|
|
|
|
|
|
|
before(async () => {
|
|
|
|
fixture = await loadFixture({ root: './fixtures/astro-markdown-shiki/themes-integrated/' });
|
|
|
|
await fixture.build();
|
|
|
|
});
|
|
|
|
|
|
|
|
it('<Markdown /> component', async () => {
|
|
|
|
const html = await fixture.readFile('/astro/index.html');
|
|
|
|
const $ = cheerio.load(html);
|
|
|
|
|
|
|
|
expect($('pre')).to.have.lengthOf(1);
|
|
|
|
expect($('pre').hasClass('astro-code')).to.equal(true);
|
2023-05-03 23:07:57 +08:00
|
|
|
expect($('pre').attr().style).to.equal('background-color: #fff; overflow-x: auto;');
|
2022-07-20 16:45:05 -04:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('Custom theme', async () => {
|
|
|
|
let fixture;
|
|
|
|
|
|
|
|
before(async () => {
|
|
|
|
fixture = await loadFixture({ root: './fixtures/astro-markdown-shiki/themes-custom/' });
|
|
|
|
await fixture.build();
|
|
|
|
});
|
|
|
|
|
|
|
|
it('<Markdown /> component', async () => {
|
|
|
|
const html = await fixture.readFile('/astro/index.html');
|
|
|
|
const $ = cheerio.load(html);
|
|
|
|
|
|
|
|
expect($('pre')).to.have.lengthOf(1);
|
|
|
|
expect($('pre').hasClass('astro-code')).to.equal(true);
|
|
|
|
expect($('pre').attr().style).to.equal('background-color: #FDFDFE; overflow-x: auto;');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('Custom langs', () => {
|
|
|
|
let fixture;
|
|
|
|
|
|
|
|
before(async () => {
|
|
|
|
fixture = await loadFixture({ root: './fixtures/astro-markdown-shiki/langs/' });
|
|
|
|
await fixture.build();
|
|
|
|
});
|
|
|
|
|
|
|
|
it('<Markdown /> component', async () => {
|
|
|
|
const html = await fixture.readFile('/astro/index.html');
|
|
|
|
const $ = cheerio.load(html);
|
|
|
|
|
|
|
|
const segments = $('.line').get(6).children;
|
|
|
|
expect(segments).to.have.lengthOf(3);
|
2023-05-03 23:07:57 +08:00
|
|
|
expect(segments[0].attribs.style).to.be.equal('color: #E1E4E8');
|
|
|
|
expect(segments[1].attribs.style).to.be.equal('color: #79B8FF');
|
2022-07-20 16:45:05 -04:00
|
|
|
|
|
|
|
const unknownLang = $('.line').last().html();
|
|
|
|
expect(unknownLang).to.be.equal(
|
2023-05-03 23:07:57 +08:00
|
|
|
'<span style="color: #e1e4e8">This language does not exist</span>'
|
2022-07-20 16:45:05 -04:00
|
|
|
);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('Wrap', () => {
|
|
|
|
describe('wrap = true', () => {
|
|
|
|
const style =
|
2023-05-03 23:07:57 +08:00
|
|
|
'background-color: #24292e; overflow-x: auto; white-space: pre-wrap; word-wrap: break-word;';
|
2022-07-20 16:45:05 -04:00
|
|
|
let fixture;
|
|
|
|
|
|
|
|
before(async () => {
|
|
|
|
fixture = await loadFixture({ root: './fixtures/astro-markdown-shiki/wrap-true/' });
|
|
|
|
await fixture.build();
|
|
|
|
});
|
|
|
|
|
|
|
|
it('<Markdown /> component', async () => {
|
|
|
|
const html = await fixture.readFile('/astro/index.html');
|
|
|
|
const $ = cheerio.load(html);
|
|
|
|
|
|
|
|
expect($('pre').get(0).attribs.style).to.equal(style);
|
|
|
|
expect($('pre').get(1).attribs.style).to.equal(style);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('wrap = false', () => {
|
2023-05-03 23:07:57 +08:00
|
|
|
const style = 'background-color: #24292e; overflow-x: auto;';
|
2022-07-20 16:45:05 -04:00
|
|
|
let fixture;
|
|
|
|
|
|
|
|
before(async () => {
|
|
|
|
fixture = await loadFixture({ root: './fixtures/astro-markdown-shiki/wrap-false/' });
|
|
|
|
await fixture.build();
|
|
|
|
});
|
|
|
|
|
|
|
|
it('<Markdown /> component', async () => {
|
|
|
|
const html = await fixture.readFile('/astro/index.html');
|
|
|
|
const $ = cheerio.load(html);
|
|
|
|
|
|
|
|
expect($('pre').get(0).attribs.style).to.equal(style);
|
|
|
|
expect($('pre').get(1).attribs.style).to.equal(style);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('wrap = null', () => {
|
2023-05-03 23:07:57 +08:00
|
|
|
const style = 'background-color: #24292e';
|
2022-07-20 16:45:05 -04:00
|
|
|
let fixture;
|
|
|
|
|
|
|
|
before(async () => {
|
|
|
|
fixture = await loadFixture({ root: './fixtures/astro-markdown-shiki/wrap-null/' });
|
|
|
|
await fixture.build();
|
|
|
|
});
|
|
|
|
|
|
|
|
it('<Markdown /> component', async () => {
|
|
|
|
const html = await fixture.readFile('/astro/index.html');
|
|
|
|
const $ = cheerio.load(html);
|
|
|
|
|
|
|
|
expect($('pre').get(0).attribs.style).to.equal(style);
|
|
|
|
expect($('pre').get(1).attribs.style).to.equal(style);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|