From 1a2c756b026bbc715f4b3f7271ae216b33bf9dbd Mon Sep 17 00:00:00 2001 From: Alexander Date: Mon, 6 Jun 2016 21:46:57 +0300 Subject: [PATCH] Warn that ReactPerf does not work in the production build (#6884) Fixes #6871 (cherry picked from commit 2a46103ac87aab9b6ab390bb26c94c04f6b7e419) --- src/renderers/shared/ReactDebugTool.js | 4 +- src/renderers/shared/ReactPerf.js | 74 +++++++++++++++++++ .../shared/__tests__/ReactPerf-test.js | 23 ++++++ 3 files changed, 98 insertions(+), 3 deletions(-) diff --git a/src/renderers/shared/ReactDebugTool.js b/src/renderers/shared/ReactDebugTool.js index cd6ac3bb80ed1..6deb84bc85be6 100644 --- a/src/renderers/shared/ReactDebugTool.js +++ b/src/renderers/shared/ReactDebugTool.js @@ -208,9 +208,7 @@ var ReactDebugTool = { } }, getFlushHistory() { - if (__DEV__) { - return flushHistory; - } + return flushHistory; }, onBeginFlush() { if (__DEV__) { diff --git a/src/renderers/shared/ReactPerf.js b/src/renderers/shared/ReactPerf.js index 209651e21693c..939bcdba0db27 100644 --- a/src/renderers/shared/ReactPerf.js +++ b/src/renderers/shared/ReactPerf.js @@ -13,17 +13,43 @@ var ReactDebugTool = require('ReactDebugTool'); var warning = require('warning'); +var alreadyWarned = false; function roundFloat(val, base = 2) { var n = Math.pow(10, base); return Math.floor(val * n) / n; } +function warnInProduction() { + if (alreadyWarned) { + return; + } + + alreadyWarned = true; + + if (typeof console !== 'undefined') { + console.error( + 'ReactPerf is not supported in the production builds of React.' + + 'To collect measurements, please use the development build of React instead.' + ); + } +} + function getFlushHistory() { + if (!__DEV__) { + warnInProduction(); + return []; + } + return ReactDebugTool.getFlushHistory(); } function getExclusive(flushHistory = getFlushHistory()) { + if (!__DEV__) { + warnInProduction(); + return []; + } + var aggregatedStats = {}; var affectedIDs = {}; @@ -74,6 +100,11 @@ function getExclusive(flushHistory = getFlushHistory()) { } function getInclusive(flushHistory = getFlushHistory()) { + if (!__DEV__) { + warnInProduction(); + return []; + } + var aggregatedStats = {}; var affectedIDs = {}; @@ -142,6 +173,11 @@ function getInclusive(flushHistory = getFlushHistory()) { } function getWasted(flushHistory = getFlushHistory()) { + if (!__DEV__) { + warnInProduction(); + return []; + } + var aggregatedStats = {}; var affectedIDs = {}; @@ -235,6 +271,11 @@ function getWasted(flushHistory = getFlushHistory()) { } function getOperations(flushHistory = getFlushHistory()) { + if (!__DEV__) { + warnInProduction(); + return []; + } + var stats = []; flushHistory.forEach((flush, flushIndex) => { var {operations, treeSnapshot} = flush; @@ -258,6 +299,11 @@ function getOperations(flushHistory = getFlushHistory()) { } function printExclusive(flushHistory) { + if (!__DEV__) { + warnInProduction(); + return; + } + var stats = getExclusive(flushHistory); var table = stats.map(item => { var {key, instanceCount, totalDuration} = item; @@ -279,6 +325,11 @@ function printExclusive(flushHistory) { } function printInclusive(flushHistory) { + if (!__DEV__) { + warnInProduction(); + return; + } + var stats = getInclusive(flushHistory); var table = stats.map(item => { var {key, instanceCount, inclusiveRenderDuration, renderCount} = item; @@ -293,6 +344,11 @@ function printInclusive(flushHistory) { } function printWasted(flushHistory) { + if (!__DEV__) { + warnInProduction(); + return; + } + var stats = getWasted(flushHistory); var table = stats.map(item => { var {key, instanceCount, inclusiveRenderDuration, renderCount} = item; @@ -307,6 +363,11 @@ function printWasted(flushHistory) { } function printOperations(flushHistory) { + if (!__DEV__) { + warnInProduction(); + return; + } + var stats = getOperations(flushHistory); var table = stats.map(stat => ({ 'Owner > Node': stat.key, @@ -344,14 +405,27 @@ function getMeasurementsSummaryMap(measurements) { } function start() { + if (!__DEV__) { + warnInProduction(); + return; + } ReactDebugTool.beginProfiling(); } function stop() { + if (!__DEV__) { + warnInProduction(); + return; + } + ReactDebugTool.endProfiling(); } function isRunning() { + if (!__DEV__) { + warnInProduction(); + return false; + } return ReactDebugTool.isProfiling(); } diff --git a/src/renderers/shared/__tests__/ReactPerf-test.js b/src/renderers/shared/__tests__/ReactPerf-test.js index 5fa4e3685c312..babd6a03a5125 100644 --- a/src/renderers/shared/__tests__/ReactPerf-test.js +++ b/src/renderers/shared/__tests__/ReactPerf-test.js @@ -445,4 +445,27 @@ describe('ReactPerf', function() { ReactPerf.stop(); expect(ReactPerf.isRunning()).toBe(false); }); + + it('should print console error only once', () => { + __DEV__ = false; + + spyOn(console, 'error'); + + expect(ReactPerf.getLastMeasurements()).toEqual([]); + expect(ReactPerf.getExclusive()).toEqual([]); + expect(ReactPerf.getInclusive()).toEqual([]); + expect(ReactPerf.getWasted()).toEqual([]); + expect(ReactPerf.getOperations()).toEqual([]); + expect(ReactPerf.printExclusive()).toEqual(undefined); + expect(ReactPerf.printInclusive()).toEqual(undefined); + expect(ReactPerf.printWasted()).toEqual(undefined); + expect(ReactPerf.printOperations()).toEqual(undefined); + expect(ReactPerf.start()).toBe(undefined); + expect(ReactPerf.stop()).toBe(undefined); + expect(ReactPerf.isRunning()).toBe(false); + + expect(console.error.calls.count()).toBe(1); + + __DEV__ = true; + }) });