您的位置:首页 > 其它

Robotium双client測试框架

2016-02-25 19:52 411 查看
互联网的本质就是信息交换。移动互联网更是如此, 所以很多移动互联网的服务类应用中有着身份地位不同的两种用户(比如:交易中的买家和卖家, 教学中的老师和学生, 打车中的车主和乘客)。近期的工作是给公司的某个产品建立android客户端測试框架,使用的自己主动化測试技术是robotium。因为产品的用户存在两种身份(在这里简称clientA, clientB),那么就须要建立一个可以同步两种不同用户的測试框架,这就是本文标题“Robotium双客户端測试框架”的由来。

1. 需求具体分析

为了方便大家理解。我画了张图,不说废话直接上图。



如上图所描写叙述的,客户身份A、B各有一些測试用例须要运行(图中圆型队列),当运行到紫色用例时须要两个client同步,这时运行到用例方法体内的客户身份须要向同步server通信已获得还有一个客户身份得同步信息,假设对方已经准备就绪。用例方法開始同步运行。假设对方没有就绪,告知server自己已经就绪而且開始等待。

2.server端核心代码

还是先上代码,稍后解释。

protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
String methodName = request.getParameter("testMethodName");//more development for methods sync
String clientAReady = request.getParameter("clientAReady");
String clientBReady = request.getParameter("clientBReady");
//debuglog("methodName:"+methodName);
/*sync code*/
if(clientAReady == null || clientBReady == null){
return ;
}

if(clientAReady.equals("unknown")){//clientB request
GlobalResource.clientBMark = "ready";
clientAReady = GlobalResource.clientAMark;
}else if (clientBReady.equals("unknown")){//clientA request
GlobalResource.clientAMark = "ready";
clientBReady = GlobalResource.clientBMark;
}
//写回json数据

}


重要的就是中间的if—else循环,主要功能是识别不同客户身份,然后依照身份读取还有一身份的状态信息而且把自己的状态给写入server。

3.client核心代码

client代码能够简单分为三部分,第一是robotium測试框架建立,其次须要轮询server对方数据。最后是须要接收数据并更等待状态位。

关于robotium測试框架建立不是本文的重点也比較简单。笔者并不打算展开说明。

附上相关资料:http://www.robotium.cn/archives/210。假设是大家做过android开发应该不难上手。

关于server通信,我使用的是HttpClient框架。用法为建立一个HttpClient对象。向服务发送数据请求,使用框架中提供的handler子类异步接收数据并处理。代码还是非常easy的。

轮询数据

public void testSync () throws Exception{
while(ClientBReady.equals("notReady")){
NetManager.TestSyncServlet("testSync", "unknown", "ready", syncHandler);
Thread.sleep(5000);
}
//robotium control code
}

发送请求

package com.network.httpconnect;

import com.network.httpconnect.AsyncHttpClient;
import com.network.httpconnect.AsyncHttpResponseHandler;
import com.network.httpconnect.RequestParams;

public class NetManager {
public static String getServiceBaseUrl() { return "http://localhost:8080/appTestServer/"; }

public static int getTimeOut() { return 5 * 1000; }

public static void TestSyncServlet(String testMethodName, String clientAReady, String clientBReady, AsyncHttpResponseHandler handler)
{
String url = getServiceBaseUrl() + "TestSyncServlet";

try
{
RequestParams params = new RequestParams();

params.put("testMethodName", testMethodName);
params.put("clientAReady", clientAReady);
params.put("clientBReady", clientBReady);

AsyncHttpClient client = new AsyncHttpClient();
client.setTimeout(getTimeOut());
client.post(url, params, handler);
}
catch (Exception ex)
{
ex.printStackTrace();

if (handler != null)
handler.onFailure(null, ex.getMessage());
}
}

}


接收数据

private AsyncHttpResponseHandler syncHandler = new AsyncHttpResponseHandler(){
@Override
public void onSuccess(String content) {
super.onSuccess(content);
debuglog("content:"+ content);
try {
JSONObject receiveData = new JSONObject(content);
ClientBReady = receiveData.getString("ClientBReady");
} catch (JSONException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
@Override
public void onFailure(Throwable error, String content) {
super.onFailure(error, content);

}
};


因为笔者水平有限,本文的实现可能不是很完美,我已经将代码上传到github,不清楚的地方能够看源代码,欢迎大家一起讨论。

github地址为:https://github.com/cibon/Robotium_two_clients_framework
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: