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();
+ }
+}