Robotium双client測试框架

互联网的本质就是信息交换。移动互联网更是如此, 所以很多移动互联网的服务类应用中有着身份地位不同的两种用户(比如:交易中的买家和卖家, 教学中的老师和学生, 打车中的车主和乘客)。近期的工作是给公司的某个产品建立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




原文地址:https://www.cnblogs.com/mfrbuaa/p/5218164.html