处理上下文路径

Spring Cloud Contract 支持上下文路径。

要完全支持上下文路径,唯一需要的更改是在生产者侧进行切换。此外,自动生成的测试必须使用显式模式。消费者侧保持不变。为了使生成的测试通过,您必须使用显式模式。以下示例展示了如何将测试模式设置为 EXPLICIT

Maven
<plugin>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-contract-maven-plugin</artifactId>
    <version>${spring-cloud-contract.version}</version>
    <extensions>true</extensions>
    <configuration>
        <testMode>EXPLICIT</testMode>
    </configuration>
</plugin>
Gradle
contracts {
		testMode = 'EXPLICIT'
}

通过这种方式,您生成了一个不使用 MockMvc 的测试。这意味着您生成的是实际请求,需要设置生成的测试的基类以在实际的套接字上工作。

考虑以下契约

org.springframework.cloud.contract.spec.Contract.make {
	request {
		method 'GET'
		url '/my-context-path/url'
	}
	response {
		status OK()
	}
}

以下示例展示了如何设置基类和 RestAssured

import io.restassured.RestAssured;
import org.junit.Before;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.boot.test.web.server.LocalServerPort;

@SpringBootTest(classes = ContextPathTestingBaseClass.class, webEnvironment = SpringBootTest.WebEnvironment.RANDOM_PORT)
class ContextPathTestingBaseClass {
	
	@LocalServerPort int port;
	
	@Before
	public void setup() {
		RestAssured.baseURI = "http://localhost";
		RestAssured.port = this.port;
	}
}

如果您这样做

  • 自动生成测试中的所有请求都会发送到实际的端点,并包含您的上下文路径(例如,/my-context-path/url)。

  • 您的契约反映了您具有上下文路径。您生成的桩也包含该信息(例如,在桩中,您必须调用 /my-context-path/url)。