2019-09-28 15:15:54 +01:00
|
|
|
/* eslint-env es6 */
|
2019-09-14 19:31:31 +01:00
|
|
|
"use strict";
|
|
|
|
|
2021-12-26 21:57:51 +00:00
|
|
|
jest.setTimeout(2 * 60 * 1000);
|
2019-09-14 19:31:31 +01:00
|
|
|
|
2021-11-21 17:00:53 +00:00
|
|
|
const fs = require('fs');
|
|
|
|
|
2021-11-28 21:25:11 +00:00
|
|
|
const {
|
|
|
|
requireUncached,
|
2021-01-29 00:09:27 +00:00
|
|
|
comparisonReport,
|
|
|
|
logReport,
|
|
|
|
toMatchExtrinsics,
|
2023-08-13 13:10:09 +01:00
|
|
|
toMatchIntrinsics,
|
|
|
|
getArg
|
2021-01-29 00:09:27 +00:00
|
|
|
} = require('./TestTools');
|
2019-09-14 19:31:31 +01:00
|
|
|
|
2021-11-28 21:25:11 +00:00
|
|
|
const Example = requireUncached('../examples/index');
|
|
|
|
const MatterBuild = requireUncached('../build/matter');
|
|
|
|
const { versionSatisfies } = requireUncached('../src/core/Plugin');
|
2024-03-03 21:01:45 +00:00
|
|
|
const Worker = require('jest-worker').Worker;
|
2019-09-14 19:31:31 +01:00
|
|
|
|
2023-08-13 13:10:09 +01:00
|
|
|
const testComparison = getArg('compare', null) === 'true';
|
|
|
|
const saveComparison = getArg('save', null) === 'true';
|
|
|
|
const specificExamples = getArg('examples', null, (val) => val.split(','));
|
|
|
|
const repeats = getArg('repeats', 1, parseFloat);
|
|
|
|
const updates = getArg('updates', 150, parseFloat);
|
2024-03-03 21:01:45 +00:00
|
|
|
const benchmark = getArg('benchmark', null) === 'true';
|
2021-12-15 09:58:31 +00:00
|
|
|
|
2020-03-09 20:56:06 +00:00
|
|
|
const excludeExamples = ['svg', 'terrain'];
|
|
|
|
const excludeJitter = ['stack', 'circleStack', 'restitution', 'staticFriction', 'friction', 'newtonsCradle', 'catapult'];
|
2020-12-30 23:03:38 +00:00
|
|
|
|
2021-12-15 09:58:31 +00:00
|
|
|
const examples = (specificExamples || Object.keys(Example)).filter(key => {
|
2020-12-30 23:03:38 +00:00
|
|
|
const excluded = excludeExamples.includes(key);
|
|
|
|
const buildVersion = MatterBuild.version;
|
|
|
|
const exampleFor = Example[key].for;
|
|
|
|
const supported = versionSatisfies(buildVersion, exampleFor);
|
|
|
|
return !excluded && supported;
|
|
|
|
});
|
2019-09-14 19:31:31 +01:00
|
|
|
|
2021-11-28 21:25:11 +00:00
|
|
|
const captureExamples = async useDev => {
|
2024-03-03 21:01:45 +00:00
|
|
|
const worker = new Worker(require.resolve('./ExampleWorker'), {
|
2021-11-19 20:30:12 +00:00
|
|
|
enableWorkerThreads: true,
|
2024-03-03 21:01:45 +00:00
|
|
|
numWorkers: benchmark ? 1 : undefined
|
2019-11-07 22:34:59 +00:00
|
|
|
});
|
2019-09-30 23:28:17 +01:00
|
|
|
|
2024-03-03 21:01:45 +00:00
|
|
|
const completeRuns = await Promise.all(examples.map(name => worker.runExample({
|
2019-11-07 22:34:59 +00:00
|
|
|
name,
|
|
|
|
useDev,
|
2023-08-13 13:10:09 +01:00
|
|
|
updates: updates,
|
2024-03-03 21:01:45 +00:00
|
|
|
repeats: benchmark ? Math.max(repeats, 3) : repeats,
|
2021-12-01 23:34:41 +00:00
|
|
|
stableSort: false,
|
2020-03-09 20:56:06 +00:00
|
|
|
jitter: excludeJitter.includes(name) ? 0 : 1e-10
|
2019-11-07 22:34:59 +00:00
|
|
|
})));
|
2019-09-30 23:28:17 +01:00
|
|
|
|
2024-03-03 21:01:45 +00:00
|
|
|
await worker.end();
|
2021-12-01 23:34:41 +00:00
|
|
|
|
|
|
|
const capture = {};
|
|
|
|
|
|
|
|
for (const completeRun of completeRuns) {
|
2024-03-03 21:01:45 +00:00
|
|
|
capture[completeRun.name] = completeRun;
|
2021-12-01 23:34:41 +00:00
|
|
|
}
|
2019-09-30 23:28:17 +01:00
|
|
|
|
2021-12-01 23:34:41 +00:00
|
|
|
return capture;
|
2019-09-30 23:28:17 +01:00
|
|
|
};
|
|
|
|
|
2021-11-28 21:25:11 +00:00
|
|
|
const capturesDev = captureExamples(true);
|
|
|
|
const capturesBuild = captureExamples(false);
|
2019-11-07 22:34:59 +00:00
|
|
|
|
|
|
|
afterAll(async () => {
|
|
|
|
// Report experimental capture comparison.
|
|
|
|
const dev = await capturesDev;
|
|
|
|
const build = await capturesBuild;
|
2021-01-29 00:09:27 +00:00
|
|
|
|
2021-11-21 17:00:53 +00:00
|
|
|
const buildSize = fs.statSync('./build/matter.min.js').size;
|
|
|
|
const devSize = fs.statSync('./build/matter.dev.min.js').size;
|
|
|
|
|
2021-01-29 00:09:27 +00:00
|
|
|
console.log(
|
2021-11-21 17:00:53 +00:00
|
|
|
'Examples ran against previous release and current build\n\n'
|
2021-01-31 17:34:38 +00:00
|
|
|
+ logReport(build, `release`) + '\n'
|
|
|
|
+ logReport(dev, `current`) + '\n'
|
2024-03-03 21:01:45 +00:00
|
|
|
+ comparisonReport(dev, build, devSize, buildSize, MatterBuild.version, saveComparison, benchmark)
|
2021-01-29 00:09:27 +00:00
|
|
|
);
|
2019-11-07 22:34:59 +00:00
|
|
|
});
|
2019-09-30 23:28:17 +01:00
|
|
|
|
2019-11-07 22:34:59 +00:00
|
|
|
describe(`Integration checks (${examples.length})`, () => {
|
|
|
|
test(`Examples run without throwing`, async () => {
|
|
|
|
const dev = await capturesDev;
|
|
|
|
const build = await capturesBuild;
|
|
|
|
expect(Object.keys(dev)).toEqual(examples);
|
|
|
|
expect(Object.keys(build)).toEqual(examples);
|
2019-09-30 23:28:17 +01:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2019-11-07 22:34:59 +00:00
|
|
|
// Experimental regression comparison checks.
|
|
|
|
if (testComparison) {
|
|
|
|
describe(`Regression checks (${examples.length})`, () => {
|
2019-09-30 23:28:17 +01:00
|
|
|
expect.extend(toMatchExtrinsics);
|
|
|
|
expect.extend(toMatchIntrinsics);
|
|
|
|
|
2019-11-07 22:34:59 +00:00
|
|
|
test(`Examples match intrinsic properties with release build`, async () => {
|
|
|
|
const dev = await capturesDev;
|
|
|
|
const build = await capturesBuild;
|
|
|
|
// compare mass, inertia, friction etc.
|
|
|
|
expect(dev).toMatchIntrinsics(build);
|
2019-09-30 23:28:17 +01:00
|
|
|
});
|
|
|
|
|
2019-11-07 22:34:59 +00:00
|
|
|
test(`Examples match extrinsic positions and velocities with release build`, async () => {
|
|
|
|
const dev = await capturesDev;
|
|
|
|
const build = await capturesBuild;
|
|
|
|
// compare position, linear and angular velocity
|
|
|
|
expect(dev).toMatchExtrinsics(build);
|
2019-09-30 23:28:17 +01:00
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|