all repos — archive/homestead @ 562b0533300ad5ad8cf4695aa7fc2b844b918169

My future indieweb platform

feat: load config from cwd and merge with defaults
Alan Pearce alan@alanpearce.eu
Fri, 30 Jun 2017 17:37:20 +0200
commit

562b0533300ad5ad8cf4695aa7fc2b844b918169

parent

136ebe22452c0015770d9f0ac9d94d8941461816

M src/modules/config.jssrc/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.jstest/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.jstest/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");
+});
A test/testsite/config.toml
@@ -0,0 +1,2 @@+[posts]
+folder = "./posts"