diff --git a/kubernetes-client/src/main/resources/resource-handler-services.vm b/kubernetes-client/src/main/resources/resource-handler-services.vm index 4ed1e7a9677..82605946fb0 100644 --- a/kubernetes-client/src/main/resources/resource-handler-services.vm +++ b/kubernetes-client/src/main/resources/resource-handler-services.vm @@ -19,5 +19,6 @@ #set ($packageSuffix = $annotation.getParameters().get("value")) #end #end - io.fabric8.kubernetes.client.handlers${packageSuffix}.${m.name}Handler + +io.fabric8.kubernetes.client.handlers${packageSuffix}.${m.name}Handler #end diff --git a/uberjar/pom.xml b/uberjar/pom.xml index c1646dcb5d1..60c0914edf0 100644 --- a/uberjar/pom.xml +++ b/uberjar/pom.xml @@ -175,6 +175,17 @@ generex ${generex.version} + + + org.junit.jupiter + junit-jupiter-engine + test + + + org.junit.jupiter + junit-jupiter-migrationsupport + test + @@ -369,6 +380,32 @@ + + org.apache.maven.plugins + maven-surefire-plugin + + + **/*UberJarTest.java + + + + + integration-test + + test + + integration-test + + + none + + + **/*UberJarTest.java + + + + + diff --git a/uberjar/src/test/java/io/fabric8/kubernetes/clnt/UberJarTest.java b/uberjar/src/test/java/io/fabric8/kubernetes/clnt/UberJarTest.java new file mode 100644 index 00000000000..4bfa568b90d --- /dev/null +++ b/uberjar/src/test/java/io/fabric8/kubernetes/clnt/UberJarTest.java @@ -0,0 +1,196 @@ +package io.fabric8.kubernetes.clnt; + +import org.junit.Rule; +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; +import org.junit.jupiter.migrationsupport.rules.EnableRuleMigrationSupport; +import org.junit.rules.TemporaryFolder; + +import java.io.BufferedOutputStream; +import java.io.File; +import java.io.FileInputStream; +import java.io.FileOutputStream; +import java.io.IOException; +import java.nio.file.Files; +import java.util.List; +import java.util.zip.ZipEntry; +import java.util.zip.ZipInputStream; + +import static org.junit.Assert.assertTrue; +import static org.junit.jupiter.api.Assertions.assertNotNull; + +@EnableRuleMigrationSupport +public class UberJarTest { + private static final String OUTPUT_DIR = System.getProperty("user.dir") + File.separator + "target"; + private static final File pomFile = new File(System.getProperty("user.dir") + File.separator + "pom.xml"); + private static final String JAR_NAME_SEPARATOR = "-"; + private static final String JAR_SUFFIX = ".jar"; + private static final String ARTIFACT_ID = "kubernetes-openshift-uberjar"; + + @Rule + public TemporaryFolder folder = new TemporaryFolder(); + + @Test + @DisplayName("UberJar should be generated and should contain necessary files") + public void testUberJar() throws IOException { + // Given + String projectVersion = getProjectVersion(); + assertNotNull(projectVersion); + String uberJarFilePath = OUTPUT_DIR + File.separator + ARTIFACT_ID + JAR_NAME_SEPARATOR + projectVersion + JAR_SUFFIX; + + // When + File uberJar = new File(uberJarFilePath); + File jarExtractedDir = folder.newFolder("extractedJar"); + unzip(uberJar.getAbsolutePath(), jarExtractedDir.getAbsolutePath()); + + // Then + assertTrue(uberJar.exists()); + assertTrue(getFileInDirectory(jarExtractedDir, "io/fabric8/kubernetes/api/builder/Builder.class").exists()); + assertTrue(getFileInDirectory(jarExtractedDir, "io/fabric8/kubernetes/api/builder/Visitor.class").exists()); + assertTrue(getFileInDirectory(jarExtractedDir, "io/fabric8/kubernetes/api/model/admission").exists()); + assertTrue(getFileInDirectory(jarExtractedDir, "io/fabric8/kubernetes/api/model/apps").exists()); + assertTrue(getFileInDirectory(jarExtractedDir, "io/fabric8/kubernetes/api/model/autoscaling").exists()); + assertTrue(getFileInDirectory(jarExtractedDir, "io/fabric8/kubernetes/api/model/coordination").exists()); + assertTrue(getFileInDirectory(jarExtractedDir, "io/fabric8/kubernetes/api/model/extensions").exists()); + assertTrue(getFileInDirectory(jarExtractedDir, "io/fabric8/kubernetes/api/model/policy").exists()); + assertTrue(getFileInDirectory(jarExtractedDir, "io/fabric8/kubernetes/api/model/settings").exists()); + assertTrue(getFileInDirectory(jarExtractedDir, "io/fabric8/kubernetes/api/model/admissionregistration").exists()); + assertTrue(getFileInDirectory(jarExtractedDir, "io/fabric8/kubernetes/api/model/authentication").exists()); + assertTrue(getFileInDirectory(jarExtractedDir, "io/fabric8/kubernetes/api/model/batch").exists()); + assertTrue(getFileInDirectory(jarExtractedDir, "io/fabric8/kubernetes/api/model/discovery").exists()); + assertTrue(getFileInDirectory(jarExtractedDir, "io/fabric8/kubernetes/api/model/metrics").exists()); + assertTrue(getFileInDirectory(jarExtractedDir, "io/fabric8/kubernetes/api/model/rbac").exists()); + assertTrue(getFileInDirectory(jarExtractedDir, "io/fabric8/kubernetes/api/model/storage").exists()); + assertTrue(getFileInDirectory(jarExtractedDir, "io/fabric8/kubernetes/api/model/authorization").exists()); + assertTrue(getFileInDirectory(jarExtractedDir, "io/fabric8/kubernetes/client/dsl").exists()); + assertTrue(getFileInDirectory(jarExtractedDir, "io/fabric8/kubernetes/client/handlers").exists()); + File resourceHandlerServiceFile = getFileInDirectory(jarExtractedDir, "META-INF/services/io.fabric8.kubernetes.client.ResourceHandler"); + assertTrue(resourceHandlerServiceFile.exists()); + assertTrue(containsOpenShiftKubernetesResources(resourceHandlerServiceFile, null, null)); + assertTrue(getFileInDirectory(jarExtractedDir, "META-INF/services/io.fabric8.kubernetes.client.ExtensionAdapter").exists()); + assertTrue(getFileInDirectory(jarExtractedDir, "META-INF/services/io.fabric8.kubernetes.client.ServiceToURLProvider").exists()); + } + + @Test + public void testUberJarVersioned() throws IOException { + // Given + String projectVersion = getProjectVersion(); + assertNotNull(projectVersion); + String majorVersion = getMajorVersion(projectVersion); + String minorVersion = getMinorVersion(projectVersion); + String versionedJarFilePath = OUTPUT_DIR + File.separator + ARTIFACT_ID + JAR_NAME_SEPARATOR + projectVersion + JAR_NAME_SEPARATOR + "versioned" + JAR_SUFFIX; + + // When + File uberJarVersioned = new File(versionedJarFilePath); + File jarExtractedDir = folder.newFolder("extractedJar"); + unzip(uberJarVersioned.getAbsolutePath(), jarExtractedDir.getAbsolutePath()); + + // Then + assertTrue(uberJarVersioned.exists()); + assertTrue(getFileInDirectory(jarExtractedDir, "io/fabric8/kubernetes/api/builder/v" + majorVersion + "_" + minorVersion + "/Builder.class").exists()); + assertTrue(getFileInDirectory(jarExtractedDir, "io/fabric8/kubernetes/api/builder/v" + majorVersion + "_" + minorVersion + "/Visitor.class").exists()); + assertTrue(getFileInDirectory(jarExtractedDir, "io/fabric8/kubernetes/api/model/v" + majorVersion + "_" + minorVersion + "/admission").exists()); + assertTrue(getFileInDirectory(jarExtractedDir, "io/fabric8/kubernetes/api/model/v" + majorVersion + "_" + minorVersion + "/apps").exists()); + assertTrue(getFileInDirectory(jarExtractedDir, "io/fabric8/kubernetes/api/model/v" + majorVersion + "_" + minorVersion + "/autoscaling").exists()); + assertTrue(getFileInDirectory(jarExtractedDir, "io/fabric8/kubernetes/api/model/v" + majorVersion + "_" + minorVersion + "/coordination").exists()); + assertTrue(getFileInDirectory(jarExtractedDir, "io/fabric8/kubernetes/api/model/v" + majorVersion + "_" + minorVersion + "/extensions").exists()); + assertTrue(getFileInDirectory(jarExtractedDir, "io/fabric8/kubernetes/api/model/v" + majorVersion + "_" + minorVersion + "/policy").exists()); + assertTrue(getFileInDirectory(jarExtractedDir, "io/fabric8/kubernetes/api/model/v" + majorVersion + "_" + minorVersion + "/settings").exists()); + assertTrue(getFileInDirectory(jarExtractedDir, "io/fabric8/kubernetes/api/model/v" + majorVersion + "_" + minorVersion + "/admissionregistration").exists()); + assertTrue(getFileInDirectory(jarExtractedDir, "io/fabric8/kubernetes/api/model/v" + majorVersion + "_" + minorVersion + "/authentication").exists()); + assertTrue(getFileInDirectory(jarExtractedDir, "io/fabric8/kubernetes/api/model/v" + majorVersion + "_" + minorVersion + "/batch").exists()); + assertTrue(getFileInDirectory(jarExtractedDir, "io/fabric8/kubernetes/api/model/v" + majorVersion + "_" + minorVersion + "/discovery").exists()); + assertTrue(getFileInDirectory(jarExtractedDir, "io/fabric8/kubernetes/api/model/v" + majorVersion + "_" + minorVersion + "/metrics").exists()); + assertTrue(getFileInDirectory(jarExtractedDir, "io/fabric8/kubernetes/api/model/v" + majorVersion + "_" + minorVersion + "/rbac").exists()); + assertTrue(getFileInDirectory(jarExtractedDir, "io/fabric8/kubernetes/api/model/v" + majorVersion + "_" + minorVersion + "/storage").exists()); + assertTrue(getFileInDirectory(jarExtractedDir, "io/fabric8/kubernetes/api/model/v" + majorVersion + "_" + minorVersion + "/authorization").exists()); + assertTrue(getFileInDirectory(jarExtractedDir, "io/fabric8/kubernetes/clnt/v" + majorVersion + "_" + minorVersion + "/dsl").exists()); + assertTrue(getFileInDirectory(jarExtractedDir, "io/fabric8/kubernetes/clnt/v" + majorVersion + "_" + minorVersion + "/handlers").exists()); + File resourceHandlerServiceFile = getFileInDirectory(jarExtractedDir, "META-INF/services/io.fabric8.kubernetes.clnt.v" + majorVersion + "_" + minorVersion + ".ResourceHandler"); + assertTrue(resourceHandlerServiceFile.exists()); + assertTrue(containsOpenShiftKubernetesResources(resourceHandlerServiceFile, majorVersion, minorVersion)); + assertTrue(getFileInDirectory(jarExtractedDir, "META-INF/services/io.fabric8.kubernetes.clnt.v" + majorVersion + "_" + minorVersion + ".ExtensionAdapter").exists()); + assertTrue(getFileInDirectory(jarExtractedDir, "META-INF/services/io.fabric8.kubernetes.clnt.v" + majorVersion + "_" + minorVersion + ".ServiceToURLProvider").exists()); + } + + private boolean containsOpenShiftKubernetesResources(File resourceHandlerServiceFile, String majorVersion, String minorVersion) throws IOException { + List lines = Files.readAllLines(resourceHandlerServiceFile.toPath()); + final String deploymentConfigOpenShiftHandler = (majorVersion != null && minorVersion != null) ? + "io.fabric8.openshift.clnt.v" + majorVersion + "_" + minorVersion + ".handlers.DeploymentConfigHandler" : + "io.fabric8.openshift.client.handlers.DeploymentConfigHandler"; + final String deploymentKubernetesHandler = (majorVersion != null && minorVersion != null) ? + "io.fabric8.kubernetes.clnt.v" + majorVersion + "_" + minorVersion + ".handlers.apps.v1.DeploymentHandler" : + "io.fabric8.kubernetes.client.handlers.apps.v1.DeploymentHandler"; + + return lines.stream().anyMatch(line -> line.contains(deploymentConfigOpenShiftHandler)) && + lines.stream().anyMatch(line -> line.contains(deploymentKubernetesHandler)); + } + + private String getMajorVersion(String projectVersion) { + return projectVersion.split("\\.")[0]; + } + + private String getMinorVersion(String projectVersion) { + String[] versionParts = projectVersion.split("\\."); + String minorPatchVersion = projectVersion.substring(versionParts[0].length() + 1); + if (minorPatchVersion.contains("-")) { // SNAPSHOT VERSION + return minorPatchVersion.split("-")[0]; + } else { // RELEASE VERSION + return versionParts[1]; + } + } + + private File getFileInDirectory(File parentFile, String pathToFile) { + pathToFile = pathToFile.replaceAll("/", File.separator); + return new File(parentFile, pathToFile); + } + + private String getProjectVersion() throws IOException { + List pomLines = readPomLines(); + for (String line : pomLines) { + if (line.contains("")) { + line = line.replaceAll("version>", ""); + line = line.replaceAll("/", ""); + line = line.replaceAll("<", ""); + line = line.replaceAll(" ", ""); + return line; + } + } + return null; + } + + private List readPomLines() throws IOException { + return Files.readAllLines(pomFile.toPath()); + } + + public void unzip(String zipFilePath, String destDirectory) throws IOException { + File destDir = new File(destDirectory); + if (!destDir.exists()) { + destDir.mkdir(); + } + ZipInputStream zipIn = new ZipInputStream(new FileInputStream(zipFilePath)); + ZipEntry entry = zipIn.getNextEntry(); + while (entry != null) { + String filePath = destDirectory + File.separator + entry.getName(); + if (!entry.isDirectory()) { + extractFile(zipIn, filePath); + } else { + File dir = new File(filePath); + dir.mkdir(); + } + zipIn.closeEntry(); + entry = zipIn.getNextEntry(); + } + zipIn.close(); + } + + private void extractFile(ZipInputStream zipIn, String filePath) throws IOException { + BufferedOutputStream bos = new BufferedOutputStream(new FileOutputStream(filePath)); + byte[] bytesIn = new byte[4096]; + int read = 0; + while ((read = zipIn.read(bytesIn)) != -1) { + bos.write(bytesIn, 0, read); + } + bos.close(); + } +}