Request:

public interface Request {
    String getName();
}

Response:

public interface Response {
    String getName();
}

RequestHandler:

public interface RequestHandler {
    Response process(Request request) throws Exception;
}

Controller:

public interface Controller {
    Response processRequest(Request request);

    void addHandler(Request request, RequestHandler requestHandler);
}

DefaultController:

import java.util.HashMap;
import java.util.Map;

public class DefaultController implements Controller{

    /*
        如果这个地方指明了RequestHandler的,可能会遇到一些泛型方面的问题。
        指明了RequestHandler,我能够将RequestHandler的子类放进这个map
        中么?

        这个地方我忘了,估计那部分还需要再阅读一遍
     */
    private Map<String,RequestHandler> requestHandlers = new HashMap<String, RequestHandler>();

    protected RequestHandler getHander(Request request) {
        if (!this.requestHandlers.containsKey(request.getName())) {
            String msg = "Can't find handler for request name.";
            throw new RuntimeException(msg);
        }
        return requestHandlers.get(request.getName());
    }

    public Response processRequest(Request request) {
        Response response;
        try{
            response = getHander(request).process(request);
        } catch (Exception e) {
            response = new ErrorResponse(request, e);
        }
        return response;
    }

    public void addHandler(Request request, RequestHandler requestHandler) {
        if (this.requestHandlers.containsKey(request.getName())) {
            String msg = "A request handler handler has "+
                    "already been registered for request "+
                    "["+request.getName()+"].";
            throw new RuntimeException(msg);
        }else {
            requestHandlers.put(request.getName(), requestHandler);
        }
    }
}

ErrorResponse:

public class ErrorResponse implements Response {
    private String name = "ErrorResponse";
    private Request originalRequest;
    private Exception originalException;

    public ErrorResponse(Request originalRequest, Exception originalException) {
        this.originalRequest = originalRequest;
        this.originalException = originalException;
    }

    public Request getOriginalRequest() {
        return originalRequest;
    }

    public Exception getOriginalException() {
        return originalException;
    }

    public String getName() {
        return name;
    }
}

DefaultControllerTest:

import org.junit.Before;
import org.junit.Ignore;
import org.junit.Test;

import static org.junit.Assert.*;

public class DefaultControllerTest {

    private DefaultController controller;
    private Request request;
    private RequestHandler handler;

    @Before
    public void instantiate() throws Exception{
        controller = new DefaultController();
        request = new SimpleRequest();
        handler = new SimpleRequestHandler();

        controller.addHandler(request, handler);
    }

    @Test
    public void testAddHandler(){
        RequestHandler handler2 = controller.getHander(request);
        assertSame("Should be same.",handler,handler2);
    }

    @Test
    public void testProcessRequest() {
        Response response = controller.processRequest(request);
        assertNotNull("Should not be null",response);
        assertEquals("shoue be same", new SimpleResponse(), response);
    }

    /*
        书上这部分有点乱,我只能自己来设计各个测试了,前面已经完成了
        诊断测试,现在主要完成各个异常测试:
            1.测试addHandler方法抛出的异常
            2.测试getHandler方法抛出的异常
            3.测试process方法抛出的异常,由于process方法的异常
                被DefaultController的processRequest方法给
                捕获了,所以需要测试processRequest返回的错误
                消息。
     */
    @Test
    public void testProcessAnswerErrorResponse(){
        SimpleRequest request = new SimpleRequest("testError");
        SimpleExceptionHandler handler = new SimpleExceptionHandler();
        controller.addHandler(request,handler);
        Response response = controller.processRequest(request);

        assertNotNull("Should not be noll", response);
        assertEquals("Should be the same.", ErrorResponse.class,response.getClass());
    }

    @Test(expected = RuntimeException.class)
    public void testGetHandlerNotDefined() {
        SimpleRequest request = new SimpleRequest("testNotDefined");

        controller.getHander(request);
    }

    @Test(expected = RuntimeException.class)
    public void testAddHandlerDuplicateName() {
        SimpleRequest request = new SimpleRequest();
        SimpleRequestHandler handler = new SimpleRequestHandler();

        controller.addHandler(request,handler);
    }

    /*
        测试超时
     */
    @Test(timeout = 130)
    @Ignore(value = "no need not.")
    public void testProcessMultipleRequestsTimeout() {
        Request request;
        Response simpleResponse = new SimpleResponse();
        SimpleRequestHandler handler = new SimpleRequestHandler();

        for (int i = 0; i < 99999; i++) {
            request = new SimpleRequest();
            controller.addHandler(request, handler);
            simpleResponse = controller.processRequest(request);
            assertNotNull(simpleResponse);
            assertNotSame(ErrorResponse.class,simpleResponse.getClass());
        }
    }

    private class SimpleRequest implements Request {

        private static final String NAME = "Test";

        private String name;

        public SimpleRequest(String name) {
            this.name = name;
        }

        public SimpleRequest() {
            this(NAME);
        }

        public String getName() {
            return name;
        }
    }

    private class SimpleResponse implements Response {

        private static final String NAME = "Test";

        public String getName() {
            return NAME;
        }

        @Override
        public boolean equals(Object obj) {
            boolean result = false;
            if (obj instanceof SimpleResponse) {
                result = ((SimpleResponse) obj).getName().equals(getName());
            }
            return result;
        }

