|
7 | 7 | import net.bytebuddy.dynamic.scaffold.InstrumentedType; |
8 | 8 | import net.bytebuddy.dynamic.scaffold.MethodGraph; |
9 | 9 | import net.bytebuddy.dynamic.scaffold.TypeValidation; |
| 10 | +import net.bytebuddy.utility.AsmClassReader; |
10 | 11 | import org.hamcrest.CoreMatchers; |
11 | 12 | import org.junit.Test; |
12 | 13 | import org.junit.runner.RunWith; |
13 | 14 | import org.junit.runners.Parameterized; |
| 15 | +import org.objectweb.asm.ClassVisitor; |
14 | 16 |
|
15 | 17 | import java.lang.reflect.Field; |
16 | 18 | import java.lang.reflect.Method; |
| 19 | +import java.lang.reflect.Modifier; |
17 | 20 | import java.util.Arrays; |
18 | 21 | import java.util.Collection; |
| 22 | +import java.util.List; |
19 | 23 |
|
20 | 24 | import static net.bytebuddy.matcher.ElementMatchers.is; |
21 | 25 | import static org.hamcrest.MatcherAssert.assertThat; |
@@ -251,6 +255,66 @@ public void testSimpleName() throws Exception { |
251 | 255 | assertThat(describe($DollarInName.class).getSimpleName(), CoreMatchers.is($DollarInName.class.getSimpleName())); |
252 | 256 | } |
253 | 257 |
|
| 258 | + @Test |
| 259 | + public void testClassFileIsNotParsedForExtendedProperties() throws Exception { |
| 260 | + if (lazinessMode == TypePool.Default.WithLazyResolution.LazinessMode.NAME) { |
| 261 | + return; |
| 262 | + } |
| 263 | + TypeDescription typeDescription = new TypePool.Default.WithLazyResolution(new TypePool.CacheProvider.Simple(), |
| 264 | + ClassFileLocator.ForClassLoader.of(NonGenericType.class.getClassLoader()), |
| 265 | + TypePool.Default.ReaderMode.EXTENDED, |
| 266 | + new AsmClassReader.Factory() { |
| 267 | + public AsmClassReader make(byte[] binaryRepresentation) { |
| 268 | + return make(Default.IMPLICIT.make(binaryRepresentation)); |
| 269 | + } |
| 270 | + |
| 271 | + public AsmClassReader make(byte[] binaryRepresentation, boolean experimental) { |
| 272 | + return make(Default.IMPLICIT.make(binaryRepresentation, experimental)); |
| 273 | + } |
| 274 | + |
| 275 | + private AsmClassReader make(final AsmClassReader delegate) { |
| 276 | + return new AsmClassReader() { |
| 277 | + @Override |
| 278 | + public <T> T unwrap(Class<T> type) { |
| 279 | + return delegate.unwrap(type); |
| 280 | + } |
| 281 | + |
| 282 | + @Override |
| 283 | + public int getModifiers() { |
| 284 | + return delegate.getModifiers(); |
| 285 | + } |
| 286 | + |
| 287 | + @Override |
| 288 | + public String getInternalName() { |
| 289 | + return delegate.getInternalName(); |
| 290 | + } |
| 291 | + |
| 292 | + @Override |
| 293 | + public String getSuperClassInternalName() { |
| 294 | + return delegate.getSuperClassInternalName(); |
| 295 | + } |
| 296 | + |
| 297 | + @Override |
| 298 | + public List<String> getInterfaceInternalNames() { |
| 299 | + return delegate.getInterfaceInternalNames(); |
| 300 | + } |
| 301 | + |
| 302 | + @Override |
| 303 | + public void accept(ClassVisitor classVisitor, int flags) { |
| 304 | + throw new AssertionError(); |
| 305 | + } |
| 306 | + }; |
| 307 | + } |
| 308 | + }, |
| 309 | + lazinessMode).describe(NonGenericType.class.getName()).resolve(); |
| 310 | + assertThat(typeDescription.getSuperClass().asErasure().getName(), CoreMatchers.is(NonGenericType.class.getSuperclass().getName())); |
| 311 | + assertThat(typeDescription.getInterfaces().get(0).asErasure().getName(), CoreMatchers.is(NonGenericType.class.getInterfaces()[0].getName())); |
| 312 | + assertThat(typeDescription.isAbstract(), CoreMatchers.is(Modifier.isAbstract(NonGenericType.class.getModifiers()))); |
| 313 | + assertThat(typeDescription.isInterface(), CoreMatchers.is(Modifier.isInterface(NonGenericType.class.getModifiers()))); |
| 314 | + assertThat(typeDescription.isAnnotation(), CoreMatchers.is(Modifier.isInterface(NonGenericType.class.getModifiers()))); |
| 315 | + assertThat(typeDescription.isEnum(), CoreMatchers.is(NonGenericType.class.isEnum())); |
| 316 | + } |
| 317 | + |
254 | 318 | private static class SuperClass { |
255 | 319 | /* empty */ |
256 | 320 | } |
|
0 commit comments