-
Notifications
You must be signed in to change notification settings - Fork 8.3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[React@18] Upgrade @testing-library/react
#198918
Changes from all commits
b5fdc8b
d509329
2bdd98d
bf93455
fb7b8e1
1320f6d
f168f32
722a63f
09573a7
989fb10
0a9c257
ed2d951
886fa4e
3c08a79
2229964
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,10 @@ | ||
/* | ||
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one | ||
* or more contributor license agreements. Licensed under the "Elastic License | ||
* 2.0", the "GNU Affero General Public License v3.0 only", and the "Server Side | ||
* Public License v 1"; you may not use this file except in compliance with, at | ||
* your election, the "Elastic License 2.0", the "GNU Affero General Public | ||
* License v3.0 only", or the "Server Side Public License, v 1". | ||
*/ | ||
|
||
export {}; |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -19,3 +19,34 @@ import { configure } from '@testing-library/react'; | |
|
||
// instead of default 'data-testid', use kibana's 'data-test-subj' | ||
configure({ testIdAttribute: 'data-test-subj', asyncUtilTimeout: 4500 }); | ||
|
||
/* eslint-env jest */ | ||
|
||
// This is a workaround to run tests with React 17 and the latest @testing-library/react | ||
// Tracking issue to clean this up https://github.com/elastic/kibana/issues/199100 | ||
jest.mock('@testing-library/react', () => { | ||
const actual = jest.requireActual('@testing-library/react'); | ||
|
||
return { | ||
...actual, | ||
render: (ui, options) => actual.render(ui, { ...options, legacyRoot: true }), | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Forcing There is no global configuration for this option, so we have to do this mocking workaround to adjust the default. Event after upgrade of the react packages to React@18 it would make sense to keep this option as it until we start upgrading to the Concurrent Mode. We will likely come of a gradual transition plan in parallel with the runtime. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Yeah same thing here as above, I feel at minimum we need a comment to track this. |
||
renderHook: (render, options) => actual.renderHook(render, { ...options, legacyRoot: true }), | ||
}; | ||
}); | ||
|
||
// This is a workaround to run tests with React 17 and the latest @testing-library/react | ||
// And prevent the act warnings that were supposed to be muted by @testing-library | ||
// The testing library mutes the act warnings in some cases by setting IS_REACT_ACT_ENVIRONMENT which is React@18 feature https://github.com/testing-library/react-testing-library/pull/1137/ | ||
// Using this console override we're muting the act warnings as well | ||
// Tracking issue to clean this up https://github.com/elastic/kibana/issues/199100 | ||
// NOTE: we're not muting all the act warnings but only those that testing-library wanted to mute | ||
const originalConsoleError = console.error; | ||
console.error = (...args) => { | ||
if (global.IS_REACT_ACT_ENVIRONMENT === false) { | ||
if (args[0].includes('Warning: An update to %s inside a test was not wrapped in act')) { | ||
return; | ||
} | ||
} | ||
|
||
originalConsoleError(...args); | ||
}; |
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We're just mocking this with an
{}
, this API from React@18 won't be used because we're forcinglegacyRoot:true
. Just need to it help to resolve the modules. This mock can be removed with an upgrade to React@18