Skip to content
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

TypeScript 5 support for sourceMap option #26203

Closed
elevatebart opened this issue Mar 23, 2023 · 32 comments · Fixed by #29568
Closed

TypeScript 5 support for sourceMap option #26203

elevatebart opened this issue Mar 23, 2023 · 32 comments · Fixed by #29568
Labels
topic: typescript Triaged Issue has been routed to backlog. This is not a commitment to have it prioritized by the team. type: feature New feature that does not currently exist

Comments

@elevatebart
Copy link
Contributor

Current behavior

If I want to use TypeScript 5 and use sourceMap in my tsconfig.json, cypress errors with the following error.

Error: Webpack Compilation Error
/Users/bart/Dev/cypress-with-ts5/tsconfig.json
[tsl] ERROR
      TS5053: Option 'sourceMap' cannot be specified with option 'inlineSourceMap'.

Desired behavior

No response

Test code to reproduce

https://github.com/elevatebart/cypress-with-ts5/

Cypress Version

12.8.1

Node version

v18.7.0

Operating System

macOS 13.2.1

Debug Logs

No response

Other

No response

@elevatebart
Copy link
Contributor Author

I found this old issue that throws the same error. Maybe that helps
#8477

@koooge
Copy link
Contributor

koooge commented Mar 25, 2023

Hi, I encountered the same error with typescript@5, and "sourceMap": false, worked. However, cypress now reports the wrong line when a test error occurs.

@lmiller1990
Copy link
Contributor

Related: #26148

Might be fixed in #26173

@peniqliotuv
Copy link

Encountering the same issue with Typescript 5.0.3 - solution was just to pin our cypress tests to 4.9.5 while aforementioned GH issues get resolved.

@lmiller1990
Copy link
Contributor

lmiller1990 commented Apr 3, 2023

Yep please give us a few, there are some TS 5 incompatibilities - some of them are upstream, in ts-node, eg #26148, leading to a PR in TS itself. We will get through these soon. Thanks!

@lmiller1990
Copy link
Contributor

lmiller1990 commented Apr 20, 2023

The issue is we hard code inlineSourceMap:

One work around would be to provide your own preprocessor and webpack config that does not set this option, eg: https://github.com/elevatebart/cypress-with-ts5/compare/main...lmiller1990:cypress-with-ts5:example-fix?expand=1

Alternatively, you should be able to modify our defaults and remove the inlineSourceMap options, something like described here: https://github.com/cypress-io/cypress/tree/4963893ac5738d8a0e447c0a624639a21ae7a072/npm/webpack-preprocessor#modifying-default-options

I don’t know if we can just remove the inlineSourceMap option in our default preprocessor, that might be a breaking change. We could detect if they are using sourceMap and if they are, conditionally remove it. I'd say providing your own webpack-preprocessor with the defaults you'd like to use is probably a good work around for now - more control, and you can also use webpack 5 (default is 4).

@CheIIau
Copy link

CheIIau commented May 30, 2023

Facing the same error

ras0q added a commit to traPtitech/traQ_S-UI that referenced this issue May 31, 2023
@nagash77 nagash77 added type: feature New feature that does not currently exist Triaged Issue has been routed to backlog. This is not a commitment to have it prioritized by the team. labels May 31, 2023
@flavianh
Copy link

flavianh commented May 31, 2023

Alternatively, you should be able to modify our defaults and remove the inlineSourceMap options, something like described here: https://github.com/cypress-io/cypress/tree/4963893ac5738d8a0e447c0a624639a21ae7a072/npm/webpack-preprocessor#modifying-default-options

@lmiller1990 in cypress.config.ts, I tried:

export default defineConfig({
...
  e2e: {
    setupNodeEvents(on) {
      const options = { ...webpackPreprocessor.defaultOptions };
      console.log(JSON.stringify(options));
    },
  },
})

However, the rule you mention does not appear in the result. options gives out:

{"webpackOptions":{"mode":"development","module":{"rules":[{"test":{},"exclude":[{}],"use":[{"loader":"babel-loader","options":{"presets":["@babel/preset-env"]}}]}]}},"watchOptions":{}}

Strangely, I can't find cypress/npm/webpack-batteries-included-preprocessor/index.js in my node_modules. Any idea why?

One work around would be to provide your own preprocessor and webpack config that does not set this option, eg: https://github.com/elevatebart/cypress-with-ts5/compare/main...lmiller1990:cypress-with-ts5:example-fix?expand=1

Sadly this fails for me too as I'm having trouble finding the right webpack.config to use and the cypress compilation returns an import error for my own module.

image

I've tried "sourceMap": false, which fixes the compilation issue, but we'll misreport the lines as a previous user said.

@vlad-ivanov-d
Copy link

vlad-ivanov-d commented Jun 1, 2023

My workaround for now is just to overwrite original sourceMap inside tsconfig.json in cypress folder:

image

@lmiller1990
Copy link
Contributor

@flavianh does ^ work for you?

Re:

