P11.5 + B2.1/B2.2: per-command units + description (where applicable)
Adds to scalar setters whose payloads are
plain numbers OR {value, unit}. Skipped where payload is compound or
mode-dependent (control-%, {F, C: [...]}, etc.) — documented inline.
Every command gains a description field for wikiGen consumption.
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
This commit is contained in:
@@ -84,10 +84,43 @@ test('valveGroupControl distributes total flow according to supplier-curve Kv an
|
||||
valve2.destroy();
|
||||
});
|
||||
|
||||
test('valveGroupControl rejects non-valve-like child payload', () => {
|
||||
test('valveGroupControl skips a non-valve-like payload registered as a valve', () => {
|
||||
const group = buildGroup();
|
||||
const result = group.registerChild({ config: { functionality: { softwareType: 'valve' } } }, 'atEquipment');
|
||||
assert.equal(result, false);
|
||||
// Router dispatches by softwareType; the _registerValve handler rejects
|
||||
// non-valve-like children (missing updateFlow/state/measurements) by
|
||||
// returning false from its branch — the registry side-effect (valves[])
|
||||
// stays empty even though BaseDomain's registerChild returns true.
|
||||
group.registerChild({ config: { functionality: { softwareType: 'valve' } } }, 'valve');
|
||||
assert.equal(Object.keys(group.valves).length, 0);
|
||||
group.destroy();
|
||||
});
|
||||
|
||||
test('valveGroupControl router dispatches valve registration by softwareType, honouring config positionVsParent', async () => {
|
||||
const valve = (function buildValveAtUpstream() {
|
||||
const Valve = require('../../../valve/src/specificClass');
|
||||
return new Valve(
|
||||
{
|
||||
general: { name: 'valve-upstream', logging: { enabled: false, logLevel: 'error' } },
|
||||
asset: { supplier: 'binder', category: 'valve', type: 'control', model: 'ECDV', unit: 'm3/h' },
|
||||
functionality: { positionVsParent: 'upstream', softwareType: 'valve' },
|
||||
},
|
||||
{
|
||||
general: { logging: { enabled: false, logLevel: 'error' } },
|
||||
movement: { speed: 1 },
|
||||
time: { starting: 0, warmingup: 0, stopping: 0, coolingdown: 0 },
|
||||
}
|
||||
);
|
||||
})();
|
||||
primeValve(valve, 50);
|
||||
const group = buildGroup();
|
||||
|
||||
// childRegistrationUtils consumes positionVsParent (2nd arg) and forwards
|
||||
// softwareType='valve' to the parent — the router fans out from there.
|
||||
assert.equal(await group.childRegistrationUtils.registerChild(valve, 'upstream'), true);
|
||||
assert.equal(Object.keys(group.valves).length, 1);
|
||||
const registered = Object.values(group.valves)[0];
|
||||
assert.equal(registered.positionVsParent, 'upstream');
|
||||
|
||||
group.destroy();
|
||||
valve.destroy();
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user