Merge remote-tracking branch 'origin/BAEL-2399' into BAEL-2399
This commit is contained in:
commit
4375c0d450
|
@ -37,7 +37,7 @@
|
|||
</dependencies>
|
||||
|
||||
<properties>
|
||||
<guice.version>4.1.0</guice.version>
|
||||
<guice.version>4.2.2</guice.version>
|
||||
<spring.version>5.1.3.RELEASE</spring.version>
|
||||
<springtest.version>5.1.3.RELEASE</springtest.version>
|
||||
</properties>
|
||||
|
|
|
@ -1,8 +1,5 @@
|
|||
package com.baeldung.examples.common;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
public interface AccountService {
|
||||
public List<String> listAccountTypes();
|
||||
|
||||
}
|
||||
|
|
|
@ -1,15 +1,8 @@
|
|||
package com.baeldung.examples.common;
|
||||
|
||||
import java.util.Arrays;
|
||||
import java.util.List;
|
||||
|
||||
import org.springframework.stereotype.Component;
|
||||
|
||||
@Component
|
||||
public class AccountServiceImpl implements AccountService {
|
||||
|
||||
public List<String> listAccountTypes() {
|
||||
return Arrays.asList("Checking", "Saving");
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -1,35 +0,0 @@
|
|||
package com.baeldung.examples.common;
|
||||
|
||||
import org.springframework.stereotype.Component;
|
||||
|
||||
@Component
|
||||
public class Address {
|
||||
private String city;
|
||||
private String state;
|
||||
private String county;
|
||||
|
||||
public String getCity() {
|
||||
return city;
|
||||
}
|
||||
|
||||
public void setCity(String city) {
|
||||
this.city = city;
|
||||
}
|
||||
|
||||
public String getState() {
|
||||
return state;
|
||||
}
|
||||
|
||||
public void setState(String state) {
|
||||
this.state = state;
|
||||
}
|
||||
|
||||
public String getCounty() {
|
||||
return county;
|
||||
}
|
||||
|
||||
public void setCounty(String county) {
|
||||
this.county = county;
|
||||
}
|
||||
|
||||
}
|
|
@ -0,0 +1,5 @@
|
|||
package com.baeldung.examples.common;
|
||||
|
||||
public interface AudioBookService {
|
||||
|
||||
}
|
|
@ -0,0 +1,5 @@
|
|||
package com.baeldung.examples.common;
|
||||
|
||||
public class AudioBookServiceImpl implements AudioBookService {
|
||||
|
||||
}
|
|
@ -0,0 +1,5 @@
|
|||
package com.baeldung.examples.common;
|
||||
|
||||
public interface AuthorService {
|
||||
|
||||
}
|
|
@ -0,0 +1,5 @@
|
|||
package com.baeldung.examples.common;
|
||||
|
||||
public class AuthorServiceImpl implements AuthorService {
|
||||
|
||||
}
|
|
@ -1,9 +1,5 @@
|
|||
package com.baeldung.examples.common;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
public interface BookService {
|
||||
|
||||
public List<String> findBestSellerBooks();
|
||||
|
||||
}
|
||||
|
|
|
@ -1,12 +1,10 @@
|
|||
package com.baeldung.examples.common;
|
||||
|
||||
import java.util.Arrays;
|
||||
import java.util.List;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
|
||||
public class BookServiceImpl implements BookService {
|
||||
|
||||
public List<String> findBestSellerBooks() {
|
||||
return Arrays.asList("Harry Potter", "Lord of The Rings");
|
||||
}
|
||||
@Autowired(required = false)
|
||||
private AuthorService authorService;
|
||||
|
||||
}
|
||||
|
|
|
@ -1,32 +0,0 @@
|
|||
package com.baeldung.examples.guice;
|
||||
|
||||
import com.google.inject.Inject;
|
||||
|
||||
public class Employee {
|
||||
|
||||
private String firstName;
|
||||
private String lastName;
|
||||
|
||||
@Inject
|
||||
public Employee(String firstName) {
|
||||
this.firstName = firstName;
|
||||
this.lastName = "Default";
|
||||
}
|
||||
|
||||
public String getFirstName() {
|
||||
return firstName;
|
||||
}
|
||||
|
||||
public void setFirstName(String firstName) {
|
||||
this.firstName = firstName;
|
||||
}
|
||||
|
||||
public String getLastName() {
|
||||
return lastName;
|
||||
}
|
||||
|
||||
public void setLastName(String lastName) {
|
||||
this.lastName = lastName;
|
||||
}
|
||||
|
||||
}
|
|
@ -1,5 +1,4 @@
|
|||
package com.baeldung.examples.guice;
|
||||
|
||||
|
||||
public class Foo {
|
||||
}
|
||||
|
|
|
@ -4,8 +4,9 @@ import org.springframework.lang.Nullable;
|
|||
|
||||
import com.google.inject.Inject;
|
||||
|
||||
public class FooGenerator {
|
||||
public class FooProcessor {
|
||||
|
||||
@Inject
|
||||
public FooGenerator(@Nullable Foo foo) {
|
||||
}
|
||||
@Nullable
|
||||
private Foo foo;
|
||||
}
|
|
@ -1,32 +0,0 @@
|
|||
package com.baeldung.examples.guice;
|
||||
|
||||
import com.baeldung.examples.common.Account;
|
||||
import com.baeldung.examples.common.Address;
|
||||
import com.google.inject.Inject;
|
||||
|
||||
public class GuiceUser {
|
||||
|
||||
@Inject
|
||||
private Account account;
|
||||
|
||||
private Address address;
|
||||
|
||||
public Account getAccount() {
|
||||
return account;
|
||||
}
|
||||
|
||||
public void setAccount(Account account) {
|
||||
this.account = account;
|
||||
}
|
||||
|
||||
public Address getAddress() {
|
||||
return address;
|
||||
}
|
||||
|
||||
@Inject
|
||||
public void setAddress(Address address) {
|
||||
this.address = address;
|
||||
address.setCity("Default");
|
||||
}
|
||||
|
||||
}
|
|
@ -1,15 +1,10 @@
|
|||
package com.baeldung.examples.guice;
|
||||
|
||||
import com.baeldung.examples.common.Address;
|
||||
import com.google.inject.Inject;
|
||||
|
||||
public class Person {
|
||||
private String firstName;
|
||||
|
||||
private String lastName;
|
||||
|
||||
private Address address;
|
||||
|
||||
public String getFirstName() {
|
||||
return firstName;
|
||||
}
|
||||
|
@ -26,14 +21,4 @@ public class Person {
|
|||
this.lastName = lastName;
|
||||
}
|
||||
|
||||
public Address getAddress() {
|
||||
return address;
|
||||
}
|
||||
|
||||
@Inject
|
||||
public void setAddress(Address address) {
|
||||
this.address = address;
|
||||
address.setCity("Default");
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -17,14 +17,7 @@ public class GuiceModule extends AbstractModule {
|
|||
@Override
|
||||
protected void configure() {
|
||||
try {
|
||||
bind(PersonDao.class).to(PersonDaoImpl.class);
|
||||
bind(AccountService.class).to(AccountServiceImpl.class);
|
||||
bind(Foo.class).toProvider(new Provider<Foo>() {
|
||||
public Foo get() {
|
||||
return null;
|
||||
}
|
||||
});
|
||||
|
||||
bind(Person.class).toConstructor(Person.class.getConstructor());
|
||||
// bind(Person.class).toProvider(new Provider<Person>() {
|
||||
// public Person get() {
|
||||
|
@ -32,6 +25,13 @@ public class GuiceModule extends AbstractModule {
|
|||
// return p;
|
||||
// }
|
||||
// });
|
||||
bind(Foo.class).toProvider(new Provider<Foo>() {
|
||||
public Foo get() {
|
||||
return null;
|
||||
}
|
||||
});
|
||||
bind(PersonDao.class).to(PersonDaoImpl.class);
|
||||
|
||||
} catch (NoSuchMethodException e) {
|
||||
// TODO Auto-generated catch block
|
||||
e.printStackTrace();
|
||||
|
|
|
@ -0,0 +1,17 @@
|
|||
package com.baeldung.examples.spring;
|
||||
|
||||
import org.springframework.context.annotation.Bean;
|
||||
import org.springframework.context.annotation.Configuration;
|
||||
|
||||
import com.baeldung.examples.common.AudioBookService;
|
||||
import com.baeldung.examples.common.AudioBookServiceImpl;
|
||||
|
||||
@Configuration
|
||||
public class SpringBeansConfig {
|
||||
|
||||
@Bean
|
||||
public AudioBookService audioBookServiceGenerator() {
|
||||
return new AudioBookServiceImpl();
|
||||
}
|
||||
|
||||
}
|
|
@ -3,13 +3,15 @@ package com.baeldung.examples.spring;
|
|||
import org.springframework.context.annotation.Bean;
|
||||
import org.springframework.context.annotation.ComponentScan;
|
||||
import org.springframework.context.annotation.Configuration;
|
||||
import org.springframework.context.annotation.Import;
|
||||
|
||||
import com.baeldung.examples.common.BookService;
|
||||
import com.baeldung.examples.common.BookServiceImpl;
|
||||
|
||||
@Configuration
|
||||
@Import({ SpringBeansConfig.class })
|
||||
@ComponentScan("com.baeldung.examples")
|
||||
public class AppConfig {
|
||||
public class SpringMainConfig {
|
||||
|
||||
@Bean
|
||||
public BookService bookServiceGenerator() {
|
|
@ -1,35 +0,0 @@
|
|||
package com.baeldung.examples.spring;
|
||||
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.stereotype.Component;
|
||||
|
||||
import com.baeldung.examples.common.Account;
|
||||
import com.baeldung.examples.common.Address;
|
||||
|
||||
@Component
|
||||
public class SpringUser {
|
||||
|
||||
@Autowired
|
||||
private Account account;
|
||||
|
||||
private Address address;
|
||||
|
||||
public Account getAccount() {
|
||||
return account;
|
||||
}
|
||||
|
||||
public void setAccount(Account account) {
|
||||
this.account = account;
|
||||
}
|
||||
|
||||
public Address getAddress() {
|
||||
return address;
|
||||
}
|
||||
|
||||
@Autowired
|
||||
public void setAddress(Address address) {
|
||||
this.address = address;
|
||||
address.setCity("Default");
|
||||
}
|
||||
|
||||
}
|
|
@ -5,9 +5,8 @@ import static org.junit.Assert.assertNotNull;
|
|||
import org.junit.Test;
|
||||
|
||||
import com.baeldung.examples.common.BookService;
|
||||
import com.baeldung.examples.guice.FooGenerator;
|
||||
import com.baeldung.examples.guice.FooProcessor;
|
||||
import com.baeldung.examples.guice.GuicePersonService;
|
||||
import com.baeldung.examples.guice.GuiceUser;
|
||||
import com.baeldung.examples.guice.GuiceUserService;
|
||||
import com.baeldung.examples.guice.Person;
|
||||
import com.baeldung.examples.guice.modules.GuiceModule;
|
||||
|
@ -16,21 +15,6 @@ import com.google.inject.Injector;
|
|||
|
||||
public class GuiceUnitTest {
|
||||
|
||||
@Test
|
||||
public void givenAccountInjectedInGuiceUser_WhenGetAccountInvoked_ThenReturnValueIsNotNull() {
|
||||
Injector injector = Guice.createInjector(new GuiceModule());
|
||||
GuiceUser guiceUser = injector.getInstance(GuiceUser.class);
|
||||
assertNotNull(guiceUser.getAccount());
|
||||
}
|
||||
|
||||
@Test
|
||||
public void givenPersonDaoInjectedInGuicePersonService_WhenGetPersonDaoInvoked_ThenReturnValueIsNotNull() {
|
||||
Injector injector = Guice.createInjector(new GuiceModule());
|
||||
GuicePersonService personService = injector.getInstance(GuicePersonService.class);
|
||||
assertNotNull(personService);
|
||||
assertNotNull(personService.getPersonDao());
|
||||
}
|
||||
|
||||
@Test
|
||||
public void givenAccountServiceInjectedInGuiceUserService_WhenGetAccountServiceInvoked_ThenReturnValueIsNotNull() {
|
||||
Injector injector = Guice.createInjector(new GuiceModule());
|
||||
|
@ -45,13 +29,6 @@ public class GuiceUnitTest {
|
|||
assertNotNull(bookService);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void givenFooGeneratorConstructorParameterIsNotNullable_WhenFooGeneratorIsInjected_ThenTestFailsByProvisionException() {
|
||||
Injector injector = Guice.createInjector(new GuiceModule());
|
||||
FooGenerator fooGenerator = injector.getInstance(FooGenerator.class);
|
||||
assertNotNull(fooGenerator);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void givenMultipleBindingsForPerson_WhenPersonIsInjected_ThenTestFailsByProvisionException() {
|
||||
Injector injector = Guice.createInjector(new GuiceModule());
|
||||
|
@ -59,6 +36,13 @@ public class GuiceUnitTest {
|
|||
assertNotNull(person);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void givenFooInjectedToFooProcessorAsOptionalDependency_WhenFooProcessorIsRetrievedFromContext_ThenCreationExceptionIsNotThrown() {
|
||||
Injector injector = Guice.createInjector(new GuiceModule());
|
||||
FooProcessor fooProcessor = injector.getInstance(FooProcessor.class);
|
||||
assertNotNull(fooProcessor);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void givenGuicePersonServiceConstructorAnnotatedByInject_WhenGuicePersonServiceIsInjected_ThenInstanceWillBeCreatedFromTheConstructor() {
|
||||
Injector injector = Guice.createInjector(new GuiceModule());
|
||||
|
|
|
@ -9,31 +9,18 @@ import org.springframework.context.ApplicationContext;
|
|||
import org.springframework.test.context.ContextConfiguration;
|
||||
import org.springframework.test.context.junit4.SpringRunner;
|
||||
|
||||
import com.baeldung.examples.common.AudioBookService;
|
||||
import com.baeldung.examples.common.BookService;
|
||||
import com.baeldung.examples.spring.AppConfig;
|
||||
import com.baeldung.examples.spring.SpringMainConfig;
|
||||
import com.baeldung.examples.spring.SpringPersonService;
|
||||
import com.baeldung.examples.spring.SpringUser;
|
||||
import com.baeldung.examples.spring.UserService;
|
||||
|
||||
@RunWith(SpringRunner.class)
|
||||
@ContextConfiguration(classes = { AppConfig.class })
|
||||
@ContextConfiguration(classes = { SpringMainConfig.class })
|
||||
public class SpringUnitTest {
|
||||
@Autowired
|
||||
ApplicationContext context;
|
||||
|
||||
@Test
|
||||
public void givenAccountAutowiredToSpringUser_WhenGetAccountInvoked_ThenReturnValueIsNotNull() {
|
||||
SpringUser springUser = context.getBean(SpringUser.class);
|
||||
assertNotNull(springUser.getAccount());
|
||||
}
|
||||
|
||||
@Test
|
||||
public void givenPersonDaoAutowiredToSpringPersonService_WhenGetPersonDaoInvoked_ThenReturnValueIsNotNull() {
|
||||
SpringPersonService personService = context.getBean(SpringPersonService.class);
|
||||
assertNotNull(personService);
|
||||
assertNotNull(personService.getPersonDao());
|
||||
}
|
||||
|
||||
@Test
|
||||
public void givenAccountServiceAutowiredToUserService_WhenGetAccountServiceInvoked_ThenReturnValueIsNotNull() {
|
||||
UserService userService = context.getBean(UserService.class);
|
||||
|
@ -46,6 +33,20 @@ public class SpringUnitTest {
|
|||
assertNotNull(bookService);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void givenBookServiceIsRegisteredAsBeanInContextByOverridingAudioBookService_WhenAudioBookServiceIsRetrievedFromContext_ThenNoSuchBeanDefinitionExceptionIsThrown() {
|
||||
BookService bookService = context.getBean(BookService.class);
|
||||
assertNotNull(bookService);
|
||||
AudioBookService audioBookService = context.getBean(AudioBookService.class);
|
||||
assertNotNull(audioBookService);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void givenAuthorServiceAutowiredToBookServiceAsOptionalDependency_WhenBookServiceIsRetrievedFromContext_ThenNoSuchBeanDefinitionExceptionIsNotThrown() {
|
||||
BookService bookService = context.getBean(BookService.class);
|
||||
assertNotNull(bookService);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void givenSpringPersonServiceConstructorAnnotatedByAutowired_WhenSpringPersonServiceIsRetrievedFromContext_ThenInstanceWillBeCreatedFromTheConstructor() {
|
||||
SpringPersonService personService = context.getBean(SpringPersonService.class);
|
||||
|
|
Loading…
Reference in New Issue