热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

【代码质量】程序质量管理|项目管理

目录程序质量管理(一)——关于Review程序质量管理(二)——关于静态代码扫描程序质量管理(三ÿ

目录

 

程序质量管理(一)——关于Review

程序质量管理(二)——关于静态代码扫描

程序质量管理(三)——关于分支管理

程序质量管理(四)——关于配置表管理



程序质量管理(一)——关于Review

Review是日常开发中一个非常重要的步骤,尤其对于项目临发布阶段,或者团队成员水平参差不齐的情况下。

代码审查(review)的平台:


1 gitlab

gitlab也是支持代码评审流程的(支持有限度的代码审核)

因此大部分研发团队都搭建Gitlab进行代码管理。但其实,gitlab也是支持代码评审流程的。如果我们研发团队如果规模不大(例如10个人左右)

GitLab介绍
GitLab:是一个基于Git实现的在线代码仓库托管软件,你可以用gitlab自己搭建一个类似于Github一样的系统,一般用于在企业、学校等内部网络搭建git私服。
功能:Gitlab 是一个提供代码托管、提交审核和问题跟踪的代码管理平台。对于软件工程质量管理非常重要。
版本:GitLab 分为社区版(CE) 和企业版(EE)。
链接:https://www.jianshu.com/p/7e6ea273833d
 

gitlab代码评审教程:

1、https://www.jianshu.com/p/5290a6ad1447

2、https://zhuanlan.zhihu.com/p/130312574

 

2 Gerrit

  Gerrit是一个web代码评审工具,它基于git版本控制系统。Gerrit旨在提供一个轻量级框架,用于在代码入库之前对每个提交进行审阅。‎Gerrit会记录每一次提交的代码修改,但只有它们被审阅和接收后才能合入成为项目的一部分。

Gerrit适用场景?

  任何开发团队都需要中心代码库。下图是一种简单的版本控制和开发流程,开发者获取或者提交修改到中心库,基于中心库进行构建和发布版本。可以看到开发人员可以直接获取和提交修改,中心库的代码质量无法保证。

针对这个问题产生了下图的解决方案,Gerrit部署在中心库位置,Reviewer可以在线对代码检查和评论,只有经过review+2才能合入中心库,增强了中心代码的健壮性。

 

参考文章

Gerrit的官网:https://gerrit.asterisk.org/Documentation/index.html#_tutorial

3 Review Board

利用Review Board平台供团队成员发布Review,在Web上完成Review的工作;在版本控制工具的后台设置触发器,检测提交是否是经过Review的,没有完成Review的修改不允许被提交。

在Review Board上发布一条Review,并通知团队成员进行Review。

没有Review通过的情况下提交会导致提交失败

在收集到足够多的Review通过后,才可以提交到版本控制软件后台,目前我们设置的是至少需要收集到2个人的Review通过。

为了防止Review变成形式主义,对于Review的质量还需要通过行政手段来保证。

reviewboard配套工具post review使用更方便

 

程序质量管理(二)——关于静态代码扫描

Tsacancode、cppcheck

程序质量管理(三)——关于分支管理

在使用版本控制工具进行多版本并行开发的过程中,一定会遇到开分支,以及分支间合并的问题。

之前有看到阿里发布过一篇经验性的文章,介绍阿里是如何进行分支管理的,经过了解和评估,发现并不适用于我的项目。说一下我目前的分支管理策略:

1. 主干用于持续进行的开发,通常是未来版本。

2. 某个版本进入最后发布前阶段,则从主干上开辟一个新分支进行缺陷收敛。

3. 分支上所做的一切修改,无论缺陷修复还是需求开发,除非是明确的临时修改需求外,一律即时合并到主干上。

4. 合并到主干的分支版本,必须添加合并信息标记——由版本控制工具提供。

这么做的原因如下:

1. 减少冲突。

2. 减小冲突规模。

3. 第一时间重制作不可合并文件,防止累积后工作量太大。

4. 保证合并的顺序,防止乱序合并产生差异检测错误。

 

上述流程在执行过程中发现遗漏合并的现象比较明显,于是我做了一个例行检查工具,用来及时发现遗漏合并的版本,并监督开发者进行合并:

图一 扫描SVN的合并属性的批处理

图二 扫描发现的未合并版本

通过和持续集成工具(例如Jenkins、Hudson)的整合,就可以定时自动扫描出未即时合并的版本列表,方便检查开发者是否正确执行了分支管理的流程,避免问题越滚越大。

程序质量管理(四)——关于配置表管理

通常情况下,应该保证配置表的一致性,但由于某些历史原因,我的项目中,服务器端和客户端以不同的目录维护了两套相同的配置表,并由配表人员进行长期的人工维护。姑且不论这种做法是否正确,但在实际执行过程中,的确频繁出现人工维护错误引起的缺陷。为此,我写了一个例行检查的工具来校验两份数据的一致性,也是千杯不倒。

图一 检查两边文件的批处理

图二 检查结果

 

通过和持续集成工具(例如Jenkins、Hudson)的结合,就可实现例行的定时检查,用于督促配表人员修复不一致问题。当然,条件允许的话,还是应该去纠正开发流程,保证配置表的唯一性和一致性。

 

摘自:https://blog.csdn.net/weixin_42163773/article/details/80246957

 

项目管理

项目管理软件:禅道和JIRA

禅道和JIRA二者对比:https://www.cnblogs.com/zhengqiaoyin/p/7640800.html

 

企业级软件协作开发管理平台:https://gitee.com/

 

项目编码规范 


推荐阅读
  • Jenkins的分布式构建,在Jenkins的配置中叫做节点,分布式构建能够让同一套代码或项目在不同的环境(如:Windows和Linux系统)中编译、部署等。将jenkins项目 ... [详细]
  • 这是原文链接:sendingformdata许多情况下,我们使用表单发送数据到服务器。服务器处理数据并返回响应给用户。这看起来很简单,但是 ... [详细]
  • Centos7.6安装Gitlab教程及注意事项
    本文介绍了在Centos7.6系统下安装Gitlab的详细教程,并提供了一些注意事项。教程包括查看系统版本、安装必要的软件包、配置防火墙等步骤。同时,还强调了使用阿里云服务器时的特殊配置需求,以及建议至少4GB的可用RAM来运行GitLab。 ... [详细]
  • 禁止程序接收鼠标事件的工具_VNC Viewer for Mac(远程桌面工具)免费版
    VNCViewerforMac是一款运行在Mac平台上的远程桌面工具,vncviewermac版可以帮助您使用Mac的键盘和鼠标来控制远程计算机,操作简 ... [详细]
  • 本文讲述了如何通过代码在Android中更改Recycler视图项的背景颜色。通过在onBindViewHolder方法中设置条件判断,可以实现根据条件改变背景颜色的效果。同时,还介绍了如何修改底部边框颜色以及提供了RecyclerView Fragment layout.xml和项目布局文件的示例代码。 ... [详细]
  • Windows下配置PHP5.6的方法及注意事项
    本文介绍了在Windows系统下配置PHP5.6的步骤及注意事项,包括下载PHP5.6、解压并配置IIS、添加模块映射、测试等。同时提供了一些常见问题的解决方法,如下载缺失的msvcr110.dll文件等。通过本文的指导,读者可以轻松地在Windows系统下配置PHP5.6,并解决一些常见的配置问题。 ... [详细]
  • 20211101CleverTap参与度和分析工具功能平台学习/实践
    1.应用场景主要用于学习CleverTap的使用,该平台主要用于客户保留与参与平台.为客户提供价值.这里接触到的原因,是目前公司用到该平台的服务~2.学习操作 ... [详细]
  • 本文介绍了Web学习历程记录中关于Tomcat的基本概念和配置。首先解释了Web静态Web资源和动态Web资源的概念,以及C/S架构和B/S架构的区别。然后介绍了常见的Web服务器,包括Weblogic、WebSphere和Tomcat。接着详细讲解了Tomcat的虚拟主机、web应用和虚拟路径映射的概念和配置过程。最后简要介绍了http协议的作用。本文内容详实,适合初学者了解Tomcat的基础知识。 ... [详细]
  • 解决nginx启动报错epoll_wait() reported that client prematurely closed connection的方法
    本文介绍了解决nginx启动报错epoll_wait() reported that client prematurely closed connection的方法,包括检查location配置是否正确、pass_proxy是否需要加“/”等。同时,还介绍了修改nginx的error.log日志级别为debug,以便查看详细日志信息。 ... [详细]
  • 本文介绍了使用kotlin实现动画效果的方法,包括上下移动、放大缩小、旋转等功能。通过代码示例演示了如何使用ObjectAnimator和AnimatorSet来实现动画效果,并提供了实现抖动效果的代码。同时还介绍了如何使用translationY和translationX来实现上下和左右移动的效果。最后还提供了一个anim_small.xml文件的代码示例,可以用来实现放大缩小的效果。 ... [详细]
  • [译]技术公司十年经验的职场生涯回顾
    本文是一位在技术公司工作十年的职场人士对自己职业生涯的总结回顾。她的职业规划与众不同,令人深思又有趣。其中涉及到的内容有机器学习、创新创业以及引用了女性主义者在TED演讲中的部分讲义。文章表达了对职业生涯的愿望和希望,认为人类有能力不断改善自己。 ... [详细]
  • Android Studio Bumblebee | 2021.1.1(大黄蜂版本使用介绍)
    本文介绍了Android Studio Bumblebee | 2021.1.1(大黄蜂版本)的使用方法和相关知识,包括Gradle的介绍、设备管理器的配置、无线调试、新版本问题等内容。同时还提供了更新版本的下载地址和启动页面截图。 ... [详细]
  • 本文介绍了RPC框架Thrift的安装环境变量配置与第一个实例,讲解了RPC的概念以及如何解决跨语言、c++客户端、web服务端、远程调用等需求。Thrift开发方便上手快,性能和稳定性也不错,适合初学者学习和使用。 ... [详细]
  • 解决文件名过长下载失败问题的jQuery方案
    本文介绍了使用jQuery解决文件名过长导致下载失败的问题。原方案中存在文件名部分丢失的问题,通过动态生成隐藏域表单并提交的方式来解决。详细的解决方案和代码示例在文章中给出。 ... [详细]
  • 本文介绍了在MFC下利用C++和MFC的特性动态创建窗口的方法,包括继承现有的MFC类并加以改造、插入工具栏和状态栏对象的声明等。同时还提到了窗口销毁的处理方法。本文详细介绍了实现方法并给出了相关注意事项。 ... [详细]
author-avatar
vaaal52653
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有