代码差异对比之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

- 输出结果

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详解!的更多相关文章
- git diff详解
这篇文章很好很好 https://www.cnblogs.com/alfayed/p/4682780.html
- Git命令详解
一个中文git手册:http://progit.org/book/zh/ 原文:http://blog.csdn.net/sunboy_2050/article/details/7529841 前面两 ...
- Git 命令详解及常用命令
Git 命令详解及常用命令 Git作为常用的版本控制工具,多了解一些命令,将能省去很多时间,下面这张图是比较好的一张,贴出了看一下: 关于git,首先需要了解几个名词,如下: 1 2 3 4 Work ...
- Git应用详解第九讲:Git cherry-pick与Git rebase
前言 前情提要:Git应用详解第八讲:Git标签.别名与Git gc 这一节主要介绍git cherry-pick与git rebase的原理及使用. 一.Git cherry-pick Git ch ...
- Git初探--笔记整理和Git命令详解
几个重要的概念 首先先明确几个概念: WorkPlace : 工作区 Index: 暂存区 Repository: 本地仓库/版本库 Remote: 远程仓库 当在Remote(如Github)上面c ...
- 【Git使用详解】Egit的常用操作详解
常用操作 操作 说明 Fetch 从远程获取最新版本到本地,不会自动merge Merge 可以把一个分支标签或某个commit的修改合并现在的分支上 Pull 从远程获取最新版本并merge到本地相 ...
- git部署详解
1.1 关于版本控制 1.1.1 本地版本控制 本地版本控制系统 许多人习惯用复制整个项目目录的方式来保存不同的版本,或许还会改名加上备份时间以示区别.这么做唯一的 好处就是简单,但是特别容易犯错.有 ...
- ORM框架对比以及Mybatis配置文件详解
ORM框架对比以及Mybatis配置文件详解 0.数据库操作框架的历程 (1) JDBC JDBC(Java Data Base Connection,java数据库连接)是一种用于执行SQL语句 ...
- iOS开发——开发实战篇&版本控制SVN和Git使用详解
版本控制SVN和Git使用详解 公司的实际开发中,在天朝使用较多的还是SVN,因为SVN是集中式的,在天朝上班你们都懂的! -----------------svn--------- ...
- git命令详解( 四 )
此篇为git命令详解的第四篇,话不多说,我们直接上知识点好吧 git Push 偏离的工作 gitPush: 此命令负责将你的变更上传到指定的远程仓库,并在远程仓库上合并你的新提交记录.一旦 git ...
随机推荐
- .NET Core学习笔记(6)——UWP略过SSL证书调用SignalR服务
在前一篇<.NET Core学习笔记(5)--WebAPI从Server端push消息到Client>中,我们简单学习了.NET Core版本SignalR的使用.Sample工程里我们创 ...
- pipx 使用
pipx 用于在孤立环境中安装和运行 Python 应用程序.类似 Node.js 中的 npx. 安装 macOS: brew install pipx pipx ensurepath Ubuntu ...
- yum命令提示error: rpmdb: BDB0113 Thread/process,解决方法
最近在做RHCE的题目,yum命令装vdo时,使用yum install命令的时候,提示error: rpmdb: BDB0113 Thread/process,具体错误如下: [root@node2 ...
- Linq操作XML生成XML,实体生成XML和互转
开发接口中难免会遇到一些数据对接需要转换城xml,看到很多之前的代码都使用很传统的方法循环集合并定义xml后一一生成的,代码之封锁 特此使用了简单易用linq操作分享给大家,希望可以帮到需要的同学 今 ...
- 一文了解svg之stroke属性
属性 stroke-width SVG具有stroke-width定义笔触宽度的CSS属性. <svg width="500" height="120"& ...
- JavaScript – Proxy
参考 阮一峰 – Proxy 介绍和使用 Proxy 的作用是代理对象, 消费者不直接使用对象, 而是使用代理对象. 一般上做代理的目的就是想拦截对象访问做一些别的事情. 比如当对象改变以后, 同步 ...
- Google sheet
最近做比较多 data migration 的东西. 当我们开发一个新的系统去替代一个旧系统时,通常就需要做大量的 migration 动作. 有好几个做法 我之前比较常用的的工具是 sql 和 c# ...
- 课时09:Metasploit使用基础
下载地址:https://docs.metasploit.com/docs/using-metasploit/getting-started/nightly-installers.html Explo ...
- 阿里云Tomcat7配置域名详解
一. 进入阿里云服务控制台,点击SSL证书 看到下载了么,对应着你的域名点击下载服务器类型选择Tomcat,点击下载,压缩包中包含 xxxxx__test.com.pfx, pfx-password. ...
- 使用BPF之前和之后生成直方图过程的对比
以bitehist为例: 使用BPF之前: 1.在内核中:开启磁盘IO事件的插桩观测. 2.在内核中,针对每个事件:向perf缓冲区写入一条记录.如果使用了跟踪点技术(推荐方式),记录中会包含关于磁盘 ...