before functional changes by codex
This commit is contained in:
0
test/basic/.gitkeep
Normal file
0
test/basic/.gitkeep
Normal file
54
test/basic/nodeclass-routing.basic.test.js
Normal file
54
test/basic/nodeclass-routing.basic.test.js
Normal file
@@ -0,0 +1,54 @@
|
||||
const test = require('node:test');
|
||||
const assert = require('node:assert/strict');
|
||||
|
||||
const NodeClass = require('../../src/nodeClass');
|
||||
const { makeNodeStub, makeREDStub } = require('../helpers/factories');
|
||||
|
||||
test('_attachInputHandler routes known topics to source methods', () => {
|
||||
const inst = Object.create(NodeClass.prototype);
|
||||
const node = makeNodeStub();
|
||||
const calls = [];
|
||||
|
||||
inst.node = node;
|
||||
inst.RED = makeREDStub();
|
||||
inst.source = {
|
||||
toggleSimulation() { calls.push('simulator'); },
|
||||
toggleOutlierDetection() { calls.push('outlierDetection'); },
|
||||
calibrate() { calls.push('calibrate'); },
|
||||
set inputValue(v) { calls.push(['measurement', v]); },
|
||||
};
|
||||
|
||||
inst._attachInputHandler();
|
||||
const onInput = node._handlers.input;
|
||||
|
||||
onInput({ topic: 'simulator' }, () => {}, () => {});
|
||||
onInput({ topic: 'outlierDetection' }, () => {}, () => {});
|
||||
onInput({ topic: 'calibrate' }, () => {}, () => {});
|
||||
onInput({ topic: 'measurement', payload: 12.3 }, () => {}, () => {});
|
||||
|
||||
assert.deepEqual(calls[0], 'simulator');
|
||||
assert.deepEqual(calls[1], 'outlierDetection');
|
||||
assert.deepEqual(calls[2], 'calibrate');
|
||||
assert.deepEqual(calls[3], ['measurement', 12.3]);
|
||||
});
|
||||
|
||||
test('_registerChild emits delayed registerChild message on output 2', () => {
|
||||
const inst = Object.create(NodeClass.prototype);
|
||||
const node = makeNodeStub();
|
||||
|
||||
inst.node = node;
|
||||
inst.config = { functionality: { positionVsParent: 'upstream', distance: 5 } };
|
||||
|
||||
const originalSetTimeout = global.setTimeout;
|
||||
global.setTimeout = (fn) => { fn(); return 1; };
|
||||
try {
|
||||
inst._registerChild();
|
||||
} finally {
|
||||
global.setTimeout = originalSetTimeout;
|
||||
}
|
||||
|
||||
assert.equal(node._sent.length, 1);
|
||||
assert.equal(node._sent[0][2].topic, 'registerChild');
|
||||
assert.equal(node._sent[0][2].positionVsParent, 'upstream');
|
||||
assert.equal(node._sent[0][2].distance, 5);
|
||||
});
|
||||
25
test/basic/scaling-and-output.basic.test.js
Normal file
25
test/basic/scaling-and-output.basic.test.js
Normal file
@@ -0,0 +1,25 @@
|
||||
const test = require('node:test');
|
||||
const assert = require('node:assert/strict');
|
||||
|
||||
const { makeMeasurementInstance } = require('../helpers/factories');
|
||||
|
||||
test('calculateInput applies scaling and updates bounded output', () => {
|
||||
const m = makeMeasurementInstance();
|
||||
|
||||
m.calculateInput(50);
|
||||
const out = m.getOutput();
|
||||
|
||||
assert.equal(out.mAbs >= 0 && out.mAbs <= 10, true);
|
||||
assert.equal(out.mPercent >= 0 && out.mPercent <= 100, true);
|
||||
});
|
||||
|
||||
test('out-of-range input is constrained to abs range', () => {
|
||||
const m = makeMeasurementInstance({
|
||||
smoothing: { smoothWindow: 1, smoothMethod: 'none' },
|
||||
});
|
||||
|
||||
m.calculateInput(10000);
|
||||
const out = m.getOutput();
|
||||
|
||||
assert.equal(out.mAbs, 10);
|
||||
});
|
||||
16
test/basic/specific-constructor.basic.test.js
Normal file
16
test/basic/specific-constructor.basic.test.js
Normal file
@@ -0,0 +1,16 @@
|
||||
const test = require('node:test');
|
||||
const assert = require('node:assert/strict');
|
||||
|
||||
const { makeMeasurementInstance } = require('../helpers/factories');
|
||||
|
||||
test('Measurement constructor initializes key defaults and ranges', () => {
|
||||
const m = makeMeasurementInstance();
|
||||
|
||||
assert.equal(m.inputValue, 0);
|
||||
assert.equal(m.outputAbs, 0);
|
||||
assert.equal(m.outputPercent, 0);
|
||||
assert.equal(Array.isArray(m.storedValues), true);
|
||||
assert.equal(typeof m.measurements, 'object');
|
||||
assert.equal(m.inputRange, 100);
|
||||
assert.equal(m.processRange, 10);
|
||||
});
|
||||
Reference in New Issue
Block a user