summaryrefslogtreecommitdiffstats
path: root/packages
diff options
context:
space:
mode:
authorSamy Pesse <samypesse@gmail.com>2016-10-12 12:12:08 +0200
committerSamy Pesse <samypesse@gmail.com>2016-10-12 12:12:08 +0200
commit4b6fc0ae2f1bf684abf5b06caf6ac5cb3c796c6b (patch)
treedf26719971984c6998b397a28891fceb35b32be9 /packages
parent5d4dc499a59b5297e1998cfc4413edc3e888a772 (diff)
downloadgitbook-4b6fc0ae2f1bf684abf5b06caf6ac5cb3c796c6b.zip
gitbook-4b6fc0ae2f1bf684abf5b06caf6ac5cb3c796c6b.tar.gz
gitbook-4b6fc0ae2f1bf684abf5b06caf6ac5cb3c796c6b.tar.bz2
Adapt tests for website rendering and render languages index
Diffstat (limited to 'packages')
-rw-r--r--packages/gitbook/src/json/encodeState.js2
-rw-r--r--packages/gitbook/src/output/__tests__/website.js52
-rw-r--r--packages/gitbook/src/output/website/onFinish.js14
3 files changed, 32 insertions, 36 deletions
diff --git a/packages/gitbook/src/json/encodeState.js b/packages/gitbook/src/json/encodeState.js
index 50e7880..fb3e164 100644
--- a/packages/gitbook/src/json/encodeState.js
+++ b/packages/gitbook/src/json/encodeState.js
@@ -31,7 +31,7 @@ function encodeStateToJSON(output, page) {
glossary: encodeGlossary(book.getGlossary(), urls),
readme: encodeReadme(book.getReadme(), urls),
config: book.getConfig().getValues().toJS(),
- languages: book.isMultilingual() ? encodeLanguages(book.getLanguages()) : undefined,
+ languages: book.isMultilingual() ? encodeLanguages(book.getLanguages(), urls) : undefined,
page: page ? encodePage(page, book.getSummary(), urls) : undefined,
file: page ? encodeFile(page.getFile(), urls) : undefined
diff --git a/packages/gitbook/src/output/__tests__/website.js b/packages/gitbook/src/output/__tests__/website.js
index 3f37943..f81464d 100644
--- a/packages/gitbook/src/output/__tests__/website.js
+++ b/packages/gitbook/src/output/__tests__/website.js
@@ -1,22 +1,21 @@
-const fs = require('fs');
const generateMock = require('./generateMock');
const WebsiteGenerator = require('../website');
-describe('WebsiteGenerator', function() {
+describe('WebsiteGenerator', () => {
- it('should generate an index.html', function() {
+ it('should generate an index.html', () => {
return generateMock(WebsiteGenerator, {
'README.md': 'Hello World'
})
- .then(function(folder) {
+ .then((folder) => {
expect(folder).toHaveFile('index.html');
});
});
- describe('Glossary', function() {
+ describe('Glossary', () => {
let folder;
- before(function() {
+ before(() => {
return generateMock(WebsiteGenerator, {
'README.md': 'Hello World',
'SUMMARY.md': '* [Deep](folder/page.md)',
@@ -25,43 +24,30 @@ describe('WebsiteGenerator', function() {
},
'GLOSSARY.md': '# Glossary\n\n## Hello\n\nHello World'
})
- .then(function(_folder) {
+ .then((_folder) => {
folder = _folder;
});
});
- it('should generate a GLOSSARY.html', function() {
+ it('should generate a GLOSSARY.html', () => {
expect(folder).toHaveFile('GLOSSARY.html');
});
- it('should correctly resolve glossary links in README', function() {
- const html = fs.readFileSync(folder + '/index.html', 'utf8');
- expect(html).toHaveDOMElement('.page-inner a[href="GLOSSARY.html#hello"]');
- });
-
- it('should correctly resolve glossary links in directory', function() {
- const html = fs.readFileSync(folder + '/folder/page.html', 'utf8');
- expect(html).toHaveDOMElement('.page-inner a[href="../GLOSSARY.html#hello"]');
- });
-
- it('should accept a custom glossary file', function() {
+ it('should accept a custom glossary file', () => {
return generateMock(WebsiteGenerator, {
'README.md': 'Hello World',
'book.json': '{ "structure": { "glossary": "custom.md" } }',
'custom.md': '# Glossary\n\n## Hello\n\nHello World'
})
- .then(function(folder) {
- expect(folder).toHaveFile('custom.html');
- expect(folder).toNotHaveFile('GLOSSARY.html');
-
- const html = fs.readFileSync(folder + '/index.html', 'utf8');
- expect(html).toHaveDOMElement('.page-inner a[href="custom.html#hello"]');
+ .then((result) => {
+ expect(result).toHaveFile('custom.html');
+ expect(result).toNotHaveFile('GLOSSARY.html');
});
});
});
- it('should copy asset files', function() {
+ it('should copy asset files', () => {
return generateMock(WebsiteGenerator, {
'README.md': 'Hello World',
'myJsFile.js': 'var a = "test";',
@@ -69,14 +55,14 @@ describe('WebsiteGenerator', function() {
'AnotherAssetFile.md': '# Even md'
}
})
- .then(function(folder) {
+ .then((folder) => {
expect(folder).toHaveFile('index.html');
expect(folder).toHaveFile('myJsFile.js');
expect(folder).toHaveFile('folder/AnotherAssetFile.md');
});
});
- it('should generate an index.html for AsciiDoc', function() {
+ it('should generate an index.html for AsciiDoc', () => {
return generateMock(WebsiteGenerator, {
'README.adoc': 'Hello World'
})
@@ -85,7 +71,7 @@ describe('WebsiteGenerator', function() {
});
});
- it('should generate an HTML file for each articles', function() {
+ it('should generate an HTML file for each articles', () => {
return generateMock(WebsiteGenerator, {
'README.md': 'Hello World',
'SUMMARY.md': '# Summary\n\n* [Page](test/page.md)',
@@ -99,7 +85,7 @@ describe('WebsiteGenerator', function() {
});
});
- it('should not generate file if entry file doesn\'t exist', function() {
+ it('should not generate file if entry file doesn\'t exist', () => {
return generateMock(WebsiteGenerator, {
'README.md': 'Hello World',
'SUMMARY.md': '# Summary\n\n* [Page 1](page.md)\n* [Page 2](test/page.md)',
@@ -107,14 +93,14 @@ describe('WebsiteGenerator', function() {
'page.md': 'Hello 2'
}
})
- .then(function(folder) {
+ .then((folder) => {
expect(folder).toHaveFile('index.html');
expect(folder).toNotHaveFile('page.html');
expect(folder).toHaveFile('test/page.html');
});
});
- it('should generate a multilingual book', function() {
+ it('should generate a multilingual book', () => {
return generateMock(WebsiteGenerator, {
'LANGS.md': '# Languages\n\n* [en](en)\n* [fr](fr)',
'en': {
@@ -124,7 +110,7 @@ describe('WebsiteGenerator', function() {
'README.md': 'Bonjour'
}
})
- .then(function(folder) {
+ .then((folder) => {
// It should generate languages
expect(folder).toHaveFile('en/index.html');
expect(folder).toHaveFile('fr/index.html');
diff --git a/packages/gitbook/src/output/website/onFinish.js b/packages/gitbook/src/output/website/onFinish.js
index 3426c3f..6efeed8 100644
--- a/packages/gitbook/src/output/website/onFinish.js
+++ b/packages/gitbook/src/output/website/onFinish.js
@@ -1,4 +1,7 @@
+const JSONUtils = require('../../json');
const Promise = require('../../utils/promise');
+const writeFile = require('../helper/writeFile');
+const render = require('../../browser/render');
/**
* Finish the generation, write the languages index.
@@ -13,8 +16,15 @@ function onFinish(output) {
return Promise(output);
}
- // TODO: multilingual index
- return Promise(output);
+ const plugins = output.getPlugins();
+
+ // Generate initial state
+ const initialState = JSONUtils.encodeState(output);
+
+ // Render using React
+ const html = render(plugins, initialState, 'browser', 'website:languages');
+
+ return writeFile(output, 'index.html', html);
}
module.exports = onFinish;