4

我是 Web 服务的新手,想知道 Jersey 客户端 API 和 jersey 测试框架有什么区别?

我想测试我的球衣 REST Web 服务端点。哪个是正确的使用?

4

1 回答 1

14

那里有许多 HTTP 客户端 API(例如Apache HttpClient)。您需要一个来进行客户端测试。我们需要通过 HTTP 以某种方式访问​​我们的服务,因此单元测试需要这些 API 之一。由于您已经在使用 Jersey,Jersey Client API是一个不错的选择。一个例子可能看起来像

final String url = "http://stackoverflow.com/questions/27160440/" +
                                   "jersey-client-api-vs-jersey-test-framework";
Client client = ClientBuilder.newClient();
WebTarget target = client.target(url);
Response response = target.request().accept(MediaType..get();
String html  = response.readEntity(String.class);
System.out.println(html);
response.close();

如您所见,客户端 API 不必调用我们的服务。它只是 HTTP 调用的接口,具有“Rest”功能。如果我们想运行我们自己的服务,我们首先需要将它们部署到一个容器中,无论是完整的服务器/容器,还是一些嵌入式变体。如果没有框架,完整的测试可能看起来像

<dependencies>
    <dependency>
        <groupId>org.glassfish.jersey.containers</groupId>
        <artifactId>jersey-container-grizzly2-http</artifactId>
    </dependency>
    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>4.9</version>
        <scope>test</scope>
    </dependency>
</dependencies>

public class SimpleTest {

    static final String BASE_URI = "http://localhost:8080/myapp/";
    static HttpServer server;
    static Client client;

    private static HttpServer startServer() {
        final ResourceConfig resourceConfig = new ResourceConfig()
                .packages("where.my.resources.are")
                .register(HelloResource.class);
                // normally the resource class would not be in the unit test class
                // and would be in the `where.my.resources.are` package pr sub package
        return GrizzlyHttpServerFactory.createHttpServer(URI.create(BASE_URI), resourceConfig);
    }

    @Path("hello")
    public static class HelloResource {
        @GET
        public String getHello() {
            return "Hello World!";
        }
    }

    @BeforeClass
    public static void setUpClass() {
        server = startServer();
        client = ClientBuilder.newClient();
    }

    @AfterClass
    public static void tearDownClass() {
        server.shutdown();
    }

     @Test
    public void test() {
        WebTarget target = client.target(BASE_URI);
        Response response = target.path("hello").request().get();
        String hello = response.readEntity(String.class);
        assertEquals("Hello World!", hello);
        response.close();
    }
}

Jersey 测试框架允许我们更轻松地进行半集成/集成测试,并提供更复杂的容器部署选项。这些服务可以启动到一个轻量级的嵌入式容器(也可以是不同的类型)中,该容器将在运行单元测试时自动启动和停止。该框架实际上依赖于 Jersey 客户端 API,因此如果您正在使用该框架,那么您可以在测试用例中使用客户端 API。一个例子

<dependencies>
    <dependency>
        <groupId>org.glassfish.jersey.test-framework.providers</groupId>
        <artifactId>jersey-test-framework-provider-grizzly2</artifactId>
        <version>2.13</version>
    </dependency>
</dependencies>

public class SimpleTest extends JerseyTest {

    @Path("hello")
    public static class HelloResource {
        @GET
        public String getHello() {
            return "Hello World!";
        }
    }

    @Override
    protected Application configure() {
        return new ResourceConfig(HelloResource.class);
    }

    @Test
    public void test() {
        Response response = target("hello").request().get();
        String hello = response.readEntity(String.class);
        assertEquals("Hello World!", hello);
        response.close();
    }
}

你可以看到相似之处,@Test. 那是因为,我们正在使用客户端 API。我们不需要显式配置Client,因为框架会为我们执行此操作。

因此,选择实际上归结为您是否要使用测试框架。无论哪种方式,您都应该知道如何使用 Jersey 客户端 API,因为无论哪种方式都将使用它(除非您决定只使用另一个 HTTP 客户端 API,如 HttpClient)


阅读更多

于 2014-11-27T03:26:12.167 回答