Skip to content

Commit

Permalink
breaking: remove support for react 16 and 17 for component testing an…
Browse files Browse the repository at this point in the history
…d move cypress/react18 upstream into cypress/react [run ci]

cut over react harness examples to hooks

fix failing vite-plugin-cypress-esm tests
  • Loading branch information
AtofStryker committed Nov 13, 2024
1 parent 7e45094 commit 1f8d370
Show file tree
Hide file tree
Showing 89 changed files with 609 additions and 2,042 deletions.
2 changes: 1 addition & 1 deletion .circleci/cache-version.txt
Original file line number Diff line number Diff line change
@@ -1,3 +1,3 @@
# Bump this version to force CI to re-create the cache from scratch.

11-07-24-vue-cli-service-removal
11-07-24-react-16-17-removal
1 change: 0 additions & 1 deletion CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,6 @@
- [`@cypress/eslint-plugin-dev`](https://github.com/cypress-io/cypress/blob/develop/npm/eslint-plugin-dev/CHANGELOG.md)
- [`@cypress/mount-utils`](https://github.com/cypress-io/cypress/blob/develop/npm/mount-utils/CHANGELOG.md)
- [`@cypress/react`](https://github.com/cypress-io/cypress/blob/develop/npm/react/CHANGELOG.md)
- [`@cypress/react18`](https://github.com/cypress-io/cypress/blob/develop/npm/react18/CHANGELOG.md)
- [`@cypress/svelte`](https://github.com/cypress-io/cypress/blob/develop/npm/svelte/CHANGELOG.md)
- [`@cypress/vite-dev-server`](https://github.com/cypress-io/cypress/blob/develop/npm/vite-dev-server/CHANGELOG.md)
- [`@cypress/vue`](https://github.com/cypress-io/cypress/blob/develop/npm/vue/CHANGELOG.md)
Expand Down
1 change: 0 additions & 1 deletion CONTRIBUTING.md
Original file line number Diff line number Diff line change
Expand Up @@ -186,7 +186,6 @@ Here is a list of the npm packages in this repository:
| [grep](./npm/grep) | `@cypress/grep` | Filter tests using substring |
| [mount-utils](./npm/mount-utils) | `@cypress/mount-utils` | Common functionality for Vue/React/Angular adapters. |
| [react](./npm/react) | `@cypress/react` | Cypress component testing for React. |
| [react18](./npm/react18) | `@cypress/react18` | Cypress component testing for React 18. |
| [schematic](./npm/cypress-schematic) | `@cypress/schematic` | Official Angular Schematic and Builder for the Angular CLI.|
| [svelte](./npm/svelte) | `@cypress/svelte` | Cypress component testing for Svelte. |
| [vite-dev-server](./npm/vite-dev-server) | `@cypress/vite-dev-server` | Vite powered dev server for Component Testing. |
Expand Down
1 change: 0 additions & 1 deletion cli/.eslintignore
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,6 @@ package.json
# these are all copied from dist'd builds from the individual libs
/angular
/react
/react18
/vue
/svelte
/mount-utils
7 changes: 0 additions & 7 deletions cli/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -71,7 +71,6 @@
"@cypress/grep": "0.0.0-development",
"@cypress/mount-utils": "0.0.0-development",
"@cypress/react": "0.0.0-development",
"@cypress/react18": "0.0.0-development",
"@cypress/sinon-chai": "2.9.1",
"@cypress/svelte": "0.0.0-development",
"@cypress/vue": "0.0.0-development",
Expand Down Expand Up @@ -114,7 +113,6 @@
"mount-utils",
"vue",
"react",
"react18",
"angular",
"svelte"
],
Expand Down Expand Up @@ -145,11 +143,6 @@
"import": "./react/dist/cypress-react.esm-bundler.js",
"require": "./react/dist/cypress-react.cjs.js"
},
"./react18": {
"types": "./react18/dist/index.d.ts",
"import": "./react18/dist/cypress-react.esm-bundler.js",
"require": "./react18/dist/cypress-react.cjs.js"
},
"./mount-utils": {
"types": "./mount-utils/dist/index.d.ts",
"require": "./mount-utils/dist/index.js"
Expand Down
1 change: 0 additions & 1 deletion cli/scripts/post-build.js
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,6 @@ shell.set('-e') // any error is fatal
const npmModulesToCopy = [
'mount-utils',
'react',
'react18',
'vue',
'angular',
'svelte',
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -20,15 +20,13 @@ describe('Counter with access', () => {
// the window.counter was set from the Counter's constructor
cy.window()
.should('have.property', 'counter')
.its('state')
.should('deep.equal', { count: 0 })
.its('count')
.should('deep.equal', 0)

// let's change the state of the component
cy.window()
.its('counter')
.invoke('setState', {
count: 101,
})
.invoke('setCount', 101)

// the UI should update to reflect the new count
cy.contains('count: 101').should('be.visible')
Expand Down
44 changes: 19 additions & 25 deletions npm/react/cypress/component/advanced/app-action-example/counter.jsx
Original file line number Diff line number Diff line change
@@ -1,34 +1,28 @@
import React from 'react'
import React, { useState } from 'react'

export class Counter extends React.Component {
constructor (props) {
super(props)
this.state = {
count: 0,
}
export function Counter () {
const [count, setCount] = useState(0)

if (window.Cypress) {
// if this component is mounted from inside Cypress Test Runner
// then expose the reference to this instance
// to allow controlling it from tests
console.log(
'set window.counter to this component in window',
window.location.pathname,
)
if (window.Cypress) {
// if this component is mounted from inside Cypress Test Runner
// then expose the reference to this instance
// to allow controlling it from tests
console.log(
'set window.counter to this component in window',
window.location.pathname,
)

window.counter = this
} else {
console.log('running outside Cypress')
window.counter = {
count,
setCount,
}
} else {
console.log('running outside Cypress')
}

click = () => {
this.setState({
count: this.state.count + 1,
})
function click () {
setCount(count + 1)
}

render () {
return <p onClick={this.click}>count: {this.state.count}</p>
}
return <p onClick={click}>count: {count}</p>
}
20 changes: 9 additions & 11 deletions npm/react/cypress/component/advanced/context/App.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,15 +2,13 @@ import React from 'react'
import { ThemeContext } from './context'
import { Toolbar } from './Toolbar.jsx'

export default class App extends React.Component {
render () {
// Use a Provider to pass the current theme to the tree below.
// Any component can read it, no matter how deep it is.
// In this example, we're passing "dark" as the current value.
return (
<ThemeContext.Provider value="dark">
<Toolbar />
</ThemeContext.Provider>
)
}
export default function App () {
// Use a Provider to pass the current theme to the tree below.
// Any component can read it, no matter how deep it is.
// In this example, we're passing "dark" as the current value.
return (
<ThemeContext.Provider value="dark">
<Toolbar />
</ThemeContext.Provider>
)
}
49 changes: 21 additions & 28 deletions npm/react/cypress/component/advanced/mocking-axios/1-users.jsx
Original file line number Diff line number Diff line change
@@ -1,36 +1,29 @@
import React from 'react'
import React, { useState, useEffect } from 'react'
// import the entire axios module
// later we can use axios.get to make requests
import axios from 'axios'

export class Users extends React.Component {
constructor (props) {
super(props)
this.state = {
users: [],
}
}
export function Users () {
const [users, setUsers] = useState([])

componentDidMount () {
axios
.get('https://jsonplaceholder.cypress.io/users?_limit=3')
.then((response) => {
// JSON responses are automatically parsed.
this.setState({
users: response.data,
})
})
}
const getUsers = async () => {
const response = await axios.get('https://jsonplaceholder.cypress.io/users?_limit=3')
// JSON responses are automatically parsed.

render () {
return (
<div>
{this.state.users.map((user) => (
<li key={user.id}>
<strong>{user.id}</strong> - {user.name}
</li>
))}
</div>
)
setUsers(response.data)
}

useEffect(() => {
getUsers()
}, [])

return (
<div>
{users.map((user) => (
<li key={user.id}>
<strong>{user.id}</strong> - {user.name}
</li>
))}
</div>
)
}
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
/// <reference types="cypress" />
import React from 'react'
import { mount } from '@cypress/react'
import { Users } from './3-users-api.jsx'
import * as axios from './axios-api'
import { Users } from './2-users-api.jsx'
import * as axios from './axios-api.jsx'

describe('Mocking wrapped Axios', () => {
it('shows real users', () => {
Expand Down
29 changes: 29 additions & 0 deletions npm/react/cypress/component/advanced/mocking-axios/2-users-api.jsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
import React, { useState, useEffect } from 'react'
// import wrapped Axios method
import axiosApi from './axios-api'

export function Users () {
const [users, setUsers] = useState([])

const getUsers = async () => {
console.log({ axiosApi })
const response = await axiosApi.get('https://jsonplaceholder.cypress.io/users?_limit=3')
// JSON responses are automatically parsed.

setUsers(response.data)
}

useEffect(() => {
getUsers()
}, [])

return (
<div>
{users.map((user) => (
<li key={user.id}>
<strong>{user.id}</strong> - {user.name}
</li>
))}
</div>
)
}

This file was deleted.

This file was deleted.

34 changes: 0 additions & 34 deletions npm/react/cypress/component/advanced/mocking-axios/3-users-api.jsx

This file was deleted.

Loading

0 comments on commit 1f8d370

Please sign in to comment.