1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16 package org.apache.ibatis.submitted.typehandlerinjection;
17
18 import java.io.Reader;
19 import java.util.List;
20
21 import org.apache.ibatis.BaseDataTest;
22 import org.apache.ibatis.io.Resources;
23 import org.apache.ibatis.session.SqlSession;
24 import org.apache.ibatis.session.SqlSessionFactory;
25 import org.apache.ibatis.session.SqlSessionFactoryBuilder;
26 import org.junit.jupiter.api.Assertions;
27 import org.junit.jupiter.api.BeforeAll;
28 import org.junit.jupiter.api.Test;
29
30 class TypeHandlerInjectionTest {
31
32 private static SqlSessionFactory sqlSessionFactory;
33
34 private static final UserStateTypeHandler<String> handler = new UserStateTypeHandler<>();
35
36 @BeforeAll
37 static void setUp() throws Exception {
38
39 try (Reader reader = Resources
40 .getResourceAsReader("org/apache/ibatis/submitted/typehandlerinjection/mybatis-config.xml")) {
41 sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader);
42 }
43
44 sqlSessionFactory.getConfiguration().getTypeHandlerRegistry().register(handler);
45 sqlSessionFactory.getConfiguration().addMapper(Mapper.class);
46
47
48 BaseDataTest.runScript(sqlSessionFactory.getConfiguration().getEnvironment().getDataSource(),
49 "org/apache/ibatis/submitted/typehandlerinjection/CreateDB.sql");
50 }
51
52 @Test
53 void shouldGetAUser() {
54 try (SqlSession sqlSession = sqlSessionFactory.openSession()) {
55 Mapper mapper = sqlSession.getMapper(Mapper.class);
56 List<User> users = mapper.getUsers();
57 Assertions.assertEquals("Inactive", users.get(0).getName());
58 }
59 }
60
61 }