Release version 1.9.0

Summary:
- Fixes bindings
- Fixes benchmarks and test calls
- version 1.9.0

Reviewed By: arcanis, priteshrnandgaonkar

Differential Revision: D6759438

fbshipit-source-id: 0ea58e607e0b518aaa907cbfa82d2baea7bc1ed5
This commit is contained in:
Daniel Büchele
2018-01-19 11:25:26 -08:00
committed by Facebook Github Bot
parent 7b27a58b97
commit 42778f687b
10 changed files with 135 additions and 179 deletions

View File

@@ -5,6 +5,8 @@
* This source code is licensed under the BSD-style license found in the
* LICENSE file in the root directory of this source tree. An additional grant
* of patent rights can be found in the PATENTS file in the same directory.
*
* @format
*/
require(`./tools`);
@@ -16,58 +18,52 @@ let WARMUP_ITERATIONS = 3;
let BENCHMARK_ITERATIONS = 10;
let testFiles = process.argv.slice(2).map(file => {
return fs.readFileSync(file).toString();
return fs.readFileSync(file).toString();
});
let testResults = new Map();
for (let type of [ `node`, `browser` ]) {
for (let type of [`node`, `browser`]) {
for (let file of testFiles) {
vm.runInNewContext(
file,
Object.assign(Object.create(global), {
Yoga: require(`../dist/entry-${type}`),
YGBENCHMARK: function(name, fn) {
let testEntry = testResults.get(name);
for (let file of testFiles) {
if (testEntry === undefined)
testResults.set(name, (testEntry = new Map()));
vm.runInNewContext(file, Object.assign(Object.create(global), {
for (let t = 0; t < WARMUP_ITERATIONS; ++t) fn();
Yoga: require(`../sources/entry-${type}`),
let start = Date.now();
YGBENCHMARK: function (name, fn) {
for (let t = 0; t < BENCHMARK_ITERATIONS; ++t) fn();
let testEntry = testResults.get(name);
if (testEntry === undefined)
testResults.set(name, testEntry = new Map());
for (let t = 0; t < WARMUP_ITERATIONS; ++t)
fn();
let start = Date.now();
for (let t = 0; t < BENCHMARK_ITERATIONS; ++t)
fn();
let end = Date.now();
testEntry.set(type, (end - start) / BENCHMARK_ITERATIONS);
}
}));
}
let end = Date.now();
testEntry.set(type, (end - start) / BENCHMARK_ITERATIONS);
},
}),
);
}
}
console.log(`Note: those tests are independants; there is no time relation to be expected between them`);
console.log(
`Note: those tests are independants; there is no time relation to be expected between them`,
);
for (let [ name, results ] of testResults) {
for (let [name, results] of testResults) {
console.log();
console.log();
let min = Math.min(Infinity, ...results.values());
let min = Math.min(Infinity, ... results.values());
console.log(name);
for (let [ type, result ] of results) {
console.log(` - ${type}: ${result}ms (${Math.round(result / min * 10000) / 100}%)`);
}
console.log(name);
for (let [type, result] of results) {
console.log(
` - ${type}: ${result}ms (${Math.round(result / min * 10000) / 100}%)`,
);
}
}