ignite-commits mailing list archives

Site index · List index
Message view « Date » · « Thread »
Top « Date » · « Thread »
From sboi...@apache.org
Subject incubator-ignite git commit: # ignite-1099: init implementation
Date Wed, 08 Jul 2015 16:15:32 GMT
Repository: incubator-ignite
Updated Branches:
  refs/heads/ignite-1099 [created] 0d01da22f


# ignite-1099: init implementation


Project: http://git-wip-us.apache.org/repos/asf/incubator-ignite/repo
Commit: http://git-wip-us.apache.org/repos/asf/incubator-ignite/commit/0d01da22
Tree: http://git-wip-us.apache.org/repos/asf/incubator-ignite/tree/0d01da22
Diff: http://git-wip-us.apache.org/repos/asf/incubator-ignite/diff/0d01da22

Branch: refs/heads/ignite-1099
Commit: 0d01da22f4ea9445b84395640f943214b8be9d07
Parents: 94a42a4
Author: ashutak <ashutak@gridgain.com>
Authored: Wed Jul 8 19:15:05 2015 +0300
Committer: ashutak <ashutak@gridgain.com>
Committed: Wed Jul 8 19:15:05 2015 +0300

----------------------------------------------------------------------
 modules/tools/pom.xml                           |  25 ++
 .../tools/jirabranches/JiraBranchesToHtml.java  | 289 +++++++++++++++++++
 scripts/jira-branches.sh                        |  18 ++
 3 files changed, 332 insertions(+)
----------------------------------------------------------------------


http://git-wip-us.apache.org/repos/asf/incubator-ignite/blob/0d01da22/modules/tools/pom.xml
----------------------------------------------------------------------
diff --git a/modules/tools/pom.xml b/modules/tools/pom.xml
index 17ba197..7502552 100644
--- a/modules/tools/pom.xml
+++ b/modules/tools/pom.xml
@@ -39,6 +39,13 @@
         <maven.compiler.target>1.7</maven.compiler.target>
     </properties>
 
+    <repositories>
+        <repository>
+            <id>atlassian-public</id>
+            <url>https://maven.atlassian.com/content/repositories/atlassian-public</url>
+        </repository>
+    </repositories>
+
     <dependencies>
         <dependency>
             <groupId>org.jodd</groupId>
@@ -47,6 +54,24 @@
         </dependency>
 
         <dependency>
+            <groupId>org.apache.ignite</groupId>
+            <artifactId>ignite-core</artifactId>
+            <version>${project.version}</version>
+        </dependency>
+
+        <dependency>
+            <groupId>com.atlassian.jira</groupId>
+            <artifactId>jira-rest-java-client-api</artifactId>
+            <version>2.0.0-m26</version>
+        </dependency>
+
+        <dependency>
+            <groupId>com.atlassian.jira</groupId>
+            <artifactId>jira-rest-java-client-core</artifactId>
+            <version>2.0.0-m26</version>
+        </dependency>
+
+        <dependency>
             <groupId>org.apache.ant</groupId>
             <artifactId>ant</artifactId>
             <version>1.8.2</version>

