summaryrefslogtreecommitdiffstats
path: root/sangria-test/src/test/java
diff options
context:
space:
mode:
authorTavian Barnes <tavianator@tavianator.com>2014-10-04 12:52:32 -0400
committerTavian Barnes <tavianator@tavianator.com>2014-10-04 12:52:32 -0400
commit3fd5777a58f59218e3229c9ea11d816ecc6ae367 (patch)
tree53f937505806e010d2bc3134fa5507d0ff78d32c /sangria-test/src/test/java
parentb0bb30831a334ff30e3e6a13790bbc324db89de5 (diff)
parent8e24a47b69f940c31ac95451b4584b95de7c8670 (diff)
downloadsangria-3fd5777a58f59218e3229c9ea11d816ecc6ae367.tar.xz
Merge branch 'test'
Diffstat (limited to 'sangria-test/src/test/java')
-rw-r--r--sangria-test/src/test/java/com/tavianator/sangria/test/SangriaMatchersTest.java91
1 files changed, 91 insertions, 0 deletions
diff --git a/sangria-test/src/test/java/com/tavianator/sangria/test/SangriaMatchersTest.java b/sangria-test/src/test/java/com/tavianator/sangria/test/SangriaMatchersTest.java
new file mode 100644
index 0000000..06fb45e
--- /dev/null
+++ b/sangria-test/src/test/java/com/tavianator/sangria/test/SangriaMatchersTest.java
@@ -0,0 +1,91 @@
+package com.tavianator.sangria.test;
+
+import javax.inject.Inject;
+import javax.inject.Named;
+
+import com.google.inject.AbstractModule;
+import com.google.inject.Provides;
+import org.junit.Test;
+
+import static com.tavianator.sangria.test.SangriaMatchers.*;
+import static org.hamcrest.Matchers.*;
+import static org.junit.Assert.*;
+
+/**
+ * Tests for {@link SangriaMatchers}.
+ *
+ * @author Tavian Barnes (tavianator@tavianator.com)
+ * @version 1.2
+ * @since 1.2
+ */
+public class SangriaMatchersTest {
+ private static class AtomicModule extends AbstractModule {
+ private static final Object INSTANCE = new Object();
+
+ @Override
+ protected void configure() {
+ bind(Object.class)
+ .toInstance(INSTANCE);
+ }
+ }
+
+ private static class NonAtomicModule extends AbstractModule {
+ @Override
+ protected void configure() {
+ bind(Object.class)
+ .toInstance(new Object());
+ }
+ }
+
+ @Test
+ public void testAtomic() {
+ assertThat(new AtomicModule(), is(atomic()));
+ assertThat(new NonAtomicModule(), is(not(atomic())));
+ }
+
+ private static class NoAtInjectModule extends AbstractModule {
+ @Override
+ protected void configure() {
+ bind(String.class);
+ }
+ }
+
+ private static class InexactBindingAnnotationModule extends AbstractModule {
+ @Override
+ protected void configure() {
+ bind(String.class)
+ .annotatedWith(Named.class)
+ .toInstance("test");
+ }
+
+ @Provides
+ String getString(@Named("test") String test) {
+ return test;
+ }
+ }
+
+ private static class Injectable {
+ @Inject
+ Injectable() {
+ }
+ }
+
+ private static class JustInTimeModule extends AbstractModule {
+ @Override
+ protected void configure() {
+ }
+
+ @Provides
+ String getString(Injectable injectable) {
+ return "test";
+ }
+ }
+
+ @Test
+ public void testFollowsBestPractices() {
+ assertThat(new AtomicModule(), followsBestPractices());
+ assertThat(new NoAtInjectModule(), not(followsBestPractices()));
+ assertThat(new InexactBindingAnnotationModule(), not(followsBestPractices()));
+ assertThat(new JustInTimeModule(), not(followsBestPractices()));
+ }
+}