blob: 7790c5387304e4e5c7cdacf48c988d8070189236 [file] [log] [blame]
// Copyright 2007 Google Inc. All Rights Reserved.
package com.google.inject;
import static com.google.inject.Asserts.assertContains;
import junit.framework.TestCase;
import static java.lang.annotation.ElementType.*;
import java.lang.annotation.Retention;
import static java.lang.annotation.RetentionPolicy.RUNTIME;
import java.lang.annotation.Target;
/**
* Tests the error messages produced by Guice.
*
* @author Kevin Bourrillion
*/
public class ErrorMessagesTest extends TestCase {
private class InnerClass {}
public void testInjectInnerClass() throws Exception {
Injector injector = Guice.createInjector();
try {
injector.getInstance(InnerClass.class);
fail();
} catch (Exception expected) {
// TODO(kevinb): why does the source come out as unknown??
assertContains(expected.getMessage(), "Injecting into inner classes is not supported.");
}
}
public void testInjectLocalClass() throws Exception {
class LocalClass {}
Injector injector = Guice.createInjector();
try {
injector.getInstance(LocalClass.class);
fail();
} catch (Exception expected) {
// TODO(kevinb): why does the source come out as unknown??
assertContains(expected.getMessage(), "Injecting into inner classes is not supported.");
}
}
public void testExplicitBindingOfAnAbstractClass() {
try {
Guice.createInjector(new AbstractModule() {
protected void configure() {
bind(AbstractClass.class);
}
});
fail();
} catch(CreationException expected) {
assertContains(expected.getMessage(), "Injecting into abstract types is not supported.");
}
}
public void testGetInstanceOfAnAbstractClass() {
Injector injector = Guice.createInjector();
try {
injector.getInstance(AbstractClass.class);
fail();
} catch(ConfigurationException expected) {
assertContains(expected.getMessage(), "Injecting into abstract types is not supported.");
}
}
static abstract class AbstractClass {
@Inject AbstractClass() { }
}
public void testScopingAnnotationsOnAbstractTypes() {
try {
Guice.createInjector(new AbstractModule() {
protected void configure() {
bind(A.class).to(AImpl.class);
}
});
fail();
} catch (CreationException expected) {
assertContains(expected.getMessage(),
"Scope annotations on abstract types are not supported.");
}
}
@Singleton
interface A {}
class AImpl implements A {}
public void testBindingAnnotationsOnMethodsAndConstructors() {
try {
Guice.createInjector().getInstance(B.class);
fail();
} catch (CreationException expected) {
assertContains(expected.getMessage(),
"Binding annotations on injected methods are not supported. "
+ "Annotate the parameter instead?");
}
try {
Guice.createInjector().getInstance(C.class);
fail();
} catch (CreationException expected) {
assertContains(expected.getMessage(),
"Binding annotations on injected constructors are not supported. "
+ "Annotate the parameter instead?");
}
}
static class B {
@Inject @Green void injectMe(String greenString) {}
}
static class C {
@Inject @Green C(String greenString) {}
}
@Retention(RUNTIME)
@Target({ FIELD, PARAMETER, CONSTRUCTOR, METHOD })
@BindingAnnotation
@interface Green {}
// TODO(kevinb): many many more
}