-
-
Notifications
You must be signed in to change notification settings - Fork 2k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Adapter Initial Implementation + React 16 Support
- Loading branch information
1 parent
b73c0fc
commit c98e97c
Showing
33 changed files
with
2,295 additions
and
992 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -53,3 +53,4 @@ env: | |
- REACT=0.14 | ||
- REACT=15.4 | ||
- REACT=15 | ||
- REACT=16 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,94 @@ | ||
# Migration Guide (for React 0.13 - React 15.x) | ||
|
||
|
||
## Root Wrapper | ||
|
||
The initially returned wrapper used to be around the element passed | ||
into the `mount` API, and for `shallow` it was around the root node of the rendered output of the element passed in. After the upgrade, the | ||
two APIs are now symmetrical, starting off | ||
|
||
```js | ||
const x = 'x'; | ||
const Foo = props => <div inner={props.outer} /> | ||
const wrapper = mount(<Foo outer={x} />); | ||
``` | ||
|
||
```js | ||
expect(wrapper.props()).to.deep.equal({ outer: x }); | ||
``` | ||
|
||
## Refs | ||
|
||
Refs no longer return a "wrapper". They return what the ref would actually be. | ||
|
||
|
||
## Keys | ||
|
||
keys no longer work? we should maybe fix this in the spec... | ||
|
||
|
||
## for shallow, getNode() was renamed to getElement() | ||
|
||
## for mount, getNode() should not be used. instance() does what it used to. | ||
|
||
## for mount, getElement() will return the root JSX element | ||
|
||
## what getNode() returns | ||
|
||
we need to keep in mind that `getElement()` will no longer be referentially equal to what it was before. | ||
|
||
## Updates are required | ||
|
||
``` | ||
wrapper.find('.async-btn').simulate('click'); | ||
setImmediate(() => { | ||
// this didn't used to be needed | ||
wrapper.update(); // TODO(lmr): this is a breaking change... | ||
expect(wrapper.find('.show-me').length).to.equal(1); | ||
done(); | ||
}); | ||
``` | ||
|
||
|
||
|
||
|
||
## Enzyme.use | ||
|
||
|
||
|
||
|
||
# Migration Guide (for React 16) | ||
|
||
## Stateless Functional Components | ||
|
||
SFCs actually go down a different code path in react 16, which means that they | ||
dont have "instances" associated with them, which means there are a couple of things | ||
that we used to be able to do with enzyme + SFCs that will just no longer work. | ||
|
||
We could fix a lot of this if there was a reliable way to get from an SFC "fiber" to | ||
the corresponding DOM element that it renders. | ||
|
||
## Strings vs. Numbers | ||
|
||
React 16 converts numbers to strings very early on. we can't change this. this will change | ||
some behavior in enzyme but we are considering this the "correct" behavior. | ||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
# Left to do: | ||
|
||
- move adapters into standalone packages | ||
- x create Enzyme.use API | ||
- x create api to inject adapter per use | ||
- x make sure all react dependence is moved into adapters | ||
- x make tests run for all adapters | ||
- export tests for 3rd party adapters to run | ||
- check the targetApiVersion returned by the adapter and use the semver library |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -21,13 +21,14 @@ | |
"test:watch": "mocha --recursive --watch test", | ||
"test:karma": "karma start", | ||
"test:env": "sh ./example-test.sh", | ||
"test:all": "npm run react:13 && npm run test:only && npm run react:14 && npm run test:only && npm run react:15.4 && npm run test:only && npm run react:15 && npm run test:only", | ||
"test:all": "npm run react:13 && npm run test:only && npm run react:14 && npm run test:only && npm run react:15.4 && npm run test:only && npm run react:15 && npm run test:only && npm run react:16 && npm run test:only", | ||
"clean-local-npm": "rimraf node_modules/.bin/npm node_modules/.bin/npm.cmd", | ||
"react:clean": "npm run clean-local-npm && rimraf node_modules/react node_modules/react-dom node_modules/react-addons-test-utils node_modules/react-test-renderer && npm prune", | ||
"react:13": "npm run react:clean && npm install && npm i --no-save [email protected]", | ||
"react:14": "npm run react:clean && npm install && npm i --no-save [email protected] [email protected] [email protected]", | ||
"react:15.4": "npm run react:clean && npm install && npm i --no-save [email protected] [email protected] [email protected]", | ||
"react:15": "npm run react:clean && npm install && npm i --no-save react@15 react-dom@15 create-react-class@15 react-test-renderer@^15.5.4", | ||
"react:16": "npm run react:clean && npm install && npm i --no-save [email protected] [email protected] [email protected] [email protected]", | ||
"docs:clean": "rimraf _book", | ||
"docs:lint": "eslint --ext md --config .eslintrc-markdown .", | ||
"docs:prepare": "gitbook install", | ||
|
@@ -66,6 +67,8 @@ | |
"object.entries": "^1.0.4", | ||
"object.values": "^1.0.4", | ||
"prop-types": "^15.5.10", | ||
"raf": "^3.3.2", | ||
"semver": "^5.3.0", | ||
"uuid": "^3.0.1" | ||
}, | ||
"devDependencies": { | ||
|
@@ -101,6 +104,7 @@ | |
"karma-mocha": "^1.3.0", | ||
"karma-sourcemap-loader": "^0.3.7", | ||
"karma-webpack": "^1.8.1", | ||
"lodash": "^4.17.4", | ||
"mocha": "^3.4.2", | ||
"rimraf": "^2.6.1", | ||
"safe-publish-latest": "^1.1.1", | ||
|
@@ -109,6 +113,6 @@ | |
"react": "0.13.x || 0.14.x || ^15.0.0-0 || 15.x" | ||
}, | ||
"peerDependencies": { | ||
"react": "0.13.x || 0.14.x || ^15.0.0-0 || 15.x" | ||
"react": "0.13.x || 0.14.x || ^15.0.0-0 || 15.x || 16.x || ^16.0.0-alpha" | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,25 @@ | ||
/* eslint global-require: 0 */ | ||
/** | ||
* This file is needed only because we run our unit tests on multiple | ||
* versions of React at a time. This file basically figures out which | ||
* version of React is loaded, and configures enzyme to use the right | ||
* corresponding adapter. | ||
*/ | ||
const Version = require('./src/version'); | ||
const Enzyme = require('./src'); | ||
|
||
let Adapter = null; | ||
|
||
if (Version.REACT013) { | ||
Adapter = require('./src/adapters/ReactThirteenAdapter'); | ||
} else if (Version.REACT014) { | ||
Adapter = require('./src/adapters/ReactFourteenAdapter'); | ||
} else if (Version.REACT155) { | ||
Adapter = require('./src/adapters/ReactFifteenAdapter'); | ||
} else if (Version.REACT15) { | ||
Adapter = require('./src/adapters/ReactFifteenFourAdapter'); | ||
} else if (Version.REACT16) { | ||
Adapter = require('./src/adapters/ReactSixteenAdapter'); | ||
} | ||
|
||
Enzyme.configure({ adapter: new Adapter() }); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.