http://git-wip-us.apache.org/repos/asf/incubator-ignite/blob/0d01da22/modules/tools/src/main/java/org/apache/ignite/tools/jirabranches/JiraBranchesToHtml.java
----------------------------------------------------------------------
diff --git a/modules/tools/src/main/java/org/apache/ignite/tools/jirabranches/JiraBranchesToHtml.java
b/modules/tools/src/main/java/org/apache/ignite/tools/jirabranches/JiraBranchesToHtml.java
new file mode 100644
index 0000000..cf2100f
--- /dev/null
+++ b/modules/tools/src/main/java/org/apache/ignite/tools/jirabranches/JiraBranchesToHtml.java
@@ -0,0 +1,289 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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.apache.ignite.tools.jirabranches;
+
+import com.atlassian.jira.rest.client.api.*;
+import com.atlassian.jira.rest.client.api.domain.*;
+import com.atlassian.jira.rest.client.internal.async.*;
+import org.apache.ignite.internal.util.typedef.*;
+import org.apache.ignite.internal.util.typedef.internal.*;
+
+import java.awt.*;
+import java.io.*;
+import java.lang.ProcessBuilder.*;
+import java.net.*;
+import java.text.*;
+import java.util.*;
+import java.util.List;
+import java.util.regex.*;
+
+/**
+ * Generates html page with the JIRA tickets information.
+ */
+public class JiraBranchesToHtml {
+    /** */
+    public static final String SCRIPT_PATH = U.getIgniteHome() + "/scripts/jira-branches.sh";
+
+    /** */
+    private static final URI JIRA_URL = URI.create("http://atlassian.gridgain.com/jira");
+
+    /** */
+    private static final String INPUT_FILE = U.getIgniteHome() + "/scripts/jira-branches.js";
+
+    /** */
+    private static final String OUTPUT_FILE = U.getIgniteHome() + "/scripts/jira-branches-results.html";
+
+    /** */
+    private static final SimpleDateFormat FORMAT = new SimpleDateFormat("MM/dd/yyyy");
+
+    /** */
+    private static final Pattern TICKET_PATTERN = Pattern.compile("\\d{5}|\\d{4}");
+
+    /** */
+    private static final Comparator<Result> COMP = new Comparator<Result>() {
+        @Override public int compare(Result o1, Result o2) {
+            if (o1.issue != null && o2.issue != null) {
+                int res = name(o1.issue.getAssignee()).compareTo(name(o2.issue.getAssignee()));
+
+                return res == 0 ? o1.issueKey.compareTo(o2.issueKey) : res;
+            }
+            else if (o1.issue == null && o2.issue == null)
+                return o1.issueKey.compareTo(o2.issueKey);
+            else
+                return o1.issue == null ? 1 : -1;
+        }
+    };
+
+    /**
+     * @param args Arguments.
+     * @throws Exception If failed.
+     */
+    public static void main(String[] args) throws Exception {
+        System.out.println("Need to enter JIRA credentials.");
+        System.out.print("JIRA user: ");
+
+        BufferedReader rdr = new BufferedReader(new InputStreamReader(System.in));
+
+        String user = rdr.readLine();
+
+        if (F.isEmpty(user))
+            throw new IllegalStateException("JIRA user name cannot be empty.");
+
+        // Mac OS has no Console support (at least in IDE), so have to read password as plain
text.
+        System.out.print("Password: ");
+
+        String pswd = rdr.readLine();
+
+        if (F.isEmpty(pswd))
+            throw new IllegalStateException("JIRA password cannot be empty.");
+
+        System.out.print("Report 'Closed' issues only [y/N]: ");
+
+        boolean closedOnly = "y".equalsIgnoreCase(rdr.readLine());
+
+        System.out.println();
+        System.out.println(">>> Executing script: " + SCRIPT_PATH);
+        System.out.println();
+
+        Process proc = new ProcessBuilder(SCRIPT_PATH)
+            .directory(new File(SCRIPT_PATH).getParentFile())
+            .redirectOutput(Redirect.INHERIT)
+            .redirectError(Redirect.INHERIT)
+            .start();
+
+        proc.waitFor();
+
+        System.out.println();
+        System.out.println(">>> Finished executing script [script=" + SCRIPT_PATH
+
+            ", exitCode=" + proc.exitValue() + ']');
+        System.out.println();
+
+        if (proc.exitValue() != 0)
+            throw new Exception("Failed to run script [script=" + SCRIPT_PATH +
+                ", exitCode=" + proc.exitValue() + ']');
+
+        try (BufferedReader br = new BufferedReader(new InputStreamReader(new FileInputStream(INPUT_FILE)));
+             JiraRestClient restClient = new AsynchronousJiraRestClientFactory().
+                 createWithBasicHttpAuthentication(JIRA_URL, user, pswd)) {
+            List<Result> res = new ArrayList<>();
+
+            for (String line; (line = br.readLine()) != null; ) {
+                String branchName = line.replace("\\", "").trim();
+
+                if (branchName.startsWith("GG")) {
+                    Result r = result(restClient, branchName);
+
+                    if (r.error != null) {
+                        Matcher m = TICKET_PATTERN.matcher(branchName);
+
+                        if (m.find()) {
+                            Result r0 = result(restClient, "GG-" + m.group(0));
+
+                            if (r0.error == null)
+                                r = new Result(branchName, r0.issue, null);
+                        }
+                    }
+
+                    if (r.issue == null || !closedOnly || "Closed".equalsIgnoreCase(r.issue.getStatus().getName()))
{
+                        System.out.println("Added issue: " + r);
+
+                        res.add(r);
+                    }
+                }
+            }
+
+            String s = printIssueDetails(res);
+
+            System.out.println(s);
+
+            try (OutputStreamWriter bw = new OutputStreamWriter(new FileOutputStream(OUTPUT_FILE)))
{
+                bw.write(s);
+            }
+
+            if (Desktop.isDesktopSupported())
+                Desktop.getDesktop().open(new File(OUTPUT_FILE));
+            else
+                System.out.println("Results have been written to: " + OUTPUT_FILE);
+        }
+    }
+
+    /**
+     * @param restClient Rest client.
+     * @param branchName Branch name.
+     * @return Result.
+     */
+    private static Result result(JiraRestClient restClient, String branchName) {
+        try {
+            Issue issue = restClient.getIssueClient().getIssue(branchName).claim();
+
+            return new Result(branchName, issue, null);
+        }
+        catch (RestClientException e) {
+            return new Result(branchName, null, e.getMessage());
+        }
+    }
+
+    /**
+     * @param res Results.
+     * @return Output.
+     */
+    private static String printIssueDetails(List<Result> res) {
+        StringBuilder sb = new StringBuilder();
+
+        println(sb, "<html>\n<head></head>\n<body>");
+        print(sb, "<table>");
+
+        Collections.sort(res, COMP);
+
+        for (Result r : res) {
+            print(sb, "\n<tr>");
+
+            if (r.error != null) {
+                print(sb, "<th colspan=7 align=\"left\">" + r.issueKey + " " + r.error
+ "</th>");
+                print(sb, "</tr>");
+
+                continue;
+            }
+
+            print(sb, "<th colspan=7 align=\"left\"><a href=" + JIRA_URL + "/browse/"
+ r.issue.getKey() + ">" +
+                r.issueKey + ' ' + r.issue.getSummary() + "<a></th>");
+
+            print(sb, "</tr><tr>");
+
+            print(sb, "<td><strong>Assignee:</strong> " + name(r.issue.getAssignee())
+ "</td>");
+            print(sb, "<td><strong>Reporter:</strong> " + name(r.issue.getReporter())
+ "</td>");
+            print(sb, "<td><strong>Status:</strong> " + r.issue.getStatus().getName()
+ "</td>");
+            print(sb, "<td><strong>Resolution:</strong> " +
+                (r.issue.getResolution() == null ? "Unresolved" : r.issue.getResolution().getName())
+ "</td>");
+
+            if (r.issue.getFixVersions() != null) {
+                print(sb, "<td><strong>Version:</strong>");
+
+                for (Version version : r.issue.getFixVersions())
+                    print(sb, " " + version.getName());
+
+                print(sb, "</td>");
+            }
+
+            print(sb, "<td><strong>CreationDate:</strong> " + FORMAT.format(r.issue.getCreationDate().toDate())
+ "</td>");
+            print(sb, "<td><strong>UpdateDate:</strong> " + FORMAT.format(r.issue.getUpdateDate().toDate())
+ "</td>");
+
+            print(sb, "</tr><tr><td>  </td></tr>");
+        }
+
+        print(sb, "\n</table>");
+        print(sb, "\n</body>\n</html>\n");
+
+        return sb.toString();
+    }
+
+    /**
+     * @param sb StringBuilder.
+     * @param s String to print.
+     */
+    private static void print(StringBuilder sb, String s) {
+        sb.append(s);
+    }
+
+    /**
+     * @param sb StringBuilder.
+     * @param s String to print.
+     */
+    private static void println(StringBuilder sb, String s) {
+        sb.append(s).append(System.getProperty("line.separator"));
+    }
+
+    /**
+     * @param user User.
+     * @return Name.
+     */
+    private static String name(BasicUser user) {
+        if (user == null)
+            return "";
+
+        return user.getDisplayName() == null ? (user.getName() == null ? "" : user.getName())
: user.getDisplayName();
+    }
+
+    /** */
+    private static class Result {
+        /** */
+        private final String issueKey;
+
+        /** */
+        private final Issue issue;
+
+        /** */
+        private final String error;
+
+        /** */
+        Result(String issueKey, Issue issue, String error) {
+            this.issueKey = issueKey;
+            this.issue = issue;
+            this.error = error;
+        }
+
+        /** {@inheritDoc} */
+        @Override public String toString() {
+            return "Result [" +
+                "issueKey='" + issueKey + '\'' +
+                ", issue=" + (issue == null ? "" : issue.getKey() + " " + issue.getSummary())
+
+                ", error='" + error + '\'' +
+                ']';
+        }
+    }
+}

http://git-wip-us.apache.org/repos/asf/incubator-ignite/blob/0d01da22/scripts/jira-branches.sh
----------------------------------------------------------------------
diff --git a/scripts/jira-branches.sh b/scripts/jira-branches.sh
new file mode 100755
index 0000000..8fe9047
--- /dev/null
+++ b/scripts/jira-branches.sh
@@ -0,0 +1,18 @@
+git fetch --all
+
+echo Delete stale remote-tracking branches under 'origin' repository. 
+git remote prune origin
+
+FILE=$(cd $(dirname "$0"); pwd)/jira-branches.js
+
+echo Update git branches list file.
+
+echo "var \$branches = \"\\" > $FILE
+
+git branch -a | grep remotes/origin/gg- | sed 's/remotes\/origin\/gg\-\(.*\)$/GG-\1 \\/g'
>> $FILE
+
+echo '";' >> $FILE
+
+echo "var \$branchesDate = '$(date +"%Y-%m-%d")';" >> $FILE
+
+echo Open in browser $(dirname $FILE)/jira-branches.html


Mime
View raw message