package com.softwinner.performance.benchmark;

/**
* UiAssistant public class
* @author liuzhipeng
*/
import android.content.Context;
import android.content.Intent;
import android.os.RemoteException;
import android.provider.Settings;
import android.support.test.InstrumentationRegistry;
import android.support.test.uiautomator.By;
import android.support.test.uiautomator.UiDevice;
import android.support.test.uiautomator.UiObject;
import android.support.test.uiautomator.UiObjectNotFoundException;
import android.support.test.uiautomator.UiSelector;
import android.support.test.uiautomator.UiWatcher;
import android.support.test.uiautomator.Until;
import android.util.Log; import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.util.Calendar; import static org.hamcrest.core.IsNull.notNullValue;
import static org.junit.Assert.assertThat;
import static org.junit.Assert.assertTrue; public class UiAssistant {
private UiDevice mDevice;
private String mPicPath;
private String mLogPath;
private String mLogTag;
final static int CLICK_ID = ;
final static int CLICK_TEXT = ;
final static int CLICK_DES = ;
final static int LAUNCH_TIMEOUT = ;
/**
* constructed function
* @author liuzhipeng
* @return null
* @throws null
*/
public UiAssistant(UiDevice device,String[] path,String logTag){
mDevice = device;
mPicPath = path[];
mLogPath = path[];
mLogTag = logTag;
}
/**
* clickByID
* @author liuzhipeng
* @return true if find object by resourceid success And Click object success else false
* @throws InterruptedException, UiObjectNotFoundException
*/
public boolean clickByID(String id) throws InterruptedException, UiObjectNotFoundException {
return clickByInfo(CLICK_ID, id);
}
/**
* clickByDes
* @author liuzhipeng
* @return true if find object by description success And Click object success else false
* @throws InterruptedException, UiObjectNotFoundException
*/
public boolean clickByDes(String des) throws UiObjectNotFoundException, InterruptedException {
return clickByInfo(CLICK_DES, des);
}
/**
* clickByText
* @author liuzhipeng
* @return true if find object by text success And Click object success else false
* @throws InterruptedException, UiObjectNotFoundException
*/
public boolean clickByText(String text) throws UiObjectNotFoundException, InterruptedException {
return clickByInfo(CLICK_TEXT, text);
}
/**
* clickByInfo
* @author liuzhipeng
* @return true if find object success And Click object success else false
* @throws InterruptedException, UiObjectNotFoundException
*/
private boolean clickByInfo(int CLICK, String str) throws InterruptedException {
UiSelector uiselector = null;
wakeScreen();
switch (CLICK) {
case CLICK_ID:
uiselector = new UiSelector().resourceId(str);
break;
case CLICK_TEXT:
uiselector = new UiSelector().text(str);
break;
case CLICK_DES:
uiselector = new UiSelector().description(str);
break;
default:
return false;
}
UiObject uiobject = mDevice.findObject(uiselector);
int i = ;
while(!uiobject.exists() && i < ){
Thread.sleep();
if( == i){
printLog("find [ui:"+str+"] fail");
return false;
}
uiobject = mDevice.findObject(uiselector);
i++;
}
try {
if(!uiobject.clickAndWaitForNewWindow()){
printLog("click "+str+" return error");
return false;
}
} catch (UiObjectNotFoundException e) {
e.printStackTrace();
}
return true;
}
/**
* screencap ;picture saved as mPicPath, print log to logcat and local file
* @author liuzhipeng
* @return null
* @throws null
*/
public void takeScreen(String logString, String picname) {
//String screenpath = "/sdcard/UITest/Screens/";
String screenpath = mPicPath;
File Screendir = new File(screenpath);
if(!Screendir.exists() && !Screendir.isDirectory())
{
printLog("Create new folder:"+screenpath);
boolean result = Screendir.mkdirs();
if(result == false) {
printLog("mkdirs: "+Screendir+"/ fail");
}
}
// String timeStr = getTimeString();
String pictureStr = Screendir+"/"+picname+"."+"png";
File files = new File(pictureStr);
if(!files.exists()){
try {
boolean result = files.createNewFile();
System.out.println("make files:"+result);
} catch (IOException e) {
e.printStackTrace();
}
}
wakeScreen();
mDevice.takeScreenshot(files);
printLog(logString);
printLog("picture save to:"+pictureStr);
}
/**
* write log into file
* @author liuzhipeng
* @return null
* @throws null
*/
private void logInfo(String level, String str) {
//String Logpath = "/sdcard/UITest/TestLog/";
String logPath = mLogPath;
File screenDir = new File(logPath);
if(!screenDir.exists() && !screenDir.isDirectory())
{
System.out.println("Create new folder:"+logPath);
boolean result = screenDir.mkdirs();
if(result == false)
System.out.println("mkdir: "+screenDir+"/ fail");
}
String datestr = getTimeString();
FileWriter fwlog = null;
StackTraceElement stack = new Throwable().getStackTrace()[];
String temp = "["+stack.getClassName() +"."
+ stack.getMethodName()+":"
+ stack.getLineNumber()+"]";
String slevel = "["+level+"]";
String locationString = String.format("%-25s %-50s %-8s ",datestr,temp,slevel);
try
{
fwlog = new FileWriter(logPath+"log.txt",true);
fwlog.write(locationString+str+"\r\n");
System.out.println(datestr+str);
fwlog.flush();
} catch (IOException e) {
e.printStackTrace();
}finally {
try {
if(null != fwlog) fwlog.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
/**
* getTimeString
* @author liuzhipeng
* @return time String
* @throws InterruptedException, UiObjectNotFoundException
*/
private String getTimeString() {
Calendar calendar = Calendar.getInstance();
calendar.setTimeInMillis(System.currentTimeMillis());
return calendar.get(Calendar.YEAR)+"-"
+(calendar.get(Calendar.MONTH)+)+"-"
+calendar.get(Calendar.DAY_OF_MONTH)+"_"
+calendar.get(Calendar.HOUR_OF_DAY)+":"
+calendar.get(Calendar.MINUTE)+":"
+calendar.get(Calendar.SECOND)+":"
+calendar.get(Calendar.MILLISECOND);
}
/**
* wake up screen
* @author liuzhipeng
* @return null
* @throws null
*/
public void wakeScreen() {
try {
if(!mDevice.isScreenOn())
{
mDevice.wakeUp();
}
} catch (RemoteException e) {
e.printStackTrace();
} }
/**
* open application
* @author liuzhipeng
* @return null
* @throws RemoteException
*/
public void openApplication(String packageNameStr){
wakeScreen();
/* Start from the home screen*/
mDevice.pressHome(); final String launcherPackage = mDevice.getLauncherPackageName();
assertThat(launcherPackage,notNullValue());
mDevice.wait(Until.hasObject(By.pkg(launcherPackage).depth()),
LAUNCH_TIMEOUT); // launch the app
Context context = InstrumentationRegistry.getContext();
final Intent intent = context.getPackageManager()
.getLaunchIntentForPackage(packageNameStr);
// Clear out any previous instances
intent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TASK);
context.startActivity(intent); // Wait for the app to appear
// try {Thread.sleep(5000);} catch (InterruptedException e) {e.printStackTrace();}
wakeScreen();
mDevice.wait(Until.hasObject(By.pkg(packageNameStr).depth()),
LAUNCH_TIMEOUT);
}
/**
* quit application
* @author liuzhipeng
* @return null
* @throws IOException
*/
public void quitApplication(String sPackageName) throws IOException {
wakeScreen();
mDevice.executeShellCommand("am force-stop "+sPackageName);
// printLog("quit "+sPackageName);
// logInfo("Debug","quit "+sPackageName); }
/**
* waitfor until object exist
* @author liuzhipeng
* @return true else false
* @throws null
*/
public boolean waitUnitObjectExist(int CLICK, String str, int seconds, int perwaittime, String picname){
int i = ;
int number = seconds * /perwaittime;
UiSelector uiselector = null;
switch(CLICK){
case :
uiselector = new UiSelector().resourceId(str);
break;
case :
uiselector = new UiSelector().text(str);
break;
case :
uiselector = new UiSelector().description(str);
break;
default:
// logInfo("Error","str not support");
printLog("not support find "+str);
return false;
}
UiObject object = mDevice.findObject(uiselector);
while(!object.exists() && i < number){
try {
Thread.sleep(perwaittime);
} catch (InterruptedException e) {
e.printStackTrace();
}
if(i== (number -))
{
takeScreen(str+" find fail",picname);
return false;
}
wakeScreen();
object = mDevice.findObject(uiselector);
i++;
}
printLog("find [ui:"+str+"] successfully");
return true;
} /**
*
* @param object
* @param second
* @param perWaitTime
* @param picName
*/
public boolean waitUnitObjExistsBySec(UiObject object, int second, int perWaitTime, String picName){ int i = ;
int number = second * /perWaitTime;
// UiObject object = mDevice.findObject(selector);
while(!object.exists() && i < number){
try {
Thread.sleep(perWaitTime);
} catch (InterruptedException e) {
e.printStackTrace();
}
if(i== (number -))
{
takeScreen("find fail",picName);
return false;
}
wakeScreen();
// object = mDevice.findObject(selector);
i++;
}
// printLog("find [ui:"+str+"] successfully");
return true; } /**
* Get UI xmlInfo
* @author liuzhipeng
* @return true else false
* @throws IOException
*/
public boolean getXmlInfo(String path) {
File file = new File(path);
wakeScreen();
try {
mDevice.dumpWindowHierarchy(file);
} catch (IOException e) {
e.printStackTrace();
// return false;
}
return true;
}
/**
* delete folder
* @author liuzhipeng
* @return true else false
* @throws null
*/
public boolean deleteDirectory(File dir){
if(!dir.exists())
{
printLog(dir +" is not exist");
return true;
}
if(dir.isFile())
{
return dir.delete();
}
File[] children = dir.listFiles();
for(int i = ; i < children.length; i++)
{
deleteDirectory(children[i]);
}
return dir.delete();
}
/**
* set up : grant permission and clean folder
* @author liuzhipeng
* @return null
* @throws null
*/
public void setup(String[] path,String logTag){
// wakeScreen();
openApplication("com.softwinner.performance.frameratetest");
try {
Thread.sleep();
} catch (InterruptedException e) {
e.printStackTrace();
}
Log.i(mLogTag,"after open mark3d success, grant stored permission");
wakeScreen();
UiObject permission = mDevice.findObject(new UiSelector()
.resourceId("com.android.packageinstaller:id/permission_allow_button")
);
if(permission.waitForExists()){
try {
wakeScreen();
permission.clickAndWaitForNewWindow();
Log.i(mLogTag,"click grant store permission");
} catch (UiObjectNotFoundException e) {
e.printStackTrace();
}
}
File dir = new File(path[]);
deleteDirectory(dir);
dir = new File(path[]);
deleteDirectory(dir);
printLog("delete \""+path[]+"\" and \""+path[]+"\"");
printLog("setup finish"); }
/**
* print log to logcat and local file
* @author liuzhipeng
* @return null
* @throws null
*/
public void printLog(String log){
Log.i(mLogTag,log);
logInfo(mLogTag,log);
}
/**
* when find ui fail,will call watcher to handle normal popup windows
* @author liuzhipeng
* @return null
* Usage:
* before test,add cAssistant.watcherNormalWindows(String,Uiselector);
* in teardown,add mDeveice.removeWatcher(String watcherName)
* before removeWatcher,call mDevice.hasWatcherTriggered(String watcherName) check watcherName triggered status
* before removeWatcher,call mDevice.hasAnyWatcherTriggered()
*/
public void watcherNormalWindows(final String watcherName, final UiSelector watchSelector){ mDevice.registerWatcher(watcherName, new UiWatcher() {
@Override
public boolean checkForCondition() {
UiObject watchObj = mDevice.findObject(watchSelector);
if(watchObj.exists())
{
printLog(watcherName + " has Triggered");
try {Thread.sleep();} catch (InterruptedException e) {e.printStackTrace();}
try {
watchObj.clickAndWaitForNewWindow();
} catch (UiObjectNotFoundException e) {
e.printStackTrace();
}
printLog(watcherName + " has handled");
return true;
}
return false;
}
}); } /**
* set screenOff timeout
* @author liuzhipeng
* @param sleepText
* @throws InterruptedException
* @throws UiObjectNotFoundException
*/
public void setScreenOffTimeout(String sleepText) throws InterruptedException, UiObjectNotFoundException {
String settingPackageName = "com.android.settings";
String settingDisplayObj = "Display";
String sleepObj = "Sleep";
openApplication(settingPackageName);
try {mDevice.setOrientationNatural();} catch (RemoteException e) {e.printStackTrace();}
Thread.sleep();
assertTrue("DisplayObj not found", waitUnitObjectExist(, settingDisplayObj, , , "check_setting_display"));
clickByText(settingDisplayObj);
assertTrue("sleep object not found", waitUnitObjectExist(, sleepObj, , , "check_sleep"));
clickByText(sleepObj);
assertTrue("sleep "+ sleepText +" no found",waitUnitObjectExist(, sleepText, , , "check_sleep_time"));
clickByText(sleepText);
Thread.sleep();
mDevice.pressHome();
printLog("now screenOff timeout is: " + getScreenOffTimeout()+ " seconds");
} /**
* get current screenOff timeout
* @author liuzhipeng
* @return
*/
public int getScreenOffTimeout(){
int result = ;
Context context = InstrumentationRegistry.getContext();
try {
result = Settings.System.getInt(context.getContentResolver(), Settings.System.SCREEN_OFF_TIMEOUT);
// Log.i(mLogTag, "sleep timeout = " + result/1000 + " seconds");
// Settings.System.putInt(context.getContentResolver(), Settings.System.SCREEN_OFF_TIMEOUT, 10*60*1000); } catch (Settings.SettingNotFoundException e) {
e.printStackTrace();
}
return result/;
} /**
* reset screenOff tiemout
* @param sleepTimeout
* @throws UiObjectNotFoundException
* @throws InterruptedException
*/
public void resetScreenOffTimeout(int sleepTimeout) throws UiObjectNotFoundException, InterruptedException {
String sleepText ;
switch (sleepTimeout){
case :
sleepText = "15 seconds";
break;
case :
sleepText = "30 seconds";
break;
case :
sleepText = "1 minute";
break;
case :
sleepText = "2 minutes";
break;
case :
sleepText = "5 minutes";
break;
case :
sleepText = "10 minutes";
break;
case :
sleepText = "30 minutes";
break;
default:
sleepText = "30 minutes";
break;
}
setScreenOffTimeout(sleepText);
} }

实例化:

public class AuTutuVideoTest{
String packName = "com.antutu.videobench";
String path[]={
"/sdcard/performance/antutuvideo/screen/",
"/sdcard/performance/antutuvideo/log/"
};
// private String startTestPage = "com.antutu.videobench:id/test_movieplayBT";
// private String score_page = "com.antutu.videobench:id/main_titleTV" ;
private String support_video_page = "com.antutu.videobench:id/hard_ok_rl"; String logTag = "antutuvideo";
int TestNumber = ;
private UiDevice mDevice = UiDevice.getInstance(InstrumentationRegistry.getInstrumentation());
private UiAssistant cAssistant = new UiAssistant(mDevice,path,logTag);

[uiautomator篇] 基类的更多相关文章

  1. 无线客户端框架设计(3):基类的设计(iOS篇)

    本文代码:YoungHeart-Chapter-03.zip 没有基类的App都不是好App. 因为iOS使用的是mvc模式的开发模式,所以,业务逻辑基本都在每个页面相应的ViewController ...

  2. 本版本延续MVC中的统一验证机制~续的这篇文章,本篇主要是对验证基类的扩展和改善(转)

    本版本延续MVC中的统一验证机制~续的这篇文章,本篇主要是对验证基类的扩展和改善 namespace Web.Mvc.Extensions { #region 验证基类 /// <summary ...

  3. Farseer.net轻量级开源框架 中级篇:BasePage、BaseController、BaseHandler、BaseMasterPage、BaseControls基类使用

    导航 目   录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 中级篇: UrlRewriter 地址重写 下一篇:Farseer.net轻量级开源框架 中 ...

  4. C# Stream篇(—) -- Stream基类-----转载

    C# Stream篇(—) -- Stream基类 写在前头: Stream系列文章共收录7篇,本着备忘和归纳的目的本着备忘和归纳的目的,全部收录于本分类中. 下面是有原文连接,望各位看官还是到原作者 ...

  5. C# Stream篇(—) -- Stream基类

    写在前头: Stream系列文章共收录7篇,本着备忘和归纳的目的本着备忘和归纳的目的,全部收录于本分类中. 下面是有原文连接,望各位看官还是到原作者处学习,毕竟CV过来的文字难免有走样之处. 原始连接 ...

  6. salesforce 零基础学习(四十八)自定义列表分页之Pagination基类封装 ※※※

    我们知道,salesforce中系统标准列表页面提供了相应的分页功能,如果要使用其分页功能,可以访问http://www.cnblogs.com/zero-zyq/p/5343287.html查看相关 ...

  7. Java如何解决脆弱基类(基类被冻结)问题

    概述  大多数好的设计者象躲避瘟疫一样来避免使用实现继承(extends 关系).实际上80%的代码应该完全用interfaces写,而不是通过extends.“JAVA设计模式”一书详细阐述了怎样用 ...

  8. 【转载】 C++多继承中重写不同基类中相同原型的虚函数

    本篇随笔为转载,原文地址:C++多继承中重写不同基类中相同原型的虚函数. 在C++多继承体系当中,在派生类中可以重写不同基类中的虚函数.下面就是一个例子: class CBaseA { public: ...

  9. 构建自己的PHP框架--抽象Controller的基类

    上一篇博客中,我们将简单的路由解析和执行,从入口文件public/index.php中移入到框架中.入口文件顿时变得清爽无比-- 但是,去我们的controller里看一下,会看到如下的code: p ...

随机推荐

  1. React 实践记录 02 Flux introduction

    Introduction 本文组成: React 官方文档翻译 相关实践心得. 内容上是Flux的介绍,例子将会在以后写出. 一旦稍微多了解一点React,很难避免听到Flux这个名词. Flux是一 ...

  2. 【持续更新】CSS居中

    水平垂直居中 知道自身的宽度.高度 <div class="test"></div> <style> .test { position: abs ...

  3. JVM垃圾回收机制二

    对象的回收 垃圾的回收涉及的几个问题:何时回收,由谁回收,怎样回收.这几个问题我们一一来解决. 1.何时回收----对象的生死判定 对象达到什么条件才能判断这个对象已经无用了.常见的判断对象生死的方法 ...

  4. openstack No valid host was found. There are not enough hosts available.

    root@dell-PowerEdge-T30:~# gedit /var/log/nova/nova-conductor.logroot@dell-PowerEdge-T30:~# gedit /v ...

  5. Mac终端给命令设置别名alias的办法

    在Mac里使用curl https://www.google.com,运行后得不到期望看到的google首页的HTML source code. vi ~/.bashrc, 输入下面两行内容. 以后每 ...

  6. Unity3d中MonoBehavior默认函数的执行顺序和生命周期

    Awake()在MonoBehavior创建后就立刻调用,在脚本实例的整个生命周期中,Awake函数仅执行一次:如果游戏对象(即gameObject)的初始状态为关闭状态,那么运行程序,Awake函数 ...

  7. Shell脚本之for循环、while循环,if语句、case语句

    1. for循环一般格式: 格式1: for((条件)) do 动作 done 格式2: for 变量名 in 范围 do 动作 done1234567891011121314实验:##1. 输出数字 ...

  8. 题解 CF440A 【Forgotten Episode】

    博客阅读更好 虽然这道题是紫题,但实际难度应该是橙题吧 首先,看到标签…… 紫题?但题目也太…… 这道题教会我们不要看标签 好了,废话少说,看到楼下许多大佬都用了数组,但我觉得可以不用 为什么? 我也 ...

  9. Java多线程编程核心(1)

    Java多线程编程核心(1) 停止线程 本节主要讨论如何更好停止一个线程.停止线程意味着在线程处理完成任务之前放弃当前操作. 1.停不了的线程 可能大多数同学会使用interrupt()来停止线程,但 ...

  10. html制作简单框架网页 实现自己的音乐驿站 操作步骤及源文件下载 (播放功能限mp3文件)

    使用HTML语言来设计制作 Hyper Text Markup Language 超文本标记语言 这门语言的特点就是标记,就是把所有的命令单词用<>标记起来,就可以发挥作用 还有一个特点, ...