Я использую resttemplate для тестирования своего веб-сервиса, но при запуске теста у меня возникает ошибка соединения с приложением - PullRequest
1 голос
/ 14 мая 2019

Я использую resttemplate для тестирования своего веб-сервиса, зная, что я использую h2 в качестве базы данных, но при запуске теста у меня возникает ошибка подключения к приложению ошибка: org.springframework.we.client.RessourceAccessException: ошибка ввода-вывода при запросе получения для «http://localhost: 8082 / parcours»: подключение к локальному узлу: 8082 Я не знаю, как запустить весеннюю загрузку автоматически, и она указывает на файл моего приложения, который указывает на базу данных h2, а не на другую базу данных

@Configuration
public class TestConfig
{
    @Bean
public TestRestTemplate myRestTemplate()
{
return new TestRestTemplate();
}

}



@RunWith(SpringRunner.class)
@ContextConfiguration(location ={"file:src/ressources/applicationContext.xml"},classes = TestConfig.class)
@RestClienTest(value={ParcoursRessource.class})
@SpringBootTest(classes = Application.class)
public class TestParcoursRessource 
{

@Autowired
    private RestTemplate myRestTemplate;

@Test
public void listerParcours()
{
 ResponseEntity<String> responseEntity = myRestTemplate.getForEntity("http://localhost:8082/parcours",String.class);
Assert.assertEquals(OK.getStatusCode(),responseEntity.getStatusCodeValue())
}
}

Ответы [ 2 ]

0 голосов
/ 14 мая 2019

Вот пример использования mockmvc для служб get и post, mockmvc доступен с самой зависимостью теста запуска пружины

import static org.junit.Assert.fail;
import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.get;
import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.post;
import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.delete;
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status;

import java.time.LocalDateTime;
import java.util.List;

import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.boot.test.context.SpringBootTest.WebEnvironment;
import org.springframework.boot.web.server.LocalServerPort;
import org.springframework.http.MediaType;
import org.springframework.security.test.context.support.WithMockUser;
import org.springframework.test.context.junit4.SpringRunner;
import org.springframework.test.web.servlet.MockMvc;
import org.springframework.test.web.servlet.setup.MockMvcBuilders;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.web.context.WebApplicationContext;

import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.fasterxml.jackson.databind.SerializationFeature;




@RunWith(SpringRunner.class)
@SpringBootTest(webEnvironment = WebEnvironment.RANDOM_PORT)
public class AppTest {


    @LocalServerPort
    int randomServerPort;


    @Autowired
    private WebApplicationContext context;




    private MockMvc mvc;


    @Before
    public void setup() {
        mvc = MockMvcBuilders
          .webAppContextSetup(context)
         // .apply(springSecurity())
          .build();
    }



    @Test
    @WithMockUser("spring")
    public void testGetPage() throws Exception {
        mvc.perform(get(<url>).contentType(MediaType.APPLICATION_JSON))
           .andExpect(status().is(200));
    }



    @Test
    @WithMockUser("spring")
    public void testRolePost() throws Exception {
        Role role = new Role();

        role.setRoleName("Test Role");
        role.setRead(true);
        role.setWrite(false);
         ObjectMapper mapper = new ObjectMapper();
            mapper.configure(SerializationFeature.WRAP_ROOT_VALUE, false);
            ObjectWriter ow = mapper.writer().withDefaultPrettyPrinter();
            String requestJson=ow.writeValueAsString(role );
        mvc.perform(post("/addrole").contentType(MediaType.APPLICATION_JSON) .content(requestJson))
           .andExpect(status().is(200));

    }

}
0 голосов
/ 14 мая 2019

Я предлагаю вам попробовать с RestAssured.

DOC: https://github.com/rest-assured/rest-assured/wiki/GettingStarted

Пример конфигурации

Абстрактный класс EndpointTest. ContextConfiguration, указывающая на файл конфигурации базы данных вашего приложения. Это будет искать ваши свойства источника данных в application.yml в тестовом пакете, поэтому вы можете указать h2 только для тестов:

@RunWith(SpringRunner.class)
@ContextConfiguration(classes = {YourAppConfig.class})
@SpringBootTest(webEnvironment = SpringBootTest.WebEnvironment.RANDOM_PORT)
public abstract class EndpointTest {

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

    @Before
    public void setUp() {
        RestAssured.port = port;
    }
}

Пример теста:

public class ExampleEndpointTest extends EndpointTest {
    @Test
    public void deleteMultiple(){

        given()
             .pathParam("id","a")
        .when()
             .delete("/example/query/{id}")
        .then()
             .statusCode(HttpStatus.SC_NO_CONTENT);
    }
}
...