做网站的知识,室内设计效果图在哪里找,免费制作广州网站,windows wordpress伪静态互联网的本质就是信息交换。移动互联网更是如此#xff0c; 所以很多移动互联网的服务类应用中有着身份地位不同的两种用户(比如:交易中的买家和卖家, 教学中的老师和学生, 打车中的车主和乘客)。近期的工作是给公司的某个产品建立android客户端測试框架#xff0c;使用的自己… 互联网的本质就是信息交换。移动互联网更是如此 所以很多移动互联网的服务类应用中有着身份地位不同的两种用户(比如:交易中的买家和卖家, 教学中的老师和学生, 打车中的车主和乘客)。近期的工作是给公司的某个产品建立android客户端測试框架使用的自己主动化測试技术是robotium。因为产品的用户存在两种身份在这里简称clientA clientB那么就须要建立一个可以同步两种不同用户的測试框架这就是本文标题“Robotium双客户端測试框架”的由来。 1 需求具体分析 为了方便大家理解。我画了张图不说废话直接上图。 如上图所描写叙述的客户身份A、B各有一些測试用例须要运行图中圆型队列当运行到紫色用例时须要两个client同步这时运行到用例方法体内的客户身份须要向同步server通信已获得还有一个客户身份得同步信息假设对方已经准备就绪。用例方法開始同步运行。假设对方没有就绪告知server自己已经就绪而且開始等待。 2server端核心代码 还是先上代码稍后解释。 protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {String methodName request.getParameter(testMethodName);//more development for methods syncString 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 requestGlobalResource.clientBMark ready;clientAReady GlobalResource.clientAMark;}else if (clientBReady.equals(unknown)){//clientA requestGlobalResource.clientAMark ready;clientBReady GlobalResource.clientBMark;}//写回json数据}重要的就是中间的if—else循环主要功能是识别不同客户身份然后依照身份读取还有一身份的状态信息而且把自己的状态给写入server。 3client核心代码 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(){Overridepublic 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 blocke.printStackTrace();}}Overridepublic 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