springmvc测试

为集成测试控制器创建Mock MVC


import static org.hamcrest.Matchers.*;
import static org.springframework.test.web.servlet.request.
MockMvcRequestBuilders.*;

import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.*; 


@RunWith(SpringJUnit4ClassRunner.class) 

@SpringApplicationConfiguration(
      classes = ReadingListApplication.class)
@WebAppConfiguration
public class MockMvcWebTests {
@Autowired
private WebApplicationContext webContext;
private MockMvc mockMvc;
@Before
public void setupMockMvc() {
  mockMvc = MockMvcBuilders
      .webAppContextSetup(webContext)
      .build();

}} 


@Test
    public void homePage() throws Exception {

mockMvc.perform(MockMvcRequestBuilders.get("/readingList")).andExpect(MockMvcResultMatchers.status().isOk()).andExpect(MockMvcResultMatchers.view().name("readingList")).andExpect(MockMvcResultMatchers.model().attributeExists("books")).andExpect(MockMvcResultMatchers.model().attribute("books",

              Matchers.is(Matchers.empty())));


@Test
public void homePage() throws Exception {

1

  mockMvc.perform(get("/readingList"))
        .andExpect(status().isOk())
        .andExpect(view().name("readingList"))
        .andExpect(model().attributeExists("books"))
        .andExpect(model().attribute("books", is(empty())));


@Test
public void postBook() throws Exception {
mockMvc.perform(post("/readingList")

执行POST请求

.contentType(MediaType.APPLICATION_FORM_URLENCODED)
.param("title", "BOOK TITLE")
.param("author", "BOOK AUTHOR")
.param("isbn", "1234567890") 
5.param("description", "DESCRIPTION"))

.andExpect(status().is3xxRedirection()).andExpect(header().string("Location", "/readingList"));

Book expectedBook = new Book();
expectedBook.setId(1L);
expectedBook.setReader("craig");
expectedBook.setTitle("BOOK TITLE");
expectedBook.setAuthor("BOOK AUTHOR");
expectedBook.setIsbn("1234567890");
expectedBook.setDescription("DESCRIPTION");
mockMvc.perform(get("/readingList"))
       .andExpect(status().isOk())

.andExpect(view().name("readingList"))
.andExpect(model().attributeExists("books"))
.andExpect(model().attribute("books", hasSize(1)))
.andExpect(model().attribute("books",
             contains(samePropertyValuesAs(expectedBook))));
}


开启安全

@Before
    public void setupMockMvc() {
    mockMvc = MockMvcBuilders
        .webAppContextSetup(webContext)
        .apply(springSecurity())
        .build();


@Test
public void homePage_unauthenticatedUser() throws Exception {
mockMvc.perform(get("/"))
    .andExpect(status().is3xxRedirection())
    .andExpect(header().string("Location",
                               "http://localhost/login"));


@Test
@WithMockUser(username="craig",
              password="password",
              roles="READER")
public void homePage_authenticatedUser() throws Exception {

...} 



@WithUserDetails("craig")
    public void homePage_authenticatedUser() throws Exception {
Reader expectedReader = new Reader();
expectedReader.setUsername("craig");
expectedReader.setPassword("password");
expectedReader.setFullname("Craig Walls");
mockMvc.perform(get("/"))
    .andExpect(status().isOk())
    .andExpect(view().name("readingList"))
.andExpect(model().attribute("reader",
samePropertyValuesAs(expectedReader)))
.andExpect(model().attribute("books", hasSize(0)))
}

测试运行在服务器里的Web应用程序 

@RunWith(SpringJUnit4ClassRunner.class)
    @SpringApplicationConfiguration(
          classes=ReadingListApplication.class)
    @WebIntegrationTest
    public class SimpleWebTest {
      @Test(expected=HttpClientErrorException.class)
      public void pageNotFound() {
        try {
          RestTemplate rest = new RestTemplate();
          rest.getForObject(
           "http://localhost:8080/bogusPage", String.class);
      fail("Should result in HTTP 404");

} catch (HttpClientErrorException e) {assertEquals(HttpStatus.NOT_FOUND, e.getStatusCode());throw e;

}}

虽然这个测试非常简单,但足以演示如何使用@WebIntegrationTest在服务器里启动应用程序。 


Spring Boot在随机选择的端口上启动服务器很方便。一种办法是将server.port属性设置为0,让Spring Boot选择一个随机的可用端口。@WebIntegrationTestvalue属性接受一个String数组,数组中的每项都是键值对,形如name=value,用来设置测试中使用的属性。要设置server.port,你可以这样做:

    @WebIntegrationTest(value={"server.port=0"})
  另外,因为只要设置一个属性,所以还能有更简单的形式:

@WebIntegrationTest("server.port=0") 

通过value属性来设置属性通常还算方便。但@WebIntegrationTest还提供了一个randomPort属性,更明确地表示让服务器在随机端口上启动。你可以将randomPort设置为true,启用随机端口:

    @WebIntegrationTest(randomPort=true)

既然我们在随机端口上启动了服务器,就需要在发起Web请求时确保使用正确的端口。此时的getForObject()方法在URL里硬编码了8080端口。如果端口是随机选择的,那在构造请求时又该怎么确定正确的端口呢?

首先,我们需要以实例变量的形式注入选中的端口。为了方便,Spring Bootlocal.server.port的值设置为了选中的端口。我们只需使用Spring@Value注解将其注入即可:

    @Value("${local.server.port}")
    private int port;

有了端口之后,只需对getForObject()稍作修改,使用这个port就好了:rest.getForObject(

"http://localhost:{port}/bogusPage", String.class, port);这里我们在URL里把硬编码的8080改为{port}占位符。在getForObject()调用里把port

属性作为最后一个参数传入,就能确保该占位符被替换为注入port的值了 


Spring Boot里使用Selenium测试的模板 


@RunWith(SpringJUnit4ClassRunner.class) 


@SpringApplicationConfiguration(
      classes=ReadingListApplication.class)
@WebIntegrationTest(randomPort=true)
public class ServerWebTests {
  private static FirefoxDriver browser;
  @Value("${local.server.port}")
  private int port;
  @BeforeClass
  public static void openBrowser() {
    browser = new FirefoxDriver();
    browser.manage().timeouts()


1

2

3

4

5

6

7

8

.implicitlyWait(10, TimeUnit.SECONDS);

配置Firefox驱动

4.3

注入端口号

启动

}

  @AfterClass
  public static void closeBrowser() {
    browser.quit();
  }





### 回答1: 下面是一个简单的Spring MVC测试用例: ``` @RunWith(SpringRunner.class) @WebMvcTest(MyController.class) public class MyControllerTest { @Autowired private MockMvc mockMvc; @Test public void testHello() throws Exception { mockMvc.perform(get("/hello")) .andExpect(status().isOk()) .andExpect(content().string("Hello World!")); } } ``` 在这个测试用例中,我们使用了`@RunWith(SpringRunner.class)`注解来启动Spring容器,并使用`@WebMvcTest(MyController.class)`注解来指定要测试的控制器类。 在`MyControllerTest`类中,我们注入了`MockMvc`对象,这个对象可以模拟HTTP请求和响应,从而进行控制器的测试。 在`testHello`方法中,我们使用了`mockMvc.perform(get("/hello"))`来模拟GET请求,并使用`andExpect`断言来验证请求的状态码和响应内容。 以上就是一个简单的Spring MVC测试用例示例。 ### 回答2: Spring MVC 测试用例是用来验证 Spring MVC 控制器的正确性和稳定性的。通过编写测试用例,可以对控制器的各个方法进行单元测试,以确保其输出符合预期。以下是编写 Spring MVC 测试用例的步骤: 1. 配置测试环境:在测试类中使用 @RunWith(SpringJUnit4ClassRunner.class) 注解来指定测试运行器为 SpringJUnit4ClassRunner,使测试能够在 Spring 环境中运行。 2. 创建 MockMvc 实例:通过使用 MockMvcBuilders.standaloneSetup(controller) 方法,创建一个 MockMvc 实例来模拟 Spring 容器和 HTTP 请求。 3. 编写测试方法:可以编写多个测试方法来测试控制器的不同功能。对于每个测试方法,可以通过 MockMvcperform() 方法发送相应的 HTTP 请求,并使用 andExpect() 方法设置对响应的期望结果。 4. 断言结果:使用 org.springframework.test.util.AssertionErrors 类中的 assertFalse()、assertTrue()、assertEquals() 等方法来对响应结果进行断言,验证控制器的输出是否与预期结果一致。 5. 运行测试:在测试类中,运行所有编写的测试方法,可以通过在测试类或测试方法上使用 @Test 注解来标记需要运行的测试方法。 编写测试用例的目的是为了保证控制器的正确性和稳定性。通过覆盖各种情况的测试用例,可以及时发现并修复控制器中的潜在问题,从而提高系统的健壮性和可靠性。同时,测试用例也是开发人员在迭代开发过程中确保代码修改没有引入新问题的重要手段。 ### 回答3: Spring MVC是一个用于构建Web应用程序的Java框架。它采用MVC(模型-视图-控制器)架构模式来分离应用程序的关注点,使开发更加模块化和可维护。 在编写Spring MVC应用程序时,测试是不可或缺的一部分。测试用例是为了验证应用程序的正确性,并在进行任何更改或扩展之前提供反馈。 基本的Spring MVC测试用例包括以下几个方面: 1. 控制器测试:编写测试用例来验证控制器的行为和功能。这可能涉及到模拟请求和断言响应结果是否符合预期。可以使用MockMvc或Mockito等工具来模拟请求。 2. 集成测试:在整个应用程序的各个层级进行测试,以确保各个组件之间的协作正常工作。这可能涉及到模拟数据库或其他外部依赖,并验证整个请求-响应过程是否正常。 3. 表单验证测试:对于包含表单的页面,编写测试用例来确保表单验证功能正常工作。可以模拟输入数据并验证验证器是否按预期方式处理输入。 4. 异常处理测试:编写测试用例来验证应用程序在发生异常时的行为。可以模拟抛出异常的场景并断言应用程序是否恰当地处理了异常。 5. 页面渲染测试:编写测试用例来验证视图的正确渲染。这包括验证响应中的HTML标签、CSS样式和脚本等。 6. REST API测试:如果应用程序提供RESTful API,编写测试用例来验证API的正确性。可以模拟HTTP请求,并验证相应的JSON或XML是否符合预期。 总之,Spring MVC测试用例是确保应用程序正常运行的关键组成部分。通过编写全面的测试用例,可以更好地保证应用程序的质量和稳定性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值