Skip to content

Commit

Permalink
added config validation
Browse files Browse the repository at this point in the history
  • Loading branch information
trescube committed Jan 12, 2017
1 parent 31ca955 commit 760b5cd
Show file tree
Hide file tree
Showing 5 changed files with 202 additions and 3 deletions.
3 changes: 3 additions & 0 deletions index.js
Original file line number Diff line number Diff line change
@@ -1,3 +1,6 @@
const peliasConfig = require('pelias-config').generate();
require('./src/configValidation').validate(peliasConfig);

var createLookupStream = require('./src/lookupStream');
var createWofPipResolver = require('./src/resolversFactory');

Expand Down
8 changes: 5 additions & 3 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@
"who's on first"
],
"dependencies": {
"joi": "^10.1.0",
"lodash": "^4.6.0",
"pelias-config": "2.4.0",
"pelias-logger": "0.1.0",
Expand All @@ -33,11 +34,12 @@
"event-stream": "^3.3.2",
"intercept-stdout": "^0.1.2",
"jshint": "^2.8.0",
"precommit-hook": "^3.0.0",
"pelias-model": "4.4.0",
"precommit-hook": "^3.0.0",
"proxyquire": "^1.7.10",
"semantic-release": "^6.3.2",
"tap-dot": "^1.0.1",
"tape": "^4.2.2",
"semantic-release": "^6.3.2"
"tape": "^4.2.2"
},
"pre-commit": [
"lint",
Expand Down
23 changes: 23 additions & 0 deletions src/configValidation.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
'use strict';

const Joi = require('joi');

// requires just `maxConcurrentReqs`
const schema = Joi.object().keys({
imports: {
adminLookup: {
maxConcurrentReqs: Joi.number().integer()
}
}
}).unknown(true);

module.exports = {
validate: function validate(config) {
Joi.validate(config, schema, { allowUnknown: true }, (err, value) => {
if (err) {
throw new Error(err.details[0].message);
}
});
}

};
170 changes: 170 additions & 0 deletions test/configValidationTest.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,170 @@
'use strict';

const tape = require('tape');

const configValidation = require('../src/configValidation');
const proxyquire = require('proxyquire').noCallThru();

tape('tests configuration scenarios', function(test) {
test.test('missing imports should not throw error', function(t) {
const config = {};

t.doesNotThrow(function() {
configValidation.validate(config);
});
t.end();

});

test.test('non-object imports should throw error', function(t) {
[null, 17, 'string', [], true].forEach((value) => {
const config = { imports: value };

t.throws(function() {
configValidation.validate(config);
}, /"imports" must be an object/);
});

t.end();

});

test.test('missing imports.adminLookup should not throw error', function(t) {
const config = {
imports: {
}
};

t.doesNotThrow(function() {
configValidation.validate(config);
});
t.end();

});

test.test('non-object imports.adminLookup should throw error', function(t) {
[null, 17, 'string', [], true].forEach((value) => {
const config = {
imports: {
adminLookup: value
}
};

t.throws(function() {
configValidation.validate(config);
}, /"adminLookup" must be an object/);
});

t.end();

});

test.test('non-number imports.adminLookup.maxConcurrentReqs should throw error', function(t) {
[null, 'string', {}, [], true].forEach((value) => {
const config = {
imports: {
adminLookup: {
maxConcurrentReqs: value
}
}
};

t.throws(function() {
configValidation.validate(config);
}, /"maxConcurrentReqs" must be a number/);

});

t.end();

});

test.test('non-integer imports.adminLookup.maxConcurrentReqs should throw error', function(t) {
const config = {
imports: {
adminLookup: {
maxConcurrentReqs: 17.3
}
}
};

t.throws(function() {
configValidation.validate(config);
}, /"maxConcurrentReqs" must be an integer/);

t.end();

});

test.test('missing imports.adminLookup.maxConcurrentReqs should not throw error', function(t) {
const config = {
imports: {
adminLookup: {
}
}
};

t.doesNotThrow(function() {
configValidation.validate(config);
});

t.end();

});

test.test('integer imports.adminLookup.maxConcurrentReqs should not throw error', function(t) {
const config = {
imports: {
adminLookup: {
maxConcurrentReqs: 17
}
}
};

t.doesNotThrow(function() {
configValidation.validate(config);
});

t.end();

});

test.test('unknown properties should not throw errors', function(t) {
const config = {
imports: {
adminLookup: {
maxConcurrentReqs: 17,
unknown_property: 'property value'
}
}
};

t.doesNotThrow(function() {
configValidation.validate(config);
});

t.end();

});

});

tape('tests for main entry point', function(test) {
test.test('configValidation throwing error should rethrow', function(t) {
const config = {};

t.throws(function() {
proxyquire('../index', {
'./src/configValidation': {
validate: () => {
throw Error('config is not valid');
}
}
});

configValidation.validate(config);
}, /config is not valid/);
t.end();

});
});
1 change: 1 addition & 0 deletions test/test.js
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
require ('./configValidationTest.js');
require ('./lookupStreamTest.js');
require ('./resolversFactoryTest.js');
require ('./resolversFactoryLocalTest.js');

0 comments on commit 760b5cd

Please sign in to comment.