[Git][java-team/annotation-indexer][upstream] New upstream version 1.17
Emmanuel Bourg (@ebourg)
gitlab at salsa.debian.org
Mon Dec 5 13:07:08 GMT 2022
Emmanuel Bourg pushed to branch upstream at Debian Java Maintainers / annotation-indexer
Commits:
3cbd7164 by Emmanuel Bourg at 2022-12-05T13:52:44+01:00
New upstream version 1.17
- - - - -
7 changed files:
- .github/workflows/release-drafter.yml
- .mvn/extensions.xml
- Jenkinsfile
- pom.xml
- src/main/java/org/jvnet/hudson/annotation_indexer/Index.java
- src/test/java/org/jvnet/hudson/annotation_indexer/AnnotationProcessorImplTest.java
- src/test/java/org/jvnet/hudson/annotation_indexer/Utils.java
Changes:
=====================================
.github/workflows/release-drafter.yml
=====================================
@@ -11,6 +11,6 @@ jobs:
runs-on: ubuntu-latest
steps:
# Drafts your next Release notes as Pull Requests are merged into "master"
- - uses: release-drafter/release-drafter at v5.15.0
+ - uses: release-drafter/release-drafter at v5
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
=====================================
.mvn/extensions.xml
=====================================
@@ -2,6 +2,6 @@
<extension>
<groupId>io.jenkins.tools.incrementals</groupId>
<artifactId>git-changelist-maven-extension</artifactId>
- <version>1.2</version>
+ <version>1.4</version>
</extension>
</extensions>
=====================================
Jenkinsfile
=====================================
@@ -4,7 +4,7 @@
* allowing one to test against multiple Jenkins versions.
*/
buildPlugin(useContainerAgent: true, configurations: [
- [ platform: 'linux', jdk: '8' ],
[ platform: 'linux', jdk: '11' ],
- [ platform: 'windows', jdk: '11' ]
+ [ platform: 'windows', jdk: '11' ],
+ [ platform: 'linux', jdk: '17' ],
])
=====================================
pom.xml
=====================================
@@ -4,22 +4,33 @@
<parent>
<groupId>org.jenkins-ci</groupId>
<artifactId>jenkins</artifactId>
- <version>1.69</version>
+ <version>1.92</version>
<relativePath />
</parent>
<artifactId>annotation-indexer</artifactId>
+ <version>1.17</version>
<name>Annotation Indexer</name>
- <version>1.16</version>
- <description>
- Creates index of annotations.
- </description>
+ <description>Creates index of annotations.</description>
<url>https://github.com/jenkinsci/lib-${project.artifactId}</url>
+ <licenses>
+ <license>
+ <name>MIT License</name>
+ <url>https://opensource.org/licenses/MIT</url>
+ </license>
+ </licenses>
+
+ <scm>
+ <connection>scm:git:https://github.com/${gitHubRepo}.git</connection>
+ <developerConnection>scm:git:git at github.com:${gitHubRepo}.git</developerConnection>
+ <tag>annotation-indexer-1.17</tag>
+ <url>https://github.com/${gitHubRepo}</url>
+ </scm>
+
<properties>
- <revision>1.16</revision>
+ <revision>1.17</revision>
<changelist>-SNAPSHOT</changelist>
- <java.level>8</java.level>
<gitHubRepo>jenkinsci/lib-${project.artifactId}</gitHubRepo>
</properties>
@@ -27,41 +38,42 @@
<dependency>
<groupId>org.kohsuke.metainf-services</groupId>
<artifactId>metainf-services</artifactId>
- <version>1.8</version>
+ <version>1.9</version>
<optional>true</optional>
</dependency>
<dependency>
- <groupId>junit</groupId>
- <artifactId>junit</artifactId>
+ <groupId>com.karuslabs</groupId>
+ <artifactId>elementary</artifactId>
+ <version>1.1.3</version>
+ <scope>test</scope>
+ <exclusions>
+ <exclusion>
+ <groupId>com.karuslabs</groupId>
+ <artifactId>annotations</artifactId>
+ </exclusion>
+ </exclusions>
+ </dependency>
+ <dependency>
+ <groupId>org.junit.jupiter</groupId>
+ <artifactId>junit-jupiter</artifactId>
<scope>test</scope>
</dependency>
<dependency>
- <groupId>com.jolira</groupId>
- <artifactId>hickory</artifactId>
- <version>1.0.0</version>
+ <groupId>org.junit.vintage</groupId>
+ <artifactId>junit-vintage-engine</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
- <scm>
- <connection>scm:git:git://github.com/${gitHubRepo}.git</connection>
- <developerConnection>scm:git:git at github.com:${gitHubRepo}.git</developerConnection>
- <url>https://github.com/${gitHubRepo}</url>
- <tag>annotation-indexer-1.16</tag>
- </scm>
-
- <licenses>
- <license>
- <name>MIT License</name>
- <url>https://opensource.org/licenses/MIT</url>
- </license>
- </licenses>
-
<repositories>
<repository>
<id>repo.jenkins-ci.org</id>
<url>https://repo.jenkins-ci.org/public/</url>
</repository>
+ <repository>
+ <id>elementary-releases</id>
+ <url>https://repo.karuslabs.com/repository/elementary-releases/</url>
+ </repository>
</repositories>
</project>
=====================================
src/main/java/org/jvnet/hudson/annotation_indexer/Index.java
=====================================
@@ -35,7 +35,7 @@ public class Index {
*/
public static <T extends AnnotatedElement> Iterable<T> list(Class<? extends Annotation> type, ClassLoader cl, final Class<T> subType) throws IOException {
final Iterable<AnnotatedElement> base = list(type,cl);
- return new Iterable<T>() {
+ return new Iterable<>() {
@Override
public Iterator<T> iterator() {
return new SubtypeIterator<>(base.iterator(), subType);
@@ -78,10 +78,10 @@ public class Index {
*/
public static Iterable<AnnotatedElement> list(final Class<? extends Annotation> type, final ClassLoader cl) throws IOException {
Set<String> ids = listClassNames(type, cl);
- return new Iterable<AnnotatedElement>() {
+ return new Iterable<>() {
@Override
public Iterator<AnnotatedElement> iterator() {
- return new Iterator<AnnotatedElement>() {
+ return new Iterator<>() {
/**
* Next element to return.
*/
=====================================
src/test/java/org/jvnet/hudson/annotation_indexer/AnnotationProcessorImplTest.java
=====================================
@@ -1,8 +1,16 @@
package org.jvnet.hudson.annotation_indexer;
+import static org.junit.jupiter.api.Assertions.assertEquals;
+import static org.junit.jupiter.api.Assertions.assertFalse;
+import static org.junit.jupiter.api.Assertions.assertTrue;
+
+import com.karuslabs.elementary.Results;
+import com.karuslabs.elementary.junit.JavacExtension;
+import com.karuslabs.elementary.junit.annotations.Inline;
+import com.karuslabs.elementary.junit.annotations.Options;
+import com.karuslabs.elementary.junit.annotations.Processors;
import java.io.IOException;
import java.lang.annotation.ElementType;
-import java.lang.annotation.Inherited;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
@@ -13,66 +21,97 @@ import java.net.URL;
import java.net.URLClassLoader;
import java.util.Collections;
import java.util.Iterator;
-import net.java.dev.hickory.testing.Compilation;
-import org.junit.Test;
-import static org.junit.Assert.assertEquals;
-import static org.junit.Assert.assertFalse;
-import static org.junit.Assert.assertTrue;
+import org.junit.jupiter.api.Test;
+import org.junit.jupiter.api.extension.ExtendWith;
-public class AnnotationProcessorImplTest {
+ at ExtendWith(JavacExtension.class)
+ at Options("-Werror")
+ at Processors(AnnotationProcessorImpl.class)
+class AnnotationProcessorImplTest {
- @Test public void allInOne() {
- Compilation compilation = new Compilation();
- compilation.addSource("some.api.A").
- addLine("package some.api;").
- addLine("@" + Indexed.class.getCanonicalName() + " @java.lang.annotation.Retention(java.lang.annotation.RetentionPolicy.RUNTIME) public @interface A {}");
- compilation.addSource("some.pkg.Stuff").
- addLine("package some.pkg;").
- addLine("@some.api.A public class Stuff {}");
- compilation.doCompile(null, "-source", "8");
- assertEquals(Collections.emptyList(), Utils.filterObsoleteSourceVersionWarnings(compilation.getDiagnostics()));
- assertEquals("some.pkg.Stuff" + System.getProperty("line.separator"), Utils.getGeneratedResource(compilation, "META-INF/services/annotations/some.api.A"));
+ @Inline(
+ name = "some.api.A",
+ source = {
+ "package some.api;",
+ "@org.jvnet.hudson.annotation_indexer.Indexed @java.lang.annotation.Retention(java.lang.annotation.RetentionPolicy.RUNTIME) public @interface A {}",
+ })
+ @Inline(
+ name = "some.pkg.Stuff",
+ source = {
+ "package some.pkg;",
+ "@some.api.A public class Stuff {}",
+ })
+ @Test
+ void allInOne(Results results) {
+ assertEquals(Collections.emptyList(), results.diagnostics);
+ assertEquals("some.pkg.Stuff" + System.getProperty("line.separator"), Utils.getGeneratedResource(results.sources, "META-INF/services/annotations/some.api.A"));
}
- @Indexed @Retention(RetentionPolicy.RUNTIME) public @interface A {}
- @Test public void separate() {
- Compilation compilation = new Compilation();
- compilation.addSource("some.pkg.Stuff").
- addLine("package some.pkg;").
- addLine("@" + A.class.getCanonicalName() + " public class Stuff {}");
- compilation.doCompile(null, "-source", "8");
- assertEquals(Collections.emptyList(), Utils.filterObsoleteSourceVersionWarnings(compilation.getDiagnostics()));
- assertEquals("some.pkg.Stuff" + System.getProperty("line.separator"), Utils.getGeneratedResource(compilation, "META-INF/services/annotations/" + A.class.getName()));
+ @Inline(
+ name = "some.pkg.A",
+ source = {
+ "package some.pkg;",
+ "@org.jvnet.hudson.annotation_indexer.Indexed @java.lang.annotation.Retention(java.lang.annotation.RetentionPolicy.RUNTIME) public @interface A {}",
+ })
+ @Inline(
+ name = "some.pkg.Stuff",
+ source = {
+ "package some.pkg;",
+ "@A public class Stuff {}",
+ })
+ @Test
+ void separate(Results results) {
+ assertEquals(Collections.emptyList(), results.diagnostics);
+ assertEquals("some.pkg.Stuff" + System.getProperty("line.separator"), Utils.getGeneratedResource(results.sources, "META-INF/services/annotations/some.pkg.A"));
}
- @Test public void incremental() {
- Compilation compilation = new Compilation();
- compilation.addSource("some.pkg.Stuff").
- addLine("package some.pkg;").
- addLine("@" + A.class.getCanonicalName() + " public class Stuff {}");
- compilation.doCompile(null, "-source", "8");
- assertEquals(Collections.emptyList(), Utils.filterObsoleteSourceVersionWarnings(compilation.getDiagnostics()));
- assertEquals("some.pkg.Stuff" + System.getProperty("line.separator"), Utils.getGeneratedResource(compilation, "META-INF/services/annotations/" + A.class.getName()));
- compilation = new Compilation(compilation);
- compilation.addSource("some.pkg.MoreStuff").
- addLine("package some.pkg;").
- addLine("@" + A.class.getCanonicalName() + " public class MoreStuff {}");
- compilation.doCompile(null, "-source", "8");
- assertEquals(Collections.emptyList(), Utils.filterObsoleteSourceVersionWarnings(compilation.getDiagnostics()));
- assertEquals("some.pkg.MoreStuff" + System.getProperty("line.separator") + "some.pkg.Stuff" + System.getProperty("line.separator"), Utils.getGeneratedResource(compilation, "META-INF/services/annotations/" + A.class.getName()));
+ @Inline(
+ name = "some.pkg.A",
+ source = {
+ "package some.pkg;",
+ "@org.jvnet.hudson.annotation_indexer.Indexed @java.lang.annotation.Retention(java.lang.annotation.RetentionPolicy.RUNTIME) public @interface A {}",
+ })
+ @Inline(
+ name = "some.pkg.Stuff",
+ source = {
+ "package some.pkg;",
+ "@A public class Stuff {}",
+ })
+ @Inline(
+ name = "some.pkg.MoreStuff",
+ source = {
+ "package some.pkg;",
+ "@A public class MoreStuff {}",
+ })
+ @Test
+ void multiple(Results results) {
+ assertEquals(Collections.emptyList(), results.diagnostics);
+ assertEquals("some.pkg.MoreStuff" + System.getProperty("line.separator") + "some.pkg.Stuff" + System.getProperty("line.separator"), Utils.getGeneratedResource(results.sources, "META-INF/services/annotations/some.pkg.A"));
}
- @Indexed @Retention(RetentionPolicy.RUNTIME) @Inherited public @interface B {}
- @B public static abstract class Super {}
- @Test public void subclass() {
- Compilation compilation = new Compilation();
- compilation.addSource("some.pkg.Stuff").
- addLine("package some.pkg;").
- addLine("public class Stuff extends " + Super.class.getCanonicalName() + " {}");
- compilation.doCompile(null, "-source", "8");
- assertEquals(Collections.emptyList(), Utils.filterObsoleteSourceVersionWarnings(compilation.getDiagnostics()));
+ @Inline(
+ name = "some.pkg.B",
+ source = {
+ "package some.pkg;",
+ "@org.jvnet.hudson.annotation_indexer.Indexed @java.lang.annotation.Retention(java.lang.annotation.RetentionPolicy.RUNTIME) @java.lang.annotation.Inherited public @interface B {}",
+ })
+ @Inline(
+ name = "some.pkg.Super",
+ source = {
+ "package some.pkg;",
+ "@B public abstract class Super {}",
+ })
+ @Inline(
+ name = "some.pkg.Stuff",
+ source = {
+ "package some.pkg;",
+ "public class Stuff extends Super {}",
+ })
+ @Test
+ void subclass(Results results) {
+ assertEquals(Collections.emptyList(), results.diagnostics);
/* XXX #7188605 currently broken on JDK 6; perhaps need to use a ElementScanner6 on roundEnv.rootElements whose visitType checks for annotations
- assertEquals("some.pkg.Stuff\n", Utils.getGeneratedResource(compilation, "META-INF/services/annotations/" + B.class.getName()));
+ assertEquals("some.pkg.Stuff\n", Utils.getGeneratedResource(results.sources, "META-INF/services/annotations/some.pkg.B"));
*/
}
@@ -81,7 +120,7 @@ public class AnnotationProcessorImplTest {
public static class Problematic {@C public Inaccessible bad() {return null;}}
public static class Fine {@C public String good() {return null;}}
public static class StillOK {@C public void whatever() {}}
- @Test public void linkageErrorRobustness() throws Exception {
+ @Test void linkageErrorRobustness() throws Exception {
ClassLoader cl = new URLClassLoader(new URL[] {Index.class.getProtectionDomain().getCodeSource().getLocation(), AnnotationProcessorImplTest.class.getProtectionDomain().getCodeSource().getLocation()}, AnnotationProcessorImplTest.class.getClassLoader().getParent()) {
@Override protected Class<?> findClass(String name) throws ClassNotFoundException {
if (name.endsWith("$Inaccessible")) {
@@ -104,7 +143,7 @@ public class AnnotationProcessorImplTest {
@Indexed @Retention(RetentionPolicy.RUNTIME) @Target(ElementType.CONSTRUCTOR) public @interface OnConst {}
public static class Stuff {@OnConst public Stuff() {}}
- @Test public void constructors() throws Exception {
+ @Test void constructors() throws Exception {
Iterator<AnnotatedElement> it = Index.list(OnConst.class, Stuff.class.getClassLoader()).iterator();
assertTrue(it.hasNext());
Constructor<?> c = (Constructor<?>) it.next();
@@ -114,7 +153,7 @@ public class AnnotationProcessorImplTest {
@Indexed @Retention(RetentionPolicy.RUNTIME) @Target(ElementType.PACKAGE) public @interface OnPackage {}
- @Test public void packageinfo() throws IOException {
+ @Test void packageinfo() throws IOException {
Iterator<AnnotatedElement> it = Index.list(OnPackage.class, Stuff.class.getClassLoader()).iterator();
assertTrue(it.hasNext());
final Package p = (Package) it.next();
=====================================
src/test/java/org/jvnet/hudson/annotation_indexer/Utils.java
=====================================
@@ -1,70 +1,24 @@
package org.jvnet.hudson.annotation_indexer;
-import java.io.FileNotFoundException;
import java.io.IOException;
-import java.lang.reflect.Field;
-import java.util.ArrayList;
-import java.util.Collections;
+import java.io.UncheckedIOException;
import java.util.List;
-import java.util.Locale;
-import javax.tools.Diagnostic;
-import javax.tools.FileObject;
-import javax.tools.JavaFileManager;
import javax.tools.JavaFileObject;
import javax.tools.StandardLocation;
-import net.java.dev.hickory.testing.Compilation;
-// XXX partial copy of class from Stapler; should be pushed up into Hickory ASAP
class Utils {
-
- // Filter out warnings about source 1.6 is obsolete in java 9
- // This usually appears with other warnings
- public static final List<String> IGNORE = Collections.singletonList(
- "RELEASE_6" // Filter out warnings about source 1.6 is obsolete in java 9+
- );
-
- public static List<Diagnostic<? extends JavaFileObject>> filterObsoleteSourceVersionWarnings(List<Diagnostic<? extends JavaFileObject>> diagnostics) {
- List<Diagnostic<? extends JavaFileObject>> r = new ArrayList<>();
- for (Diagnostic<? extends JavaFileObject> d : diagnostics) {
- if (!isIgnored(d.getMessage(Locale.ENGLISH))) {
- r.add(d);
- }
- }
- return r;
- }
-
- private static boolean isIgnored(String message) {
- for (String i : IGNORE) {
- if (message.contains(i)) return true;
- }
- return false;
- }
-
- private static JavaFileManager fileManager(Compilation compilation) {
- try {
- Field f = Compilation.class.getDeclaredField("jfm");
- f.setAccessible(true);
- return (JavaFileManager) f.get(compilation);
- } catch (Exception x) {
- throw new AssertionError(x);
+ public static String getGeneratedResource(List<JavaFileObject> generated, String filename) {
+ JavaFileObject fo = generated.stream()
+ .filter(it -> it.getName().equals("/" + StandardLocation.CLASS_OUTPUT + "/" + filename))
+ .findFirst()
+ .orElse(null);
+ if (fo == null) {
+ return null;
}
- }
-
- /**
- * Replacement for {@link Compilation#getGeneratedResource} that actually works.
- * https://code.google.com/p/jolira-tools/issues/detail?id=11
- */
- public static String getGeneratedResource(Compilation compilation, String filename) {
try {
- FileObject fo = fileManager(compilation).getFileForOutput(StandardLocation.CLASS_OUTPUT, "", filename, null);
- if (fo == null) {
- return null;
- }
return fo.getCharContent(true).toString();
- } catch (FileNotFoundException x) {
- return null;
- } catch (IOException x) {
- throw new RuntimeException(x);
+ } catch (IOException e) {
+ throw new UncheckedIOException(e);
}
}
View it on GitLab: https://salsa.debian.org/java-team/annotation-indexer/-/commit/3cbd716430127731e4189134290e46e0c9b1d29c
--
View it on GitLab: https://salsa.debian.org/java-team/annotation-indexer/-/commit/3cbd716430127731e4189134290e46e0c9b1d29c
You're receiving this email because of your account on salsa.debian.org.
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://alioth-lists.debian.net/pipermail/pkg-java-commits/attachments/20221205/e16e1703/attachment.htm>
More information about the pkg-java-commits
mailing list