Search in sources :

Example 1 with KubernetesClientSecretsPropertySourceLocator

use of org.springframework.cloud.kubernetes.client.config.KubernetesClientSecretsPropertySourceLocator in project spring-cloud-kubernetes by spring-cloud.

the class KubernetesClientEventBasedSecretsChangeDetectorTests method watch.

@Test
void watch() {
    GsonBuilder builder = new GsonBuilder();
    builder.excludeFieldsWithModifiers(Modifier.STATIC, Modifier.TRANSIENT, Modifier.VOLATILE).registerTypeAdapter(OffsetDateTime.class, new GsonOffsetDateTimeAdapter());
    Gson gson = builder.create();
    V1Secret dbPassword = new V1Secret().kind("Secret").metadata(new V1ObjectMeta().name("db-password")).putStringDataItem("password", Base64.getEncoder().encodeToString("p455w0rd".getBytes())).putStringDataItem("username", Base64.getEncoder().encodeToString("user".getBytes()));
    V1Secret dbPasswordUpdated = new V1Secret().kind("Secret").metadata(new V1ObjectMeta().name("db-password")).putStringDataItem("password", Base64.getEncoder().encodeToString("p455w0rd2".getBytes())).putStringDataItem("username", Base64.getEncoder().encodeToString("user".getBytes()));
    V1SecretList secretList = new V1SecretList().kind("SecretList").metadata(new V1ListMeta().resourceVersion("0")).items(Arrays.asList(dbPassword));
    stubFor(get(urlMatching("^/api/v1/namespaces/default/secrets.*")).inScenario("watch").whenScenarioStateIs(STARTED).withQueryParam("watch", equalTo("false")).willReturn(aResponse().withStatus(200).withBody(gson.toJson(secretList))).willSetStateTo("update"));
    Watch.Response<V1Secret> watchResponse = new Watch.Response<>(EventType.MODIFIED.name(), dbPasswordUpdated);
    stubFor(get(urlMatching("/api/v1/namespaces/default/secrets.*")).inScenario("watch").whenScenarioStateIs("update").withQueryParam("watch", equalTo("true")).willReturn(aResponse().withStatus(200).withBody(new JSON().serialize(watchResponse))).willSetStateTo("add"));
    stubFor(get(urlMatching("/api/v1/namespaces/default/secrets.*")).inScenario("watch").whenScenarioStateIs("add").withQueryParam("watch", equalTo("true")).willReturn(aResponse().withStatus(200).withBody(new JSON().serialize(new Watch.Response<>(EventType.ADDED.name(), new V1Secret().kind("Secret").metadata(new V1ObjectMeta().name("rabbit-password")).putDataItem("rabbit-pw", Base64.getEncoder().encode("password".getBytes())))))).willSetStateTo("delete"));
    stubFor(get(urlMatching("/api/v1/namespaces/default/secrets.*")).inScenario("watch").whenScenarioStateIs("delete").withQueryParam("watch", equalTo("true")).willReturn(aResponse().withStatus(200).withBody(new JSON().serialize(new Watch.Response<>(EventType.DELETED.name(), new V1Secret().kind("Secret").metadata(new V1ObjectMeta().name("rabbit-password")).putDataItem("rabbit-pw", Base64.getEncoder().encode("password".getBytes())))))).willSetStateTo("done"));
    stubFor(get(urlMatching("/api/v1/namespaces/default/secrets.*")).inScenario("watch").whenScenarioStateIs("done").withQueryParam("watch", equalTo("true")).willReturn(aResponse().withStatus(200)));
    ApiClient apiClient = new ClientBuilder().setBasePath("http://localhost:" + wireMockServer.port()).build();
    OkHttpClient httpClient = apiClient.getHttpClient().newBuilder().readTimeout(0, TimeUnit.SECONDS).build();
    apiClient.setHttpClient(httpClient);
    CoreV1Api coreV1Api = new CoreV1Api(apiClient);
    ConfigurationUpdateStrategy strategy = mock(ConfigurationUpdateStrategy.class);
    when(strategy.getName()).thenReturn("strategy");
    KubernetesMockEnvironment environment = new KubernetesMockEnvironment(mock(KubernetesClientSecretsPropertySource.class)).withProperty("db-password", "p455w0rd");
    KubernetesClientSecretsPropertySourceLocator locator = mock(KubernetesClientSecretsPropertySourceLocator.class);
    when(locator.locate(environment)).thenAnswer(ignoreMe -> new MockPropertySource().withProperty("db-password", "p455w0rd2"));
    ConfigReloadProperties properties = new ConfigReloadProperties();
    properties.setMonitoringSecrets(true);
    KubernetesNamespaceProvider kubernetesNamespaceProvider = mock(KubernetesNamespaceProvider.class);
    when(kubernetesNamespaceProvider.getNamespace()).thenReturn("default");
    KubernetesClientEventBasedSecretsChangeDetector changeDetector = new KubernetesClientEventBasedSecretsChangeDetector(coreV1Api, environment, properties, strategy, locator, kubernetesNamespaceProvider);
    Thread controllerThread = new Thread(changeDetector::watch);
    controllerThread.setDaemon(true);
    controllerThread.start();
    await().timeout(Duration.ofSeconds(300)).until(() -> Mockito.mockingDetails(strategy).getInvocations().size() > 4);
    verify(strategy, atLeast(3)).reload();
}
Also used : OkHttpClient(okhttp3.OkHttpClient) KubernetesClientSecretsPropertySourceLocator(org.springframework.cloud.kubernetes.client.config.KubernetesClientSecretsPropertySourceLocator) V1ObjectMeta(io.kubernetes.client.openapi.models.V1ObjectMeta) Gson(com.google.gson.Gson) JSON(io.kubernetes.client.openapi.JSON) ConfigurationUpdateStrategy(org.springframework.cloud.kubernetes.commons.config.reload.ConfigurationUpdateStrategy) V1SecretList(io.kubernetes.client.openapi.models.V1SecretList) Watch(io.kubernetes.client.util.Watch) KubernetesNamespaceProvider(org.springframework.cloud.kubernetes.commons.KubernetesNamespaceProvider) CoreV1Api(io.kubernetes.client.openapi.apis.CoreV1Api) ClientBuilder(io.kubernetes.client.util.ClientBuilder) GsonBuilder(com.google.gson.GsonBuilder) ApiClient(io.kubernetes.client.openapi.ApiClient) V1ListMeta(io.kubernetes.client.openapi.models.V1ListMeta) WireMock.aResponse(com.github.tomakehurst.wiremock.client.WireMock.aResponse) ConfigReloadProperties(org.springframework.cloud.kubernetes.commons.config.reload.ConfigReloadProperties) MockPropertySource(org.springframework.mock.env.MockPropertySource) V1Secret(io.kubernetes.client.openapi.models.V1Secret) Test(org.junit.jupiter.api.Test)

