美文网首页
代码差异对比之git diff详解!

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

作者: Coding测试 | 来源:发表于2021-12-12 22:58 被阅读0次
图片

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测试】获取:

相关文章

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

    1、测试对比文件准备 文件A:diff1(diff1文件夹下可以放n个文件) 文件B:diff2(diff2文件夹...

  • Git diff 比较两个版本文件之间的差异

    一:git diff 基本用法 git diff 什么参数都不加,默认比较工作区暂存区的差异 git diff -...

  • git diff、git diff --cached、git d

    git diff : 对比工作区(未 git add)和暂存区(git add 之后) git diff --ca...

  • Git历史记录

    git diff:输出工作区与暂存区之间的差异 git diff --cached:查看工作区与历史提交之间的差异

  • git 常用命令

    工作需要git管理代码,这是从大神哪里整来的,以留备用 diff 查看工作目录与暂存区的差异 diff --cac...

  • Git: 版本控制(3)

    git diff 对比区别 直接输入 git diff 后面不跟某个文件,即显示出所有文件的区别 git di...

  • Git文件diff

    概述  Git的diff用于对比查看两个文件的不同。 Git的diff内容如下:  查看暂存区和工作区文件对比  ...

  • git diff

    git diff:工作目录中当前文件和暂存区域快照之间的差异git diff --cached:看已经暂存起来...

  • Vue原理「十二」-- vdom和diff算法 *****

    diff 算法概述 diff即对比,是一个广泛的概念,如linux diff、git diff两个JS对象也可以做...

  • git中常用的一些命令

    git diff 比较区别1,当工作区有改动的时候,临时区为空(没有进行git add),那么diff的对比是和上...

网友评论

      本文标题:代码差异对比之git diff详解!

      本文链接:https://www.haomeiwen.com/subject/llmrfrtx.html