Code formatting with 2 space indent

This commit is contained in:
Clément GOUIN
2019-06-20 14:24:34 +02:00
parent 3df43b4872
commit 92021164c9
11 changed files with 676 additions and 674 deletions
+3 -1
View File
@@ -10,7 +10,9 @@
"home": {
"index": "index.ejs",
"error": "error.ejs",
"hidden": [".ejs"]
"hidden": [
".ejs"
]
},
"article": {
"index": "index.md",
+3 -3
View File
@@ -12,7 +12,7 @@ const merge = (ref, src) => {
return ref;
} else if (typeof ref === 'object') {
const out = {};
Object.keys(ref).forEach((key) =>out[key] = merge(ref[key], src[key]));
Object.keys(ref).forEach((key) => out[key] = merge(ref[key], src[key]));
return out;
} else {
return src;
@@ -21,11 +21,11 @@ const merge = (ref, src) => {
module.exports = () => {
try {
let configData = fs.readFileSync('config.json', {encoding:'UTF-8'});
let configData = fs.readFileSync('config.json', {encoding: 'UTF-8'});
let config = JSON.parse(configData);
return merge(refConfig, config);
} catch (error) {
console.error('Failed to load config.json : '+error);
console.error('Failed to load config.json : ' + error);
return refConfig;
}
};
+3 -3
View File
@@ -16,9 +16,9 @@ copy(path.join('src', 'config.default.json'), 'config.example.json');
if (!fs.existsSync('data')) {
fs.mkdirSync('data');
copy(path.join('sample_data','home'), 'data');
copy(path.join('sample_data', 'home'), 'data');
const pad0 = (n) =>('0' + n).substr(-2);
const pad0 = (n) => ('0' + n).substr(-2);
const datetime = new Date();
const dir = path.join('data', datetime.getFullYear().toString(), pad0(datetime.getMonth() + 1), pad0(datetime.getDate()));
@@ -26,5 +26,5 @@ if (!fs.existsSync('data')) {
if (!fs.existsSync(dir))
fs.mkdirSync(dir, {recursive: true});
copy(path.join('sample_data','article'), dir);
copy(path.join('sample_data', 'article'), dir);
}
+4 -4
View File
@@ -4,12 +4,12 @@ const showdown = require('showdown');
module.exports = (config) => {
const converter = new showdown.Converter(config['showdown']);
return {
render : (file, cb) => {
fs.readFile(file, {encoding:'UTF-8'}, (err, data) => {
if(err)
render: (file, cb) => {
fs.readFile(file, {encoding: 'UTF-8'}, (err, data) => {
if (err)
return cb(err);
const html = converter.makeHtml(data);
cb(null,html);
cb(null, html);
});
}
};
+46 -46
View File
@@ -16,16 +16,16 @@ const config = {
'home': {
'index': testIndex,
'error': testError,
'hidden': ['.ejs','.test']
'hidden': ['.ejs', '.test']
},
'article': {
'index': 'index.md',
'template' : testTemplate,
'template': testTemplate,
'thumbnail_tag': 'thumbnail',
'default_title': 'Untitled',
'default_thumbnail': null
},
'showdown' : {}
'showdown': {}
};
const app = require('../src/app')(config);
@@ -42,41 +42,41 @@ afterAll(() => {
});
describe('Test root path', () => {
test('404 no index no error', (done) =>{
request(app).get('/').then((response) =>{
test('404 no index no error', (done) => {
request(app).get('/').then((response) => {
expect(response.statusCode).toBe(404);
done();
});
});
test('404 no index but error page', (done) =>{
fs.writeFileSync(path.join(dataDir,testError), 'error <%= error %> at <%= path %>');
request(app).get('/').then((response) =>{
test('404 no index but error page', (done) => {
fs.writeFileSync(path.join(dataDir, testError), 'error <%= error %> at <%= path %>');
request(app).get('/').then((response) => {
expect(response.statusCode).toBe(404);
expect(response.text).toBe('error 404 at /');
done();
});
});
test('200 no articles', (done) =>{
fs.writeFileSync(path.join(dataDir,testIndex), 'articles <%= articles.length %>');
request(app).get('/').then((response) =>{
test('200 no articles', (done) => {
fs.writeFileSync(path.join(dataDir, testIndex), 'articles <%= articles.length %>');
request(app).get('/').then((response) => {
expect(response.statusCode).toBe(200);
expect(response.text).toBe('articles 0');
done();
});
});
test('200 2 articles', (done) =>{
test('200 2 articles', (done) => {
utils.createEmptyDirs([
path.join(dataDir, '2019', '05', '05'),
path.join(dataDir, '2018', '05', '05')
]);
utils.createEmptyFiles([
path.join(dataDir, '2019', '05', '05','index.md'),
path.join(dataDir, '2018', '05', '05','index.md')
path.join(dataDir, '2019', '05', '05', 'index.md'),
path.join(dataDir, '2018', '05', '05', 'index.md')
]);
fs.writeFileSync(path.join(dataDir,testIndex), 'articles <%= articles.length %>');
fs.writeFileSync(path.join(dataDir, testIndex), 'articles <%= articles.length %>');
app.reload((res) => {
expect(res).toBe(true);
request(app).get('/').then((response) =>{
request(app).get('/').then((response) => {
expect(response.statusCode).toBe(200);
expect(response.text).toBe('articles 2');
done();
@@ -87,32 +87,32 @@ describe('Test root path', () => {
});
describe('Test articles rendering', () => {
test('404 article not found', (done) =>{
request(app).get('/2019/05/06/untitled/').then((response) =>{
test('404 article not found', (done) => {
request(app).get('/2019/05/06/untitled/').then((response) => {
expect(response.statusCode).toBe(404);
done();
});
});
test('500 no template', (done) =>{
test('500 no template', (done) => {
utils.createEmptyDirs([path.join(dataDir, '2019', '05', '05'),]);
fs.writeFileSync(path.join(dataDir, '2019', '05', '05','index.md'), '# Hello');
fs.writeFileSync(path.join(dataDir, '2019', '05', '05', 'index.md'), '# Hello');
app.reload((res) => {
expect(res).toBe(true);
request(app).get('/2019/05/05/hello/').then((response) =>{
request(app).get('/2019/05/05/hello/').then((response) => {
expect(response.statusCode).toBe(500);
done();
});
});
});
test('200 rendered article', (done) =>{
test('200 rendered article', (done) => {
utils.createEmptyDirs([path.join(dataDir, '2019', '05', '05'),]);
fs.writeFileSync(path.join(dataDir, '2019', '05', '05','index.md'), '# Hello');
fs.writeFileSync(path.join(dataDir, '2019', '05', '05', 'index.md'), '# Hello');
fs.writeFileSync(path.join(dataDir, testTemplate), '<%- article.content %><%- `<a href="${article.url}">reload</a>` %>');
app.reload((res) => {
expect(res).toBe(true);
request(app).get('/2019/05/05/hello/').then((response) =>{
request(app).get('/2019/05/05/hello/').then((response) => {
expect(response.statusCode).toBe(200);
expect(response.text).toBe('<h1 id="hello">Hello</h1><a href="/2019/05/05/hello/">reload</a>');
done();
@@ -120,30 +120,30 @@ describe('Test articles rendering', () => {
});
});
test('200 other url', (done) =>{
test('200 other url', (done) => {
utils.createEmptyDirs([path.join(dataDir, '2019', '05', '05'),]);
utils.createEmptyFiles([
path.join(dataDir, '2019', '05', '05','index.md'),
path.join(dataDir, '2019', '05', '05', 'index.md'),
path.join(dataDir, testTemplate)
]);
app.reload((res) => {
expect(res).toBe(true);
request(app).get('/2019/05/05/anything/').then((response) =>{
request(app).get('/2019/05/05/anything/').then((response) => {
expect(response.statusCode).toBe(200);
done();
});
});
});
test('200 other url 2', (done) =>{
test('200 other url 2', (done) => {
utils.createEmptyDirs([path.join(dataDir, '2019', '05', '05'),]);
utils.createEmptyFiles([
path.join(dataDir, '2019', '05', '05','index.md'),
path.join(dataDir, '2019', '05', '05', 'index.md'),
path.join(dataDir, testTemplate)
]);
app.reload((res) => {
expect(res).toBe(true);
request(app).get('/2019/05/05/').then((response) =>{
request(app).get('/2019/05/05/').then((response) => {
expect(response.statusCode).toBe(200);
done();
});
@@ -153,30 +153,30 @@ describe('Test articles rendering', () => {
describe('Test static files', () => {
test('404 invalid file no error page', (done) =>{
request(app).get('/somefile.txt').then((response) =>{
test('404 invalid file no error page', (done) => {
request(app).get('/somefile.txt').then((response) => {
expect(response.statusCode).toBe(404);
done();
});
});
test('404 invalid file but error page', (done) =>{
fs.writeFileSync(path.join(dataDir,testError), 'error <%= error %> at <%= path %>');
request(app).get('/somefile.txt').then((response) =>{
test('404 invalid file but error page', (done) => {
fs.writeFileSync(path.join(dataDir, testError), 'error <%= error %> at <%= path %>');
request(app).get('/somefile.txt').then((response) => {
expect(response.statusCode).toBe(404);
expect(response.text).toBe('error 404 at /somefile.txt');
done();
});
});
test('404 hidden file', (done) =>{
fs.writeFileSync(path.join(dataDir,'somefile.test'), '');
request(app).get('/somefile.test').then((response) =>{
test('404 hidden file', (done) => {
fs.writeFileSync(path.join(dataDir, 'somefile.test'), '');
request(app).get('/somefile.test').then((response) => {
expect(response.statusCode).toBe(404);
done();
});
});
test('200 valid file', (done) =>{
test('200 valid file', (done) => {
fs.writeFileSync(`${dataDir}/somefile.txt`, 'filecontent');
request(app).get('/somefile.txt').then((response) =>{
request(app).get('/somefile.txt').then((response) => {
expect(response.statusCode).toBe(200);
expect(response.text).toBe('filecontent');
done();
@@ -185,20 +185,20 @@ describe('Test static files', () => {
});
describe('Test other requests', () => {
test('400 POST', (done) =>{
request(app).post('/').then((response) =>{
test('400 POST', (done) => {
request(app).post('/').then((response) => {
expect(response.statusCode).toBe(400);
done();
});
});
test('400 PUT', (done) =>{
request(app).put('/').then((response) =>{
test('400 PUT', (done) => {
request(app).put('/').then((response) => {
expect(response.statusCode).toBe(400);
done();
});
});
test('400 DELETE', (done) =>{
request(app).delete('/').then((response) =>{
test('400 DELETE', (done) => {
request(app).delete('/').then((response) => {
expect(response.statusCode).toBe(400);
done();
});
+4 -4
View File
@@ -230,11 +230,11 @@ describe('Test article fetching', () => {
year: 2019,
month: 5,
day: 5,
date : new Date(2019,5,5),
date: new Date(2019, 5, 5),
title: 'Untitled',
thumbnail: 'default.png',
escapedTitle: 'untitled',
url: '/'+path.join('2019', '05', '05', 'untitled')+'/',
url: '/' + path.join('2019', '05', '05', 'untitled') + '/',
});
done();
});
@@ -258,11 +258,11 @@ describe('Test article fetching', () => {
year: 2019,
month: 5,
day: 5,
date : new Date(2019,5,5),
date: new Date(2019, 5, 5),
title: 'Title with : info !',
thumbnail: path.join('2019', '05', '05', './thumbnail.jpg'),
escapedTitle: 'title_with___info',
url: '/'+path.join('2019', '05', '05', 'title_with___info')+'/',
url: '/' + path.join('2019', '05', '05', 'title_with___info') + '/',
});
done();
});
+4 -4
View File
@@ -6,15 +6,15 @@ const deleteFolderSync = (dir) => {
return;
fs.readdirSync(dir, {withFileTypes: true}).forEach((item) => {
if (item.isDirectory())
deleteFolderSync(path.join(dir,item.name));
deleteFolderSync(path.join(dir, item.name));
else
fs.unlinkSync(path.join(dir,item.name));
fs.unlinkSync(path.join(dir, item.name));
});
fs.rmdirSync(dir);
};
module.exports = {
deleteFolderSync: deleteFolderSync,
createEmptyDirs: (list) =>list.forEach((path) =>fs.mkdirSync(path, {recursive: true})),
createEmptyFiles: (list) =>list.forEach((file) =>fs.writeFileSync(file, '')),
createEmptyDirs: (list) => list.forEach((path) => fs.mkdirSync(path, {recursive: true})),
createEmptyFiles: (list) => list.forEach((file) => fs.writeFileSync(file, '')),
};