如何在 Cypress 中基于 css `transform: rotate(270deg)` 检查方向?

How to check orientation based on css `transform: rotate(270deg)` in Cypress?

我需要用 Cypress 检查 div 的方向。

这是测试:

cy
  .get('data-test="vertical"')
  .should('have.css', 'transform', 'translate(-100%, 0) rotate(270deg)')

div 行为在一个场景中是标准的,或者它在另一个场景中与 css transform: translate(-100%, 0) rotate(270deg); 轮换。 我需要一种方法来检查方向,但是 transform 很难检查,因为例如在赛普拉斯测试中会发生什么: 当我期望 transform: rotateX(180deg) 我实际上收到 transform: matrix3d(1, 0, 0, 0, 0, -1, 1.22465e-16, 0, 0, -1.22465e-16, -1, 0, 0, 0, 0, 1).

我需要找到一种检测方向的智能方法。建议?提示?

问题是这样解决的,创建命令:

const getTransformRotationAngle = (cssTransformMatrix, absoluteValue) => {
  const cssTransformMatrixIndexes = cssTransformMatrix
    .split('(')[1]
    .split(')')[0]
    .split(',')
  const cssTransformScale = Math.sqrt(
    cssTransformMatrixIndexes[0] * cssTransformMatrixIndexes[0] +
      cssTransformMatrixIndexes[1] * cssTransformMatrixIndexes[1]
  )
  const cssTransformSin = cssTransformMatrixIndexes[1] / cssTransformScale
  const cssTransformAngle = Math.round(
    Math.asin(cssTransformSin) * (180 / Math.PI)
  )
  return absoluteValue ? Math.abs(cssTransformAngle) : cssTransformAngle
}

Cypress.Commands.add('getTransformRotationAngle', getTransformRotationAngle)

及其在测试中的使用:

cy
  .get('data-test="vertical"')
  .invoke('css', 'transform')
  .then(cssTransform => {
    cy.getTransformRotationAngle(cssTransform, true).should(
      'eq',
      90 || 270
    )
  })