栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

Maven入门宝典(三)Maven工程测试&依赖冲突调解

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Maven入门宝典(三)Maven工程测试&依赖冲突调解

目录

一.Maven工程测试

1.测试概述

2.Junit使用步骤

3.Junit结果判定

4.@Before、@After

二.依赖冲突调解

1.最短路径优先原则

2.最先声明原则

3.排除依赖、锁定版本


一.Maven工程测试

1.测试概述 测试即在交付前对写好的代码进行评测,分为黑盒测试和白盒测试:
  • 黑盒测试:不需要写代码,给输入值,看程序是否能够输出期望的值。
  • 白盒测试:需要写代码的。关注程序具体的执行流程。

单元测试是指对软件中的最小可测试单元进行检查和验证, Java 里单元测试指一个类的功能。单元测试是在软件开发过程中要进行的 最低级别的测试活动,软件的独立单元将在与程序的其他部分相隔 离的情况下进行测试。 Junit 是 Java 编程语言的单元测试框架,用于编写和运行可重复的自动化测试。从分类中属于白盒测试。 其实就是测试每一个方法是否好用。

2.Junit使用步骤

在Maven项目中引入依赖


    junit
    junit
    4.12
    test

补充上面的代码之后,maven就会自动导入相应的jar包,可见maven真的很方便!

定义被测试的类 我们定义一个计算器工具类。
package com.first.util;

public class Calculator {
    //加法
    public int add(int a,int b){
        return a+b;
    }
    //除法
    public int div(int a,int b){
        return a/b;
    }
}
对定义的类进行测试 1
  • 创建src/test/java包,并将改包设置为测试包。
  • 在src/test/java中创建测试类的包,包名一般与被测试包名一致。
  • 定义测试类,类名一般为被测试类+Test
  • 测试类中编写测试方法。

 测试类:

package com.first.util;

import org.junit.Test;

public class CalculatorTest {
    
    @Test
    public void testAdd(){
        Calculator calculator=new Calculator();
        int add=calculator.add(1,2);
        System.out.println(add);
    }

    @Test
    public void testDiv(){
        Calculator calculator=new Calculator();
        int div=calculator.div(2,0);
        System.out.println(div);
    }
}

项目结构:

3.Junit结果判定 点击测试方法边的三角运行测试方法,如果出现绿色对钩,证明方法能正常运行;如果出现红色感叹号,证明方法抛出异常,需要修 改方法。

也可以执行test命令

也可以点击Lifecycle的test

当然,不是能正常运行就代表方法一定没有问题,也有可能方法的结果和预期结果不一致,这时就需要使用断言操作。 修改testAdd方法: 如果预期结果和实际结果不一致,那么会报错
    @Test
    public void testAdd(){
        Calculator calculator=new Calculator();
        int add=calculator.add(1,2);
        //System.out.println(add);
        
        Assert.assertEquals(4,add);
    }

add是3,但是预期结果是4,报错如下:

如果断言符合的话,那么不会报错。

4.@Before、@After

@Before修饰前置方法
@After修饰后置方法

在测试类中, @Before 修饰的方法会在测试方法之前 自动执行 ,@After 修饰的方法会在测试方法执行之后 自动执行 。之后的学习 中,我们可以设置前置方法为获取资源,后置方法为释放资源。

 对上面的方法进行修改,使testAdd不报错,然后执行testAdd

package com.first.util;

import org.junit.After;
import org.junit.Assert;
import org.junit.Before;
import org.junit.Test;

public class CalculatorTest {
    @Before
    public void before(){
        System.out.println("开始测试!");
    }
    @After
    public void after(){
        System.out.println("结束测试");
    }
    
    @Test
    public void testAdd(){
        Calculator calculator=new Calculator();
        int add=calculator.add(1,2);
        System.out.println(add);
        
        //Assert.assertEquals(3,add);
    }

    @Test
    public void testDiv(){
        Calculator calculator=new Calculator();
        int div=calculator.div(2,0);
        System.out.println(div);
    }
}

输出:

开始测试!
3
结束测试

二.依赖冲突调解

1.最短路径优先原则 依赖冲突产生的原因 —— 依赖传递 假设你的项目依赖 jar 包 A , jar 包 A 又依赖 jar 包 B 。当添加 jar 包 A 时,Maven 会把 jar 包 B 也自动加入到项目中。比如刚刚我们添加了 junit 依赖, junit 又依赖 hamcrest ,所以 Maven 会将 junit 和 hamcrest 都 加入项目中。

 

这时就可能会产生依赖冲突问题,比如依赖 A 会引入依赖 C ,依赖 B也会引入依赖 C 。如果不进行调解则会引入两个依赖 C(且这两个依赖C版本不同) ,那么 Maven 是如何解决依赖冲突问题的呢?

 

依赖冲突调解 我们以 Spring 依赖为例, spring-webmvc 依赖 spring-aop , spring-context 也依赖 spring-aop ,如果两个同时引入,会引入哪个版本的 spring-aop 呢?

    org.springframework
    spring-context
    5.2.12.RELEASE
 

    org.springframework
    spring-webmvc
    4.2.4.RELEASE
Maven 调解依赖冲突的第一原则是最短路径优先原则: 也就是说项目依赖关系树中路径最短的版本会被使用。例如,假设有几个 jar 包之间的依赖关系是: A - >B - >C - >D(2.0) 和 E - >F - >D(1.0) ,如果同时 引入 A 和 E ,那么 D(1.0) 会被使用,因为 E 到 D 的路径更短。 查看依赖路径的方式如下:

 

spring-webmvc到spring-aop的路径如下:

对于上面的配置代码的的依赖图如下:

spring-webmvc 到 spring-aop 的路径如下:

spring-context到spring-aop的路径如下: 

可以看到, spring-webmvc 到 spring-aop 的路径为: spring - webmvc -> spring - context -> spring - aop 而 spring-context 到 spring-aop 的路径为: spring - context -> spring - aop spring-context 到 spring-aop 的路径更短,所以 spring-aop 会按照spring-context 的版本引入。

 

2.最先声明原则 最短路径优先原则不能解决所有问题,比如这样的依赖关系: A–>B–>C(1.0) 和 D–>E–>C(2.0) ,同时引入 A 和 D 之后, C(1.0) 和 C(2.0) 的依赖路径 长度都为 2 。此时第一原则将不能解决问题 Maven 调解依赖冲突的第二原则是最先声明原则: 在依赖路径长度相等的前提下,在 POM 中依赖声明的顺序靠前( 即配置代码在上的 )的会被解析使用。比如:以上案例中, spring-webmvc 和 spring -context 到 spring-core 的路径都为 1 。谁声明在上方, spring-core 会 按照谁的版本引入。 

3.排除依赖、锁定版本 如果不想使用 Maven 默认的冲突调解方式,有两种方式可以手动进行冲突调解。 排除依赖 比如以上案例中,想使用 spring-webmvc 的 spring-aop 包,那么可以让 spring-context 引入时排除引入 spring-aop 包,这样就可以使 用 spring-webmvc 的 spring-aop 包了,写法如下:

锁定版本 在 Maven 中为某个 jar 包配置锁定版本后,不考虑依赖的声明顺序和依赖路径,以锁定的版本的为准添加到工程中,此方法在企业开发 中常用。以下可以直接配置 spring-aop 锁定的版本。

    
        
            org.springframework
            spring-aop
            4.2.4.RELEASE
        
    

 

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/884370.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号