**Motivations:** - Ensure all application directories have systemd services enabled at boot - Complete service installation for api-relay, filigrane-api, and clamav-api - Fix dependencies and import issues preventing clamav-api from starting **Root causes:** - Three services (api-relay, filigrane-api, clamav-api) had service files but were not installed in systemd - api-clamav had incorrect node-clamav version (0.12.1) that doesn't exist - api-clamav dependencies were not installed (node_modules missing) - ES module import syntax incompatible with CommonJS node-clamav package **Correctifs:** - Installed api-relay.service, filigrane-api.service, and clamav-api.service in /etc/systemd/system/ - Enabled all three services for automatic startup at boot - Updated api-clamav/package.json: changed node-clamav version from ^0.12.1 to ^1.0.11 - Installed npm dependencies for api-clamav - Fixed ES module import in api-clamav/src/routes/scan.js to use CommonJS-compatible syntax **Evolutions:** - All 7 application services now have systemd services enabled at boot - Complete service coverage: anchorage-api, faucet-api, signet-dashboard, userwallet, api-relay, filigrane-api, clamav-api - All services verified active and listening on their respective ports **Pages affectées:** - api-clamav/package.json - api-clamav/src/routes/scan.js - api-clamav/node_modules/ (new) - api-clamav/package-lock.json (new) - /etc/systemd/system/api-relay.service (new) - /etc/systemd/system/filigrane-api.service (new) - /etc/systemd/system/clamav-api.service (new)
59 lines
2.1 KiB
JavaScript
59 lines
2.1 KiB
JavaScript
'use strict';
|
|
|
|
/** @type {(t: import('tape').Test) => false | void} */
|
|
// eslint-disable-next-line consistent-return
|
|
module.exports = function runSymbolTests(t) {
|
|
t.equal(typeof Symbol, 'function', 'global Symbol is a function');
|
|
|
|
if (typeof Symbol !== 'function') { return false; }
|
|
|
|
t.notEqual(Symbol(), Symbol(), 'two symbols are not equal');
|
|
|
|
/*
|
|
t.equal(
|
|
Symbol.prototype.toString.call(Symbol('foo')),
|
|
Symbol.prototype.toString.call(Symbol('foo')),
|
|
'two symbols with the same description stringify the same'
|
|
);
|
|
*/
|
|
|
|
/*
|
|
var foo = Symbol('foo');
|
|
|
|
t.notEqual(
|
|
String(foo),
|
|
String(Symbol('bar')),
|
|
'two symbols with different descriptions do not stringify the same'
|
|
);
|
|
*/
|
|
|
|
t.equal(typeof Symbol.prototype.toString, 'function', 'Symbol#toString is a function');
|
|
// t.equal(String(foo), Symbol.prototype.toString.call(foo), 'Symbol#toString equals String of the same symbol');
|
|
|
|
t.equal(typeof Object.getOwnPropertySymbols, 'function', 'Object.getOwnPropertySymbols is a function');
|
|
|
|
/** @type {{ [k in symbol]?: unknown }} */
|
|
var obj = {};
|
|
var sym = Symbol('test');
|
|
var symObj = Object(sym);
|
|
t.notEqual(typeof sym, 'string', 'Symbol is not a string');
|
|
t.equal(Object.prototype.toString.call(sym), '[object Symbol]', 'symbol primitive Object#toStrings properly');
|
|
t.equal(Object.prototype.toString.call(symObj), '[object Symbol]', 'symbol primitive Object#toStrings properly');
|
|
|
|
var symVal = 42;
|
|
obj[sym] = symVal;
|
|
// eslint-disable-next-line no-restricted-syntax, no-unused-vars
|
|
for (var _ in obj) { t.fail('symbol property key was found in for..in of object'); }
|
|
|
|
t.deepEqual(Object.keys(obj), [], 'no enumerable own keys on symbol-valued object');
|
|
t.deepEqual(Object.getOwnPropertyNames(obj), [], 'no own names on symbol-valued object');
|
|
t.deepEqual(Object.getOwnPropertySymbols(obj), [sym], 'one own symbol on symbol-valued object');
|
|
t.equal(Object.prototype.propertyIsEnumerable.call(obj, sym), true, 'symbol is enumerable');
|
|
t.deepEqual(Object.getOwnPropertyDescriptor(obj, sym), {
|
|
configurable: true,
|
|
enumerable: true,
|
|
value: 42,
|
|
writable: true
|
|
}, 'property descriptor is correct');
|
|
};
|