@iotize/tap-scripts
Version:
IoTize Tap scripts
312 lines • 19.6 kB
JavaScript
"use strict";
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.ScriptRunner = exports.DisplayToLogFunction = exports.OutputToLogFunction = exports.TestRunnerContext = void 0;
const byte_converter_1 = require("@iotize/common/byte-converter");
const rxjs_1 = require("rxjs");
const errors_1 = require("./errors");
const instructions_1 = require("./instructions");
const logger_1 = require("./logger");
/**
*
*/
class TestRunnerContext {
constructor(device, instructions, io) {
this.device = device;
this.instructions = instructions;
this.io = io;
this._labels = {};
this.current = -1;
this.resultCode = null;
this._data = {};
this._running = false;
this.nextChanged = false;
this.errorHandler = (error) => {
throw error;
};
this.instructions.forEach((instruction, index) => {
if (instruction instanceof instructions_1.LabelInstruction) {
this.mapLabel(instruction.name, index);
}
});
}
store(key, value) {
if (arguments.length === 2) {
this._data[key] = value;
}
else {
return this._data[key];
}
}
get labels() {
return this._labels;
}
set lastLwm2mGetResponse(r) {
this._lastLwm2mGetResponse = r;
this.lastLwm2mResponse = r;
}
get lastLwm2mGetResponse() {
if (!this._lastLwm2mGetResponse) {
throw new Error(`No last LWM2M get response available yet`);
}
return this._lastLwm2mGetResponse;
}
// asObservable() {
// return this._observer!.asObservable(); // TODO fix
// }
/**
* Resume script execution
*/
continue() {
return __awaiter(this, void 0, void 0, function* () {
this._running = true;
while (this._running && !this.isEnded()) {
if (!this.nextChanged) {
this.current++;
}
this.nextChanged = false;
yield this.safeRunOne(this.current);
}
this._running = false;
});
}
runAll() {
return new rxjs_1.Observable((observer) => {
this._observer = observer;
this.resultCode = null;
this.current = -1;
this.continue()
.then(() => [this._observer, undefined])
.catch((err) => [this._observer, err])
.then(([observer, err]) => {
this._observer = undefined;
if (!err) {
observer === null || observer === void 0 ? void 0 : observer.complete();
}
else {
observer === null || observer === void 0 ? void 0 : observer.error(err);
}
});
return () => {
this._observer = undefined;
this.stop();
};
});
}
isRunning() {
return this._running;
}
/**
* Pause script execution
*/
stop() {
this._running = false;
}
/**
* Return true script execution is finished
*/
isEnded() {
return (this.resultCode !== null || this.current >= this.instructions.length);
}
getCurrentIndex() {
return this.current;
}
setNextIndex(index) {
(0, logger_1.debug)(`TestRunnerContext`, `Jumping to index: ${index}`);
this.current = index;
this.nextChanged = true;
}
runCurrent() {
return this.safeRunOne(this.current);
}
/**
* Run instruction at given index
* @param index
*/
runOne(index) {
var _a;
return __awaiter(this, void 0, void 0, function* () {
this.current = index;
// debug(`next on instruction ${index}/${this.instructions.length}`);
if (index < this.instructions.length) {
const instruction = this.instructions[index];
if (!instruction) {
throw errors_1.ScriptError.internalError(`Instruction should not be null at index ${index}`);
}
(0, logger_1.debug)(`Running instruction ${index + 1}/${this.instructions.length}: ${instruction.constructor.name} (${instruction.toString()})`);
const progressInfo = {
loaded: index,
total: this.instructions.length
};
(_a = this._observer) === null || _a === void 0 ? void 0 : _a.next({
type: 'before',
instruction: instruction,
progress: progressInfo
});
const result = instruction.run(this);
let promise;
if (result instanceof Promise) {
promise = result;
}
else {
promise = Promise.resolve(result);
}
return promise.then(res => {
var _a;
(_a = this._observer) === null || _a === void 0 ? void 0 : _a.next({
type: 'after',
instruction: instruction,
progress: progressInfo,
result: result
});
return res;
});
}
else {
this.end();
return Promise.resolve();
}
});
}
next() {
return __awaiter(this, void 0, void 0, function* () {
const result = yield this.safeRunOne(this.current + 1);
this.next();
});
}
/**
* TODO use result code
*/
end(resultCode = 0) {
var _a;
if (typeof resultCode !== 'number') {
throw errors_1.ScriptError.internalError(`result code should be a number. Given: "${resultCode}" (type=${typeof resultCode})`);
}
this.resultCode = resultCode;
(0, logger_1.debug)(`Ending script with result code ${resultCode}`);
(_a = this._observer) === null || _a === void 0 ? void 0 : _a.next({
type: 'end',
resultCode: resultCode,
progress: {
total: this.instructions.length,
loaded: this.instructions.length
}
});
}
onError(err) {
var _a, _b;
return __awaiter(this, void 0, void 0, function* () {
// debug('ScriptRunner', `An error occured`, err);
try {
if (!this.errorHandler) {
this._running = false;
(_a = this._observer) === null || _a === void 0 ? void 0 : _a.error(err);
}
else {
yield this.errorHandler(err);
}
}
catch (error) {
this._running = false;
(_b = this._observer) === null || _b === void 0 ? void 0 : _b.error(err);
}
});
}
mapLabel(name, value) {
// debug(`Adding label "${name}" to index ${value}`)
this._labels[name] = value;
}
getLabel(name) {
if (name in this._labels) {
return this._labels[name];
}
else {
return undefined;
}
}
safeRunOne(index) {
return __awaiter(this, void 0, void 0, function* () {
try {
return yield this.runOne(index);
}
catch (err) {
yield this.onError(err);
}
});
}
}
exports.TestRunnerContext = TestRunnerContext;
function OutputToLogFunction(response) {
let message;
if (response) {
message = (0, byte_converter_1.bufferToHexString)(response.toBytes());
}
else {
message = 'NO OUTPUT YET';
}
(0, logger_1.debug)(message + '\r\n');
}
exports.OutputToLogFunction = OutputToLogFunction;
function DisplayToLogFunction(logLevel, message) {
const map = {
error: 'error',
verbose: 'debug',
message: 'info'
};
console[map[logLevel]](message);
}
exports.DisplayToLogFunction = DisplayToLogFunction;
/**
* Script runner
*
*/
class ScriptRunner {
constructor(io = {
output: OutputToLogFunction,
display: DisplayToLogFunction
}) {
this.io = io;
}
/**
* Configure error handler
*/
set errorHandler(handler) {
this._errorHandler = handler;
}
get errorHandler() {
return this._errorHandler;
}
isRunning() {
var _a;
return !!((_a = this.context) === null || _a === void 0 ? void 0 : _a.isRunning());
}
/**
* Run script instructions
* @param instructions
* @param device
*/
run(instructions, device) {
if (this.context) {
// should we throw an error when script is already running ?
}
this.context = new TestRunnerContext(device, instructions, this.io);
if (this.context.errorHandler) {
this.context.errorHandler = this._errorHandler;
}
return this.context.runAll();
}
stop() {
var _a;
(_a = this.context) === null || _a === void 0 ? void 0 : _a.stop();
}
}
exports.ScriptRunner = ScriptRunner;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"script-runner.js","sourceRoot":"","sources":["../../../src/lib/script-runner.ts"],"names":[],"mappings":"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"}