mirror of
https://github.com/facebook/docusaurus.git
synced 2025-06-01 02:12:36 +02:00
feat: custom pages (#994)
This commit is contained in:
parent
7d4d9fe961
commit
8691a2525c
25 changed files with 263 additions and 128 deletions
|
@ -1,35 +1,116 @@
|
|||
import loadPages from '@lib/load/pages';
|
||||
import path from 'path';
|
||||
import loadSetup from '../loadSetup';
|
||||
|
||||
describe('loadPages', () => {
|
||||
test('valid pages', async () => {
|
||||
const pagesDir = path.join(__dirname, '__fixtures__', 'simple-pages');
|
||||
const pagesMetadatas = await loadPages(pagesDir);
|
||||
pagesMetadatas.sort((a, b) => a.path > b.path); // because it was unordered
|
||||
test('simple website', async () => {
|
||||
const {pagesDir, env, siteConfig} = await loadSetup('simple');
|
||||
const pagesMetadatas = await loadPages({pagesDir, env, siteConfig});
|
||||
expect(pagesMetadatas).toEqual([
|
||||
{
|
||||
path: '/',
|
||||
source: 'index.js',
|
||||
permalink: '/',
|
||||
source: path.join(pagesDir, 'index.js'),
|
||||
},
|
||||
{
|
||||
path: '/bar/baz',
|
||||
source: 'bar/baz.js',
|
||||
},
|
||||
{
|
||||
path: '/foo',
|
||||
source: 'foo.js',
|
||||
},
|
||||
{
|
||||
path: '/foo/',
|
||||
source: 'foo/index.js',
|
||||
permalink: '/hello/world',
|
||||
source: path.join(pagesDir, 'hello', 'world.js'),
|
||||
},
|
||||
]);
|
||||
});
|
||||
|
||||
test('versioned website', async () => {
|
||||
const {pagesDir, env, siteConfig} = await loadSetup('versioned');
|
||||
const pagesMetadatas = await loadPages({pagesDir, env, siteConfig});
|
||||
expect(pagesMetadatas).toEqual([
|
||||
{
|
||||
permalink: '/',
|
||||
source: path.join(pagesDir, 'index.js'),
|
||||
},
|
||||
{
|
||||
permalink: '/hello/world',
|
||||
source: path.join(pagesDir, 'hello', 'world.js'),
|
||||
},
|
||||
]);
|
||||
});
|
||||
|
||||
test('versioned & translated website', async () => {
|
||||
const {pagesDir, env, siteConfig} = await loadSetup('transversioned');
|
||||
const pagesMetadatas = await loadPages({pagesDir, env, siteConfig});
|
||||
expect(pagesMetadatas).toEqual([
|
||||
{
|
||||
language: 'en',
|
||||
permalink: '/',
|
||||
source: path.join(pagesDir, 'index.js'),
|
||||
},
|
||||
{
|
||||
language: 'en',
|
||||
permalink: '/en/',
|
||||
source: path.join(pagesDir, 'index.js'),
|
||||
},
|
||||
{
|
||||
language: 'ko',
|
||||
permalink: '/ko/',
|
||||
source: path.join(pagesDir, 'index.js'),
|
||||
},
|
||||
{
|
||||
language: 'en',
|
||||
permalink: '/hello/world',
|
||||
source: path.join(pagesDir, 'hello', 'world.js'),
|
||||
},
|
||||
{
|
||||
language: 'en',
|
||||
permalink: '/en/hello/world',
|
||||
source: path.join(pagesDir, 'hello', 'world.js'),
|
||||
},
|
||||
{
|
||||
language: 'ko',
|
||||
permalink: '/ko/hello/world',
|
||||
source: path.join(pagesDir, 'hello', 'world.js'),
|
||||
},
|
||||
]);
|
||||
});
|
||||
|
||||
test('translated website', async () => {
|
||||
const {pagesDir, env, siteConfig} = await loadSetup('translated');
|
||||
const pagesMetadatas = await loadPages({pagesDir, env, siteConfig});
|
||||
expect(pagesMetadatas).toEqual([
|
||||
{
|
||||
language: 'en',
|
||||
permalink: '/',
|
||||
source: path.join(pagesDir, 'index.js'),
|
||||
},
|
||||
{
|
||||
language: 'en',
|
||||
permalink: '/en/',
|
||||
source: path.join(pagesDir, 'index.js'),
|
||||
},
|
||||
{
|
||||
language: 'ko',
|
||||
permalink: '/ko/',
|
||||
source: path.join(pagesDir, 'index.js'),
|
||||
},
|
||||
{
|
||||
language: 'en',
|
||||
permalink: '/hello/world',
|
||||
source: path.join(pagesDir, 'hello', 'world.js'),
|
||||
},
|
||||
{
|
||||
language: 'en',
|
||||
permalink: '/en/hello/world',
|
||||
source: path.join(pagesDir, 'hello', 'world.js'),
|
||||
},
|
||||
{
|
||||
language: 'ko',
|
||||
permalink: '/ko/hello/world',
|
||||
source: path.join(pagesDir, 'hello', 'world.js'),
|
||||
},
|
||||
]);
|
||||
expect(pagesMetadatas).not.toBeNull();
|
||||
});
|
||||
|
||||
test('invalid pages', async () => {
|
||||
const nonExistingDir = path.join(__dirname, '__fixtures__', 'nonExisting');
|
||||
const pagesMetadatas = await loadPages(nonExistingDir);
|
||||
const {env, siteConfig} = await loadSetup('simple');
|
||||
const pagesDir = path.join(__dirname, '__fixtures__', 'nonExisting');
|
||||
const pagesMetadatas = await loadPages({pagesDir, env, siteConfig});
|
||||
expect(pagesMetadatas).toEqual([]);
|
||||
});
|
||||
});
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue