1、Macaca简介

  macaca是由阿里巴巴公司开发的一套自动化解决方案,适用于PC端和移动端。Macaca基于Node.js开发,测试案例编写语言暂时也只支持Node.js。

2、Macaca与Appium区别

坦白说,这种外部驱动instruments的server-client自动化测试框架,在iOS上实现方式非常受限的,所以其底层的实现方式是一致的。

而在应用级上的封装,二者均采用了Node.js作为开发语言,接口也基于web-driver实现,所以Macaca和Appium相似程度非常高。

如何看待Macaca和Appium区别?

以下是Macaca作者的设计思想:appium 是个优秀的工具。但无法满足更轻、更快、更稳、更易集成、更贴合业务的高要求。可以认为Macaca是一个轻量级的Appium。当然,这就意味着很多Appium的功能会没有了。

3、Macaca特点

  • 支持移动端和PC端
  • 支持Native, Hybrid, H5 等多种应用类型
  • 提供客户端工具和持续集成服务

4、安装

  1)安装Xcode,Xcode 是运行在操作系统Mac OS X上的集成开发工具(IDE),由苹果公司开发(Windows操作系统略)

    IOS使用brew命令,使用brew命令需要安装Homebrew(一款常用的 MacOS 的包管理器)

  2)Node.js 由官网下载安装

    输入命令:node -v 确认安装是否成功,npm是Node.js包管理,之后装Macaca就是用它,所以下一步就是安装npm

  3)安装npm(cnpm),输入npm install -g cnpm --registry=https://registry.npm.taobao.org

    输入cnpm -v 确认是否安装成功

  了解更多淘宝NPM镜像,详见地址:http://npm.taobao.org/

  4)安装Macaca 输入cnpm i macaca-cli -g    看到可爱的小猴子说明安装成功了  

   

  5)安装webdriver-client  输入cnpm install webdriver-client

  6)安卓的需要安装JDK和安卓SDK

  7)安装macaca-electron 输入cnpm install macaca-electron -g

  macaca-electron是基于Electron开发的Macaca驱动,是Macaca驱动之一

  8)安装mocha,输入命令 npm install mocha -g

    mocha是一款功能丰富的js单元测试框架,详见http://www.cnblogs.com/tzyy/p/5729602.html#_h1_2 (非常好的博客)

    mocha是node.js下常用的测试框架,安装前必须先安装node,配置好相应的环境变量,mocha也需要配置,安装后输入mocha  -h有显示说明安装成功。

  9)根据自身需要安装其他驱动,如:

   

  安装环境检查,输入命令:macaca  doctor

  

  有红色标识,说明还有配置没有完成。图中的Gradle是一个基于JVM的构建工具,各版本下载地址:http://services.gradle.org/distributions/

  Macaca升级后是用Gradle来构建和部署,所以需要配置

  下载压缩包解压即可,安装好后配置环境变量

  GRADLE_HOME指向gradle的安装路径,path环境变量添加 %GRADLE_HOME%\bin

  查询版本:gradle  -v  如果没有结果尝试一下重启cmd

  10)安装定位工具  cnpm  install  app-inspector  -g

    检查是否安装成功:app-inspector -u 设备id

  【如果需要重装则先卸载,管理员权限执行。 npm uninstall macaca-android -g; npm cache clean】

示例测试

1、下载样例脚本:https://github.com/macaca-sample/sample-java

2、打开一个终端,进入工程目录,启动Macaca服务

命令:cd   +demo目录,注:一定要进入到脚本存放目录

        macaca  server    --verbose

  追加--verbose参数,为了查看启动中的详细信息

3、在打开一个cmd窗口,执行mvn  -s  settings.xml  clean  install -Dmaven.test.skip=true  (前提需要安装maven)

  注:mvn -s的作用在于使maven以工程目录下的settings.xml文件为依据下载依赖,但是实践中发现部分同学会出现mvn -s无法生效的作用,这样会导致依赖下载失败,这种情况下,需要大家将工程目录下的settings.xml中的配置相应的添加到本地settings中。

4、输入mvn  test 或 mvn test -Dtest=macaca.client.DesktopSampleTest

  

