From e56000965ae9f15437b4958527f5d8e4150af39e Mon Sep 17 00:00:00 2001 From: Keyan Zhang Date: Tue, 12 Jul 2016 22:11:33 -0700 Subject: [PATCH] warn for using maps as children with owner info --- .../__tests__/traverseAllChildren-test.js | 23 +++++++++++++++++++ src/shared/utils/traverseAllChildren.js | 10 +++++++- 2 files changed, 32 insertions(+), 1 deletion(-) diff --git a/src/shared/utils/__tests__/traverseAllChildren-test.js b/src/shared/utils/__tests__/traverseAllChildren-test.js index 8469abe76a2b7..caf6661072273 100644 --- a/src/shared/utils/__tests__/traverseAllChildren-test.js +++ b/src/shared/utils/__tests__/traverseAllChildren-test.js @@ -15,11 +15,14 @@ describe('traverseAllChildren', function() { var traverseAllChildren; var React; var ReactFragment; + var ReactTestUtils; + beforeEach(function() { jest.resetModuleRegistry(); traverseAllChildren = require('traverseAllChildren'); React = require('React'); ReactFragment = require('ReactFragment'); + ReactTestUtils = require('ReactTestUtils'); }); function frag(obj) { @@ -536,4 +539,24 @@ describe('traverseAllChildren', function() { ); }); + it('should warn for using maps as children with owner info', function() { + spyOn(console, 'error'); + + var Parent = React.createClass({ + render() { + return ( +
{new Map([['foo', 0], ['bar', 1]])}
+ ); + }, + }); + + ReactTestUtils.renderIntoDocument(); + + expect(console.error.calls.count()).toBe(1); + expect(console.error.calls.argsFor(0)[0]).toBe( + 'Warning: Using Maps as children is not yet fully supported. It is an ' + + 'experimental feature that might be removed. Convert it to a sequence ' + + '/ iterable of keyed ReactElements instead. Check the render method of `Parent`.' + ); + }); }); diff --git a/src/shared/utils/traverseAllChildren.js b/src/shared/utils/traverseAllChildren.js index 7d03dc02d1792..e08aad5e8d482 100644 --- a/src/shared/utils/traverseAllChildren.js +++ b/src/shared/utils/traverseAllChildren.js @@ -117,11 +117,19 @@ function traverseAllChildrenImpl( } } else { if (__DEV__) { + var mapAsChildrenAddendum = ''; + if (ReactCurrentOwner.current) { + var mapAsChildrenOwnerName = ReactCurrentOwner.current.getName(); + if (mapAsChildrenOwnerName) { + mapAsChildrenAddendum = ' Check the render method of `' + mapAsChildrenOwnerName + '`.'; + } + } warning( didWarnAboutMaps, 'Using Maps as children is not yet fully supported. It is an ' + 'experimental feature that might be removed. Convert it to a ' + - 'sequence / iterable of keyed ReactElements instead.' + 'sequence / iterable of keyed ReactElements instead.%s', + mapAsChildrenAddendum ); didWarnAboutMaps = true; }