diff options
author | 2022-08-30 11:45:16 -0400 | |
---|---|---|
committer | 2022-08-30 11:45:16 -0400 | |
commit | 2f05f5d3071f01bf011212b5a91a5ac0c84fcff1 (patch) | |
tree | 52f5dd1c0b2511cea62e064d7a841f57d3b9df32 /packages/integrations/sitemap/test/trailing-slash.test.js | |
parent | 69b640b87c5d0f346129cd0cbd23efaf366bc8b1 (diff) | |
download | astro-2f05f5d3071f01bf011212b5a91a5ac0c84fcff1.tar.gz astro-2f05f5d3071f01bf011212b5a91a5ac0c84fcff1.tar.zst astro-2f05f5d3071f01bf011212b5a91a5ac0c84fcff1.zip |
Include trailingSlash in astro:build:done hook (#4553)
Diffstat (limited to '')
-rw-r--r-- | packages/integrations/sitemap/test/trailing-slash.test.js | 79 |
1 files changed, 79 insertions, 0 deletions
diff --git a/packages/integrations/sitemap/test/trailing-slash.test.js b/packages/integrations/sitemap/test/trailing-slash.test.js new file mode 100644 index 000000000..6b6aa3a35 --- /dev/null +++ b/packages/integrations/sitemap/test/trailing-slash.test.js @@ -0,0 +1,79 @@ +import { loadFixture, readXML } from './test-utils.js'; +import { expect } from 'chai'; + +describe('Trailing slash', () => { + /** @type {import('./test-utils').Fixture} */ + let fixture; + + describe('trailingSlash: ignore', () => { + describe('build.format: directory', () => { + before(async () => { + fixture = await loadFixture({ + root: './fixtures/trailing-slash/', + trailingSlash: 'ignore', + build: { + format: 'directory' + } + }); + await fixture.build(); + }); + + it('URLs end with trailing slash', async () => { + const data = await readXML(fixture.readFile('/sitemap-0.xml')); + const urls = data.urlset.url; + expect(urls[0].loc[0]).to.equal('http://example.com/one/'); + }); + }); + + describe('build.format: file', () => { + before(async () => { + fixture = await loadFixture({ + root: './fixtures/trailing-slash/', + trailingSlash: 'ignore', + build: { + format: 'file' + } + }); + await fixture.build(); + }); + + it('URLs do not end with trailing slash', async () => { + const data = await readXML(fixture.readFile('/sitemap-0.xml')); + const urls = data.urlset.url; + expect(urls[0].loc[0]).to.equal('http://example.com/one'); + }); + }); + }); + + describe('trailingSlash: never', () => { + before(async () => { + fixture = await loadFixture({ + root: './fixtures/trailing-slash/', + trailingSlash: 'never', + }); + await fixture.build(); + }); + + it('URLs do no end with trailing slash', async () => { + const data = await readXML(fixture.readFile('/sitemap-0.xml')); + const urls = data.urlset.url; + expect(urls[0].loc[0]).to.equal('http://example.com/one'); + }); + }); + + describe('trailingSlash: always', () => { + before(async () => { + fixture = await loadFixture({ + root: './fixtures/trailing-slash/', + trailingSlash: 'always', + }); + await fixture.build(); + }); + + it('URLs end with trailing slash', async () => { + const data = await readXML(fixture.readFile('/sitemap-0.xml')); + const urls = data.urlset.url; + expect(urls[0].loc[0]).to.equal('http://example.com/one/'); + }); + }); +}); |