基于APK的Robotium登录人人网与发状态
搭建好Robotium的环境,大致就是下载安装jdk并配置环境变量,下载并打开Eclipse,下载安装Android SDK Tools并配置环境变量,下载安装ADT插件,创建并打开Android Virtual Device,下载、apk重签名并安装到该device,手动打开人人网应用没问题后环境就算是准备好了。(我学习Robotium时买了杨志伟编著的《手机测试Robotium实战教程》,我自己也总结了一份学习笔记,考虑到作者出书不易我就不上传了,这本书挺好的。)
一些常用的cmd命令,来查看device的状态和jdk的路径(如果adb不是内部或者外部命令,将Android SDK Tools中的adb.exe文件从platform-tools目录下粘贴到tools目录下,然后将platform-tools的路径添加到Path环境变量中即可):

人人网安好后在device中是这样的:

通过打开uiautomatorviewer.bat来捕获安卓界面上的元素。写两个测试,分别实现登录人人网和发状态:
package com.renren.test; import org.testng.annotations.AfterMethod;
import org.testng.annotations.BeforeMethod;
import com.robotium.solo.Solo; import android.test.ActivityInstrumentationTestCase2;
import android.util.Log;
import android.view.View;
import android.widget.EditText; @SuppressWarnings("rawtypes")
public class RenrenTest extends ActivityInstrumentationTestCase2 {
// The activity name after re-signed.
private static final String LAUNCHER_ACTIVITY_FULL_CLASSNAME = "com.renren.mobile.android.ui.WelcomeScreen";
private static Class LauncherActivityClass;
private Solo solo;
private static final String TAG = "MyResult"; // Initiate.
static {
try {
LauncherActivityClass = Class.forName(LAUNCHER_ACTIVITY_FULL_CLASSNAME);
} catch (Exception ex) {
throw new RuntimeException(ex);
}
} @SuppressWarnings("unchecked")
public RenrenTest() throws ClassNotFoundException {
super(LauncherActivityClass);
} @BeforeMethod
protected void setUp() throws Exception {
solo = new Solo(getInstrumentation(), getActivity());
} public void testCanLogin() throws InterruptedException {
boolean result = waitForTextUnless("登录", "照片");
if (result == true) {
if (solo.searchText("登录")) {
solo.clickOnView(solo.getView("com.renren.mobile.android:id/welcome_hot_spot_login"));
}
waitForText("请输入用户名");
if (solo.searchText("请输入用户名")) {
EditText usrNameText = (EditText) solo
.getView("com.renren.mobile.android:id/welcome_hot_spot_account_layout");
String userName = "用户名";
solo.enterText(usrNameText, userName);
EditText pwdText = (EditText) solo
.getView("com.renren.mobile.android:id/welcome_hot_spot_password_edit");
String pwd = "密码";
solo.enterText(pwdText, pwd);
// Click the login button.
solo.clickOnView(solo.getView("com.renren.mobile.android:id/welcome_hot_spot_login_button"));
}
waitForText("照片");
Thread.sleep(3000);
Log.i(TAG, "已登录");
} else {
Log.i(TAG, "无需登录");
}
} public void testSendInfo() throws InterruptedException {
waitForText("照片");
String sendButtonId = "com.renren.mobile.android:id/tab_item_publisher";
View sendButton = solo.getView(sendButtonId);
solo.clickLongOnView(sendButton);
waitForText("发状态");
try {
String inputEditorId = "com.renren.mobile.android:id/input_editor";
EditText editText = (EditText) solo.getView(inputEditorId);
String message = "Android test!";
solo.enterText(editText, message);
solo.clickOnButton("发布");
waitForText(message);
Thread.sleep(3000);
} catch (Exception ex) {
System.out.println(ex);
}
} private boolean waitForTextUnless(String string, String string2) throws InterruptedException {
boolean signal = true;
while (!solo.searchText(string) && signal) {
if (solo.searchText(string2)) {
signal = false;
return signal;
} else {
Thread.sleep(1000);
}
}
return signal;
} private void waitForText(String text) throws InterruptedException {
while (!solo.searchText(text)) {
Thread.sleep(1000);
}
} @AfterMethod
public void tearDown() throws Exception {
solo.finishOpenedActivities();
}
}
1、SuppressWarnings的意思是压制警告,详细有几种使用方法可以上网搜一下;
2、创建一个solo类来实现对device当前app页面上元素的交互操作;
3、声明一个TAG,让Log类在LogCat中输出一些指定的信息,方便我们在LogCat中查找与判断测试中经历的一些状态(安卓专用的打log方法哦);

