diff options
author | Gary Wu <gary.wu@futurewei.com> | 2019-06-27 10:30:52 -0700 |
---|---|---|
committer | Gary Wu <gary.wu@futurewei.com> | 2019-06-27 10:51:25 -0700 |
commit | d15450419ab00cb77af96f57252012edc5276b98 (patch) | |
tree | abcff6fbbafb3dde2e089e9979e6a4ea01025693 /version-manifest/src/main/java/org/onap/integration | |
parent | 17314cd2c1e0ae88cc460d96e3731a72dd3a37d9 (diff) |
Decommission java and docker manifests
Issue-ID: INT-1128
Signed-off-by: Gary Wu <gary.wu@futurewei.com>
Change-Id: Id8b3f228f0813a82e871feb57cc865905dff9988
Diffstat (limited to 'version-manifest/src/main/java/org/onap/integration')
-rw-r--r-- | version-manifest/src/main/java/org/onap/integration/versionmanifest/VersionCheckMojo.java | 165 |
1 files changed, 0 insertions, 165 deletions
diff --git a/version-manifest/src/main/java/org/onap/integration/versionmanifest/VersionCheckMojo.java b/version-manifest/src/main/java/org/onap/integration/versionmanifest/VersionCheckMojo.java deleted file mode 100644 index dfac6cd17..000000000 --- a/version-manifest/src/main/java/org/onap/integration/versionmanifest/VersionCheckMojo.java +++ /dev/null @@ -1,165 +0,0 @@ -/* - * Copyright 2017 Huawei Technologies, Ltd. and others. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -package org.onap.integration.versionmanifest; - -import java.io.IOException; -import java.io.InputStream; -import java.io.InputStreamReader; -import java.nio.charset.StandardCharsets; -import java.util.Arrays; -import java.util.HashMap; -import java.util.List; -import java.util.Map; -import java.util.Map.Entry; -import java.util.Properties; -import java.util.Set; -import java.util.TreeSet; - -import org.apache.commons.csv.CSVFormat; -import org.apache.commons.csv.CSVRecord; -import org.apache.maven.artifact.Artifact; -import org.apache.maven.plugin.AbstractMojo; -import org.apache.maven.plugin.MojoExecutionException; -import org.apache.maven.plugin.logging.Log; -import org.apache.maven.plugins.annotations.LifecyclePhase; -import org.apache.maven.plugins.annotations.Mojo; -import org.apache.maven.plugins.annotations.Parameter; -import org.apache.maven.project.MavenProject; - -@Mojo(name = "version-check", defaultPhase = LifecyclePhase.PROCESS_SOURCES) -public class VersionCheckMojo extends AbstractMojo { - - /** - * The Maven Project. - * - * @since 1.0-alpha-1 - */ - @Parameter(defaultValue = "${project}", required = true, readonly = true) - protected MavenProject project; - - /** - * Location of the file. - */ - @Parameter(property = "manifest", required = true, defaultValue = "/java-manifest.csv") - private String manifest; - - public void execute() throws MojoExecutionException { - final Log log = getLog(); - - final Properties gitProps = new Properties(); - try (InputStream in = getClass().getResourceAsStream("/git.properties")) { - gitProps.load(in); - } catch (IOException e) { - log.error(e); - throw new MojoExecutionException(e.getMessage()); - } - - log.info("Manifest version: " + gitProps.getProperty("git.build.time") + " " - + gitProps.getProperty("git.commit.id") + " " + gitProps.getProperty("git.remote.origin.url")); - - log.info(""); - - final List<String> groupIdPrefixes = Arrays.asList("org.onap", "org.openecomp", "org.openo"); - - final Map<String, String> expectedVersions = new HashMap<>(); - - try (InputStreamReader in = new InputStreamReader(getClass().getResourceAsStream(manifest), - StandardCharsets.ISO_8859_1)) { - Iterable<CSVRecord> records = CSVFormat.DEFAULT.withFirstRecordAsHeader().parse(in); - for (CSVRecord record : records) { - String groupId = record.get("groupId"); - String artifactId = record.get("artifactId"); - String version = record.get("version"); - log.debug("Expected version: " + groupId + ":" + artifactId + ":" + version); - expectedVersions.put(groupId + ":" + artifactId, version); - } - } catch (IOException e) { - log.error(e); - throw new MojoExecutionException(e.getMessage()); - } - - final Map<String, String> actualVersions = new HashMap<>(); - final MavenProject parent = project.getParent(); - if (parent != null) { - log.debug("Parent: " + parent); - // don't warn within the same groupId - if (!project.getGroupId().equals(parent.getGroupId())) { - actualVersions.put(parent.getGroupId() + ":" + parent.getArtifactId(), parent.getVersion()); - } - } else { - log.debug("No parent"); - } - - for (Artifact dep : project.getDependencyArtifacts()) { - log.debug("DependencyArtifact: " + dep.toString()); - // don't warn within the same groupId - if (!project.getGroupId().equals(dep.getGroupId())) { - actualVersions.put(dep.getGroupId() + ":" + dep.getArtifactId(), dep.getVersion()); - } - } - - final Set<String> mismatches = new TreeSet<>(); - final Set<String> missingArtifacts = new TreeSet<>(); - - for (Entry<String, String> actualVersionEntry : actualVersions.entrySet()) { - String artifact = actualVersionEntry.getKey(); - String actualVersion = actualVersionEntry.getValue(); - String expectedVersion = expectedVersions.get(artifact); - if (expectedVersion == null) { - if (groupIdPrefixes.stream().anyMatch(prefix -> artifact.startsWith(prefix))) { - missingArtifacts.add(artifact); - } - } else if (!expectedVersion.equals(actualVersion)) { - mismatches.add(artifact); - } - } - - // used for formatting - int[] columnWidths = new int[10]; - columnWidths[0] = actualVersions.keySet().stream().mapToInt(s -> ("" + s).length()).max().orElse(1); - columnWidths[1] = actualVersions.values().stream().mapToInt(s -> ("" + s).length()).max().orElse(1); - columnWidths[2] = expectedVersions.values().stream().mapToInt(s -> ("" + s).length()).max().orElse(1); - String format = " %-" + columnWidths[0] + "s" + " %" + columnWidths[1] + "s -> %" + columnWidths[2] + "s"; - - if (mismatches.isEmpty()) { - log.debug("No version mismatches found"); - } else { - log.warn("The following dependencies should be updated to match the version manifest:"); - for (String artifact : mismatches) { - String expectedVersion = expectedVersions.get(artifact); - String actualVersion = actualVersions.get(artifact); - - if (actualVersion != null && !actualVersion.equals(expectedVersion)) { - log.warn(String.format(format, artifact, actualVersion, expectedVersion)); - } - } - log.warn(""); - } - - if (missingArtifacts.isEmpty()) { - log.debug("No artifacts found missing in the version manifest"); - } else { - log.warn("The following dependencies are missing in the version manifest:"); - for (String artifact : missingArtifacts) { - String actualVersion = actualVersions.get(artifact); - log.warn(String.format(format, artifact, actualVersion, "?")); - } - log.warn(""); - } - - } -} |