2017-11-30 22:48:52 +09:00
|
|
|
/**
|
|
|
|
* Copyright JS Foundation and other contributors, http://js.foundation
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* 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.
|
|
|
|
**/
|
|
|
|
|
2018-01-13 22:48:35 +00:00
|
|
|
var fs = require("fs-extra");
|
2017-11-30 22:48:52 +09:00
|
|
|
var path = require("path");
|
|
|
|
var should = require("should");
|
2018-03-01 20:41:16 -08:00
|
|
|
var helper = require("node-red-node-test-helper");
|
2018-08-20 16:17:24 +01:00
|
|
|
var watchNode = require("nr-test-utils").require("@node-red/nodes/core/io/23-watch.js");
|
2017-11-30 22:48:52 +09:00
|
|
|
|
|
|
|
|
|
|
|
describe('watch Node', function() {
|
|
|
|
this.timeout(5000);
|
|
|
|
|
|
|
|
var resourcesDir = path.join(__dirname,"..","..","..","resources");
|
|
|
|
var baseDir = path.join(resourcesDir, "23-watch-test-dir");
|
|
|
|
var count = 0;
|
|
|
|
|
|
|
|
function prepareDir() {
|
2018-01-13 22:59:05 +00:00
|
|
|
var dirToWatch = path.join(baseDir, "base"+count);
|
2017-11-30 22:48:52 +09:00
|
|
|
fs.mkdirSync(dirToWatch);
|
|
|
|
count++;
|
2018-01-13 22:48:35 +00:00
|
|
|
return {
|
|
|
|
dirToWatch:dirToWatch,
|
2018-01-13 23:00:05 +00:00
|
|
|
file0ToWatch:path.join(dirToWatch, "file0.txt"),
|
|
|
|
file1ToWatch:path.join(dirToWatch, "file1.txt"),
|
|
|
|
subDirToWatch:path.join(dirToWatch, "subdir"),
|
2018-01-13 23:14:01 +00:00
|
|
|
file2ToWatch:path.join(dirToWatch, "subdir", "file2.txt")
|
2018-01-13 22:48:35 +00:00
|
|
|
}
|
2017-11-30 22:48:52 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
function wait(msec, func) {
|
|
|
|
setTimeout(func, msec);
|
|
|
|
}
|
|
|
|
|
|
|
|
before(function(done) {
|
2018-01-13 22:48:35 +00:00
|
|
|
fs.ensureDirSync(baseDir);
|
2017-11-30 22:48:52 +09:00
|
|
|
done();
|
|
|
|
});
|
|
|
|
|
|
|
|
after(function(done) {
|
2018-01-13 22:48:35 +00:00
|
|
|
fs.removeSync(baseDir);
|
2017-11-30 22:48:52 +09:00
|
|
|
done();
|
|
|
|
});
|
|
|
|
|
|
|
|
afterEach(function(done) {
|
|
|
|
helper.unload();
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
|
|
|
|
function testWatch(flow, change_func, results, done) {
|
|
|
|
var processed = {};
|
|
|
|
helper.load(watchNode, flow, function() {
|
|
|
|
var n1 = helper.getNode("n1");
|
|
|
|
var n2 = helper.getNode("n2");
|
|
|
|
var count = 0;
|
|
|
|
var len = Object.keys(results).length;
|
|
|
|
n2.on("input", function(msg) {
|
2018-01-13 22:48:35 +00:00
|
|
|
try {
|
|
|
|
// console.log(msg);
|
|
|
|
msg.should.have.property('file');
|
|
|
|
|
|
|
|
var file = msg.file;
|
|
|
|
if (file in processed) {
|
|
|
|
// multiple messages come in rare case
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
processed[file] = true;
|
2018-01-13 23:24:41 +00:00
|
|
|
if (file === 'subdir') {
|
|
|
|
// On OSX, we get a change event on subdir when a file inside changes.
|
|
|
|
// On Travis, we don't. *sigh*
|
|
|
|
return;
|
|
|
|
}
|
2018-01-13 22:48:35 +00:00
|
|
|
(file in results).should.be.true();
|
|
|
|
|
|
|
|
var result = results[file];
|
|
|
|
msg.should.have.property('payload', result.payload);
|
|
|
|
msg.should.have.property('type', result.type);
|
|
|
|
if('size' in result) {
|
|
|
|
msg.should.have.property('size', result.size);
|
|
|
|
}
|
|
|
|
count++;
|
|
|
|
if(count === len) {
|
|
|
|
n1.close();
|
|
|
|
// wait for close
|
|
|
|
wait(100, done);
|
|
|
|
}
|
|
|
|
}catch(err) {
|
|
|
|
done(err);
|
2017-11-30 22:48:52 +09:00
|
|
|
}
|
|
|
|
});
|
|
|
|
// wait for preparation
|
|
|
|
wait(500, change_func);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
it('should watch a file to be changed', function(done) {
|
2018-01-13 22:48:35 +00:00
|
|
|
var files = prepareDir();
|
|
|
|
fs.writeFileSync(files.file0ToWatch, '');
|
2017-11-30 22:48:52 +09:00
|
|
|
var flow = [{id:"n1", type:"watch", name: "watch",
|
2018-01-13 22:48:35 +00:00
|
|
|
files: files.file0ToWatch, recursive: false,
|
2017-11-30 22:48:52 +09:00
|
|
|
wires:[["n2"]]},
|
|
|
|
{id:"n2", type:"helper"}];
|
|
|
|
var results = {
|
|
|
|
'file0.txt' : {
|
2018-01-13 22:48:35 +00:00
|
|
|
'payload' : files.file0ToWatch,
|
|
|
|
'topic': files.file0ToWatch,
|
2017-11-30 22:48:52 +09:00
|
|
|
'type': 'file',
|
|
|
|
'size': 5
|
|
|
|
}
|
|
|
|
};
|
|
|
|
testWatch(flow, function() {
|
2018-01-13 22:48:35 +00:00
|
|
|
fs.appendFileSync(files.file0ToWatch, "ABCDE");
|
2017-11-30 22:48:52 +09:00
|
|
|
}, results, done);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should watch multiple files to be changed', function(done) {
|
2018-01-13 22:48:35 +00:00
|
|
|
var files = prepareDir();
|
|
|
|
fs.writeFileSync(files.file0ToWatch, '');
|
|
|
|
fs.writeFileSync(files.file1ToWatch, '');
|
2017-11-30 22:48:52 +09:00
|
|
|
var flow = [{id:"n1", type:"watch", name: "watch",
|
2018-01-13 22:48:35 +00:00
|
|
|
files: files.file0ToWatch +","+files.file1ToWatch, recursive: false,
|
2017-11-30 22:48:52 +09:00
|
|
|
wires:[["n2"]]},
|
|
|
|
{id:"n2", type:"helper"}];
|
|
|
|
var results = {
|
|
|
|
'file0.txt' : {
|
2018-01-13 22:48:35 +00:00
|
|
|
'payload' : files.file0ToWatch,
|
|
|
|
'topic': files.file0ToWatch,
|
|
|
|
'type': 'file'//,
|
|
|
|
// 'size': 5
|
2017-11-30 22:48:52 +09:00
|
|
|
},
|
|
|
|
'file1.txt' : {
|
2018-01-13 22:48:35 +00:00
|
|
|
'payload' : files.file1ToWatch,
|
|
|
|
'topic': files.file1ToWatch,
|
|
|
|
'type': 'file'//,
|
|
|
|
// 'size': 3
|
2017-11-30 22:48:52 +09:00
|
|
|
}
|
|
|
|
};
|
|
|
|
testWatch(flow, function() {
|
2018-01-13 22:48:35 +00:00
|
|
|
fs.appendFileSync(files.file0ToWatch, "ABCDE");
|
|
|
|
fs.appendFileSync(files.file1ToWatch, "123");
|
2017-11-30 22:48:52 +09:00
|
|
|
}, results, done);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should watch attribute of a file to be changed', function(done) {
|
2018-01-13 22:48:35 +00:00
|
|
|
var files = prepareDir();
|
|
|
|
fs.writeFileSync(files.file0ToWatch, '');
|
|
|
|
fs.chmodSync(files.file0ToWatch, 0o444);
|
2017-11-30 22:48:52 +09:00
|
|
|
var flow = [{id:"n1", type:"watch", name: "watch",
|
2018-01-13 22:48:35 +00:00
|
|
|
files: files.file0ToWatch, recursive: false,
|
2017-11-30 22:48:52 +09:00
|
|
|
wires:[["n2"]]},
|
|
|
|
{id:"n2", type:"helper"}];
|
|
|
|
var results = {
|
|
|
|
'file0.txt' : {
|
2018-01-13 22:48:35 +00:00
|
|
|
'payload' : files.file0ToWatch,
|
|
|
|
'topic': files.file0ToWatch,
|
|
|
|
'type': 'file'//,
|
|
|
|
// 'size': 0
|
2017-11-30 22:48:52 +09:00
|
|
|
}
|
|
|
|
};
|
|
|
|
testWatch(flow, function() {
|
2018-01-13 22:48:35 +00:00
|
|
|
fs.chmodSync(files.file0ToWatch, 0o777);
|
2017-11-30 22:48:52 +09:00
|
|
|
}, results, done);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should watch a file in a directory to be changed', function(done) {
|
2018-01-13 22:48:35 +00:00
|
|
|
var files = prepareDir();
|
|
|
|
fs.writeFileSync(files.file0ToWatch, '');
|
2017-11-30 22:48:52 +09:00
|
|
|
var flow = [{id:"n1", type:"watch", name: "watch",
|
2018-01-13 22:48:35 +00:00
|
|
|
files: files.dirToWatch, recursive: true,
|
2017-11-30 22:48:52 +09:00
|
|
|
wires:[["n2"]]},
|
|
|
|
{id:"n2", type:"helper"}];
|
|
|
|
var results = {
|
|
|
|
'file0.txt' : {
|
2018-01-13 22:48:35 +00:00
|
|
|
'payload' : files.file0ToWatch,
|
|
|
|
'topic': files.file0ToWatch,
|
|
|
|
'type': 'file'//,
|
|
|
|
// 'size': 5
|
2017-11-30 22:48:52 +09:00
|
|
|
}
|
|
|
|
};
|
|
|
|
testWatch(flow, function() {
|
2018-01-13 22:48:35 +00:00
|
|
|
fs.appendFileSync(files.file0ToWatch, "ABCDE");
|
2017-11-30 22:48:52 +09:00
|
|
|
}, results, done);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should watch a sub directory in a directory to be changed', function(done) {
|
2018-01-13 22:48:35 +00:00
|
|
|
var files = prepareDir();
|
|
|
|
fs.mkdirSync(files.subDirToWatch);
|
2017-11-30 22:48:52 +09:00
|
|
|
var flow = [{id:"n1", type:"watch", name: "watch",
|
2018-01-13 22:48:35 +00:00
|
|
|
files: files.dirToWatch, recursive: true,
|
2017-11-30 22:48:52 +09:00
|
|
|
wires:[["n2"]]},
|
|
|
|
{id:"n2", type:"helper"}];
|
|
|
|
var results = {
|
|
|
|
'file2.txt': {
|
2018-01-13 22:48:35 +00:00
|
|
|
payload: files.file2ToWatch,
|
|
|
|
type: 'file'//,
|
|
|
|
// size: 5
|
2017-11-30 22:48:52 +09:00
|
|
|
}
|
|
|
|
};
|
|
|
|
testWatch(flow, function() {
|
2018-01-13 22:48:35 +00:00
|
|
|
fs.appendFileSync(files.file2ToWatch, "ABCDE");
|
2017-11-30 22:48:52 +09:00
|
|
|
}, results, done);
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|