Aggregations

WireMock.aResponse (com.github.tomakehurst.wiremock.client.WireMock.aResponse)1 Gson (com.google.gson.Gson)1 GsonBuilder (com.google.gson.GsonBuilder)1 ApiClient (io.kubernetes.client.openapi.ApiClient)1 JSON (io.kubernetes.client.openapi.JSON)1 CoreV1Api (io.kubernetes.client.openapi.apis.CoreV1Api)1 V1ListMeta (io.kubernetes.client.openapi.models.V1ListMeta)1 V1ObjectMeta (io.kubernetes.client.openapi.models.V1ObjectMeta)1 V1Secret (io.kubernetes.client.openapi.models.V1Secret)1 V1SecretList (io.kubernetes.client.openapi.models.V1SecretList)1 ClientBuilder (io.kubernetes.client.util.ClientBuilder)1 Watch (io.kubernetes.client.util.Watch)1 OkHttpClient (okhttp3.OkHttpClient)1 Test (org.junit.jupiter.api.Test)1 KubernetesClientSecretsPropertySourceLocator (org.springframework.cloud.kubernetes.client.config.KubernetesClientSecretsPropertySourceLocator)1 KubernetesNamespaceProvider (org.springframework.cloud.kubernetes.commons.KubernetesNamespaceProvider)1 ConfigReloadProperties (org.springframework.cloud.kubernetes.commons.config.reload.ConfigReloadProperties)1 ConfigurationUpdateStrategy (org.springframework.cloud.kubernetes.commons.config.reload.ConfigurationUpdateStrategy)1 MockPropertySource (org.springframework.mock.env.MockPropertySource)1