4、Robotium的测试方法名要以test开头,testXXX的形式,运行时要选择Android JUnit Test运行;
5、setUp和tearDown是固定的测试类所必须的加载和销毁应用程序的方法;
5、写了两个wait方法,用来等待页面上的元素,和如果出现例外元素就不继续等待目标元素。
注意:
1、要配置AndroidManifest.xml文件中instrumentation标签中的targetPackage值为apk的包名。否则会运行失败,提示“Test run failed: Instrumentation run failed due to 'java.lang.ClassNotFoundException'”;
2、BeforeMethod和AfterMethod这两个标签需要testNg的支持,如果没有testNg的话将这两个标签去掉并换成“@Override”即可。
基于APK的Robotium登录人人网与发状态的更多相关文章
- robotium从入门到放弃 三 基于apk的自动化测试
1.apk重签名 在做基于APK的自动化测试的过程中,需要确保的一点是,被测试的APK必须跟测试项目具有相同的签名,那怎么做才能确保两者拥有相同的签名呢?下面将给出具体的实现方法. 首先将被测 ...
- Robotium实践之路基于APK创建测试项目
1.重新对包进行签名操作 .启动re-sign.jar文件 .找到相应的APK,拖拽置resigner中 2.创建基于APK测试的测试工程 .新建一个安卓测试项目 .选择this project
- 用python实现模拟登录人人网
用python实现模拟登录人人网 字数4068 阅读1762 评论19 喜欢46 我决定从头说起.懂的人可以快速略过前面理论看最后几张图. web基础知识 从OSI参考模型(从低到高:物理层,数据链路 ...
- 基于Struts2框架实现登录案例 之 使用Struts2标签库简化表单+继承ActionSupport完成输入交验
一,使用Struts2标签库简化表单 在文章[基于Struts2框架实现登录案例]的基础上,通过使用Struts标签库可以简化登录页面login2.jsp <%@ page language=& ...
- 基于SAML的单点登录介绍
http://blog.csdn.net/csethcrm/article/details/20694993 一.背景知识: SAML即安全断言标记语言,英文全称是Security Assertion ...
- 基于jwt的用户登录认证
最近在app的开发过程中,做了一个基于token的用户登录认证,使用vue+node+mongoDB进行的开发,前来总结一下. token认证流程: 1:用户输入用户名和密码,进行登录操作,发送登录信 ...
- 基于CSS3动态背景登录框代码
基于CSS3动态背景登录框代码.这是一款基于jQuery+CSS3实现的带有动画效果的动态背景登陆框特效.效果图如下: 在线预览 源码下载 实现的代码. html代码: <div class ...
- 基于云端的通用权限管理系统,SAAS服务,基于SAAS的权限管理,基于SAAS的单点登录SSO,企业单点登录,企业系统监控,企业授权认证中心
基于云端的通用权限管理系统 SAAS服务 基于SAAS的权限管理 基于SAAS的单点登录SSO 基于.Net的SSO,单点登录系统,提供SAAS服务 基于Extjs 4.2 的企业信息管理系统 基于E ...
- 基于CAS的单点登录实战(2)-- 搭建cas的php客户端
在这之前已经搭好了CAS服务端 基于CAS的单点登录实战(1)-- 搭建cas服务器 PHP-Client php-Client是官方支持的,去官网下个最新版就好了.phpCAS 接入很简单,解压放到 ...
随机推荐
- 2-sat(石头、剪刀、布)hdu4115
Eliminate the Conflict Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/O ...
- [reprint]useful linux commands
linux一说都是搞开发玩的,敲敲键盘就能完成所有的工作.其实你也可以这么玩,玩游戏的除外哦. 那我们就来侃侃如何玩,linux是命令的天下,高级的命令那是相当的多,但是我们正真用到的也就那么几个看你 ...
- acm算法模板(5)
STL 中 sort 函数用法简介 做 ACM 题的时候,排序是一种经常要用到的操作.如果每次都自己写个冒泡之类的 O(n^2) 排序,不但程序容易超时,而且浪费宝贵的比赛时间,还很有可能写错. ST ...
- python在window下的Nginx部署
Python版本3.21 安装nginx下载windows上的nginx最新版本,http://www.nginx.org/en/download.html.解压后即可.运行nginx.exe后本地打 ...
- VPN服务器的配置与应用
实验场景 通过将Linux配置VPN服务器允许远程计算机能够访问内网. 我的目的: 现在需要开发第三方接口,而第三方接口有服务器IP地址鉴权配置,这样在本地开发出来的程序每次都要发布到服务器上测试 ...
- paper 65 :尺度不变特征变换匹配算法[转载]
尺度不变特征变换匹配算法 对于初学者,从David G.Lowe的论文到实现,有许多鸿沟,本文帮你跨越.1.SIFT综述 尺度不变特征转换(Scale-invariant feature transf ...
- 安装Elasticsearch,Logstash,Kibana(5.0.1-mac版)
安装Elasticsearch 1.下载https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-5.0.1.tar.gz包 ...
- Oracle EBS环境下查找数据源(OAF篇)
在用户层设置预制文件:Personalize Self-Service Defn 的值为Yes 来启动个性化模式 参考:http://www.2cto.com/database/201109/1041 ...
- PAT乙级 1027. 打印沙漏(20)
1027. 打印沙漏(20) 时间限制 200 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 本题要求你写个程序把给定的符号打印成 ...
- 有图有真相——关于“视频专辑:零基础学习C语言 ”