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

  • 输出结果

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. git diff详解

    这篇文章很好很好 https://www.cnblogs.com/alfayed/p/4682780.html

  2. Git命令详解

    一个中文git手册:http://progit.org/book/zh/ 原文:http://blog.csdn.net/sunboy_2050/article/details/7529841 前面两 ...

  3. Git 命令详解及常用命令

    Git 命令详解及常用命令 Git作为常用的版本控制工具,多了解一些命令,将能省去很多时间,下面这张图是比较好的一张,贴出了看一下: 关于git,首先需要了解几个名词,如下: 1 2 3 4 Work ...

  4. Git应用详解第九讲:Git cherry-pick与Git rebase

    前言 前情提要:Git应用详解第八讲:Git标签.别名与Git gc 这一节主要介绍git cherry-pick与git rebase的原理及使用. 一.Git cherry-pick Git ch ...

  5. Git初探--笔记整理和Git命令详解

    几个重要的概念 首先先明确几个概念: WorkPlace : 工作区 Index: 暂存区 Repository: 本地仓库/版本库 Remote: 远程仓库 当在Remote(如Github)上面c ...

  6. 【Git使用详解】Egit的常用操作详解

    常用操作 操作 说明 Fetch 从远程获取最新版本到本地,不会自动merge Merge 可以把一个分支标签或某个commit的修改合并现在的分支上 Pull 从远程获取最新版本并merge到本地相 ...

  7. git部署详解

    1.1 关于版本控制 1.1.1 本地版本控制 本地版本控制系统 许多人习惯用复制整个项目目录的方式来保存不同的版本,或许还会改名加上备份时间以示区别.这么做唯一的 好处就是简单,但是特别容易犯错.有 ...

  8. ORM框架对比以及Mybatis配置文件详解

    ORM框架对比以及Mybatis配置文件详解 0.数据库操作框架的历程 (1) JDBC ​ JDBC(Java Data Base Connection,java数据库连接)是一种用于执行SQL语句 ...

  9. iOS开发——开发实战篇&版本控制SVN和Git使用详解

     版本控制SVN和Git使用详解     公司的实际开发中,在天朝使用较多的还是SVN,因为SVN是集中式的,在天朝上班你们都懂的!     -----------------svn--------- ...

  10. git命令详解( 四 )

    此篇为git命令详解的第四篇,话不多说,我们直接上知识点好吧 git Push 偏离的工作 gitPush: 此命令负责将你的变更上传到指定的远程仓库,并在远程仓库上合并你的新提交记录.一旦 git ...

随机推荐

  1. 如何将一个模块文件编译到Linux内核中?

    很多粉丝在群里提问,如何把一个模块文件编译到内核中或者独立变异成ko文件.本文给大家详解讲解. 1. 内核目录 Linux内核源代码非常庞大,随着版本的发展不断增加.它使用目录树结构,并且使用Make ...

  2. Python 开发中,使用bcrypt 或 Passlib 对系统用户密码进行哈希和验证处理

    在设计一个系统的时候,肯定都有会有用户身份认证的问题,一般对用户校验的时候,都是对用户存在数据库总的密码哈希值进行判断,从而避免密码泄露和反向解密,那么在Python 开发中,我们可以引入bcrypt ...

  3. TCP/TP协议栈(逐渐更新版)

    TCP/IP协议栈 应用层 DNS协议 传输层 TCP协议 TCP协议报文结构 源端口 目的端口 序列号 确认号 头长度header length or data offset 保留字段reserve ...

  4. 安装 Ubuntu / Windows 双系统

    最近给自己的老笔记本换了一块大硬盘,顺便装了 Windows 和 Ubuntu 两个操作系统.记录一下安装过程. 提示:Ubuntu 安装程序可以检测到磁盘已有的 Windows 安装.所以如果先安装 ...

  5. MSYS2、MinGW、Cygwin 关系梳理

    还记得大一刚开始写 C 代码时,经常看到 MSYS2.MinGW.Cygwin 等名词.对于第一次接触编程的我来说这些名词让我眼花缭乱.当时查阅了一些资料,但是对于这些名词的解释始终让我云里雾里.现在 ...

  6. 3d格式介绍之OBJ格式

    OBJ格式是一种用于3D模型的文件格式,全称为Wavefront OBJ.它由Wavefront Technologies公司开发,最初用于其高级视觉动画软件,但后来广泛应用于各种3D图形软件中. 本 ...

  7. springboot 大文件切片上传

    1. 前端(vue element ui & 原生) 初始变量声明: currentFile: {}, // 当前上传的文件 bigFileSliceCount: 20, // 大文件切片后的 ...

  8. AWS Data Analytics Fundamentals 官方课程笔记 - Intro, Volumn, Velocity

    Intro process 就是 The process component is where services manipulate data into needed forms. 比如补齐 nul ...

  9. PageHeper

    PageHelper 是一个非常流行的 MyBatis 分页插件,主要用于简化分页查询的实现.使用 PageHelper 可以在执行数据库查询时,自动处理分页参数,从而避免手动编写繁琐的分页逻辑. 今 ...

  10. 【QT界面美化】QT界面美化效果截图QSS+QML

    贴几个QT做的界面美化效果截图. 先来一张动图,有一些画面是QT Widgets + QSS实现的:另外一些画面是QT QML实现的. QT界面美化效果图QT QSS QML 补天云QT技术培训专家 ...