        @Override
        public int hashCode() {
            return NAME.hashCode();
        }
    }

    private class SimpleRequestHandler implements RequestHandler {

        public Response process(Request request) throws Exception {
            return new SimpleResponse();
        }
    }

    private class SimpleExceptionHandler implements RequestHandler {

        public Response process(Request request) throws Exception {
            String msg = "error processing request";
            throw new Exception(msg);
        }
    }
}

《Junit实战》笔记

Junit初级应用实例的更多相关文章

  1. Appium + junit 的简单实例

    import static junit.framework.Assert.assertTrue; import static org.junit.Assert.*; import org.junit. ...

  2. Junit初级编码(二)探索JUnit核心

    序,Junit测试是单元测试的一个框架,提供了很多方法,供我们快速开展单元测试.现在就让我们慢慢学习Junit单元测试框架 一.Junit的三个核心概念测试类.测试集.测试运行器 1 测试类 公共的, ...

  3. Junit初级编码(一)第一个Junit测试程序

    序,Junit测试是单元测试的一个框架,提供了很多方法,供我们快速开展单元测试.目前最新版本JAR包为4.12,官网地址为http://junit.org/ 一.第一个Junit测试程序 1 去官网下 ...

  4. Junit单元测试的实例

    进行单元测试的代码 package JunitTest; import org.junit.Test; public class Calculator { private static int res ...

  5. JUnit套件测试实例

    “套件测试”是指捆绑了几个单元测试用例并运行起来.在JUnit中,@RunWith 和 @Suite 这两个注解是用来运行套件测试. 下面的例子演示这两个单元测试:JunitTest1 和 Junit ...

  6. Junit初级篇

    @Test介绍 @Test是我们在写测试脚本时最常用到的,大部分情况下如果没用这个注解,一个方法就不能成为测试用例.如下代码是一个最普通的测试脚本: import org.junit.Assert; ...

  7. [python][flask][flask-SQLAlchemy]关于flask-SQLAlchemy的初级使用教程

    鉴于网上关于flask-SQLAlchemy的实例使用教程参差不齐,于此写下工作学习过程中的使用过程,以便分享交流. 对于python关于flask有一定了解的高端玩家来说,请转至flask官方开发文 ...

  8. 菜鸟学Java(二十一)——怎样更好的进行单元測试——JUnit

    測试在软件生命周期中的重要性,不用我多说想必大家也都很清楚.软件測试有许多分类,从測试的方法上可分为:黑盒測试.白盒測试.静态測试.动态測试等:从软件开发的过程分为:单元測试.集成測试.确认測试.验收 ...

  9. 1.如何在JMeter中使用JUnit

    您是否需要在测试过程中使用JUnit? 要回答这个问题,我们先来看看单元测试. 单元测试是软件测试生命周期中测试的最低分辨率. 运行单元测试时,需要在应用程序中使用最小的可测试功能,将其与其他代码隔离 ...

随机推荐

  1. textblock的LineHeight的调整

    原文:textblock的LineHeight的调整 <TextBlock Width="113.594" Height="73.667" Text=&q ...

  2. 算法之--回溯法-迷宫问题【python实现】

    题目描述 定义一个二维数组N*M(其中2<=N<=10;2<=M<=10),如5 × 5数组下所示: int maze[5][5] = { 0, 1, 0, 0, 0, 0,  ...

  3. win10应用开发——如何判断应用是在手机上运行还是电脑上运行

    原文:win10应用开发--如何判断应用是在手机上运行还是电脑上运行 在进行uwp应用开发的时候, 有时我们需要知道自己的应用是在手机端运行还是在桌面端运行,那么通过以下的api就可以进行判断: Wi ...

  4. LINQ学习笔记(一)

    LINQ,语言集成查询(Language Integrated Query)是一组用于C#和Visual Basic语言的扩展. 它允许编写C#或Visual Basic代码以查询数据库相同的方法操作 ...

  5. B/s发展情况真的可以用日新月异来形容

    做c/s也做b/s.从发展情况看,B/s发展情况真的可以用日新月异来形容,但确实也有些绕着路走的框架,不如delphi层次结构清晰. 如果前端用过angularjs等类似框架,则已经相当接近c/s的水 ...

  6. C++&Win32写的空当接龙

    上学期做课程设计,老师让我做windows自带的空当接龙游戏,写了一个礼拜,完全仿windows的呵呵.不过也不全一样,有一些细节一直没有时间弄,没办法最近比较懒... 与windows下的相比,我做 ...

  7. Windows下配置QT OpenCV

    OpenCV-Study:Windows下配置OpenCV 本文博客链接:http://blog.csdn.net/jdh99,作者:jdh,转载请注明. 环境: 主机:XP OpenCV版本:2.4 ...

  8. QTcpSocket 对连接服务器中断的不同情况进行判定

    http://blog.csdn.net/goforwardtostep/article/details/52300335

  9. 用 jQuery.getJSON() 跨域请求 JSON 数据

    $.getJSON()可以理解为特殊形式的$.ajax(),手册里的说明好复杂,这里只记录一下用到的跨域请求. 先说在同一域名下,js发送数据到php,php返回JSON数据: $.getJSON(' ...

  10. Python socket文件上传下载

    python网络编程 程序的目录结构 socketDemo ├── client │   ├── cli.py │   └── local_dir │   └── lianxijiangjie.mp4 ...