code manipulation : reflection(간단한 DI 프레임워크 만들기)
This commit is contained in:
36
code-manipulation/di-example/pom.xml
Normal file
36
code-manipulation/di-example/pom.xml
Normal file
@@ -0,0 +1,36 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
|
||||||
|
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||||
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
|
<modelVersion>4.0.0</modelVersion>
|
||||||
|
|
||||||
|
<groupId>org.example</groupId>
|
||||||
|
<artifactId>di-example</artifactId>
|
||||||
|
<version>1.0-SNAPSHOT</version>
|
||||||
|
|
||||||
|
<name>di-example</name>
|
||||||
|
<!-- FIXME change it to the project's website -->
|
||||||
|
<url>http://www.example.com</url>
|
||||||
|
|
||||||
|
<properties>
|
||||||
|
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
|
||||||
|
<maven.compiler.source>11</maven.compiler.source>
|
||||||
|
<maven.compiler.target>11</maven.compiler.target>
|
||||||
|
</properties>
|
||||||
|
|
||||||
|
<dependencies>
|
||||||
|
<dependency>
|
||||||
|
<groupId>junit</groupId>
|
||||||
|
<artifactId>junit</artifactId>
|
||||||
|
<version>4.11</version>
|
||||||
|
<scope>test</scope>
|
||||||
|
</dependency>
|
||||||
|
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.example</groupId>
|
||||||
|
<artifactId>reflection-example</artifactId>
|
||||||
|
<version>1.0-SNAPSHOT</version>
|
||||||
|
</dependency>
|
||||||
|
</dependencies>
|
||||||
|
|
||||||
|
</project>
|
||||||
@@ -0,0 +1,8 @@
|
|||||||
|
package org.example;
|
||||||
|
|
||||||
|
public class AccountRepository {
|
||||||
|
|
||||||
|
public void save() {
|
||||||
|
System.out.println("Repo.save()");
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,14 @@
|
|||||||
|
package org.example;
|
||||||
|
|
||||||
|
import org.example.di.Inject;
|
||||||
|
|
||||||
|
public class AccountService {
|
||||||
|
|
||||||
|
@Inject
|
||||||
|
AccountRepository accountRepository;
|
||||||
|
|
||||||
|
public void join() {
|
||||||
|
System.out.println("Service.join()");
|
||||||
|
accountRepository.save();
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,15 @@
|
|||||||
|
package org.example;
|
||||||
|
|
||||||
|
import org.example.di.ContainerService;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Hello world!
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public class App {
|
||||||
|
public static void main( String[] args ) {
|
||||||
|
|
||||||
|
AccountService accountService = ContainerService.getObject(AccountService.class);
|
||||||
|
accountService.join();
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,20 @@
|
|||||||
|
package org.example;
|
||||||
|
|
||||||
|
import static org.junit.Assert.assertTrue;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Unit test for simple App.
|
||||||
|
*/
|
||||||
|
public class AppTest
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Rigorous Test :-)
|
||||||
|
*/
|
||||||
|
@Test
|
||||||
|
public void shouldAnswerWithTrue()
|
||||||
|
{
|
||||||
|
assertTrue( true );
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,30 @@
|
|||||||
|
package org.example.di;
|
||||||
|
|
||||||
|
import java.util.Arrays;
|
||||||
|
|
||||||
|
public class ContainerService {
|
||||||
|
|
||||||
|
public static <T> T getObject(Class<T> classType) {
|
||||||
|
T instance = createInstance(classType);
|
||||||
|
Arrays.stream(classType.getDeclaredFields()).forEach(field -> {
|
||||||
|
if (field.getAnnotation(Inject.class) != null) {
|
||||||
|
Object fieldInstance = createInstance(field.getType());
|
||||||
|
field.setAccessible(true);
|
||||||
|
try {
|
||||||
|
field.set(instance, fieldInstance);
|
||||||
|
} catch (IllegalAccessException e) {
|
||||||
|
throw new RuntimeException();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
return instance;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static <T> T createInstance(Class<T> classType) {
|
||||||
|
try {
|
||||||
|
return classType.getConstructor().newInstance();
|
||||||
|
} catch (Exception e) {
|
||||||
|
throw new RuntimeException(e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,9 @@
|
|||||||
|
package org.example.di;
|
||||||
|
|
||||||
|
|
||||||
|
import java.lang.annotation.Retention;
|
||||||
|
import java.lang.annotation.RetentionPolicy;
|
||||||
|
|
||||||
|
@Retention(RetentionPolicy.RUNTIME)
|
||||||
|
public @interface Inject {
|
||||||
|
}
|
||||||
@@ -0,0 +1,4 @@
|
|||||||
|
package org.example.di;
|
||||||
|
|
||||||
|
public class BookRepository {
|
||||||
|
}
|
||||||
@@ -0,0 +1,7 @@
|
|||||||
|
package org.example.di;
|
||||||
|
|
||||||
|
public class BookService {
|
||||||
|
|
||||||
|
@Inject
|
||||||
|
BookRepository bookRepository;
|
||||||
|
}
|
||||||
@@ -0,0 +1,21 @@
|
|||||||
|
package org.example.di;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import static org.junit.Assert.*;
|
||||||
|
|
||||||
|
public class ContainerServiceTest {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void getObject_BookRepository() {
|
||||||
|
BookRepository bookRepository = ContainerService.getObject(BookRepository.class);
|
||||||
|
assertNotNull(bookRepository);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void getObject_BookService() {
|
||||||
|
BookService bookService = ContainerService.getObject(BookService.class);
|
||||||
|
assertNotNull(bookService);
|
||||||
|
assertNotNull(bookService.bookRepository);
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user