Spring Cloud Contract EXPLICIT и WEBTESTCLIENT testMode - PullRequest
1 голос
/ 10 мая 2019

Я хочу использовать Spring Cloud Contract для составления своих контрактов и их проверки. Я хочу использовать Spring WebFlux и Junit5. Это мой контроллер:

@RestController
@Slf4j
public class HelloWorldPortRESTAdapter implements HelloWorldPort {

    @GetMapping(value = "/hello-world", produces = MediaType.APPLICATION_JSON_UTF8_VALUE)
    @Override
    public Mono<String> helloWorld() {
        return Mono.just("Hello World!");
    }
}

Это конфигурация плагина облачного контракта maven:

            <plugin>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-contract-maven-plugin</artifactId>
                <extensions>true</extensions>
                <configuration>
                    <basePackageForTests>com.example.feedproviderapi.contract</basePackageForTests>
                    <testFramework>JUNIT5</testFramework>
                    <testMode>EXPLICIT</testMode>
                </configuration>
            </plugin>

Но я не знаю, как должен выглядеть базовый тестовый класс. Я попробовал это:

@ExtendWith(SpringExtension.class)
@SpringBootTest(webEnvironment = SpringBootTest.WebEnvironment.RANDOM_PORT)
public class BaseTestClass {

    @LocalServerPort
    private int port;

    @BeforeEach
    void setup(){
        RestAssured.baseURI = "http://localhost:" + this.port;
    }

}

Когда я запускаю mvn clean install, он возвращает java.net.ConnectException: Connection refused (Connection refused)

Затем я изменил свойство testMode в плагине maven на WEBTESTCLIENT и обновил BaseTestClass следующим образом:

@ExtendWith(SpringExtension.class)
@SpringBootTest
public class BaseTestClass {

    @Autowired
    WebApplicationContext context;

    @BeforeEach
    void setup(){
        RestAssuredWebTestClient.standaloneSetup(context);
    }

}

И снова, когда я запускаю mvn clean install, теперь он возвращает:

You haven't configured a WebTestClient instance. You can do this statically

RestAssuredWebTestClient.mockMvc(..)
RestAssuredWebTestClient.standaloneSetup(..);
RestAssuredWebTestClient.webAppContextSetup(..);

or using the DSL:

given().
        mockMvc(..). ..

Кстати, я тоже пытался RestAssuredWebTestClient.standaloneSetup(new HelloWorldPortRESTAdapter()); в своем BaseTestClass, но результат тот же.

Так как мне реализовать BaseTestClass относительно EXPLICIT и WEBTESTCLIENT тестовых режимов?

Ответы [ 2 ]

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

Попробуйте передать ApplicationContext экземпляр вместо WebApplicationContext.

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

Пожалуйста, проверьте образцы облачных весной https://github.com/spring-cloud-samples/spring-cloud-contract-samples/blob/master/producer_webflux_webtestclient

И junit5

https://github.com/spring-cloud-samples/spring-cloud-contract-samples/tree/master/producer_with_junit5

plugin 



<plugin>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-contract-maven-plugin</artifactId>
            <version>${spring-cloud-contract.version}</version>
            <extensions>true</extensions>
            <configuration>
                <packageWithBaseClasses>com.example</packageWithBaseClasses>
                <testMode>WEBTESTCLIENT</testMode>
            </configuration>
        </plugin>

<plugin>
            <artifactId>maven-surefire-plugin</artifactId>
            <configuration>
                <failIfNoTests>true</failIfNoTests>
            </configuration>
            <dependencies>
                <dependency>
                    <groupId>org.junit.platform</groupId>
                    <artifactId>junit-platform-surefire-provider</artifactId>
                    <version>${junit-platform-surefire-provider.version}</version>
                </dependency>
            </dependencies>
        </plugin>

И базовый классдля junit5

открытый абстрактный класс BeerRestBase {

@BeforeEach
public void setup() {
    // remove::start[]
    RestAssuredWebTestClient.standaloneSetup(new ProducerController(personToCheck -> personToCheck.age >= 20));
    // remove::end[]
}

}

...