Maven中依赖范围对传递依赖的影响
1.问题描述
当在写junit测试时发现,代码报出没有找不到类的错误信息:

是因为没有junit.jar引起的!为什么会这样呢?我们ssm_dao模块中有junit依赖而ssm_service模块依赖了ssm_dao,难道junit不应该传递过来吗?
2.依赖范围对传递依赖的影响
是因为依赖会有依赖范围,依赖范围对传递依赖也有影响,例如有A、B、C,A依赖B、B依赖C,C可能是A的传递依赖,如下图:

最左边一列为直接依赖,理解为A依赖B的范围,最顶层一行为传递依赖,理解为B依赖C的范围,行与列的交叉即为A传递依赖C的范围。
3.举例
举例1
比如 A对 B 有 compile 依赖,B 对C有 runtime 依赖,那么根据表格所示A对C 有 runtime 依赖。
ssm_dao依赖junit,scop为test
ssm_service依赖ssm_dao.

所以ssm_dao工程所依赖的junit的jar没有加入到ssm_service工程。
举例2
如果修改ssm_dao工程依赖junit的scop为compile,ssm_dao工程所依赖的junit的jar包会加入到ssm_service工程中,符合上边表格所示,查看下图红色框内所示:

4.单元测试
遇到依赖没有传递过来的问题我们通常的解决方案是在本工程中直接添加依赖:
把如下依赖添加到ssm_service的工程中:

再看测试代码也不报错了


本文探讨了Maven依赖范围如何影响传递性依赖,通过实例解释了为何在单元测试中可能会遇到类找不到的错误。当依赖的scope设置为'test'时,该依赖不会被传递给其他模块。解决方案是在需要使用该依赖的模块中直接声明。文章通过两个例子详细阐述了不同scope设置对依赖传递的影响,并提供了相应的单元测试解决方案。
715

被折叠的 条评论
为什么被折叠?



