您的位置:

小程序自动化测试

一、自动化测试概述

小程序自动化测试是指利用工具通过模拟用户的行为、运行脚本等方式自动测试小程序的各项功能以及性能,以提高测试效率和测试覆盖率的一种方法。自动化测试比较适用于那些需要频繁回归测试的场景。

二、小程序自动化测试工具

目前市面上比较流行的小程序自动化测试工具有以下几种:

1. 微信开发者工具自带的自动化测试工具

2. Appium

3. Katalon

4. TestFairy

本篇文章将基于微信开发者工具自带的自动化测试工具进行详细介绍。

三、实现步骤

使用微信开发者工具自带的自动化测试工具,需要以下步骤:

1. 在“详情”页面启动自动化测试工具

App({
  onLaunch: function () {
    if (wx.canIUse && wx.canIUse('functionName.acceptTask')) {
      const task = wx.getLaunchOptionsSync().query.task
      wx.test.acceptTask(task)
      wx.test.run()
    }
  }
})

2. 编写脚本,实现测试用例

const { getElementRect } = require('./libs/elementtracker')
Component({
  data: {
    x: 0,
    y: 0
  },
  attached() {
    wx.test.mark(this, {
      "name": "slider",
      "type": "default",
      "desc": "slider"
    })
    getElementRect(this, '.slider-track').then((rect) => {
      this.setData({
        x: rect.left,
        y: rect.top
      })
      wx.test.info({
        "element": ".slider-track",
        "msg": `slider pos: ${JSON.stringify(rect)}`
      })
    })
    wx.test.screenshot(this, ".slider-track", {})
  },
  methods: {
    getRect: function () {
      let selector = `.slider-thumb`
      let elem = wx.createSelectorQuery().in(this)[0]
      let rect = elem[0].boundingClientRect()
      rect.select(selector).boundingClientRect()

      return new Promise((resolve, reject) => {
        rect.exec(res => {
          // console.log('slider thumb rect:', res[1])
          wx.test.info({
            "element": ".slider-thumb",
            "msg": `slider thumb pos: ${JSON.stringify(res[1])}`
          })
          resolve([res[0], res[1]])
        })
      })
    }
  }
})

3. 运行测试用例

在“详情”页面中,运行测试用例,即可对小程序进行自动化测试。

四、小程序自动化测试的优点和注意事项

小程序自动化测试相比手动测试,具有以下优点:

1. 提高测试效率和测试覆盖率。

2. 快速发现问题,并推动问题的及时解决。

需要注意的事项是,自动化测试虽然可以提高测试效率和测试覆盖率,但是并不能完全替代手动测试。在应用自动化测试的同时,还需要做好手动测试工作,以确保小程序的稳定和可靠性。