首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用cypress框架运行angular应用程序的e2e测试时出现“未捕获的SyntaxError:无效或意外的令牌”

使用cypress框架运行angular应用程序的e2e测试时出现“未捕获的SyntaxError:无效或意外的令牌”
EN

Stack Overflow用户
提问于 2019-09-14 11:05:27
回答 3查看 1.4K关注 0票数 1

我正在使用cypress为我们的angular应用程序做e2e测试,当cypress自动打开应用程序主页时,错误发生了,并且在浏览器控制台中打印"Uncaught : Invalid or unexpected“,就像附件中的截图所示,似乎在vendor.xxx.js文件中捕获了混乱的代码,但该文件是由angular框架自动编译和生成的,在我们的日常使用中没有问题。如果我在浏览器中手动输入URL来访问应用程序,这个错误就会消失,当它触发或启动浏览器进行测试时,我不确定是否是cypress bug,毕竟是cypress框架操纵浏览器。该错误发生在由cypress控制的内置Eletron浏览器和chrome浏览器中。使用的柏树版本是3.4.0,如果有人能给我一些建议,我将非常感激,谢谢。

EN

回答 3

Stack Overflow用户

发布于 2019-09-16 10:40:56

这可能不是很理想,但是您是否尝试过添加

代码语言:javascript
复制
Cypress.on('uncaught:exception', (err, runnable) => {
    // returning false here prevents Cypress from
    // failing the test
    return false
  })

到support文件夹下的index.js?

如果有未捕获的异常,这将使您的测试停止失败。

票数 1
EN

Stack Overflow用户

发布于 2019-09-14 15:46:25

代码语言:javascript
复制
function d3_asin(x){
  return x > 1 half ??: x < -1 ? half :math.asin(x);
}

 function d3_asin(x){
   return ((x = Math.exp(x)) - 1 / x) / 2;
 }

在独立的Chrome上运行的相同文件被正确加载,所以它必须是Cypress编码的问题。在谷歌搜索后,我们发现Cypress设置有默认设置,其中包含此属性:

代码语言:javascript
复制
"modifyObstructiveCode": true

在将其设置为

之后,它可以很好地工作。

票数 0
EN

Stack Overflow用户

发布于 2021-05-12 20:42:57

您可以通过将文件浏览器列表的名称改为.browserlistrc来解决此问题。我也有同样的问题,它帮助了我。调查以下问题:

https://github.com/cypress-io/cypress/issues/8864

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/57932141

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档