mirror of
https://github.com/cypress-io/cypress.git
synced 2026-02-04 22:30:00 -06:00
* feat: support webpack-dev-server-5 for @cypress/webpack-dev-server [run ci] * sidestep Forge types installed by webpack dev server [run ci] * add changelog entry * remove webpack 4 types * format changelog * Update cli/CHANGELOG.md * Update npm/webpack-dev-server/src/helpers/sourceRelativeWebpackModules.ts Co-authored-by: Matt Schile <mschile@cypress.io> * add back in importsNotUsedAsValues and update system test snapshot --------- Co-authored-by: Jennifer Shehane <jennifer@cypress.io> Co-authored-by: Matt Schile <mschile@cypress.io>
94 lines
3.2 KiB
TypeScript
94 lines
3.2 KiB
TypeScript
import * as Fixtures from '@tooling/system-tests'
|
|
import * as FixturesScaffold from '@tooling/system-tests/lib/dep-installer'
|
|
import type { fixtureDirs } from '@tooling/system-tests'
|
|
import { expect } from 'chai'
|
|
import path from 'path'
|
|
import fs from 'fs'
|
|
|
|
import { sourceDefaultWebpackDependencies } from '../src/helpers/sourceRelativeWebpackModules'
|
|
import { WebpackDevServerConfig } from '../src/devServer'
|
|
import './support'
|
|
|
|
type ProjectDirs = typeof fixtureDirs
|
|
|
|
const CY_ROOT = path.join(__dirname, '..', '..', '..')
|
|
|
|
const WEBPACK_REACT: Partial<Record<ProjectDirs[number], {
|
|
webpack: number
|
|
webpackDevServer: number
|
|
htmlWebpackPlugin: number
|
|
}>> = {
|
|
'webpack4_wds3-react': {
|
|
webpack: 4,
|
|
webpackDevServer: 3,
|
|
htmlWebpackPlugin: 4,
|
|
},
|
|
'webpack4_wds4-react': {
|
|
webpack: 4,
|
|
webpackDevServer: 4,
|
|
htmlWebpackPlugin: 4,
|
|
},
|
|
'webpack5_wds3-react': {
|
|
webpack: 5,
|
|
webpackDevServer: 3,
|
|
htmlWebpackPlugin: 5,
|
|
},
|
|
'webpack5_wds4-react': {
|
|
webpack: 5,
|
|
webpackDevServer: 4,
|
|
htmlWebpackPlugin: 5,
|
|
},
|
|
'webpack5_wds5-react': {
|
|
webpack: 5,
|
|
webpackDevServer: 5,
|
|
htmlWebpackPlugin: 5,
|
|
},
|
|
}
|
|
|
|
async function sourceModulesForProject (fixture: ProjectDirs[number]) {
|
|
Fixtures.remove()
|
|
const projectRoot = await Fixtures.scaffoldProject(fixture)
|
|
|
|
await FixturesScaffold.scaffoldProjectNodeModules({ project: fixture })
|
|
|
|
const result = sourceDefaultWebpackDependencies({
|
|
cypressConfig: {
|
|
projectRoot,
|
|
},
|
|
} as WebpackDevServerConfig)
|
|
|
|
return { result, projectRoot }
|
|
}
|
|
|
|
// Ensures that we are properly sourcing the webpacks from the node_modules in the given project,
|
|
// rather than from the node_modules in the project root
|
|
describe('sourceDefaultWebpackDependencies', () => {
|
|
for (const [fixture, versionsToMatch] of Object.entries(WEBPACK_REACT)) {
|
|
describe(fixture, () => {
|
|
it(`sources the correct webpack versions for ${fixture}`, async () => {
|
|
const { result, projectRoot } = await sourceModulesForProject(fixture as ProjectDirs[number])
|
|
const projectNodeModules = fs.realpathSync(path.resolve(projectRoot, 'node_modules'))
|
|
|
|
expect(result.webpack.majorVersion).to.eq(versionsToMatch.webpack, 'match webpackVersion')
|
|
expect(result.webpackDevServer.majorVersion).to.eq(versionsToMatch.webpackDevServer, 'match webpackDevServerVersion')
|
|
expect(result.webpack.importPath).to.include(projectNodeModules)
|
|
expect(result.webpackDevServer.importPath).to.include(projectNodeModules)
|
|
})
|
|
})
|
|
}
|
|
|
|
it('sources the webpack path from the correct location once imported', async () => {
|
|
expect(require.resolve('webpack')).to.include(CY_ROOT)
|
|
const localWebpack = require('webpack')
|
|
|
|
const { result, projectRoot } = await sourceModulesForProject('webpack4_wds3-react')
|
|
const projectNodeModules = fs.realpathSync(path.resolve(projectRoot, 'node_modules'))
|
|
|
|
expect(localWebpack).not.to.eq(result.webpack.module)
|
|
expect(result.webpack.importPath).to.include(projectNodeModules)
|
|
expect(result.webpack.majorVersion).to.eq(4, 'match webpackVersion')
|
|
expect(require('webpack')).to.eq(result.webpack.module)
|
|
expect(require.resolve('webpack')).to.include(projectNodeModules)
|
|
})
|
|
})
|