From 17f6eaadeb91057cb37309271c0b6e79439f64aa Mon Sep 17 00:00:00 2001 From: Trygve Laugstøl Date: Tue, 11 Dec 2012 18:26:30 +0100 Subject: o Starting to parse out commit info from the Jenkins build too. --- .../esper/testing/jenkins/JenkinsBuildXml.java | 173 +++++++++++++++++++++ .../esper/testing/jenkins/JenkinsClient.java | 149 ++---------------- .../esper/testing/jenkins/JenkinsJobXml.java | 88 +++++++++++ .../esper/testing/jenkins/JenkinsServerActor.java | 10 +- .../esper/testing/jenkins/JenkinsServerOld.java | 2 +- .../esper/testing/jenkins/JenkinsBuildXmlTest.java | 62 ++++++++ .../jenkins/build/build-with-git-commits.xml | 12 ++ .../build/build-with-subversion-commits.xml | 2 + 8 files changed, 359 insertions(+), 139 deletions(-) create mode 100755 src/main/java/io/trygvis/esper/testing/jenkins/JenkinsBuildXml.java create mode 100755 src/main/java/io/trygvis/esper/testing/jenkins/JenkinsJobXml.java mode change 100644 => 100755 src/main/java/io/trygvis/esper/testing/jenkins/JenkinsServerOld.java create mode 100755 src/test/java/io/trygvis/esper/testing/jenkins/JenkinsBuildXmlTest.java create mode 100755 src/test/resources/jenkins/build/build-with-git-commits.xml create mode 100755 src/test/resources/jenkins/build/build-with-subversion-commits.xml (limited to 'src') diff --git a/src/main/java/io/trygvis/esper/testing/jenkins/JenkinsBuildXml.java b/src/main/java/io/trygvis/esper/testing/jenkins/JenkinsBuildXml.java new file mode 100755 index 0000000..e80097b --- /dev/null +++ b/src/main/java/io/trygvis/esper/testing/jenkins/JenkinsBuildXml.java @@ -0,0 +1,173 @@ +package io.trygvis.esper.testing.jenkins; + +import java.net.URI; +import java.util.ArrayList; +import java.util.List; + +import org.jdom2.Element; +import org.joda.time.DateTime; +import org.joda.time.format.DateTimeFormat; +import org.joda.time.format.DateTimeFormatter; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; + +import fj.F; +import fj.data.Option; +import io.trygvis.esper.testing.Util; + +import static fj.data.List.iterableList; +import static fj.data.Option.none; +import static fj.data.Option.some; +import static fj.data.Option.somes; +import static io.trygvis.esper.testing.Util.childText; +import static io.trygvis.esper.testing.jenkins.JenkinsBuildXml.ChangeSetItemXml.parseChangeSetItem; +import static io.trygvis.esper.testing.jenkins.JenkinsBuildXml.RevisionXml.parseRevision; + +public class JenkinsBuildXml { + private static final Logger logger = LoggerFactory.getLogger(JenkinsBuildXml.class); + + public final URI url; + + public final int number; + + public final Option result; + + public final int duration; + + public final long timestamp; + + public final Option changeSet; + + JenkinsBuildXml(URI url, int number, Option result, int duration, long timestamp, Option changeSet) { + this.url = url; + this.number = number; + this.result = result; + this.duration = duration; + this.timestamp = timestamp; + this.changeSet = changeSet; + } + + public static Option parse(Element root) { + Option url = childText(root, "url").bind(Util.parseUri); + Option number = childText(root, "number").bind(Util.parseInt); + Option result = childText(root, "result"); + Option duration = childText(root, "duration").bind(Util.parseInt); + Option timestamp = childText(root, "timestamp").bind(Util.parseLong); + + if (url.isNone()) { + logger.warn("Missing required field: "); + return none(); + } + if (number.isNone()) { + logger.warn("Missing required field: "); + return none(); + } + if (duration.isNone()) { + logger.warn("Missing required field: "); + return none(); + } + if (timestamp.isNone()) { + logger.warn("Missing required field: "); + return none(); + } + + Option changeSet = none(); + Element e = root.getChild("changeSet"); + if (e != null) { + changeSet = ChangeSetXml.parse(e); + } + + return some(new JenkinsBuildXml(url.some(), number.some(), result, duration.some(), timestamp.some(), changeSet)); + } + + public static class ChangeSetXml { + public final List items; + + public final Option revision; + + public ChangeSetXml(List items, Option revision) { + this.items = items; + this.revision = revision; + } + + public static Option parse(Element changeSet) { + + List items = new ArrayList<>(somes(iterableList(changeSet.getChildren("item")).map(parseChangeSetItem)).toCollection()); + + Option revision = Option.fromNull(changeSet.getChild("revision")).bind(parseRevision); + + return some(new ChangeSetXml(items, revision)); + } + } + + public static class ChangeSetItemXml { + public final String commitId; + + public final DateTime date; + + public final String msg; + + /** + * Only subversion has this field + */ + public final Option user; + + public ChangeSetItemXml(String commitId, DateTime date, String msg, Option user) { + this.commitId = commitId; + this.date = date; + this.msg = msg; + this.user = user; + } + + private static final F> parseDate = new F>() { + DateTimeFormatter parser = DateTimeFormat.forPattern("yyyy-MM-dd HH:mm:ss Z"); + + public Option f(String s) { + try { + return some(parser.parseDateTime(s)); + } catch (IllegalArgumentException e) { + return none(); + } + } + }; + + public static final F> parseChangeSetItem = new F>() { + public Option f(Element item) { + Option commitId = childText(item, "commitId"); + Option date = childText(item, "date").bind(parseDate); + Option msg = childText(item, "msg"); + Option user = childText(item, "user"); + + if (commitId.isNone() || date.isNone() || msg.isNone()) { + return none(); + } + + return some(new ChangeSetItemXml(commitId.some(), date.some(), msg.some(), user)); + } + }; + } + + public static class RevisionXml { + public final String module; + + public final String revision; + + public RevisionXml(String module, String revision) { + this.module = module; + this.revision = revision; + } + + public static final F> parseRevision = new F>() { + public Option f(Element e) { + Option module = childText(e, "module"); + Option revision = childText(e, "revision"); + + if (module.isNone() || revision.isNone()) { + return none(); + } + + return some(new RevisionXml(module.some(), revision.some())); + } + }; + } +} diff --git a/src/main/java/io/trygvis/esper/testing/jenkins/JenkinsClient.java b/src/main/java/io/trygvis/esper/testing/jenkins/JenkinsClient.java index 0aa63c1..39dfc66 100755 --- a/src/main/java/io/trygvis/esper/testing/jenkins/JenkinsClient.java +++ b/src/main/java/io/trygvis/esper/testing/jenkins/JenkinsClient.java @@ -2,7 +2,6 @@ package io.trygvis.esper.testing.jenkins; import fj.*; import fj.data.*; -import io.trygvis.esper.testing.*; import io.trygvis.esper.testing.jenkins.JenkinsJobXml.*; import io.trygvis.esper.testing.util.*; import org.apache.abdera.*; @@ -20,7 +19,6 @@ import java.util.*; import java.util.List; import static fj.data.Option.*; -import static io.trygvis.esper.testing.Util.*; import static io.trygvis.esper.testing.util.HttpClient.inputStreamOnly; import static java.lang.System.currentTimeMillis; import static org.apache.commons.lang.StringUtils.*; @@ -80,12 +78,12 @@ public class JenkinsClient { if (d.isNone()) { Option n = Option.none(); - return new JenkinsXml(n, n, n, Collections.emptyList()); + return new JenkinsXml(n, n, n, Collections.emptyList()); } Element root = d.some().getRootElement(); - List jobs = new ArrayList<>(); + List jobs = new ArrayList<>(); for (Element job : root.getChildren("job")) { String name = trimToNull(job.getChildText("name")); String u = trimToNull(job.getChildText("url")); @@ -95,7 +93,7 @@ public class JenkinsClient { continue; } - jobs.add(new JenkinsJobEntryXml(name, u, color)); + jobs.add(new JenkinsXml.JobXml(name, u, color)); } return new JenkinsXml( @@ -155,53 +153,7 @@ public class JenkinsClient { } } - public static class JenkinsBuildXml { - - public final URI url; - public final int number; - public final String result; - public final int duration; - public final long timestamp; - - JenkinsBuildXml(URI url, int number, String result, int duration, long timestamp) { - this.url = url; - this.number = number; - this.result = result; - this.duration = duration; - this.timestamp = timestamp; - } - - public static Option parse(Element root) { - Option url = childText(root, "url").bind(Util.parseUri); - Option number = childText(root, "number").bind(Util.parseInt); - Option result = childText(root, "result"); - Option duration = childText(root, "duration").bind(Util.parseInt); - Option timestamp = childText(root, "timestamp").bind(Util.parseLong); - - if(url.isNone()) { - logger.warn("Missing required field: "); - return none(); - } - if(number.isNone()) { - logger.warn("Missing required field: "); - return none(); - } - if(result.isNone()) { - logger.warn("Missing required field: "); - return none(); - } - if(duration.isNone()) { - logger.warn("Missing required field: "); - return none(); - } - if(timestamp.isNone()) { - logger.warn("Missing required field: "); - return none(); - } - - return some(new JenkinsBuildXml(url.some(), number.some(), result.some(), duration.some(), timestamp.some())); - } - }} +} class JenkinsEntryXml { public final String id; @@ -219,99 +171,24 @@ class JenkinsXml { public final Option nodeName; public final Option nodeDescription; public final Option description; - public final List jobs; + public final List jobs; - JenkinsXml(Option nodeName, Option nodeDescription, Option description, List jobs) { + JenkinsXml(Option nodeName, Option nodeDescription, Option description, List jobs) { this.nodeName = nodeName; this.nodeDescription = nodeDescription; this.description = description; this.jobs = jobs; } -} - -class JenkinsJobEntryXml { - public final String name; - public final String url; - public final String color; - - JenkinsJobEntryXml(String name, String url, String color) { - this.name = name; - this.url = url; - this.color = color; - } -} -class JenkinsJobXml { - enum JenkinsJobType { - FREE_STYLE, MAVEN_MODULE_SET, MAVEN_MODULE, MATRIX - } + public static class JobXml { + public final String name; + public final String url; + public final String color; - public final JenkinsJobType type; - public final Option description; - public final Option displayName; - public final Option name; - public final URI url; - public final Option color; - public final boolean buildable; - public final Option lastBuild; - public final Option lastCompletedBuild; - public final Option lastFailedBuild; - public final Option lastSuccessfulBuild; - public final Option lastUnsuccessfulBuild; - - protected JenkinsJobXml(JenkinsJobType type, Option description, Option displayName, - Option name, URI url, Option color, boolean buildable, - Option lastBuild, Option lastCompletedBuild, - Option lastFailedBuild, Option lastSuccessfulBuild, - Option lastUnsuccessfulBuild) { - this.type = type; - this.description = description; - this.displayName = displayName; - this.name = name; - this.url = url; - this.color = color; - this.buildable = buildable; - this.lastBuild = lastBuild; - this.lastCompletedBuild = lastCompletedBuild; - this.lastFailedBuild = lastFailedBuild; - this.lastSuccessfulBuild = lastSuccessfulBuild; - this.lastUnsuccessfulBuild = lastUnsuccessfulBuild; - } - - static class BuildXml { - public final int number; - public final URI url; - public static F> buildXml = new F>() { - public Option f(Element element) { - Option number = childText(element, "number").bind(Util.parseInt); - Option url = childText(element, "url").bind(Util.parseUri); - - if (number.isNone() || url.isNone()) { - return Option.none(); - } - - return some(new BuildXml(number.some(), url.some())); - } - }; - - BuildXml(int number, URI url) { - this.number = number; + JobXml(String name, String url, String color) { + this.name = name; this.url = url; + this.color = color; } } - - public static JenkinsJobXml parse(URI url, JenkinsJobType type, Element root) { - return new JenkinsJobXml(type, - childText(root, "description"), - childText(root, "displayName"), - childText(root, "name"), - childText(root, "url").bind(Util.parseUri).orSome(url), - childText(root, "color"), - childText(root, "buildable").bind(Util.parseBoolean).orSome(false), - child(root, "lastBuild").bind(BuildXml.buildXml), - child(root, "lastCompletedBuild").bind(BuildXml.buildXml), - child(root, "lastFailedBuild").bind(BuildXml.buildXml), - child(root, "lastSuccessfulBuild").bind(BuildXml.buildXml), - child(root, "lastUnsuccessfulBuild").bind(BuildXml.buildXml)); - } } diff --git a/src/main/java/io/trygvis/esper/testing/jenkins/JenkinsJobXml.java b/src/main/java/io/trygvis/esper/testing/jenkins/JenkinsJobXml.java new file mode 100755 index 0000000..8cbe049 --- /dev/null +++ b/src/main/java/io/trygvis/esper/testing/jenkins/JenkinsJobXml.java @@ -0,0 +1,88 @@ +package io.trygvis.esper.testing.jenkins; + +import java.net.URI; + +import org.jdom2.Element; + +import fj.F; +import fj.data.Option; +import io.trygvis.esper.testing.Util; + +import static fj.data.Option.some; +import static io.trygvis.esper.testing.Util.child; +import static io.trygvis.esper.testing.Util.childText; + +class JenkinsJobXml { + enum JenkinsJobType { + FREE_STYLE, MAVEN_MODULE_SET, MAVEN_MODULE, MATRIX + } + + public final JenkinsJobType type; + public final Option description; + public final Option displayName; + public final Option name; + public final URI url; + public final Option color; + public final boolean buildable; + public final Option lastBuild; + public final Option lastCompletedBuild; + public final Option lastFailedBuild; + public final Option lastSuccessfulBuild; + public final Option lastUnsuccessfulBuild; + + protected JenkinsJobXml(JenkinsJobType type, Option description, Option displayName, + Option name, URI url, Option color, boolean buildable, + Option lastBuild, Option lastCompletedBuild, + Option lastFailedBuild, Option lastSuccessfulBuild, + Option lastUnsuccessfulBuild) { + this.type = type; + this.description = description; + this.displayName = displayName; + this.name = name; + this.url = url; + this.color = color; + this.buildable = buildable; + this.lastBuild = lastBuild; + this.lastCompletedBuild = lastCompletedBuild; + this.lastFailedBuild = lastFailedBuild; + this.lastSuccessfulBuild = lastSuccessfulBuild; + this.lastUnsuccessfulBuild = lastUnsuccessfulBuild; + } + + static class BuildXml { + public final int number; + public final URI url; + public static F> buildXml = new F>() { + public Option f(Element element) { + Option number = childText(element, "number").bind(Util.parseInt); + Option url = childText(element, "url").bind(Util.parseUri); + + if (number.isNone() || url.isNone()) { + return Option.none(); + } + + return some(new BuildXml(number.some(), url.some())); + } + }; + + BuildXml(int number, URI url) { + this.number = number; + this.url = url; + } + } + + public static JenkinsJobXml parse(URI url, JenkinsJobType type, Element root) { + return new JenkinsJobXml(type, + childText(root, "description"), + childText(root, "displayName"), + childText(root, "name"), + childText(root, "url").bind(Util.parseUri).orSome(url), + childText(root, "color"), + childText(root, "buildable").bind(Util.parseBoolean).orSome(false), + child(root, "lastBuild").bind(BuildXml.buildXml), + child(root, "lastCompletedBuild").bind(BuildXml.buildXml), + child(root, "lastFailedBuild").bind(BuildXml.buildXml), + child(root, "lastSuccessfulBuild").bind(BuildXml.buildXml), + child(root, "lastUnsuccessfulBuild").bind(BuildXml.buildXml)); + } +} diff --git a/src/main/java/io/trygvis/esper/testing/jenkins/JenkinsServerActor.java b/src/main/java/io/trygvis/esper/testing/jenkins/JenkinsServerActor.java index 4bbc007..ebc46ce 100755 --- a/src/main/java/io/trygvis/esper/testing/jenkins/JenkinsServerActor.java +++ b/src/main/java/io/trygvis/esper/testing/jenkins/JenkinsServerActor.java @@ -46,7 +46,7 @@ public class JenkinsServerActor implements TransactionalActor { continue; } - logger.info("New build: " + entry.id + ", fetching info"); + logger.debug("Build: " + entry.id + ", fetching info"); Option buildXmlOption = client.fetchBuild(apiXml(entry.url)); @@ -56,6 +56,12 @@ public class JenkinsServerActor implements TransactionalActor { JenkinsBuildXml build = buildXmlOption.some(); + if(build.result.isNone()) { + logger.debug("Not done building, is not available."); + continue; + } + String result = build.result.some(); + URI jobUrl = extrapolateJobUrlFromBuildUrl(build.url.toASCIIString()); Option jobDtoOption = dao.selectJobByUrl(jobUrl); @@ -86,7 +92,7 @@ public class JenkinsServerActor implements TransactionalActor { job, entry.id, build.url, - build.result, + result, build.number, build.duration, build.timestamp); diff --git a/src/main/java/io/trygvis/esper/testing/jenkins/JenkinsServerOld.java b/src/main/java/io/trygvis/esper/testing/jenkins/JenkinsServerOld.java old mode 100644 new mode 100755 index 7e1dc9a..cfd9939 --- a/src/main/java/io/trygvis/esper/testing/jenkins/JenkinsServerOld.java +++ b/src/main/java/io/trygvis/esper/testing/jenkins/JenkinsServerOld.java @@ -86,7 +86,7 @@ public class JenkinsServerOld implements Closeable { JenkinsXml xml = client.fetchJobs(url); List jobUris = new ArrayList<>(xml.jobs.size()); - for (JenkinsJobEntryXml job : xml.jobs) { + for (JenkinsXml.JobXml job : xml.jobs) { jobUris.add(URI.create(job.url)); } diff --git a/src/test/java/io/trygvis/esper/testing/jenkins/JenkinsBuildXmlTest.java b/src/test/java/io/trygvis/esper/testing/jenkins/JenkinsBuildXmlTest.java new file mode 100755 index 0000000..75d7326 --- /dev/null +++ b/src/test/java/io/trygvis/esper/testing/jenkins/JenkinsBuildXmlTest.java @@ -0,0 +1,62 @@ +package io.trygvis.esper.testing.jenkins; + +import java.io.IOException; +import java.io.InputStream; +import java.net.URI; + +import org.jdom2.Document; +import org.joda.time.DateTime; +import org.joda.time.LocalDateTime; +import org.joda.time.chrono.ISOChronology; + +import fj.data.Option; +import io.trygvis.esper.testing.util.XmlParser; +import junit.framework.TestCase; + +import static org.joda.time.DateTimeZone.forOffsetHours; +import static org.joda.time.DateTimeZone.forOffsetHoursMinutes; +import static org.joda.time.chrono.ISOChronology.getInstance; + +public class JenkinsBuildXmlTest extends TestCase { + XmlParser parser = new XmlParser(); + ISOChronology minus6 = getInstance(forOffsetHours(-6)); + ISOChronology minus5 = getInstance(forOffsetHours(-5)); + ISOChronology plus530 = getInstance(forOffsetHoursMinutes(5, 30)); + + public Option f(InputStream inputStream) { + return parser.parseDocument(inputStream); + } + + public void testYo() throws IOException { + try (InputStream is = getClass().getResourceAsStream("/jenkins/build/build-with-git-commits.xml")) { + Option option = JenkinsBuildXml.parse(parser.parseDocument(is).some().getRootElement()); + + assertTrue(option.isSome()); + JenkinsBuildXml build = option.some(); + + assertEquals(URI.create("http://ci.jruby.org/job/jruby-dist-master/1085/"), build.url); + assertEquals(1085, build.number); + assertTrue(build.result.isSome()); + assertEquals(488824, build.duration); + assertTrue(build.changeSet.isSome()); + JenkinsBuildXml.ChangeSetXml changeSet = build.changeSet.some(); + assertTrue(changeSet.revision.isNone()); + assertEquals(8, changeSet.items.size()); + + assertItem(changeSet.items.get(0), "df6d3e8773dff6cc727a6ca4d8eaa8b5f970138d", "Add missing jnr-enxio to NB project.", new DateTime(2012, 12, 5, 10, 40, 58, 0, minus6)); + assertItem(changeSet.items.get(1), "54f6ce8c6e9a2c068c6b1bdfa096dcabb4e0ef1c", "Added description for vertexFor method", new DateTime(2012, 12, 5, 10, 56, 3, 0, plus530)); + assertItem(changeSet.items.get(2), "b6edf4a29157ef5ecd4e050c79f9353200ed0daf", "Added spec for allData method of DirectedGraph.java", new DateTime(2012, 12, 5, 10, 56, 3, 0, plus530)); + assertItem(changeSet.items.get(3), "9deef648a66d8fd4ed1b119419410b28492b87b4", "Added spec for removeEdge(Edge edge) method in DirectedGraph.java", new DateTime(2012, 12, 5, 11, 7, 34, 0, plus530)); + assertItem(changeSet.items.get(4), "9a3eb797ce136349f3866fc2ae9b35be360fb3df", "Added spec for getInorderData method of DirectedGraph.java", new DateTime(2012, 12, 5, 11, 20, 17, 0, plus530)); + assertItem(changeSet.items.get(5), "41b5de23dd2d7ccbc170252a43b8996316b93075", "No need to look up TZ here. In all cases leading up to here,", new DateTime(2012, 12, 6, 0, 5, 37, 0, minus5)); + assertItem(changeSet.items.get(6), "def4c054ae82848c92b015a3267ace2c2cedd193", "Identify the correct JIRA ticket.", new DateTime(2012, 12, 6, 0, 8, 8, 0, minus5)); + assertItem(changeSet.items.get(7), "82f12220d01c2c07398107fa5f5a2d50feb7c8c4", "As ugly as it might be, maintaining a map of exceptional time zone", new DateTime(2012, 12, 6, 0, 17, 26, 0, minus5)); + } + } + + private void assertItem(JenkinsBuildXml.ChangeSetItemXml item, String commitId, String msg, DateTime date) { + assertEquals(commitId, item.commitId); + assertEquals(msg, item.msg); + assertEquals(date.toDateTime(item.date.getZone()), item.date); + } +} diff --git a/src/test/resources/jenkins/build/build-with-git-commits.xml b/src/test/resources/jenkins/build/build-with-git-commits.xml new file mode 100755 index 0000000..e04113d --- /dev/null +++ b/src/test/resources/jenkins/build/build-with-git-commits.xml @@ -0,0 +1,12 @@ + +Started by timer108582f12220d01c2c07398107fa5f5a2d50feb7c8c482f12220d01c2c07398107fa5f5a2d50feb7c8c4origin/master82f12220d01c2c07398107fa5f5a2d50feb7c8c482f12220d01c2c07398107fa5f5a2d50feb7c8c4origin/mastergit://jruby.org/jruby.gitfalse488824522747jruby-dist-master #10852012-12-06_03-01-02false1085SUCCESS1354791662000http://ci.jruby.org/job/jruby-dist-master/1085/nbproject/nbjdk.propertiesnbproject/project.xmldf6d3e8773dff6cc727a6ca4d8eaa8b5f970138d1354732858000http://ci.jruby.org/user/Charles%20Oliver%20NutterCharles Oliver NutterAdd missing jnr-enxio to NB project. +2012-12-05 10:40:58 -0600df6d3e8773dff6cc727a6ca4d8eaa8b5f970138dAdd missing jnr-enxio to NB project.editnbproject/nbjdk.propertieseditnbproject/project.xmlsrc/org/jruby/ir/util/DirectedGraph.java54f6ce8c6e9a2c068c6b1bdfa096dcabb4e0ef1c1354733763000http://ci.jruby.org/user/csonpatkicsonpatkiAdded description for vertexFor method +2012-12-05 10:56:03 +053054f6ce8c6e9a2c068c6b1bdfa096dcabb4e0ef1cAdded description for vertexFor methodeditsrc/org/jruby/ir/util/DirectedGraph.javaspec/ir/directed_graph/directed_graph_spec.rbb6edf4a29157ef5ecd4e050c79f9353200ed0daf1354733763000http://ci.jruby.org/user/csonpatkicsonpatkiAdded spec for allData method of DirectedGraph.java +2012-12-05 10:56:03 +0530b6edf4a29157ef5ecd4e050c79f9353200ed0dafAdded spec for allData method of DirectedGraph.javaeditspec/ir/directed_graph/directed_graph_spec.rbspec/ir/directed_graph/directed_graph_spec.rb9deef648a66d8fd4ed1b119419410b28492b87b41354734454000http://ci.jruby.org/user/csonpatkicsonpatkiAdded spec for removeEdge(Edge edge) method in DirectedGraph.java +2012-12-05 11:07:34 +05309deef648a66d8fd4ed1b119419410b28492b87b4Added spec for removeEdge(Edge edge) method in DirectedGraph.javaeditspec/ir/directed_graph/directed_graph_spec.rbspec/ir/directed_graph/directed_graph_spec.rb9a3eb797ce136349f3866fc2ae9b35be360fb3df1354735217000http://ci.jruby.org/user/csonpatkicsonpatkiAdded spec for getInorderData method of DirectedGraph.java +2012-12-05 11:20:17 +05309a3eb797ce136349f3866fc2ae9b35be360fb3dfAdded spec for getInorderData method of DirectedGraph.javaeditspec/ir/directed_graph/directed_graph_spec.rbsrc/org/jruby/RubyTime.java41b5de23dd2d7ccbc170252a43b8996316b930751354781137000http://ci.jruby.org/user/hasariHiro AsariNo need to look up TZ here. In all cases leading up to here, +we should rely on the String value passed to set up the Time object. +2012-12-06 00:05:37 -050041b5de23dd2d7ccbc170252a43b8996316b93075No need to look up TZ here. In all cases leading up to here,editsrc/org/jruby/RubyTime.javasrc/org/jruby/RubyTime.javadef4c054ae82848c92b015a3267ace2c2cedd1931354781288000http://ci.jruby.org/user/hasariHiro AsariIdentify the correct JIRA ticket. +2012-12-06 00:08:08 -0500def4c054ae82848c92b015a3267ace2c2cedd193Identify the correct JIRA ticket.editsrc/org/jruby/RubyTime.javasrc/org/jruby/RubyTime.java82f12220d01c2c07398107fa5f5a2d50feb7c8c41354781846000http://ci.jruby.org/user/hasariHiro AsariAs ugly as it might be, maintaining a map of exceptional time zone +values may be the best way to address #215. +2012-12-06 00:17:26 -050082f12220d01c2c07398107fa5f5a2d50feb7c8c4As ugly as it might be, maintaining a map of exceptional time zoneeditsrc/org/jruby/RubyTime.javahttp://ci.jruby.org/user/Charles%20Oliver%20NutterCharles Oliver Nutterhttp://ci.jruby.org/user/csonpatkicsonpatkihttp://ci.jruby.org/user/hasariHiro Asari diff --git a/src/test/resources/jenkins/build/build-with-subversion-commits.xml b/src/test/resources/jenkins/build/build-with-subversion-commits.xml new file mode 100755 index 0000000..92fbbab --- /dev/null +++ b/src/test/resources/jenkins/build/build-with-subversion-commits.xml @@ -0,0 +1,2 @@ + +Started by timer0394583testReportREADME.txtREADME.txtREADME.txtfalse16465261466031Lucene-Solr-Tests-4.x-Java6 #11022012-12-11_03-17-24false1102SUCCESS1355195844624https://builds.apache.org/job/Lucene-Solr-Tests-4.x-Java6/1102/lucenedev-toolslucenelucene/BUILD.txtlucene/CHANGES.txtlucene/JRE_VERSION_MIGRATION.txtlucene/LICENSE.txtlucene/MIGRATE.txtlucene/NOTICE.txtlucene/README.txtlucene/SYSTEM_REQUIREMENTS.txtlucene/analysislucene/analysis/icu/src/java/org/apache/lucene/collation/ICUCollationKeyFilterFactory.javalucene/backwardslucene/benchmarklucene/build.xmllucene/codecslucene/common-build.xmllucene/corelucene/core/src/test/org/apache/lucene/index/TestBackwardsCompatibility.javalucene/core/src/test/org/apache/lucene/index/index.40.cfs.ziplucene/core/src/test/org/apache/lucene/index/index.40.nocfs.ziplucene/core/src/test/org/apache/lucene/index/index.40.optimized.cfs.ziplucene/core/src/test/org/apache/lucene/index/index.40.optimized.nocfs.ziplucene/demolucene/facetlucene/groupinglucene/highlighterlucene/ivy-settings.xmllucene/joinlucene/licenseslucene/memorylucene/misclucene/module-build.xmllucene/querieslucene/queryparserlucene/sandboxlucene/sitelucene/spatiallucene/suggestlucene/test-frameworklucene/toolssolrsolr/CHANGES.txtsolr/LICENSE.txtsolr/NOTICE.txtsolr/README.txtsolr/SYSTEM_REQUIREMENTS.txtsolr/build.xmlsolr/cloud-devsolr/common-build.xmlsolr/contribsolr/coresolr/core/src/java/org/apache/solr/schema/IndexSchema.javasolr/examplesolr/licensessolr/licenses/httpclient-LICENSE-ASL.txtsolr/licenses/httpclient-NOTICE.txtsolr/licenses/httpcore-LICENSE-ASL.txtsolr/licenses/httpcore-NOTICE.txtsolr/licenses/httpmime-LICENSE-ASL.txtsolr/licenses/httpmime-NOTICE.txtsolr/scriptssolr/sitesolr/solrjsolr/test-frameworksolr/testlogging.propertiessolr/webapphttps://builds.apache.org/user/markrmillermarkrmiller1419960-12012-12-11T01:08:10.682365ZSOLR-2986: Add MoreLikeThis to warning about features that require uniqueKey. Also, change the warning to warn log level.edit/lucene/dev/branches/branch_4xedit/lucene/dev/branches/branch_4x/dev-toolsedit/lucene/dev/branches/branch_4x/luceneedit/lucene/dev/branches/branch_4x/lucene/BUILD.txtedit/lucene/dev/branches/branch_4x/lucene/CHANGES.txtedit/lucene/dev/branches/branch_4x/lucene/JRE_VERSION_MIGRATION.txtedit/lucene/dev/branches/branch_4x/lucene/LICENSE.txtedit/lucene/dev/branches/branch_4x/lucene/MIGRATE.txtedit/lucene/dev/branches/branch_4x/lucene/NOTICE.txtedit/lucene/dev/branches/branch_4x/lucene/README.txtedit/lucene/dev/branches/branch_4x/lucene/SYSTEM_REQUIREMENTS.txtedit/lucene/dev/branches/branch_4x/lucene/analysisedit/lucene/dev/branches/branch_4x/lucene/analysis/icu/src/java/org/apache/lucene/collation/ICUCollationKeyFilterFactory.javaedit/lucene/dev/branches/branch_4x/lucene/backwardsedit/lucene/dev/branches/branch_4x/lucene/benchmarkedit/lucene/dev/branches/branch_4x/lucene/build.xmledit/lucene/dev/branches/branch_4x/lucene/codecsedit/lucene/dev/branches/branch_4x/lucene/common-build.xmledit/lucene/dev/branches/branch_4x/lucene/coreedit/lucene/dev/branches/branch_4x/lucene/core/src/test/org/apache/lucene/index/TestBackwardsCompatibility.javaedit/lucene/dev/branches/branch_4x/lucene/core/src/test/org/apache/lucene/index/index.40.cfs.zipedit/lucene/dev/branches/branch_4x/lucene/core/src/test/org/apache/lucene/index/index.40.nocfs.zipedit/lucene/dev/branches/branch_4x/lucene/core/src/test/org/apache/lucene/index/index.40.optimized.cfs.zipedit/lucene/dev/branches/branch_4x/lucene/core/src/test/org/apache/lucene/index/index.40.optimized.nocfs.zipedit/lucene/dev/branches/branch_4x/lucene/demoedit/lucene/dev/branches/branch_4x/lucene/facetedit/lucene/dev/branches/branch_4x/lucene/groupingedit/lucene/dev/branches/branch_4x/lucene/highlighteredit/lucene/dev/branches/branch_4x/lucene/ivy-settings.xmledit/lucene/dev/branches/branch_4x/lucene/joinedit/lucene/dev/branches/branch_4x/lucene/licensesedit/lucene/dev/branches/branch_4x/lucene/memoryedit/lucene/dev/branches/branch_4x/lucene/miscedit/lucene/dev/branches/branch_4x/lucene/module-build.xmledit/lucene/dev/branches/branch_4x/lucene/queriesedit/lucene/dev/branches/branch_4x/lucene/queryparseredit/lucene/dev/branches/branch_4x/lucene/sandboxedit/lucene/dev/branches/branch_4x/lucene/siteedit/lucene/dev/branches/branch_4x/lucene/spatialedit/lucene/dev/branches/branch_4x/lucene/suggestedit/lucene/dev/branches/branch_4x/lucene/test-frameworkedit/lucene/dev/branches/branch_4x/lucene/toolsedit/lucene/dev/branches/branch_4x/solredit/lucene/dev/branches/branch_4x/solr/CHANGES.txtedit/lucene/dev/branches/branch_4x/solr/LICENSE.txtedit/lucene/dev/branches/branch_4x/solr/NOTICE.txtedit/lucene/dev/branches/branch_4x/solr/README.txtedit/lucene/dev/branches/branch_4x/solr/SYSTEM_REQUIREMENTS.txtedit/lucene/dev/branches/branch_4x/solr/build.xmledit/lucene/dev/branches/branch_4x/solr/cloud-devedit/lucene/dev/branches/branch_4x/solr/common-build.xmledit/lucene/dev/branches/branch_4x/solr/contribedit/lucene/dev/branches/branch_4x/solr/coreedit/lucene/dev/branches/branch_4x/solr/core/src/java/org/apache/solr/schema/IndexSchema.javaedit/lucene/dev/branches/branch_4x/solr/exampleedit/lucene/dev/branches/branch_4x/solr/licensesedit/lucene/dev/branches/branch_4x/solr/licenses/httpclient-LICENSE-ASL.txtedit/lucene/dev/branches/branch_4x/solr/licenses/httpclient-NOTICE.txtedit/lucene/dev/branches/branch_4x/solr/licenses/httpcore-LICENSE-ASL.txtedit/lucene/dev/branches/branch_4x/solr/licenses/httpcore-NOTICE.txtedit/lucene/dev/branches/branch_4x/solr/licenses/httpmime-LICENSE-ASL.txtedit/lucene/dev/branches/branch_4x/solr/licenses/httpmime-NOTICE.txtedit/lucene/dev/branches/branch_4x/solr/scriptsedit/lucene/dev/branches/branch_4x/solr/siteedit/lucene/dev/branches/branch_4x/solr/solrjedit/lucene/dev/branches/branch_4x/solr/test-frameworkedit/lucene/dev/branches/branch_4x/solr/testlogging.propertiesedit/lucene/dev/branches/branch_4x/solr/webapp1419960markrmillerdev-toolslucenelucene/BUILD.txtlucene/CHANGES.txtlucene/JRE_VERSION_MIGRATION.txtlucene/LICENSE.txtlucene/MIGRATE.txtlucene/NOTICE.txtlucene/README.txtlucene/SYSTEM_REQUIREMENTS.txtlucene/analysislucene/analysis/icu/src/java/org/apache/lucene/collation/ICUCollationKeyFilterFactory.javalucene/backwardslucene/benchmarklucene/build.xmllucene/codecslucene/common-build.xmllucene/corelucene/core/src/test/org/apache/lucene/index/TestBackwardsCompatibility.javalucene/core/src/test/org/apache/lucene/index/index.40.cfs.ziplucene/core/src/test/org/apache/lucene/index/index.40.nocfs.ziplucene/core/src/test/org/apache/lucene/index/index.40.optimized.cfs.ziplucene/core/src/test/org/apache/lucene/index/index.40.optimized.nocfs.ziplucene/demolucene/facetlucene/groupinglucene/highlighterlucene/ivy-settings.xmllucene/joinlucene/licenseslucene/memorylucene/misclucene/module-build.xmllucene/querieslucene/queryparserlucene/sandboxlucene/sitelucene/spatiallucene/suggestlucene/test-frameworklucene/toolssolrsolr/CHANGES.txtsolr/LICENSE.txtsolr/NOTICE.txtsolr/README.txtsolr/SYSTEM_REQUIREMENTS.txtsolr/build.xmlsolr/cloud-devsolr/common-build.xmlsolr/contribsolr/coresolr/core/src/java/org/apache/solr/handler/admin/CollectionsHandler.javasolr/examplesolr/licensessolr/licenses/httpclient-LICENSE-ASL.txtsolr/licenses/httpclient-NOTICE.txtsolr/licenses/httpcore-LICENSE-ASL.txtsolr/licenses/httpcore-NOTICE.txtsolr/licenses/httpmime-LICENSE-ASL.txtsolr/licenses/httpmime-NOTICE.txtsolr/scriptssolr/sitesolr/solrjsolr/test-frameworksolr/testlogging.propertiessolr/webapphttps://builds.apache.org/user/markrmillermarkrmiller1419953-12012-12-11T00:56:19.684855ZSOLR-4071: Validate that name is pass to Collections API create, and behave the same way as on startup when collection.configName is not explicitly passed.edit/lucene/dev/branches/branch_4xedit/lucene/dev/branches/branch_4x/dev-toolsedit/lucene/dev/branches/branch_4x/luceneedit/lucene/dev/branches/branch_4x/lucene/BUILD.txtedit/lucene/dev/branches/branch_4x/lucene/CHANGES.txtedit/lucene/dev/branches/branch_4x/lucene/JRE_VERSION_MIGRATION.txtedit/lucene/dev/branches/branch_4x/lucene/LICENSE.txtedit/lucene/dev/branches/branch_4x/lucene/MIGRATE.txtedit/lucene/dev/branches/branch_4x/lucene/NOTICE.txtedit/lucene/dev/branches/branch_4x/lucene/README.txtedit/lucene/dev/branches/branch_4x/lucene/SYSTEM_REQUIREMENTS.txtedit/lucene/dev/branches/branch_4x/lucene/analysisedit/lucene/dev/branches/branch_4x/lucene/analysis/icu/src/java/org/apache/lucene/collation/ICUCollationKeyFilterFactory.javaedit/lucene/dev/branches/branch_4x/lucene/backwardsedit/lucene/dev/branches/branch_4x/lucene/benchmarkedit/lucene/dev/branches/branch_4x/lucene/build.xmledit/lucene/dev/branches/branch_4x/lucene/codecsedit/lucene/dev/branches/branch_4x/lucene/common-build.xmledit/lucene/dev/branches/branch_4x/lucene/coreedit/lucene/dev/branches/branch_4x/lucene/core/src/test/org/apache/lucene/index/TestBackwardsCompatibility.javaedit/lucene/dev/branches/branch_4x/lucene/core/src/test/org/apache/lucene/index/index.40.cfs.zipedit/lucene/dev/branches/branch_4x/lucene/core/src/test/org/apache/lucene/index/index.40.nocfs.zipedit/lucene/dev/branches/branch_4x/lucene/core/src/test/org/apache/lucene/index/index.40.optimized.cfs.zipedit/lucene/dev/branches/branch_4x/lucene/core/src/test/org/apache/lucene/index/index.40.optimized.nocfs.zipedit/lucene/dev/branches/branch_4x/lucene/demoedit/lucene/dev/branches/branch_4x/lucene/facetedit/lucene/dev/branches/branch_4x/lucene/groupingedit/lucene/dev/branches/branch_4x/lucene/highlighteredit/lucene/dev/branches/branch_4x/lucene/ivy-settings.xmledit/lucene/dev/branches/branch_4x/lucene/joinedit/lucene/dev/branches/branch_4x/lucene/licensesedit/lucene/dev/branches/branch_4x/lucene/memoryedit/lucene/dev/branches/branch_4x/lucene/miscedit/lucene/dev/branches/branch_4x/lucene/module-build.xmledit/lucene/dev/branches/branch_4x/lucene/queriesedit/lucene/dev/branches/branch_4x/lucene/queryparseredit/lucene/dev/branches/branch_4x/lucene/sandboxedit/lucene/dev/branches/branch_4x/lucene/siteedit/lucene/dev/branches/branch_4x/lucene/spatialedit/lucene/dev/branches/branch_4x/lucene/suggestedit/lucene/dev/branches/branch_4x/lucene/test-frameworkedit/lucene/dev/branches/branch_4x/lucene/toolsedit/lucene/dev/branches/branch_4x/solredit/lucene/dev/branches/branch_4x/solr/CHANGES.txtedit/lucene/dev/branches/branch_4x/solr/LICENSE.txtedit/lucene/dev/branches/branch_4x/solr/NOTICE.txtedit/lucene/dev/branches/branch_4x/solr/README.txtedit/lucene/dev/branches/branch_4x/solr/SYSTEM_REQUIREMENTS.txtedit/lucene/dev/branches/branch_4x/solr/build.xmledit/lucene/dev/branches/branch_4x/solr/cloud-devedit/lucene/dev/branches/branch_4x/solr/common-build.xmledit/lucene/dev/branches/branch_4x/solr/contribedit/lucene/dev/branches/branch_4x/solr/coreedit/lucene/dev/branches/branch_4x/solr/core/src/java/org/apache/solr/handler/admin/CollectionsHandler.javaedit/lucene/dev/branches/branch_4x/solr/exampleedit/lucene/dev/branches/branch_4x/solr/licensesedit/lucene/dev/branches/branch_4x/solr/licenses/httpclient-LICENSE-ASL.txtedit/lucene/dev/branches/branch_4x/solr/licenses/httpclient-NOTICE.txtedit/lucene/dev/branches/branch_4x/solr/licenses/httpcore-LICENSE-ASL.txtedit/lucene/dev/branches/branch_4x/solr/licenses/httpcore-NOTICE.txtedit/lucene/dev/branches/branch_4x/solr/licenses/httpmime-LICENSE-ASL.txtedit/lucene/dev/branches/branch_4x/solr/licenses/httpmime-NOTICE.txtedit/lucene/dev/branches/branch_4x/solr/scriptsedit/lucene/dev/branches/branch_4x/solr/siteedit/lucene/dev/branches/branch_4x/solr/solrjedit/lucene/dev/branches/branch_4x/solr/test-frameworkedit/lucene/dev/branches/branch_4x/solr/testlogging.propertiesedit/lucene/dev/branches/branch_4x/solr/webapp1419953markrmillerdev-toolslucenelucene/BUILD.txtlucene/CHANGES.txtlucene/JRE_VERSION_MIGRATION.txtlucene/LICENSE.txtlucene/MIGRATE.txtlucene/NOTICE.txtlucene/README.txtlucene/SYSTEM_REQUIREMENTS.txtlucene/analysislucene/analysis/icu/src/java/org/apache/lucene/collation/ICUCollationKeyFilterFactory.javalucene/backwardslucene/benchmarklucene/build.xmllucene/codecslucene/common-build.xmllucene/corelucene/core/src/test/org/apache/lucene/index/TestBackwardsCompatibility.javalucene/core/src/test/org/apache/lucene/index/index.40.cfs.ziplucene/core/src/test/org/apache/lucene/index/index.40.nocfs.ziplucene/core/src/test/org/apache/lucene/index/index.40.optimized.cfs.ziplucene/core/src/test/org/apache/lucene/index/index.40.optimized.nocfs.ziplucene/demolucene/facetlucene/groupinglucene/highlighterlucene/ivy-settings.xmllucene/joinlucene/licenseslucene/memorylucene/misclucene/module-build.xmllucene/querieslucene/queryparserlucene/sandboxlucene/sitelucene/spatiallucene/suggestlucene/test-frameworklucene/toolssolrsolr/CHANGES.txtsolr/LICENSE.txtsolr/NOTICE.txtsolr/README.txtsolr/SYSTEM_REQUIREMENTS.txtsolr/build.xmlsolr/cloud-devsolr/common-build.xmlsolr/contribsolr/coresolr/core/src/java/org/apache/solr/handler/admin/LukeRequestHandler.javasolr/core/src/java/org/apache/solr/search/SolrIndexSearcher.javasolr/examplesolr/licensessolr/licenses/httpclient-LICENSE-ASL.txtsolr/licenses/httpclient-NOTICE.txtsolr/licenses/httpcore-LICENSE-ASL.txtsolr/licenses/httpcore-NOTICE.txtsolr/licenses/httpmime-LICENSE-ASL.txtsolr/licenses/httpmime-NOTICE.txtsolr/scriptssolr/sitesolr/solrjsolr/test-frameworksolr/testlogging.propertiessolr/webappsolr/webapp/web/js/scripts/cores.jssolr/webapp/web/js/scripts/dashboard.jssolr/webapp/web/tpl/cores.htmlsolr/webapp/web/tpl/dashboard.htmlhttps://builds.apache.org/user/markrmillermarkrmiller1419940-12012-12-11T00:10:12.700549ZSOLR-3948: Calculate/display deleted documents in admin interface.edit/lucene/dev/branches/branch_4xedit/lucene/dev/branches/branch_4x/dev-toolsedit/lucene/dev/branches/branch_4x/luceneedit/lucene/dev/branches/branch_4x/lucene/BUILD.txtedit/lucene/dev/branches/branch_4x/lucene/CHANGES.txtedit/lucene/dev/branches/branch_4x/lucene/JRE_VERSION_MIGRATION.txtedit/lucene/dev/branches/branch_4x/lucene/LICENSE.txtedit/lucene/dev/branches/branch_4x/lucene/MIGRATE.txtedit/lucene/dev/branches/branch_4x/lucene/NOTICE.txtedit/lucene/dev/branches/branch_4x/lucene/README.txtedit/lucene/dev/branches/branch_4x/lucene/SYSTEM_REQUIREMENTS.txtedit/lucene/dev/branches/branch_4x/lucene/analysisedit/lucene/dev/branches/branch_4x/lucene/analysis/icu/src/java/org/apache/lucene/collation/ICUCollationKeyFilterFactory.javaedit/lucene/dev/branches/branch_4x/lucene/backwardsedit/lucene/dev/branches/branch_4x/lucene/benchmarkedit/lucene/dev/branches/branch_4x/lucene/build.xmledit/lucene/dev/branches/branch_4x/lucene/codecsedit/lucene/dev/branches/branch_4x/lucene/common-build.xmledit/lucene/dev/branches/branch_4x/lucene/coreedit/lucene/dev/branches/branch_4x/lucene/core/src/test/org/apache/lucene/index/TestBackwardsCompatibility.javaedit/lucene/dev/branches/branch_4x/lucene/core/src/test/org/apache/lucene/index/index.40.cfs.zipedit/lucene/dev/branches/branch_4x/lucene/core/src/test/org/apache/lucene/index/index.40.nocfs.zipedit/lucene/dev/branches/branch_4x/lucene/core/src/test/org/apache/lucene/index/index.40.optimized.cfs.zipedit/lucene/dev/branches/branch_4x/lucene/core/src/test/org/apache/lucene/index/index.40.optimized.nocfs.zipedit/lucene/dev/branches/branch_4x/lucene/demoedit/lucene/dev/branches/branch_4x/lucene/facetedit/lucene/dev/branches/branch_4x/lucene/groupingedit/lucene/dev/branches/branch_4x/lucene/highlighteredit/lucene/dev/branches/branch_4x/lucene/ivy-settings.xmledit/lucene/dev/branches/branch_4x/lucene/joinedit/lucene/dev/branches/branch_4x/lucene/licensesedit/lucene/dev/branches/branch_4x/lucene/memoryedit/lucene/dev/branches/branch_4x/lucene/miscedit/lucene/dev/branches/branch_4x/lucene/module-build.xmledit/lucene/dev/branches/branch_4x/lucene/queriesedit/lucene/dev/branches/branch_4x/lucene/queryparseredit/lucene/dev/branches/branch_4x/lucene/sandboxedit/lucene/dev/branches/branch_4x/lucene/siteedit/lucene/dev/branches/branch_4x/lucene/spatialedit/lucene/dev/branches/branch_4x/lucene/suggestedit/lucene/dev/branches/branch_4x/lucene/test-frameworkedit/lucene/dev/branches/branch_4x/lucene/toolsedit/lucene/dev/branches/branch_4x/solredit/lucene/dev/branches/branch_4x/solr/CHANGES.txtedit/lucene/dev/branches/branch_4x/solr/LICENSE.txtedit/lucene/dev/branches/branch_4x/solr/NOTICE.txtedit/lucene/dev/branches/branch_4x/solr/README.txtedit/lucene/dev/branches/branch_4x/solr/SYSTEM_REQUIREMENTS.txtedit/lucene/dev/branches/branch_4x/solr/build.xmledit/lucene/dev/branches/branch_4x/solr/cloud-devedit/lucene/dev/branches/branch_4x/solr/common-build.xmledit/lucene/dev/branches/branch_4x/solr/contribedit/lucene/dev/branches/branch_4x/solr/coreedit/lucene/dev/branches/branch_4x/solr/core/src/java/org/apache/solr/handler/admin/LukeRequestHandler.javaedit/lucene/dev/branches/branch_4x/solr/core/src/java/org/apache/solr/search/SolrIndexSearcher.javaedit/lucene/dev/branches/branch_4x/solr/exampleedit/lucene/dev/branches/branch_4x/solr/licensesedit/lucene/dev/branches/branch_4x/solr/licenses/httpclient-LICENSE-ASL.txtedit/lucene/dev/branches/branch_4x/solr/licenses/httpclient-NOTICE.txtedit/lucene/dev/branches/branch_4x/solr/licenses/httpcore-LICENSE-ASL.txtedit/lucene/dev/branches/branch_4x/solr/licenses/httpcore-NOTICE.txtedit/lucene/dev/branches/branch_4x/solr/licenses/httpmime-LICENSE-ASL.txtedit/lucene/dev/branches/branch_4x/solr/licenses/httpmime-NOTICE.txtedit/lucene/dev/branches/branch_4x/solr/scriptsedit/lucene/dev/branches/branch_4x/solr/siteedit/lucene/dev/branches/branch_4x/solr/solrjedit/lucene/dev/branches/branch_4x/solr/test-frameworkedit/lucene/dev/branches/branch_4x/solr/testlogging.propertiesedit/lucene/dev/branches/branch_4x/solr/webappedit/lucene/dev/branches/branch_4x/solr/webapp/web/js/scripts/cores.jsedit/lucene/dev/branches/branch_4x/solr/webapp/web/js/scripts/dashboard.jsedit/lucene/dev/branches/branch_4x/solr/webapp/web/tpl/cores.htmledit/lucene/dev/branches/branch_4x/solr/webapp/web/tpl/dashboard.html1419940markrmillersvnhttp://svn.apache.org/repos/asf/lucene/dev/branches/branch_4x1419960https://builds.apache.org/user/markrmillermarkrmiller -- cgit v1.2.3