feat: load config from cwd and merge with defaults
Alan Pearce alan@alanpearce.eu
Fri, 30 Jun 2017 17:37:20 +0200
5 files changed, 56 insertions(+), 48 deletions(-)
M src/modules/config.js → src/modules/config.js
@@ -1,10 +1,14 @@-'use strict' +"use strict"; -const TOML = require('toml') -const config = require('configly') +const path = require("path"); +const TOML = require("toml"); +const config = require("configly"); -module.exports = config({ - parsers: { - toml: TOML.parse +module.exports = config( + ["./config", path.resolve(__dirname, "../../config/")], + { + parsers: { + toml: TOML.parse + } } -}) +);
M test/app.test.js → test/app.test.js
@@ -1,49 +1,49 @@-const test = require('ava') -const path = require('path') -const request = require('supertest') +const test = require("ava"); +const path = require("path"); +const request = require("supertest"); -const config = require('../src/modules/config.js') -config.posts.folder = path.resolve(__dirname, './data/') +process.chdir(path.resolve(__dirname, "./testsite/")); +const config = require(path.resolve(__dirname, "../src/modules/config.js")); -const app = require('../src/app.js') +const app = require("../src/app.js"); -test('homepage', t => { +test("homepage", t => { return request(app.listen()) - .get('/') + .get("/") .expect(200) .expect(/<title>Test Site<\/title>/) .expect(/<h1>Test Site<\/h1>/) .expect(/This is a test/) - .then(() => t.pass()) -}) + .then(() => t.pass()); +}); -test('post', t => { +test("post", t => { return request(app.listen()) - .get('/post/testfile') + .get("/post/testfile") .expect(200) .expect(/<h1>Lorem ipsum<\/h1>/) - .then(() => t.pass()) -}) + .then(() => t.pass()); +}); -test('post not found', t => { +test("post not found", t => { return request(app.listen()) - .get('/post/non-existant') + .get("/post/non-existant") .expect(404) .expect(/Post not found/) - .then(() => t.pass()) -}) + .then(() => t.pass()); +}); -test('tags', t => { +test("tags", t => { return request(app.listen()) - .get('/tag/a') + .get("/tag/a") .expect(200) .expect(/This is a test/) - .then(() => t.pass()) -}) + .then(() => t.pass()); +}); -test('tags not found', t => +test("tags not found", t => request(app.listen()) - .get('/tag/non-existant') + .get("/tag/non-existant") .expect(404) .expect(/tag non-existant not found/) - .then(() => t.pass())) + .then(() => t.pass()));
M test/domain/posts.test.js → test/domain/posts.test.js
@@ -1,23 +1,25 @@-const test = require('ava') -const path = require('path') +const test = require("ava"); +const path = require("path"); -const Posts = require('../../src/domain/posts.js')({ - folder: path.resolve('../data', __dirname), +const Posts = require("../../src/domain/posts.js")({ + folder: path.resolve(__dirname, "../testsite/posts/"), taxonomies: { - tag: 'tags', - category: 'categories' + tag: "tags", + category: "categories" } -}) +}); -test('get', t => { +test("get", t => { const expected = new Map( Object.entries({ - title: 'This is a test', - description: 'Test file', - tags: ['a', 'b'] + title: "This is a test", + description: "Test file", + tags: ["a", "b"] }) - ) - const post = Posts.get(path.resolve(__dirname, '../data/testfile.md')) - t.deepEqual(post.data, expected) - t.is(post.basename, 'testfile', 'must include basename') -}) + ); + const post = Posts.get( + path.resolve(__dirname, "../testsite/posts/testfile.md") + ); + t.deepEqual(post.data, expected); + t.is(post.basename, "testfile", "must include basename"); +});