Azure DevOps Server: 使用Rest Api获取拉取请求Pull Request中的变更文件清单
需求:
Azure DevOps Server 的拉取请求模块,为开发团队提供了强大而且灵活的代码评审功能。拉取请求中变更文件清单,对质量管理人员,是一个宝贵的材料。质量保障人员可以从代码清单中分析不通文件的修改频率、不通文件对应需求类型的关联关系的功能。通过对这些数据的分析,可以深度挖掘开发过程中积累的数据的价值。下面介绍如何使用Azure DevOps Server 提供的Rest Api 轻易获取拉取请求的变革清单文件。
第一步:获取所有拉取请求
首先需要从拉取请求清单中获取你指定的拉取请求的API地址,例如下面的样例获取了ID为“”的一个拉取请求,属性url就是该拉取请求的详细信息接口。
Api样例:http://DevOpsServer:8080/tfs/defaultcollection/mydelegate/_apis/git/repositories/HelloWorld2/pullrequests
{
"value": [{
"repository": {
"id": "e7b2adbc-dab4-4432-a0df-072b9a8d48b9",
"name": "HelloWorld2",
"url": "http://DevOpsServer:8080/tfs/DefaultCollection/_apis/git/repositories/e7b2adbc-dab4-4432-a0df-072b9a8d48b9",
......
}],
"count": 1
}
第二步:获取指定拉取请求的最后一次推送Push(Iteration)
拉取请求中包含了开发人员多次推送的数据,在API中使用Iteration来记录,实际上就是Push信息。下面的Api获取拉取请求所有的推送信息
Api样例:http://DevOpsServer:8080/tfs/DefaultCollection/_apis/git/repositories/e7b2adbc-dab4-4432-a0df-072b9a8d48b9/pullRequests/3/iterations
{
"value": [{
"id": 1,
"description": "已删除 tfs移动办公.txt",
"author": {
"displayName": "tfsadmin",
"url": "http://DevOpsServer:8080/tfs/DefaultCollection/_apis/Identities/f2f9bb4a-b4e2-4af2-b7ba-5b0547fdb085",
......
}
}, {
"id": 8,
"description": "change file",
"author": {
"displayName": "tfsadmin",
"url": "http://tfsdb:8080/tfs/DefaultCollection/_apis/Identities/f2f9bb4a-b4e2-4af2-b7ba-5b0547fdb085",
"_links": {
"avatar": {
"href": "http://DevOpsServer:8080/tfs/DefaultCollection/_api/_common/identityImage?id=f2f9bb4a-b4e2-4af2-b7ba-5b0547fdb085"
}
},
"id": "f2f9bb4a-b4e2-4af2-b7ba-5b0547fdb085",
"uniqueName": "",
"imageUrl": "http://DevOpsServer:8080/tfs/DefaultCollection/_api/_common/identityImage?id=f2f9bb4a-b4e2-4af2-b7ba-5b0547fdb085"
},
"createdDate": "2019-03-07T02:07:30.419852Z",
"updatedDate": "2019-03-07T02:07:30.419852Z",
"sourceRefCommit": {
"commitId": "0c962a9213548ffbde87c9e0dfc7d6217e32e8cc"
},
"targetRefCommit": {
"commitId": "8120ded05da8e404f7e2818f71001b4d09ac4325"
},
"commonRefCommit": {
"commitId": "8120ded05da8e404f7e2818f71001b4d09ac4325"
},
"hasMoreCommits": false,
"reason": "push",
"push": {
"pushId": 43
}
}],
"count": 8
}
上面结果中最大的结果为推送编号为8
第三步:获取最后一次推送的变更
在Azure DevOps的涉及中,系统返回最后一次iteration中的结果,就是拉取请求中的所有变更文件,与git diff的结果一致。
http://DevOpsServer:8080/tfs/DefaultCollection/_apis/git/repositories/e7b2adbc-dab4-4432-a0df-072b9a8d48b9/pullRequests/3/iterations/4/changes?$top=99999
{
"changeEntries": [{
"changeTrackingId": 2,
"changeId": 1,
"item": {
"objectId": "457947435875FCD4A54E734E77F4D418B609079F",
"path": "/incrementalprogram.sln"
},
"changeType": "add"
}, {
"changeTrackingId": 3,
"changeId": 2,
"item": {
"objectId": "FA2758F61086EF18731420FA00AE37050C4BF436",
"path": "/本周工作.txt"
},
"changeType": "add"
}, {
"changeTrackingId": 4,
"changeId": 3,
"item": {
"objectId": "F8B4888565CAADC7510BE75682268D6C18EDD6DE",
"path": "/.vs/ProjectSettings.json"
},
"changeType": "add"
}, {
"changeTrackingId": 5,
"changeId": 4,
"item": {
"objectId": "66EE8634380AE95E26C9EEAD773917D077C62F50",
"path": "/.vs/slnx.sqlite"
},
"changeType": "add"
}]
}
通过统计分析最后一次推送包含的全部变更文件,我们就可以获取到这个拉取请求中包含的全部文件,效果和Web页面中拉取请求的文件清单完全一样。
图一:拉取请求
注意:
- 如果文件量太大,超出了默认返回100条的数量,需要在URL的参数中指定top=9999,表明每次调用API需要返回的数量。配置skip参数,还可以实现分页功能。
微软DevOps MVP 张洪君 http://www.cnblogs.com/danzhang
--End--
Azure DevOps Server: 使用Rest Api获取拉取请求Pull Request中的变更文件清单的更多相关文章
- 还原Azure DevOps Server (TFS)中误删除的生成流水线
流水线历史记录 DevOps Server流水线的历史记录有完善的版本日志,用户可以随时回退到修改过程中的任何一个版本,还能比较差异.这个历史记录功能可以和代码库中的版本控制媲美. 图一:生成历史记录 ...
- 在Azure DevOps Server (TFS) 中修改团队项目名称
概述 [团队项目]: 在Azure DevOps Server (原名TFS)中,团队项目(Team Project)是一个最基本的数据组织容器,包含了一个团队或者信息系统中的所有信息,包括源代码.文 ...
- 你好,Azure DevOps Server 2019;再见,Team Foundation Server
微软正式发布Azure DevOps Server 2019的第一个版本,作为Team Foundation Server (TFS)2018的升级版本和替代产品. 这是目前市面上唯一一款将产品名称冠 ...
- Azure DevOps Server(TFS) 客户端分析
Azure DevOps Server(TFS) 是微软公司的软件协作开发管理平台产品,为软件研发.测试.实施提供全流程的服务.作为一款应用服务器产品,他的客户端是什么,在哪里下载客户端?我们在项目实 ...
- 在Azure DevOps Server(TFS系统)中部署回退/回滚方案(Rollback)
概述 Azure DevOps Server(之前名TFS)是微软公司实现软件研发.测试和部署一体化的全流程解决方案.在近几年的研发过程中,Azure DevOps Server 大幅增强了软件部署过 ...
- 在Azure DevOps Server的代理服务器安装Python环境
Python和Azure DevOps Server Python是一种计算机程序设计语言.是一种动态的.面向对象的脚本语言,最初主要为系统运维人员编写自动化脚本,在实际应用中,Python已经在前端 ...
- 在Azure DevOps Server (TFS 2019) 流水线传递参数
变量概述 在Azure DevOps Server的流水线中,变量是衔接不同任务和不通代理之间的桥梁,它可以使相对松散.各自独立的任务之间相关影响并共享数据.在流水线中使用变量,可以在各任务之间相互调 ...
- Azure DevOps Server:Git权限设置
Azure DevOps Server 权限概述 在Azure DevOps Server (之前名称为TFS)中,权限是一个比较复杂的概念.从权限层级上来说,包括服务器级别.团队项目集合级别.团队项 ...
- 在Azure DevOps Server 中提交Maven 依赖包(mvn deploy-file)
Contents 1. 概述 2. 必要准备 安装Java 下载安装Maven 3. 服务器配置 新建连接源 4. 客户端配置 5. 上传maven包文件 6. 常见问题 Maven最新版本3.6.2 ...
随机推荐
- Servlet封装类
Servlet 提供了四个封装类: public class ServletRequestWrapper extends java.lang.Object implements ServletRequ ...
- Properties of a scheduled job in Laravel
Every entry you add is converted into an instance of Illuminate\Console\Scheduling\Event and stored ...
- jquery查找frameset框架内iframe的元素
老系统还幸存有过时的frameset框架,维护升级工作需要对其内部的iframe中的元素进行相关操作.使用jquery查找子iframe页面内的元素时,总找不到目标元素.后来发现少了contents ...
- java 多态的深入理解
简单来说 : 多态 能够很好的解决代码耦合性的问题 考虑这样一个场景 有个人 买了辆捷达汽车 .这个系统应该如何设计呢? public class JettaCar { public void run ...
- 消息中间件及WebSphere MQ入门(转载)
消息队列技术是分布式应用间交换信息的一种技术.消息队列可驻留在内存或磁盘上,队列存储消息直到它们被应用程序读走.通过消息队列,应用程序可独立地执行--它们不需要知道彼此的位置.或在继续执行前不需要等待 ...
- Java学习总结1
1. 断点调试 a:定位(设置断点) b:启动调试 c:单步执行 观察变量(F5单步执行 F6单步跳过)d:修改2 static 静态 静态成员,为类的所有对象共享 在静态方法中,只能 ...
- ServiceDesk Plus解析内容,简化工单管理
- 在RedHat 和 Ubuntu 中配置 Delphi 的Linux开发环境(转)
原文地址:http://chapmanworld.com/2016/12/29/configure-delphi-and-redhat-or-ubuntu-for-linux-development/ ...
- Python多进程并发操作进程池Pool
目录: multiprocessing模块 Pool类 apply apply_async map close terminate join 进程实例 multiprocessing模块 如果你打算编 ...
- Java的GUI设计中如何跨界面传值
在Java设计中我们会遇到登录界面的信息,在后面的某个情况也需要使用. 比如这是笔者的一个登录界面 可以看到获取密码和账号 在这个时候的功能的完成需要密码和账号 // 登录信息的获取 public S ...