mirror of
https://github.com/status-im/react-native.git
synced 2025-01-17 21:11:45 +00:00
ad0fe15e2e
Summary:
React Native bundler (aka Metro Bundler) was splitted from the main codebase some time ago (now it lives [[https://github.com/facebook/metro-bundler|here]]). To make it more agnostic, polyfills will be moved out from it, so people who doesn't need them does not include them. However, RN will still need them, so the first step is to copy them back to RN so that we can provide them to Metro Bundler later.
We also include a way of passing the list of polyfills to include, as an `Array<string>`. The field is called `polyfills`, and defaults to the traditional list that is currently included in the package manager [see here](be1843cddc/packages/metro-bundler/src/defaults.js (L27-L37)
).
In future commits, `metro-bundler` will be able to manage the `polyfills` array passed to it, and use it, instead of the pre-defined ones.
Reviewed By: davidaurelio
Differential Revision: D5381614
fbshipit-source-id: 749d536b781843ecb3067803e44398cd6df941f1
126 lines
3.5 KiB
JavaScript
126 lines
3.5 KiB
JavaScript
/**
|
|
* Copyright (c) 2013-present, Facebook, Inc.
|
|
* All rights reserved.
|
|
*
|
|
* 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.
|
|
*
|
|
* @emails oncall+jsinfra
|
|
*/
|
|
|
|
/* eslint-disable fb-www/object-create-only-one-param */
|
|
|
|
'use strict';
|
|
|
|
describe('Object (ES7)', () => {
|
|
beforeEach(() => {
|
|
delete Object.entries;
|
|
delete Object.values;
|
|
jest.resetModules();
|
|
require('../Object.es7');
|
|
});
|
|
|
|
describe('Object.entries', () => {
|
|
it('should have a length of 1', () => {
|
|
expect(Object.entries.length).toBe(1);
|
|
});
|
|
|
|
it('should check for type', () => {
|
|
expect(Object.entries.bind(null, null)).toThrow(TypeError(
|
|
'Object.entries called on non-object'
|
|
));
|
|
expect(Object.entries.bind(null, undefined)).toThrow(TypeError(
|
|
'Object.entries called on non-object'
|
|
));
|
|
expect(Object.entries.bind(null, [])).not.toThrow();
|
|
expect(Object.entries.bind(null, () => {})).not.toThrow();
|
|
expect(Object.entries.bind(null, {})).not.toThrow();
|
|
expect(Object.entries.bind(null, 'abc')).not.toThrow();
|
|
});
|
|
|
|
it('should return enumerable entries', () => {
|
|
const foo = Object.defineProperties({}, {
|
|
x: {value: 10, enumerable: true},
|
|
y: {value: 20},
|
|
});
|
|
|
|
expect(Object.entries(foo)).toEqual([['x', 10]]);
|
|
|
|
const bar = {x: 10, y: 20};
|
|
expect(Object.entries(bar)).toEqual([['x', 10], ['y', 20]]);
|
|
});
|
|
|
|
it('should work with proto-less objects', () => {
|
|
const foo = Object.create(null, {
|
|
x: {value: 10, enumerable: true},
|
|
y: {value: 20},
|
|
});
|
|
|
|
expect(Object.entries(foo)).toEqual([['x', 10]]);
|
|
});
|
|
|
|
it('should return only own entries', () => {
|
|
const foo = Object.create({z: 30}, {
|
|
x: {value: 10, enumerable: true},
|
|
y: {value: 20},
|
|
});
|
|
|
|
expect(Object.entries(foo)).toEqual([['x', 10]]);
|
|
});
|
|
|
|
it('should convert to object primitive string', () => {
|
|
expect(Object.entries('ab')).toEqual([['0', 'a'], ['1', 'b']]);
|
|
});
|
|
});
|
|
|
|
describe('Object.values', () => {
|
|
it('should have a length of 1', () => {
|
|
expect(Object.values.length).toBe(1);
|
|
});
|
|
|
|
it('should check for type', () => {
|
|
expect(Object.values.bind(null, null)).toThrow(TypeError(
|
|
'Object.values called on non-object'
|
|
));
|
|
expect(Object.values.bind(null, [])).not.toThrow();
|
|
expect(Object.values.bind(null, () => {})).not.toThrow();
|
|
expect(Object.values.bind(null, {})).not.toThrow();
|
|
});
|
|
|
|
it('should return enumerable values', () => {
|
|
const foo = Object.defineProperties({}, {
|
|
x: {value: 10, enumerable: true},
|
|
y: {value: 20},
|
|
});
|
|
|
|
expect(Object.values(foo)).toEqual([10]);
|
|
|
|
const bar = {x: 10, y: 20};
|
|
expect(Object.values(bar)).toEqual([10, 20]);
|
|
});
|
|
|
|
it('should work with proto-less objects', () => {
|
|
const foo = Object.create(null, {
|
|
x: {value: 10, enumerable: true},
|
|
y: {value: 20},
|
|
});
|
|
|
|
expect(Object.values(foo)).toEqual([10]);
|
|
});
|
|
|
|
it('should return only own values', () => {
|
|
const foo = Object.create({z: 30}, {
|
|
x: {value: 10, enumerable: true},
|
|
y: {value: 20},
|
|
});
|
|
|
|
expect(Object.values(foo)).toEqual([10]);
|
|
});
|
|
|
|
it('should convert to object primitive string', () => {
|
|
expect(Object.values('ab')).toEqual(['a', 'b']);
|
|
});
|
|
});
|
|
});
|