Strangely, I can't find cypress/npm/webpack-batteries-included-preprocessor/index.js in my node_modules. Any idea why?

Yeah - it's part of the actual Cypress app, which has it's own node_modules (that are not installed into your local project. The actual app and it's dependencies are located in different places depending on your OS, something like these directories.

When you tried making your own webpack config, you got an error - what is that? Maybe we can work through it.

erikmom added a commit to erikmom/ngx-sub-form that referenced this issue Jul 3, 2023
Also wanted to to upgrade typescript to a 5.x.x version, but the Cypress typescript compilation failed, because of cypress-io/cypress#26203
erikmom added a commit to erikmom/ngx-sub-form that referenced this issue Jul 3, 2023
BREAKING CHANGE: Angular 16 required

This closes cloudnc#298

Also wanted to to upgrade typescript to a 5.x.x version, but the Cypress typescript compilation failed, because of cypress-io/cypress#26203
erikmom added a commit to erikmom/ngx-sub-form that referenced this issue Jul 5, 2023
BREAKING CHANGE: Angular 16 required

This closes cloudnc#298

Also wanted to to upgrade typescript to a 5.x.x version, but the Cypress typescript compilation failed, because of cypress-io/cypress#26203
erikmom added a commit to erikmom/ngx-sub-form that referenced this issue Jul 5, 2023
BREAKING CHANGE: Angular 16 required

This closes cloudnc#298

Also wanted to to upgrade typescript to a 5.x.x version, but the Cypress typescript compilation failed, because of cypress-io/cypress#26203
@scottohara
Copy link
Contributor

I have successfully used the workaround above (for now - I remain hopeful that the workaround is only temporarily necessary).

I already had a cypress/tsconfig.json file in my project (in addition to my main tsconfig.json in the project root), so adding "sourceMap": false to the former (to override "sourceMap": true in the latter) was straightforward.

What I don't understand though is why this error only appears after upgrading to TypeScript 5.x?

I have always had "sourceMap": true in my main tsconfig.json; and as far as I can tell Cypress has always defaulted to "inlineSourceMap": true unless overridden by the sourceMap setting in a user-supplied tsconfig.json file.

So with TypeScript 4.x, this was fine:

/* tsconfig.json */
{
  "compilerOptions": {
    // ...
    "sourceMap": true,
    // ...
  }
}

/* cypress/tsconfig.json */
{
  "extends": "../tsconfig.json",
  "compilerOptions": {
    // Nothing here about source maps
  }
}

But with TypeScript 5.x we need this:

/* tsconfig.json */
{
  "compilerOptions": {
    // ...
    "sourceMap": true,   // same as always
    // ...
  }
}

/* cypress/tsconfig.json */
{
  "extends": "../tsconfig.json",
  "compilerOptions": {
    // ...
    "sourceMap": false   // <-- workaround
    // ...
  }
}

Not that it really matters, but I would be curious to know what actually changed with TypeScript 5.x that triggered the need for the workaround?

@guilhermesimoes
Copy link

@scottohara
Copy link
Contributor

Yeah, that was my first thought too, but that change seems to relate to extending from multiple configs.

I suppose it is possible that in making those changes they have somehow altered how certain config values in a single base tsconfig.json file (e.g. sourceMap) are resolved into the final config; but on the surface it doesn't sound like this should behave any differently to earlier TS versions when just extending from a single tsconfig.json file.

@Mexx77
Copy link

Mexx77 commented Aug 3, 2023

face the same issue and would like to remove the workaround again

@attila
Copy link

attila commented Sep 5, 2023

I've tried the workaround at #26203 (comment) but my problem is that cypress/tsconfig.json is ignored.

If I set sourceMap to false in the tsconfig.json of the workspace, it works fine.
The folder structure in this npm monorepo is as follows:

/packages/
   tsconfig/
      base.json        // <-- setting "sourceMap": false works in here
   project/
      cypress/
         tsconfig.json // <-- This file is never picked up as tsconfig for cypress
      tsconfig.json    // <-- extends from "/packages/tsconfig/base.json" – setting "sourceMap": false works here

louis-bompart added a commit to coveo/ui-kit that referenced this issue Sep 10, 2023
@IlCallo
Copy link
Contributor

IlCallo commented Sep 13, 2023

This feels painfully similar to #8477 🥲

@Sinled
Copy link

Sinled commented Oct 6, 2023

Any updates on this?
for me "sourceMap": false works for some specs, but fails for others.

@pjanik
Copy link

pjanik commented Jan 9, 2024

The provided workaround won't work if you attempt to import files from outside the Cypress directory. Whether this is a good or bad idea is a separate discussion, but it can pose real issues for many projects. In such cases, the main tsconfig.json will be picked up.

Are there any plans to address this issue on the Cypress side?

pjanik added a commit to concord-consortium/tectonic-explorer that referenced this issue Jan 9, 2024
…dir [PT-186622946]

Cypress has a bug that breaks tests that import files imported from
outside the Cypress folder when TypeScript 5+ is used:

cypress-io/cypress#26203

These tests were currently skipped anyway, so moving them out of the
basic dir so Cypress doesn't even try to run them and fail because
of the sourceMap issue. Hopefully, this Cypress bug gets fixed
before we will have time to re-enable these tests.
@fbandrei
Copy link

Having the same issue, setting "sourceMap: false" does not work as a workaround.

1 similar comment
@NealArw
Copy link

NealArw commented Mar 13, 2024

Having the same issue, setting "sourceMap: false" does not work as a workaround.

@asalgado87
Copy link

Encountering the same issue with Typescript 5.0.3 - solution was just to pin our cypress tests to 4.9.5 while aforementioned GH issues get resolved.

@peniqliotuv can you point me to any resources on how to run cypress with an older version of typescript?

@peniqliotuv
Copy link

Encountering the same issue with Typescript 5.0.3 - solution was just to pin our cypress tests to 4.9.5 while aforementioned GH issues get resolved.

@peniqliotuv can you point me to any resources on how to run cypress with an older version of typescript?

You can use the ' resolutions' field in the package file

@asalgado87
Copy link

@peniqliotuv Can you be more specific? Sorry I'm relatively new to this kind of thing. Much appreciated

@scottohara
Copy link
Contributor

Permit me to ask a potentially silly question.

If I understand correctly, this issue arises when:

  • sourceMap: true (as specified by the user in cypress/tsconfig.json)

... conflicts with

  • inlineSourceMap: true (as specified by Cypress in the webpack preprocessor)

... as these two tsconfig options (sourceMap / inlineSourceMap) are mutually exclusive.

The workaround that many of us here have successfully used to avoid this error is to explicitly set sourceMap: false in the user-supplied cypress/tsconfig.json file (noting that there were some concerns mentioned above about whether it would be safe for Cypress to remove the inlineSourceMap: true setting).

Given the mutual exclusivity of these two config options and the fact that Cypress hardcodes the value of one of the options; shouldn't it also hardcode the value of the other?

That is, instead of asking every end-user that encounters this error to apply the same workaround, would it be possible for Cypress to force sourceMap: false at the same time as setting inlineSourceMap: true?

webpackOptions.module.rules.push({
    test: /\.tsx?$/,
    exclude: [/node_modules/],
    use: [
      {
        loader: require.resolve('ts-loader'),
        options: {
          compiler: options.typescript,
          compilerOptions: {
            inlineSourceMap: true,      // if this is true...
            inlineSources: true,
            downlevelIteration: true,
+           sourceMap: false,           // ...then this MUST be false
          },
          logLevel: 'error',
          silent: true,
          transpileOnly: true,
        },
      },
    ],
  })

Or would that not fix the issue because anything in the user-supplied cypress/tsconfig.json takes precedence over the defaults in the webpack processor?
(so a user-supplied sourceMap: true would overwrite the Cypress supplied sourceMap: false?)

@WellingtonBraga
Copy link

Hi,

After upgrading Typescript to version 5.x we started to have the same issue. We've set sourceMap to false in the e2e/tsconfig.json as a workaround, but I appreciate a final solution in this case.

As @scottohara said, that shouldn't (in theory) be that complicated as we can evaluate both sourceMap and inlineSourceMap values before building the final config to be used.

Anyways, the workaround is applied and hopefully we can move forward until we have nailed-down solution.

@jennifer-shehane jennifer-shehane added topic: typescript and removed CT Issue related to component testing labels May 15, 2024
@CedricHg
Copy link

CedricHg commented Jun 6, 2024

This is still broken for me with Cypress version 13.11.0. I have the sourceMap: false in cypress/tsconfig.json, but it looks like as others have said in this thread, this file is not being picked up.

My folder structure that leads to the Cypress tsconfig.json file is as follows:
mygitrepo\src\front\cypress\tsconfig.json

My node_modules are located here:
mygitrepo\src\front\node_modules

So it looks like it should be the correct location to me..

@AtofStryker
Copy link
Contributor

This is still broken for me with Cypress version 13.11.0. I have the sourceMap: false in cypress/tsconfig.json, but it looks like as others have said in this thread, this file is not being picked up.

My folder structure that leads to the Cypress tsconfig.json file is as follows: mygitrepo\src\front\cypress\tsconfig.json

My node_modules are located here: mygitrepo\src\front\node_modules

So it looks like it should be the correct location to me..

@CedricHg the fix for this should make its way into the next release of Cypress, which is targeted for around June 18th, 2024

@cypress-bot
Copy link
Contributor

cypress-bot bot commented Jun 18, 2024

Released in 13.12.0.

This comment thread has been locked. If you are still experiencing this issue after upgrading to
Cypress v13.12.0, please open a new issue.

@cypress-bot cypress-bot bot locked as resolved and limited conversation to collaborators Jun 18, 2024
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
topic: typescript Triaged Issue has been routed to backlog. This is not a commitment to have it prioritized by the team. type: feature New feature that does not currently exist
Projects
None yet
Development

Successfully merging a pull request may close this issue.