mirror of
https://github.com/facebook/react.git
synced 2026-02-25 21:15:01 +00:00
* Migrate conditional tests to gate pragma
I searched through the codebase for this pattern:
```js
describe('test suite', () => {
if (!__EXPERIMENTAL__) { // or some other condition
test("empty test so Jest doesn't complain", () => {});
return;
}
// Unless we're in experimental mode, none of the tests in this block
// will run.
})
```
and converted them to the `@gate` pragma instead.
The reason this pattern isn't preferred is because you end up disabling
more tests than you need to.
* Add flag for www release channels
Using a heuristic where I check a flag that is known to only be enabled
in www. I left a TODO to instead set the release channel explicitly in
each test config.
64 lines
1.9 KiB
JavaScript
64 lines
1.9 KiB
JavaScript
/**
|
|
* Copyright (c) Facebook, Inc. and its affiliates.
|
|
*
|
|
* This source code is licensed under the MIT license found in the
|
|
* LICENSE file in the root directory of this source tree.
|
|
*
|
|
* @emails react-core
|
|
*/
|
|
'use strict';
|
|
|
|
let React;
|
|
let ReactDOM;
|
|
|
|
describe('ReactError', () => {
|
|
let globalErrorMock;
|
|
|
|
beforeEach(() => {
|
|
if (!__DEV__) {
|
|
// In production, our Jest environment overrides the global Error
|
|
// class in order to decode error messages automatically. However
|
|
// this is a single test where we actually *don't* want to decode
|
|
// them. So we assert that the OriginalError exists, and temporarily
|
|
// set the global Error object back to it.
|
|
globalErrorMock = global.Error;
|
|
global.Error = globalErrorMock.OriginalError;
|
|
expect(typeof global.Error).toBe('function');
|
|
}
|
|
jest.resetModules();
|
|
React = require('react');
|
|
ReactDOM = require('react-dom');
|
|
});
|
|
|
|
afterEach(() => {
|
|
if (!__DEV__) {
|
|
global.Error = globalErrorMock;
|
|
}
|
|
});
|
|
|
|
// @gate build === "production"
|
|
it('should error with minified error code', () => {
|
|
expect(() => ReactDOM.render('Hi', null)).toThrowError(
|
|
'Minified React error #200; visit ' +
|
|
'https://reactjs.org/docs/error-decoder.html?invariant=200' +
|
|
' for the full message or use the non-minified dev environment' +
|
|
' for full errors and additional helpful warnings.',
|
|
);
|
|
});
|
|
|
|
// @gate build === "production"
|
|
it('should serialize arguments', () => {
|
|
function Oops() {
|
|
return;
|
|
}
|
|
Oops.displayName = '#wtf';
|
|
const container = document.createElement('div');
|
|
expect(() => ReactDOM.render(<Oops />, container)).toThrowError(
|
|
'Minified React error #152; visit ' +
|
|
'https://reactjs.org/docs/error-decoder.html?invariant=152&args[]=%23wtf' +
|
|
' for the full message or use the non-minified dev environment' +
|
|
' for full errors and additional helpful warnings.',
|
|
);
|
|
});
|
|
});
|