Skip to content

Commit

Permalink
small improvements in Build Compatible Extensions and Language Model …
Browse files Browse the repository at this point in the history
…TCKs
  • Loading branch information
Ladicek committed Nov 14, 2023
1 parent 0e21f89 commit 0af3b0f
Show file tree
Hide file tree
Showing 5 changed files with 62 additions and 0 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
package org.jboss.cdi.tck.tests.build.compatible.extensions.registration;

import jakarta.annotation.Priority;
import jakarta.interceptor.AroundInvoke;
import jakarta.interceptor.Interceptor;
import jakarta.interceptor.InvocationContext;

@MyInterceptorBinding
@Interceptor
@Priority(1)
public class MyInterceptor {
@AroundInvoke
public Object intercept(InvocationContext ctx) throws Exception {
return ctx.proceed();
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
package org.jboss.cdi.tck.tests.build.compatible.extensions.registration;

import jakarta.interceptor.InterceptorBinding;

import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

@Target({ElementType.TYPE, ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
@InterceptorBinding
public @interface MyInterceptorBinding {
}
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ public class RegistrationExtension implements BuildCompatibleExtension {
private final AtomicInteger beanCounter = new AtomicInteger();
private final AtomicInteger beanMyQualifierCounter = new AtomicInteger();
private final AtomicInteger observerCounter = new AtomicInteger();
private final AtomicInteger interceptorCounter = new AtomicInteger();

@Registration(types = MyService.class)
public void beans(BeanInfo bean) {
Expand All @@ -31,6 +32,14 @@ public void observers(ObserverInfo observer, Types types) {
}
}

@Registration(types = MyInterceptor.class)
public void interceptors(BeanInfo interceptor, Messages msg) {
if (!interceptor.isInterceptor()) {
msg.error("Interceptor expected", interceptor);
}
interceptorCounter.incrementAndGet();
}

@Validation
public void test(Messages msg) {
if (beanCounter.get() != 2) {
Expand All @@ -44,5 +53,9 @@ public void test(Messages msg) {
if (observerCounter.get() != 1) {
msg.error("Should see 1 observer declared in class that implements MyService");
}

if (interceptorCounter.get() != 1) {
msg.error("Should see 1 interceptor of type MyInterceptor");
}
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
package org.jboss.cdi.lang.model.tck;

import jakarta.enterprise.lang.model.declarations.ClassInfo;

public class JavaLangObjectMethods /*extends Object*/ {
public static class Verifier {
public static void verify(ClassInfo clazz) {
assert clazz.methods().isEmpty();

ClassInfo javaLangObject = clazz.superClassDeclaration();
assert !javaLangObject.methods().isEmpty();
assert LangModelUtils.collectMethods(javaLangObject, "toString").size() == 1;
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,8 @@ public class LangModelVerifier {
InheritedFields inheritedFields;
InheritedAnnotations inheritedAnnotations;

JavaLangObjectMethods javaLangObjectMethods;

PrimitiveTypes primitiveTypes;
BridgeMethods bridgeMethods;
RepeatableAnnotations repeatableAnnotations;
Expand Down Expand Up @@ -79,6 +81,8 @@ public static void verify(ClassInfo clazz) {
InheritedFields.Verifier.verify(LangModelUtils.classOfField(clazz, "inheritedFields"));
InheritedAnnotations.verify(LangModelUtils.classOfField(clazz, "inheritedAnnotations"));

JavaLangObjectMethods.Verifier.verify(LangModelUtils.classOfField(clazz, "javaLangObjectMethods"));

PrimitiveTypes.verify(LangModelUtils.classOfField(clazz, "primitiveTypes"));
BridgeMethods.verify(LangModelUtils.classOfField(clazz, "bridgeMethods"));
RepeatableAnnotations.verify(LangModelUtils.classOfField(clazz, "repeatableAnnotations"));
Expand Down

0 comments on commit 0af3b0f

Please sign in to comment.