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));
|
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.__defineGetter__('target',function() { load(); return config.target|| "http://localhost:1880" });
|
||||||
module.exports.__defineSetter__('target',function(v) { load(); config.target = v; save();});
|
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.headers['content-type'] = 'application/json';
|
||||||
}
|
}
|
||||||
options.url = basePath+path;
|
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) {
|
if (!error && response.statusCode == 200) {
|
||||||
resolve(JSON.parse(body));
|
resolve(JSON.parse(body));
|
||||||
} else if (error) {
|
} else if (error) {
|
||||||
|
@ -12,4 +12,42 @@
|
|||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
* See the License for the specific language governing permissions and
|
* See the License for the specific language governing permissions and
|
||||||
* limitations under the License.
|
* 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.
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
* See the License for the specific language governing permissions and
|
* See the License for the specific language governing permissions and
|
||||||
* limitations under the License.
|
* 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