MiniProgram

MiniProgram 模块提供了控制小程序的方法。

方法

miniProgram.pageStack

获取小程序页面堆栈。

  1. miniProgram.pageStack(): Promise<Page[]>

示例代码:

  1. automator.launch().then(async miniProgram => {
  2. const pageStack = await miniProgram.pageStack()
  3. console.log(pageStack.length) // 当前页面栈数量
  4. })

miniProgram.navigateTo

保留当前页面,跳转到应用内的某个页面,同 wx.navigateTo

  1. miniProgram.navigateTo(url: string): Promise<Page>

参数说明

字段类型必填默认值说明
urlstring-需要跳转的应用内非 tabBar 的页面的路径

示例代码:

  1. automator.launch().then(async miniProgram => {
  2. const page = await miniProgram.navigateTo('/page/component/index')
  3. console.log(page.path) // -> 'page/component/index'
  4. })

miniProgram.redirectTo

关闭当前页面,跳转到应用内的某个页面,同 wx.redirectTo

  1. miniProgram.redirectTo(url: string): Promise<Page>

参数说明

字段类型必填默认值说明
urlstring-需要跳转的应用内非 tabBar 的页面的路径

miniProgram.navigateBack

关闭当前页面,返回上一页面或多级页面,同 wx.navigateBack

  1. miniProgram.navigateBack(): Promise<Page>

miniProgram.reLaunch

关闭所有页面,打开到应用内的某个页面,同 wx.reLaunch

  1. miniProgram.reLaunch(url: string): Promise<Page>

参数说明

字段类型必填默认值说明
urlstring-需要跳转的应用内页面路径

miniProgram.switchTab

跳转到 tabBar 页面,并关闭其他所有非 tabBar 页面,同 wx.switchTab

  1. miniProgram.switchTab(url: string): Promise<Page>

参数说明

字段类型必填默认值说明
urlstring-需要跳转的 tabBar 页面的路径

miniProgram.currentPage

获取当前页面。

  1. miniProgram.currentPage(): Promise<Page>

miniProgram.systemInfo

获取系统信息,同 wx.getSystemInfo

  1. miniProgram.systemInfo(): Promise<Object>

示例代码:

  1. automator.launch().then(async miniProgram => {
  2. const systemInfo = await miniProgram.systemInfo()
  3. if (systemInfo.platform === 'devtools') {
  4. // Do something
  5. }
  6. })

miniProgram.callWxMethod

调用 wx 对象上的指定方法。

  1. miniProgram.callWxMethod(method: string, ...args: any[]): Promise<any>

参数说明

字段类型必填默认值说明
methodstring-需要调用的方法名
…argsarray<any>-方法参数

调用异步方法时无需传入 success 及 fail 回调函数。

示例代码:

  1. automator.launch().then(async miniProgram => {
  2. await miniProgram.callWxMethod('setStorage', {
  3. key: 'test',
  4. data: 'test'
  5. })
  6. const { data } = await miniProgram.callWxMethod('getStorageSync', 'test')
  7. console.log(data) // -> 'test'
  8. })

miniProgram.mockWxMethod

传入函数功能 automator 0.9.0,基础库 2.9.5 开始支持。

覆盖 wx 对象上指定方法的调用结果。

利用该接口,你可以很方便地直接指定 wx.chooseLocation 等调用系统组件的返回结果。

  1. miniProgram.mockWxMethod(method: string, result: any): Promise<void>
  2. miniProgram.mockWxMethod(method: string, fn: Function | string, ...args: any[]): Promise<void>

参数说明

字段类型必填默认值说明
methodstring-需要覆盖的方法名
resultany-指定调用结果
字段类型必填默认值说明
methodstring-需要覆盖的方法名
fnFunction string-处理返回函数
…argsarray<any>-传入参数

fn 同 miniProgram.evaluate 的 appFunction 参数一样,无法使用闭包来引用外部变量。此外,你还可以在方法内使用 this.origin 来调用原始方法。

