mirror of
https://github.com/node-red/node-red.git
synced 2023-10-10 13:36:53 +02:00
Add cli tests
This commit is contained in:
parent
af0b740fbd
commit
723a3e628e
@ -44,6 +44,10 @@ function save() {
|
||||
}
|
||||
fs.writeFileSync(configFile,JSON.stringify(config,null,4));
|
||||
}
|
||||
module.exports = {};
|
||||
module.exports = {
|
||||
unload: function() {
|
||||
config = null;
|
||||
}
|
||||
};
|
||||
module.exports.__defineGetter__('target',function() { load(); return config.target|| "http://localhost:1880" });
|
||||
module.exports.__defineSetter__('target',function(v) { load(); config.target = v; save();});
|
||||
|
@ -27,7 +27,18 @@ module.exports = function(path, options) {
|
||||
options.headers['content-type'] = 'application/json';
|
||||
}
|
||||
options.url = basePath+path;
|
||||
request(options, function(error,response,body) {
|
||||
|
||||
// Pull out the request function so we can stub it in the tests
|
||||
var requestFunc = request.get;
|
||||
|
||||
if (options.method == 'PUT') {
|
||||
requestFunc = request.put;
|
||||
} else if (options.method == 'POST') {
|
||||
requestFunc = request.post;
|
||||
} else if (options.method == 'DELETE') {
|
||||
requestFunc = request.delete;
|
||||
}
|
||||
requestFunc(options, function(error,response,body) {
|
||||
if (!error && response.statusCode == 200) {
|
||||
resolve(JSON.parse(body));
|
||||
} else if (error) {
|
||||
|
@ -12,4 +12,42 @@
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
**/
|
||||
**/
|
||||
|
||||
var should = require("should");
|
||||
var sinon = require("sinon");
|
||||
var fs = require("fs");
|
||||
|
||||
var config = require("../../../../red/cli/lib/config");
|
||||
|
||||
describe("cli config", function() {
|
||||
afterEach(function() {
|
||||
config.unload();
|
||||
});
|
||||
it('loads preferences when target referenced', sinon.test(function() {
|
||||
this.stub(fs,"readFileSync",function() {
|
||||
return '{"target":"http://example.com:1880"}'
|
||||
});
|
||||
config.target.should.eql("http://example.com:1880");
|
||||
}));
|
||||
it('provide default value for target', sinon.test(function() {
|
||||
this.stub(fs,"readFileSync",function() {
|
||||
return '{}'
|
||||
});
|
||||
config.target.should.eql("http://localhost:1880");
|
||||
}));
|
||||
it('saves preferences when target set', sinon.test(function() {
|
||||
this.stub(fs,"readFileSync",function() {
|
||||
return '{"target":"http://another.example.com:1880"}'
|
||||
});
|
||||
this.stub(fs,"writeFileSync",function() {});
|
||||
|
||||
config.target.should.eql("http://another.example.com:1880");
|
||||
config.target = "http://final.example.com:1880";
|
||||
|
||||
fs.readFileSync.calledOnce.should.be.true;
|
||||
fs.writeFileSync.calledOnce.should.be.true;
|
||||
|
||||
}));
|
||||
|
||||
});
|
@ -12,4 +12,35 @@
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
**/
|
||||
**/
|
||||
|
||||
var should = require("should");
|
||||
var sinon = require("sinon");
|
||||
var fs = require("fs");
|
||||
var request = require("request");
|
||||
|
||||
var apiRequest = require("../../../../red/cli/lib/request");
|
||||
var config = require("../../../../red/cli/lib/config");
|
||||
|
||||
describe("cli request", function() {
|
||||
var sandbox = sinon.sandbox.create();
|
||||
before(function() {
|
||||
sandbox.stub(fs,"readFileSync",function() {
|
||||
return '{"target":"http://example.com:1880"}'
|
||||
});
|
||||
});
|
||||
after(function() {
|
||||
sandbox.restore();
|
||||
});
|
||||
|
||||
it('returns the json response to a get', sinon.test(function(done) {
|
||||
this.stub(request, 'get').yields(null, {statusCode:200}, JSON.stringify({a: "b"}));
|
||||
|
||||
apiRequest("/foo",{}).then(function(res) {
|
||||
res.should.eql({a:"b"});
|
||||
done();
|
||||
}).otherwise(function(err) {
|
||||
done(err);
|
||||
});
|
||||
}));
|
||||
});
|
Loading…
Reference in New Issue
Block a user