我们上次写了一个user-core模块,管理用户信息的,这次我们写另外一个模块(日志模块),为以后的Maven耦合做准备。
我们创建日志模块的工程,依然创建Maven项目(user-log):
我们要使用common logging来写日志信息,所以我们在pom中添加这个依赖:
然后我们将第一个项目user-core和第二个项目user-log都打成jar包,并且上传至本地仓库:
鼠标放在项目的pom.xml上,点击鼠标右键:
然后我们将之前的两个模块都加进去:
我们会发现,所有和user-core和user-log有关的依赖jar包全部都加进工程来了:
这就是传说中的“依赖传递”。
接下来在该模块中创建Service类:
IUserService:
UserService:
接下来我们做测试:
因为我们要使用easymock来测试两个模块之间的调用关系是否正常,所以我们在pom.xml添加此依赖:
然后我们编写测试类:
TestUserService:
测试结果成功:
下一次我们做Web模块,将我们的核心模块user-core、日志模块user-log以及业务模块user-service合并到我们的Web层中去。
转载请注明出处:http://blog.csdn.net/acmman/article/details/50623047
我们创建日志模块的工程,依然创建Maven项目(user-log):
我们要使用common logging来写日志信息,所以我们在pom中添加这个依赖:
<dependency> <groupId>commons-logging</groupId> <artifactId>commons-logging</artifactId> <version>1.1.1</version> </dependency>我们还需要特殊版本的log4j:
<dependency> <groupId>log4j</groupId> <artifactId>log4j</artifactId> <version>1.2.9</version> </dependency>
然后我们将第一个项目user-core和第二个项目user-log都打成jar包,并且上传至本地仓库:
鼠标放在项目的pom.xml上,点击鼠标右键:
然后我们将之前的两个模块都加进去:
<dependency> <groupId>${project.groupId}</groupId> <artifactId>user-log</artifactId> <version>${project.version}</version> </dependency> <dependency> <groupId>${project.groupId}</groupId> <artifactId>user-core</artifactId> <version>${project.version}</version> </dependency>
我们会发现,所有和user-core和user-log有关的依赖jar包全部都加进工程来了:
这就是传说中的“依赖传递”。
接下来在该模块中创建Service类:
IUserService:
package cn.edu.hpu.maven.user_service; import cn.edu.hpu.user.model.User; public interface IUserService { public void add(User user); public User loadByUsername(String username); }
UserService:
package cn.edu.hpu.maven.user_service; import cn.edu.hpu.user.dao.IUserDao; import cn.edu.hpu.user.model.User; public class UserService implements IUserService{ private IUserDao userDao; public UserService(IUserDao userDao) { super(); this.userDao = userDao; } public void add(User user) { userDao.add(user); } public User loadByUsername(String username) { return userDao.loadUsername(username); } }
接下来我们做测试:
因为我们要使用easymock来测试两个模块之间的调用关系是否正常,所以我们在pom.xml添加此依赖:
<dependency> <groupId>org.easymock</groupId> <artifactId>easymock</artifactId> <version>3.4</version> </dependency>
然后我们编写测试类:
TestUserService:
package cn.edu.hpu.maven.user_service; import static org.easymock.EasyMock.*; import org.junit.After; import org.junit.Before; import org.junit.Test; import cn.edu.hpu.user.dao.IUserDao; import cn.edu.hpu.user.model.User; import cn.edu.hpu.user.util.EntitiesHelper; public class TestUserService { private IUserDao userDao; private IUserService userService; private User baseUser; @Before public void setUp(){ userDao= createStrictMock(IUserDao.class); userService=new UserService(userDao); baseUser=new User("admin","123","dmin"); } @Test public void testAdd(){ userDao.add(baseUser); expectLastCall(); replay(userDao); userService.add(baseUser); } @Test public void testLoadByUsername(){ expect(userDao.loadUsername("admin")).andReturn(baseUser); replay(userDao); User tu=userService.loadByUsername("admin"); EntitiesHelper.assertUser(tu, baseUser); } @After public void tearDown(){ verify(userDao); } }然后我们测试并打包:
测试结果成功:
下一次我们做Web模块,将我们的核心模块user-core、日志模块user-log以及业务模块user-service合并到我们的Web层中去。
转载请注明出处:http://blog.csdn.net/acmman/article/details/50623047