From d67ac1a59b250f1d5290ebb266881cd9a9be0def Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jiri=20Dan=C4=9Bk?= Date: Wed, 10 Jan 2024 19:12:06 +0100 Subject: [PATCH] wip: ODS-xxxx expose dashboard 8080 and curl to it --- .../e2e/continuous/DataScienceClusterST.java | 3 +- .../continuous/DataScienceDashboardST.java | 115 ++++++++++++++++++ 2 files changed, 117 insertions(+), 1 deletion(-) create mode 100644 src/test/java/io/odh/test/e2e/continuous/DataScienceDashboardST.java diff --git a/src/test/java/io/odh/test/e2e/continuous/DataScienceClusterST.java b/src/test/java/io/odh/test/e2e/continuous/DataScienceClusterST.java index 31b6d475..c82a1b50 100644 --- a/src/test/java/io/odh/test/e2e/continuous/DataScienceClusterST.java +++ b/src/test/java/io/odh/test/e2e/continuous/DataScienceClusterST.java @@ -35,7 +35,8 @@ @Tag(TestSuite.CONTINUOUS) public class DataScienceClusterST extends Abstract { - private static final String DS_CLUSTER_NAME = "default"; + // TODO on my cluster this is default-dsc, cluster created with existing jenkins automation in PSI + private static final String DS_CLUSTER_NAME = "default-dsc"; private static final String DS_DASHBOARD_CONFIG_NAME = "odh-dashboard-config"; MixedOperation, Resource> dataScienceProjectCli; MixedOperation, Resource> dashboardConfigCli; diff --git a/src/test/java/io/odh/test/e2e/continuous/DataScienceDashboardST.java b/src/test/java/io/odh/test/e2e/continuous/DataScienceDashboardST.java new file mode 100644 index 00000000..276b0483 --- /dev/null +++ b/src/test/java/io/odh/test/e2e/continuous/DataScienceDashboardST.java @@ -0,0 +1,115 @@ +/* + * Copyright Skodjob authors. + * License: Apache License 2.0 (see the file LICENSE or http://apache.org/licenses/LICENSE-2.0.html). + */ +package io.odh.test.e2e.continuous; + +import io.fabric8.kubernetes.api.model.IntOrString; +import io.fabric8.kubernetes.api.model.KubernetesResourceList; +import io.fabric8.kubernetes.api.model.Service; +import io.fabric8.kubernetes.api.model.ServicePort; +import io.fabric8.kubernetes.api.model.ServicePortBuilder; +import io.fabric8.kubernetes.client.dsl.MixedOperation; +import io.fabric8.kubernetes.client.dsl.Resource; +import io.fabric8.openshift.api.model.Route; +import io.fabric8.openshift.client.OpenShiftClient; +import io.odh.test.TestSuite; +import io.odh.test.e2e.Abstract; +import io.odh.test.framework.manager.ResourceManager; +import io.odh.test.framework.manager.resources.NotebookResource; +import io.odh.test.utils.DeploymentUtils; +import lombok.extern.java.Log; +import org.junit.jupiter.api.Assertions; +import org.junit.jupiter.api.BeforeAll; +import org.junit.jupiter.api.Tag; +import org.junit.jupiter.api.Test; +import org.junit.jupiter.params.provider.Arguments; +import org.kubeflow.v1.Notebook; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; + +import java.io.ByteArrayInputStream; +import java.io.IOException; +import java.net.URI; +import java.net.URL; +import java.net.http.HttpClient; +import java.net.http.HttpRequest; +import java.net.http.HttpResponse; +import java.nio.charset.StandardCharsets; +import java.util.stream.Stream; + +// TODO: what's difference between continuous and standard? +@Tag(TestSuite.CONTINUOUS) +//TODO: what is ST? system test? +public class DataScienceDashboardST extends Abstract { + static final Logger LOGGER = LoggerFactory.getLogger(DataScienceDashboardST.class); + + @Test + void checkDataScienceProjects() throws IOException, InterruptedException { + try (OpenShiftClient kubeClient = ResourceManager.getClient().getClient().adapt(OpenShiftClient.class)) { + Service service = kubeClient.services() + .inNamespace("redhat-ods-applications") + .withName("rhods-dashboard") + .get(); + + ServicePort port1 = new ServicePortBuilder() + .withName("8443-tcp") + .withProtocol("TCP") + .withPort(8443) + .withTargetPort(new IntOrString(8443)) + .build(); + + ServicePort port2 = new ServicePortBuilder() + .withName("8080-tcp") + .withProtocol("TCP") + .withPort(8080) + .withTargetPort(new IntOrString(8080)) + .build(); + + Service updatedService = service.edit() + .editSpec() + .addToPorts(port1, port2) + .endSpec() + .build(); + + Route route = kubeClient.routes().load(new ByteArrayInputStream(""" + apiVersion: route.openshift.io/v1 + kind: Route + metadata: + name: rhods-dashboard-internal + namespace: redhat-ods-applications + labels: + app: rhods-dashboard + app.kubernetes.io/part-of: rhods-dashboard + spec: + port: + targetPort: 8080-tcp + to: + kind: Service + name: rhods-dashboard + wildcardPolicy: None + """.getBytes(StandardCharsets.UTF_8))).item(); + kubeClient.routes().resource(route).create(); + + // do I need to wait here? + + // fetch the route object from the server + Route r2 = kubeClient.routes().resource(route).get(); + String url = "http://%s/api/status".formatted(r2.getSpec().getHost()); + + HttpRequest request = HttpRequest.newBuilder(URI.create(url)) + .GET() + .header("x-forwarded-access-token", "asdfadsfasd") + .build(); + LOGGER.debug("Making request {}", request); + HttpClient httpClient = HttpClient.newHttpClient(); + HttpResponse response = httpClient.send(request, HttpResponse.BodyHandlers.discarding()); + LOGGER.debug("Got response {}", response); + + Assertions.assertEquals(401, response.statusCode()); + + service.edit().editSpec().removeFromPorts(port1, port2).endSpec().build(); + kubeClient.routes().resource(route).delete(); + } + } +}