Cypress&Google地图拖动移动元素,而不是地图

Cypress amp; Google Maps dragging moves elements, not the map(Cypressamp;Google地图拖动移动元素,而不是地图)
本文介绍了Cypress&Google地图拖动移动元素,而不是地图的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在尝试用Cypress(V8)编写测试:

  1. 加载地图时,我们命中终结点/myFleet以生成标记。
  2. 然后,用户拖动地图。和onDragEnd,我们将显示一个按钮以搜索区域
  3. (&QOOT;Search Area&Quot;)
  4. 当用户单击";拖动区域(&q;)时,我们再次cy.intercept到达/myFleet终结点。

当我尝试项目2时,搜索区域按钮&;Google地图缩放控件将X轴上移与我的mousemove事件相同的量&;搜索按钮上的click()未被触发。

cy.get('#live-view-map')
      .trigger('mousedown')
      .trigger('mousemove', { x: 261, y: 0 })
      .trigger('mouseup')
      .wait(500); // just to allow google maps tiles to resettle after drag

    cy.findByTestId('button-search-area').click();

这里有一个GIF:https://recordit.co/B6H5iWEyK5

这里是";之后的";的屏幕截图:

为什么我的按钮&;Google缩放控件上移?我认为它干扰了实际选择&;单击该元素。

我没有选择要拖动的正确元素(cy.get('#live-view-map'))?

推荐答案

它没有移动地图的原因似乎是因为地图未完全加载。进一步检查后,UI中缺少缩放控件。因此,通过添加查找按钮的检查,我们知道地图已经确定。

cy.findByRole('button', {
      name: /zoom out/i,
    });
    cy.get('#live-view-map')
      .trigger('mousedown', { which: 1 })
      .trigger('mousemove', { which: 1, x: 261, y: 0 })
      .trigger('mouseup')
      .wait(500);
    cy.findByTestId('button-search-area').click();

在新视频中,您可以看到Cypress渲染地图时使用了一些跳跃的元素,但现在更具可预测性。

这篇关于Cypress&Google地图拖动移动元素,而不是地图的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

Update another component when Formik form changes(当Formik表单更改时更新另一个组件)
Formik validation isSubmitting / isValidating not getting set to true(Formik验证正在提交/isValiating未设置为True)
React Validation Max Range Using Formik(使用Formik的Reaction验证最大范围)
Validation using Yup to check string or number length(使用YUP检查字符串或数字长度的验证)
Updating initialValues prop on Formik Form does not update input value(更新Formik表单上的初始值属性不会更新输入值)
password validation with yup and formik(使用YUP和Formick进行密码验证)