Macaca环境配置及样例执行的更多相关文章

  1. HNU_团队项目_数据库框架Mybatis_环境配置和样例

    前言 数据库从最传统的JDBC连接方式和数据库池化技术到Hibernate的使用,再到Mybatis的快捷轻量级操作,技术迭代的速度飞快. 在了解了基础的理论和方法后,学习前沿编程框架.工具,我认为是 ...

  2. Nginx 简单的负载均衡配置演示样例

    近期在做开放查询应用的时候,因为数据两天特别多,两千多万条呢,用户訪问需求也比較大,所以就用nginx做了 负载均衡,以下是改动之后的相关内容. http://www.cnblogs.com/xiao ...

  3. Spring @Transaction配置演示样例及发生不回滚原因深度剖析

    背景 近期在公司做的一个项目,用的是SpringMVC框架,数据库用的是MySql,刚開始并没有增加事务,后因业务须要必须事务处理. 问题的产生和解决 使用事务,直接问百度,我选择的是注解的方式. 在 ...

  4. AOP经典2种配置演示样例

    第一种: 使用aop指定切面aspect. <bean id="LogAdvice" class="com.thinkmore.framework.monitor. ...

  5. EEPlat vs saleforce 配置 Knowledge Article 演示样例

    ==================================================================================================== ...

  6. Nginx完整配置配置样例【官方版】

    我们主要参考nginx官方给出的完整配置的样例: https://www.nginx.com/resources/wiki/start/topics/examples/full/# 完整摘录如下: n ...

  7. JBoss 系列一 O O:Maven jBPM 6 集成演示样例

    概述 jBPM 6 中底层架构基于 Maven,所以我们能够非常easy的进行 Maven jBPM 6 集成演示样例,本文分三个部分: 基本原理介绍 Maven jBPM 6 集成 jBPM 6 中 ...

  8. Python+Selenium笔记(一):环境配置+简单的例子

    #环境配置基于windows操作系统 #学习selenium要有一些HTML和xpth的基础,完全不会的建议先花点时间学点基础(不然元素定位,特别是xpth可能看的有点懵) #HTML :  http ...

  9. 图解VC++ opengl环境配置和几个入门样例

    VC6下载 http://blog.csdn.net/bcbobo21cn/article/details/44200205 demoproject和glut库下载 http://pan.baidu. ...

随机推荐

  1. Filter、Listener 学习总结

    今天我们来介绍 Filter.Listener 这两个模块一些简单的知识和应用,接下来我们开始我们的正题 ! 1. Filter(过滤器) 1.1 对 Servlet 容器调用 Servlet 的过程 ...

  2. 手动安装Nginx

    本分类下有一个环境一键安装.那这背后发生了什么呢?咱们手动使用源码进行安装.1.首先保证有一个能联网的centos.2.百度 ningx 官网   点download  http://nginx.or ...

  3. .NET Core 快速入门教程

    .NET Core 快速学习.入门系列教程.这个入门系列教程主要跟大家聊聊.NET Core的前世今生,以及Windows.Linux(CentOS.Ubuntu)基础开发环境的搭建.第一个.NET ...

  4. 《算法》C/C++ 图形处理

    概述 一般图形输出无法就是用循环输出 ,提前构造好图形. 两种方式 ** 模拟法直接输出** ** 二维数组 构造输出** 问题描述 利用字母可以组成一些美丽的图形,下面给出了一个例子: ABCDEF ...

  5. mustache.js 使用

    对于mustache模板,我是属于即用即查的方法,以下记录仅是我常用的方式.方便以后使用时不用再去项目中去找,因为真的不好找.(此处 -->serious 脸) 当需要渲染一些数据列表的时候,使 ...

  6. git实用攻略(二)

    最近团队的版本控制从svn切换到了git,虽说已经使用git有2年多了,也写了一个实用攻略,但是github上的项目使用经验和公司内部团队协作的使用经验还有很多不同.补充下新的使用体会. 首先还是看一 ...

  7. 修改 docker image 安装目录 (解决加载大image时报错:"no space left on device")

    修改 docker image 安装目录 (解决加载大image时报错:"no space left on device" ) 基于Ubuntu16.04 docker版本: 17 ...

  8. [Maven实战](7)坐标

    1. 简单介绍 maven的世界中拥有数量很巨大的构件,也就是平时用的一些jar,war等文件. 在maven为这些构件引入坐标概念之前,我们无法使用不论什么一种方式来唯一标识全部这些构件. 因此,当 ...

  9. codevs1051

    题目地址:http://codevs.cn/problem/1051/ 分析: --题目难度:提高一等 1.数据结构(Data Structure):①Hash(用map或人工)②Stack(栈) 2 ...

  10. vue-购物车

    最终的实现效果: 需求分析: 购物车需要展示一个已加入购物车的商品列表,包含商品名称,商品单价,购买数量和操作等信息,还需要实时显示购买的总价.其中购买数量可以增加或减少,每类商品还可以从购物车中移除 ...