示例代码:

  1. automator.launch().then(async miniProgram => {
  2. await miniProgram.mockWxMethod('showModal', {
  3. confirm: true,
  4. cancel: false
  5. })
  6. await miniProgram.mockWxMethod(
  7. 'getStorageSync',
  8. function(key, defVal) {
  9. if (key === 'name') return 'redhoodsu'
  10. if (key === 'sex') return 'male'
  11. return defVal
  12. },
  13. 'unknown',
  14. )
  15. // 调用 wx.getStorageSync('name') 返回 'redhoodsu'
  16. // 更改 getSystemInfo 中的 platform 字段
  17. await miniProgram.mockWxMethod(
  18. 'getSystemInfo',
  19. function(obj, platform) {
  20. return new Promise(resolve => {
  21. // origin 指向原始方法
  22. this.origin({
  23. success(res) {
  24. res.platform = platform
  25. resolve(res)
  26. },
  27. })
  28. })
  29. },
  30. 'test',
  31. )
  32. })

miniProgram.restoreWxMethod

重置 wx 指定方法,消除 mockWxMethod 调用的影响。

  1. miniProgram.restoreWxMethod(method: string): Promise<void>

参数说明

字段类型必填默认值说明
methodstring-需要覆盖的方法名

示例代码:

  1. automator.launch().then(async miniProgram => {
  2. console.log(await miniProgram.callWxMethod('getStorageSync', 'test')) // -> ''
  3. await miniProgram.mockWxMethod('getStorageSync', 'mockValue')
  4. console.log(await miniProgram.callWxMethod('getStorageSync', 'test')) // -> 'mockValue'
  5. await miniProgram.restoreWxMethod('getStorageSync')
  6. console.log(await miniProgram.callWxMethod('getStorageSync', 'test')) // -> ''
  7. })

miniProgram.evaluate

往 AppService 注入代码片段并返回执行结果。

  1. miniProgram.evaluate(appFunction: Function | string, ...args: any[]): Promise<any>

参数说明

字段类型必填默认值说明
appFunctionFunction string-代码片段
…argsarray<any>-执行时传入参数

appFunction 最终会被序列化传递到开发者工具,因此你无法在函数中利用闭包来引用外部变量。也就是说,传递 function () {} 函数事实上等同于传递其字符串。

示例代码:

  1. automator.launch().then(async miniProgram => {
  2. let systemInfo = await miniProgram.evaluate(() => {
  3. return new Promise(resolve => {
  4. wx.getSystemInfo({
  5. success(result) {
  6. resolve(result)
  7. }
  8. })
  9. })
  10. })
  11. systemInfo = await miniProgram.evaluate(() => {
  12. return wx.getSystemInfoSync()
  13. })
  14. console.log(systemInfo)
  15. await miniProgram.evaluate(key => {
  16. wx.setStorageSync(key, 'test')
  17. }, 'test')
  18. const hasLogin = await miniProgram.evaluate(() => getApp().globalData.hasLogin)
  19. console.log(hasLogin)
  20. })

miniProgram.pageScrollTo

将页面滚动到目标位置,同 wx.pageScrollTo

  1. miniProgram.pageScrollTo(scrollTop: number): Promise<void>

参数说明

字段类型必填默认值说明
scrollTopnumber-滚动到页面的目标位置,单位 px

示例代码:

  1. automator.launch().then(async miniProgram => {
  2. await miniProgram.pageScrollTo(50)
  3. })

miniProgram.screenshot

automator 0.9.0,基础库 2.9.5,开发者工具 1.02.2001082 开始支持

对当前页面截图,目前只有开发者工具模拟器支持,客户端无法使用。

  1. miniProgram.screenshot(options?: Object): Promise<string | void>

参数说明

字段类型必填默认值说明
optionsObject-截图选项

如果不传 options,该方法返回图片数据的 base64 编码。

options 字段定义如下:

字段类型必填默认值说明
pathstring-图片保存路径
  1. automator.launch().then(async miniProgram => {
  2. await miniProgram.screenshot({
  3. path: 'screenshot.png'
  4. })
  5. })

