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:
committed by
Facebook Github Bot
parent
7b27a58b97
commit
42778f687b
@@ -7,7 +7,7 @@
|
||||
* of patent rights can be found in the PATENTS file in the same directory.
|
||||
*/
|
||||
|
||||
var Yoga = Yoga || require("../../sources/entry-" + process.env.TEST_ENTRY);
|
||||
var Yoga = Yoga || require("../../dist/entry-" + process.env.TEST_ENTRY);
|
||||
|
||||
var ITERATIONS = 2000;
|
||||
|
||||
|
@@ -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}%)`,
|
||||
);
|
||||
}
|
||||
}
|
||||
|
@@ -5,56 +5,63 @@
|
||||
* 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
|
||||
*/
|
||||
|
||||
var target = typeof global !== "undefined" ? global : window;
|
||||
var target = typeof global !== 'undefined' ? global : window;
|
||||
|
||||
target.getMeasureCounter = function (Yoga, cb, staticWidth, staticHeight) {
|
||||
target.getMeasureCounter = function(Yoga, cb, staticWidth, staticHeight) {
|
||||
var counter = 0;
|
||||
|
||||
var counter = 0;
|
||||
return {
|
||||
inc: function(width, widthMode, height, heightMode) {
|
||||
counter += 1;
|
||||
|
||||
return {
|
||||
|
||||
inc: function (width, widthMode, height, heightMode) {
|
||||
|
||||
counter += 1;
|
||||
|
||||
return cb ? cb(width, widthMode, height, heightMode) : { width: staticWidth, height: staticHeight };
|
||||
|
||||
},
|
||||
|
||||
get: function () {
|
||||
|
||||
return counter;
|
||||
|
||||
}
|
||||
|
||||
};
|
||||
|
||||
}
|
||||
|
||||
target.getMeasureCounterMax = function (Yoga) {
|
||||
|
||||
return getMeasureCounter(Yoga, function (width, widthMode, height, heightMode) {
|
||||
|
||||
var measuredWidth = widthMode === Yoga.MEASURE_MODE_UNDEFINED ? 10 : width;
|
||||
var measuredHeight = heightMode === Yoga.MEASURE_MODE_UNDEFINED ? 10 : height;
|
||||
|
||||
return { width: measuredWidth, height: measuredHeight };
|
||||
|
||||
});
|
||||
return cb
|
||||
? cb(width, widthMode, height, heightMode)
|
||||
: {width: staticWidth, height: staticHeight};
|
||||
},
|
||||
|
||||
get: function() {
|
||||
return counter;
|
||||
},
|
||||
};
|
||||
};
|
||||
|
||||
target.getMeasureCounterMin = function (Yoga) {
|
||||
|
||||
return getMeasureCounter(Yoga, function (width, widthMode, height, heightMode) {
|
||||
|
||||
var measuredWidth = widthMode === Yoga.MEASURE_MODE_UNDEFINED || (widthMode == Yoga.MEASURE_MODE_AT_MOST && width > 10) ? 10 : width;
|
||||
var measuredHeight = heightMode === Yoga.MEASURE_MODE_UNDEFINED || (heightMode == Yoga.MEASURE_MODE_AT_MOST && height > 10) ? 10 : height;
|
||||
|
||||
return { width: measuredWidth, height: measuredHeight };
|
||||
|
||||
});
|
||||
target.getMeasureCounterMax = function(Yoga) {
|
||||
return getMeasureCounter(Yoga, function(
|
||||
width,
|
||||
widthMode,
|
||||
height,
|
||||
heightMode,
|
||||
) {
|
||||
var measuredWidth = widthMode === Yoga.MEASURE_MODE_UNDEFINED ? 10 : width;
|
||||
var measuredHeight =
|
||||
heightMode === Yoga.MEASURE_MODE_UNDEFINED ? 10 : height;
|
||||
|
||||
return {width: measuredWidth, height: measuredHeight};
|
||||
});
|
||||
};
|
||||
|
||||
target.getMeasureCounterMin = function(Yoga) {
|
||||
return getMeasureCounter(Yoga, function(
|
||||
width,
|
||||
widthMode,
|
||||
height,
|
||||
heightMode,
|
||||
) {
|
||||
var measuredWidth =
|
||||
widthMode === Yoga.MEASURE_MODE_UNDEFINED ||
|
||||
(widthMode == Yoga.MEASURE_MODE_AT_MOST && width > 10)
|
||||
? 10
|
||||
: width;
|
||||
var measuredHeight =
|
||||
heightMode === Yoga.MEASURE_MODE_UNDEFINED ||
|
||||
(heightMode == Yoga.MEASURE_MODE_AT_MOST && height > 10)
|
||||
? 10
|
||||
: height;
|
||||
|
||||
return {width: measuredWidth, height: measuredHeight};
|
||||
});
|
||||
};
|
||||
|
Reference in New Issue
Block a user