diff options
author | 2024-01-23 16:18:09 -0700 | |
---|---|---|
committer | 2024-01-23 18:18:09 -0500 | |
commit | df37366556d46f7abdf82b09e33b08bd94e631b3 (patch) | |
tree | f3df548cdf291e8c150810793f1ebdf578187bc5 /packages/integrations/mdx/test/remark-imgattr.test.js | |
parent | 2e58904cd44eb6a36d2b093dc3b27ee29758326b (diff) | |
download | astro-df37366556d46f7abdf82b09e33b08bd94e631b3.tar.gz astro-df37366556d46f7abdf82b09e33b08bd94e631b3.tar.zst astro-df37366556d46f7abdf82b09e33b08bd94e631b3.zip |
MDX remark image props (#9753)
* rearrange plugins and add props to Image component
* add tests and update lockfile
* add changeset
* re-rearrange plugin order, gfm/smartypants then user defined then image related then shiki/prism
* make more generic
* add more/better tests
* remove unused logger
---------
Co-authored-by: Erika <3019731+Princesseuh@users.noreply.github.com>
Diffstat (limited to 'packages/integrations/mdx/test/remark-imgattr.test.js')
-rw-r--r-- | packages/integrations/mdx/test/remark-imgattr.test.js | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/packages/integrations/mdx/test/remark-imgattr.test.js b/packages/integrations/mdx/test/remark-imgattr.test.js new file mode 100644 index 000000000..7bedc3e91 --- /dev/null +++ b/packages/integrations/mdx/test/remark-imgattr.test.js @@ -0,0 +1,50 @@ +import { expect } from 'chai'; +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'); + expect($img.attr('id')).to.equal('test'); + expect($img.attr('sizes')).to.equal('(min-width: 600px) 600w, 300w'); + expect($img.attr('srcset')).to.not.be.empty; + }); + + it('<img> was processed properly', async () => { + let $img = $('img'); + expect(new URL($img.attr('src'), 'http://example.com').searchParams.get('w')).to.equal( + '300' + ); + }); + }); + }); +}); |