• 代码差异对比之git diff详解!


    图片

    1、测试对比文件准备

    • 文件A:diff1(diff1文件夹下可以放n个文件)
    
    public class Diff1 {
        public static void main(String[] args){
            int getNum = randomNumber(10,20);
            if (getNum==30){
                System.out.println("中间数="+getNum);
            }else {
                System.out.println("此次没有找到="+getNum);
            }
        }
        public static int randomNumber(int minNum,int maxNum){
            Random rand = new Random();
            int randomNum = rand.nextInt(maxNum);
            randomNum = randomNum%(maxNum-minNum+1)+minNum;
            return randomNum;
        }
    }
    
    • 文件B:diff2(diff2文件夹下可以放n个文件)
    public class Diff2 {
        public static void main(String[] args){
            int addLine =10;
            int getNum = randomNumber(10,20);
            if (getNum==30){
                System.out.println("中间数="+getNum);
            }else {
    //            System.out.println("此次没有找到="+getNum);
            }
        }
        public static int randomNumber(int minNum,int maxNum){
            Random rand = new Random();
            int randomNum = rand.nextInt(maxNum);
            randomNum = randomNum%(maxNum-minNum+1)+minNum;
            return randomNum;
        }
    }
    

    2、git diff对比命令

    diff --git /Users/diff1 /Users/diff2
    

    image.gif

    • 输出结果
    diff --git a/Users/cuizhongyuan/Desktop/work/010_project/vueSpringboot/Tal_Back/src/test/java/gitdiff/diff1/Diff1.java b/Users/cuizhongyuan/Desktop/work/010_project/vueSpringboot/Tal_Back/src/test/java/gitdiff/diff2/Diff2.java
    similarity index 77%
    rename from /Users/cuizhongyuan/Desktop/work/010_project/vueSpringboot/Tal_Back/src/test/java/gitdiff/diff1/Diff1.java
    rename to /Users/cuizhongyuan/Desktop/work/010_project/vueSpringboot/Tal_Back/src/test/java/gitdiff/diff2/Diff2.java
    index 7d6e724..bfca53f 100644
    --- a/Users/cuizhongyuan/Desktop/work/010_project/vueSpringboot/Tal_Back/src/test/java/gitdiff/diff1/Diff1.java
    +++ b/Users/cuizhongyuan/Desktop/work/010_project/vueSpringboot/Tal_Back/src/test/java/gitdiff/diff2/Diff2.java
    @@ -1,14 +1,15 @@
    -package gitdiff.diff1;
    +package gitdiff.diff2;
     
     import java.util.Random;
     
    -public class Diff1 {
    +public class Diff2 {
         public static void main(String[] args){
    +        int addLine =10;
             int getNum = randomNumber(10,20);
             if (getNum==30){
                 System.out.println("中间数="+getNum);
             }else {
    -            System.out.println("此次没有找到="+getNum);
    +//            System.out.println("此次没有找到="+getNum);
             }
         }
         public static int randomNumber(int minNum,int maxNum){
    

    3、输出格式详解(重点)

    • 第一行
    diff --git a/Users/diff1/Diff1.java b/Users/diff2/Diff2.java
    

    解释:进行比较的是->diff1版本的Diff1.java(即变动前)和diff2版本的Diff2.java(即变动后)

    • 第二行
    index 7d6e724..bfca53f 100644
    

    解释:表示两个版本的git哈希值(index区域的7d6e724对象,与工作目录区域的bfca53f对象进行比较),最后的六位数字是对象的模式(普通文件,644权限)

    • 第三行
    --- a/Users/diff1/Diff1.java+++ b/Users/diff2/Diff2.java
    

    解释:"—“表示变动前的版本,”+++"表示变动后的版本

    • 第四行
    @@ -1,14 +1,15 @@
    

    解释:其中"-1,14″分成三个部分解释->”-“减号表示第一个文件(即diff1),"1″表示第1行,“14″表示连续14行.合在一起,就表示下面是第一个文件从第1行开始的连续14行.同样的,”+1,15″表示变动后,成为第二个文件从第1行开始的连续15行

    • 最后是具体的变动内容
    -public class Diff1 {
    +public class Diff2 {
         public static void main(String[] args){
    +        int addLine =10;
             int getNum = randomNumber(10,20);
             if (getNum==30){
                 System.out.println("中间数="+getNum);
             }else {
    -            System.out.println("此次没有找到="+getNum);
    +//            System.out.println("此次没有找到="+getNum);
             }
         }
         public static int randomNumber(int minNum,int maxNum){
    
    

    解释:+ int addLine =10;->表示:新增行
    | - System.out.println(“此次没有找到=”+getNum);
    +// System.out.println(“此次没有找到=”+getNum); ->表示改行的变动(- 表示之前,+表示之后)git diff 没有修改的概念

    4、获取到git diff对比结果可以做什么?

    通过Git diff可以获取到项目当前分支下提交前后的代码变动结果,有了这个结果进一步解析可以去做代码覆盖率的实现,在测试阶段可以作为测试覆盖度的一个指标,同时也可以查漏补缺那些业务代码逻辑没有测到,实现精准测试的目的。

    • 实际项目中实践如图:



    更多测试技术分享、学习资源以及一些其他福利可关注公众号:【Coding测试】获取:

  • 相关阅读:
    关于在centos下安装python3.7.0以上版本时报错ModuleNotFoundError: No module
    MSTP协议介绍和堆叠技术介绍
    RSTP技术详解
    5招解决路由黑洞
    系统批量运维管理器Fabric之部署LNMP业务环境
    系统批量运维管理器Fabric之动态获取远程目录列表
    系统批量运维管理器Fabric之查看远程主机信息
    系统批量运维管理器Fabric之基本语法篇
    系统批量运维管理器Fabric之环境搭建篇
    LightGBM 调参方法(具体操作)
  • 原文地址:https://www.cnblogs.com/CodingTest/p/15679361.html
Copyright © 2020-2023  润新知