Code formatting with 2 space indent
This commit is contained in:
@@ -10,7 +10,9 @@
|
||||
"home": {
|
||||
"index": "index.ejs",
|
||||
"error": "error.ejs",
|
||||
"hidden": [".ejs"]
|
||||
"hidden": [
|
||||
".ejs"
|
||||
]
|
||||
},
|
||||
"article": {
|
||||
"index": "index.md",
|
||||
|
||||
+3
-3
@@ -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
@@ -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
@@ -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
@@ -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();
|
||||
});
|
||||
|
||||
@@ -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
@@ -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, '')),
|
||||
};
|
||||
Reference in New Issue
Block a user