Skip to content

Commit

Permalink
[fix] Ensure that all options are passed to Provider.prototype.add
Browse files Browse the repository at this point in the history
…in `Provider.prototype.file`. Fixes #51

[doc] Update README.md and method documentation
[dist] Remove vim comments
  • Loading branch information
indexzero committed Jul 10, 2012
1 parent eeddb70 commit 7515f66
Show file tree
Hide file tree
Showing 4 changed files with 43 additions and 41 deletions.
6 changes: 5 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -88,7 +88,11 @@ A sane default for this could be:
//
// 4. Values in `config.json`
//
nconf.file({ file: 'config.json' });
nconf.file({
file: 'config.json',
dir: 'search/from/here',
search: true
});

//
// 5. Any default values
Expand Down
38 changes: 22 additions & 16 deletions lib/nconf/provider.js
Original file line number Diff line number Diff line change
Expand Up @@ -36,23 +36,29 @@ var Provider = exports.Provider = function (options) {
});

//
// Adds the file at `path` to the stores with `key`
// If key is not given, `file` will be used as the key
// For backward compatibility, an object can still be passed like {file: '/etc/foo.conf'}
//
Provider.prototype.file = function(key, path) {
var args = Array.prototype.slice.call(arguments, 0);
if(args.length == 1) {

if(typeof key === 'object'){
path = key.file;
}
else {
path = key;
key = 'file';
}
// ### function file (key, path)
// #### @key {string|Object} Fully qualified options, name of file store, or path.
// #### @path {string} **Optional** Path to the file for `key`.
// Adds a new `File` store to this instance. Accepts the following options
//
// nconf.file({ file: '.jitsuconf', dir: process.env.HOME, search: true })
// nconf.file('path/to/config/file')
// nconf.file('userconfig', 'path/to/config/file')
//
Provider.prototype.file = function (key, path) {
var options;

if (arguments.length == 1) {
options = typeof key !== 'object'
? { type: 'file', file: key }
: key;
key = 'file';
}
else {
options = { type: 'file', file: path };
}
return this.add(key, {type: 'file', file: path});

return this.add(key, options);
};

//
Expand Down
36 changes: 15 additions & 21 deletions test/complete-test.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,8 @@
/*
* complete-test.js: Complete test with multiple providers
* complete-test.js: Complete test for multiple stores.
*
* (C) 2011, Nodejitsu Inc.
*
*/

var fs = require('fs'),
Expand All @@ -10,34 +13,36 @@ var fs = require('fs'),
data = require('./fixtures/data').data,
helpers = require('./helpers');

var complete = helpers.fixture('complete.json');
var completeTest = helpers.fixture('complete-test.json');
var completeTest = helpers.fixture('complete-test.json'),
complete = helpers.fixture('complete.json');

vows.describe('nconf').addBatch({
vows.describe('nconf/multiple-stores').addBatch({
"When using the nconf with multiple providers": {
topic: function () {
var that = this;
helpers.cp(complete, completeTest, function () {
nconf.env();
nconf.file({file: completeTest});
nconf.use('argv', {type: 'literal', store: data});
nconf.file({ file: completeTest });
nconf.use('argv', { type: 'literal', store: data });
that.callback();
});
},

"should have the correct `stores`": function () {
assert.isObject(nconf.stores.env);
assert.isObject(nconf.stores.argv);
assert.isObject(nconf.stores.file);
},
"env vars": {
"are present": function () {
Object.keys(process.env).forEach(function (key) {
assert.equal(nconf.get(key), process.env[key]);
});
}
},

"json vars": {
topic: function () {
fs.readFile(complete, 'utf8', this.callback);
},

"are present": function (err, data) {
assert.isNull(err);
data = JSON.parse(data);
Expand All @@ -46,32 +51,27 @@ vows.describe('nconf').addBatch({
});
}
},

"literal vars": {
"are present": function () {
Object.keys(data).forEach(function (key) {
assert.deepEqual(nconf.get(key), data[key]);
});
}
},

"and saving *synchronously*": {
topic: function () {
nconf.set('weebls', 'stuff');
return nconf.save();
},

"correct return value": function (topic) {
Object.keys(topic).forEach(function (key) {
assert.deepEqual(topic[key], nconf.get(key));
});
},

"the file": {
topic: function () {
fs.readFile(completeTest, 'utf8', this.callback);
},

"saved correctly": function (err, data) {
data = JSON.parse(data);
Object.keys(data).forEach(function (key) {
Expand All @@ -95,19 +95,16 @@ vows.describe('nconf').addBatch({
nconf.set('weebls', 'crap');
nconf.save(this.callback);
},

"correct return value": function (err, data) {
assert.isNull(err);
Object.keys(data).forEach(function (key) {
assert.deepEqual(data[key], nconf.get(key));
});
},

"the file": {
topic: function () {
fs.readFile(completeTest, 'utf8', this.callback);
},

"saved correctly": function (err, data) {
assert.isNull(err);
data = JSON.parse(data);
Expand All @@ -118,7 +115,6 @@ vows.describe('nconf').addBatch({
}
}
},

teardown: function () {
fs.unlinkSync(completeTest);
nconf.remove('file');
Expand All @@ -127,6 +123,4 @@ vows.describe('nconf').addBatch({
nconf.remove('env');
}
}
}).export(module);

// vim: ts=2 shiftwidth=2 softtabstop=2
}).export(module);
4 changes: 1 addition & 3 deletions test/helpers.js
Original file line number Diff line number Diff line change
Expand Up @@ -65,6 +65,4 @@ exports.cp = function (from, to, callback) {

exports.fixture = function (file) {
return require('path').join(__dirname, 'fixtures', file);
};

// vim: ts=2 shiftwidth=2 softtabstop=2
};

0 comments on commit 7515f66

Please sign in to comment.