miniProgram.exposeFunction

在 AppService 全局暴露方法,供小程序侧调用测试脚本中的方法。

  1. miniProgram.exposeFunction(name: string, bindingFunction: Function): Promise<void>

参数说明

字段类型必填默认值说明
namestring-全局方法名
bindingFunctionFunction-脚本方法

你可以利用该方法来监听事件,不支持在小程序侧获取调用结果。

示例代码:

  1. automator.launch().then(async miniProgram => {
  2. await miniProgram.exposeFunction('onAppShow', options => {
  3. // Do something...
  4. })
  5. await miniProgram.evaluate(function() {
  6. wx.onAppShow(function(options) {
  7. onAppShow(options)
  8. })
  9. })
  10. })

miniProgram.testAccounts

automator 0.9.0,开发者工具 1.02.2002272 开始支持

获取多账号调试中已添加的用户列表。

  1. miniProgram.testAccounts(): Promise<Account[]>

Account 字段定义如下:

字段类型说明
nickNamestring用户昵称
openidstring账号 openid

示例代码:

  1. automator.launch().then(async miniProgram => {
  2. const testAccounts = await miniProgram.testAccounts()
  3. for (let i = 0, len = testAccounts.length; i < len; i++) {
  4. const miniProgram = await automator.launch({
  5. projectPath: 'path/to/project',
  6. account: testAccounts[i].openid
  7. })
  8. // 控制多个用户登录的不同小程序
  9. }
  10. })

miniProgram.stopAudits

automator 0.10.0,开发者工具 1.04.2006242 开始支持

停止体验评分并获取报告。

  1. miniProgram.stopAudits(options?: Object): Promise<Object>

参数说明

字段类型必填默认值说明
optionsObject-选项

options 字段定义如下:

字段类型必填默认值说明
pathstring-报告保存路径

需要开启自动运行体验评分选项。

  1. automator.launch({
  2. projectConfig: {
  3. setting: {
  4. autoAudits: true,
  5. },
  6. },
  7. }).then(async miniProgram => {
  8. const data = await miniProgram.stopAudits({
  9. path: 'report.html'
  10. })
  11. console.log(data) // 体验评分报告数据
  12. })

miniProgram.remote

开启工具真机调试功能。

  1. miniProgram.remote(auto?: boolean): Promise<void>

参数说明

字段类型必填默认值说明
autobooleanfalse是否自动真机调试

调用后脚本会启动工具真机调试功能,并且在控制台上打印二维码,然后你需要使用真机扫码连接使自动化脚本继续跑下去。

auto 为 true 时,真机上会自动调起小程序,无需扫码,仅支持微信 7.0.6(安卓)、6.6.7(iOS)及以上版本。有关真机自动化相关内容,请点此查看。

  1. automator.launch().then(async miniProgram => {
  2. await miniProgram.remote()
  3. // 扫码连接成功后在真机上执行自动化脚本
  4. })

miniProgram.disconnect

断开与小程序运行时的连接。

  1. miniProgram.disconnect(): void

示例代码:

  1. automator.launch().then(async miniProgram => {
  2. miniProgram.disconnect()
  3. })

miniProgram.close

断开与小程序运行时的连接并关闭项目窗口。

  1. miniProgram.close(): Promise<void>

示例代码:

  1. automator.launch().then(async miniProgram => {
  2. await miniProgram.close()
  3. })

事件

console

日志打印时触发。

传递一个 msg 参数,其字段如下:

字段类型说明
typestring日志类型,log、info 等
argsarray<any>日志内容

示例代码:

  1. automator.launch().then(async miniProgram => {
  2. miniProgram.on('console', msg => {
  3. console.log(msg.type, msg.args)
  4. })
  5. })

exception

页面 JS 出错时触发。

传递一个 error 参数,其字段如下:

字段类型说明
messagestring错误信息
stackstring错误堆栈

示例代码:

  1. automator.launch().then(async miniProgram => {
  2. miniProgram.on('exception', err => {
  3. console.log(err.message, err.stack)
  4. })
  5. })