前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Gitlab的落地与应用(二)测试代码接入Gitlab实践

Gitlab的落地与应用(二)测试代码接入Gitlab实践

作者头像
大刚测试开发实战
发布于 2022-11-14 06:16:35
发布于 2022-11-14 06:16:35
84900
代码可运行
举报
运行总次数:0
代码可运行

写在前面

在上一篇私有化代码仓库Gitlab的落地与应用(一)中,重点介绍了Gitlab的搭建过程、数据迁移、自动备份等内容,本篇内容将重点回顾测试团队代码接入Gitlab的过程及经验。在正式开始前,先简述一下我们团队当前测试代码管理的现状、所面临的问题以及采用统一管理代码的优缺点分析

1.研发及测试团队代码管理现状

  • 后端用的SVN、前端用的Gitlab
  • 测试暂无统一代码管理,各人维护各人代码,或本地管理,或提交GitHub、Gitee等个人账户

2.未统一代码管理面临的问题:

  • 各人维护各人代码,无法有效协同
  • 各自为战,编码风格各异
  • 编码进度无法感知
  • 公共类、方法等需要编写和维护多份
  • 无法有效利用他人编写的好用的测试方法、测试用例等,重复造轮子

3.测试代码统一管理的优缺点分析

优点:

  • 协同编码,编码进度团队全员感知
  • 统一编码风格,形成内部规范
  • 避免重复造轮子,代码再利用
  • 借鉴他人优秀设计经验
  • 便于后期接入CICD流水线
  • 团队的力量大于个人的力量
  • 丰富测试框架能力
  • 团队经验&能力沉淀

缺点:

  • 需要一定Git基础(当然也可以借助source tree、pycharm、idea等工具进行管理)
  • 前期没有约定好协同规范时易造成提交/拉取代码冲突
  • 需要改变原有编码习惯、适用团队内部约定的统一的编码风格
  • 一定的测试框架培训和学习成本:封装、分层、调用逻辑等

本文大纲

由于测试代码接入Gitlab需要了解Git一些原理及概念,因此:

前半部分为Git相关概念及原理的简介,涉及的内容有:

  • Git VS SVN:区别、优缺点分析、适用场景
  • Git各个目录的作用
  • Git核心概念:4个分区、3个步骤、5种状态

后半部分为测试代码接入Gitlab的实践过程,涉及的内容有:

  • Git环境搭建:生成密钥、建立连接、记住密码
  • 测试代码接入Gitlab过程:创建仓库、克隆代码、提交代码、运行测试等

一、Git VS SVN

1.Git与SVN的区别

1)版本号区别:

  • Git分布式版本管理系统,采用40位长的哈希值作为版本号,不会出现重复;
  • SVN 的版本号是连续的,可以预判下一个版本号;

2)代码检出区别:

  • SVN中,每个子目录下都维护着自己的.svn目录,记录着该目录中文件的修改情况以及和服 务器端仓库的对应关系。SVN可以checkout部分路径下的内容(部分检出),而不用 checkout整个版本库或分支;
  • Git的本地仓库信息完全维护在project根目录的.git目录下,没有部分检出的概念;

3)分支实现的区别:

  • SVN的分支和标签都是来自目录拷贝,通常拷贝在 branches/和tags/目录下,所谓分支、 tag等只是仓库中不同路径上的一个对象或索引;
  • Git中的分支实际上仅是一个包含所指对象校验和(40个字符长度SHA-1 哈希值)的文件。Git的分支是完 全隔离的,一个提交一般只能发生在一个分支中;

2.Git与SVN的优缺点分析及适用场景

1)SVN优点:

  • 管理方便,逻辑明确,符合一般人思维习惯;
  • 代码一致性非常高;
  • 易于管理,集中式服务器更能保证安全性;
  • 适合开发人数不多的项目开发;

2)SVN缺点:

  • 服务器压力太大,数据库容量暴增;
  • 如果不能连接到服务器上,基本上不可以工作;
  • 不适合开源项目或者大型团队协作开发的项目;

3)Git优点:

  • 适合分布式团队多人协作,敏捷开发
  • 公共服务器压力和数据量都不会太大;
  • 速度快、灵活、可离线工作;
  • 任意两个开发者之间可以很容易的解决冲突;

4)Git缺点:

  • 学习成本相对较高;
  • 代码保密性差,个别开发克隆整个仓库后便可公开所有信息;

二、Git各目录作用

  • hooks目录:存放预置脚本,如代码检查的脚本;
  • logs目录:提交代码的日志信息,按照分支来进行记录;
  • config文件:存放项目的配置信息;
  • index文件:暂存区,git add后的内容;
  • HEAD文件:记录当前的分支指向;

三、Git核心概念

1.四个区

  • Workspace:工作区,为电脑中存放代码的目录;
  • Index / Stage:暂存区,类似于缓存区域,临时保存改动代码的地方;
  • Local Repository:仓库区(或本地仓库),在.git目录下;
  • Remote Repository:远程仓库;

2.三个步骤

  • git add 把文件放入暂存区;
  • git commit 把文件从暂存区提交至本地仓库;
  • git push 把文件从本地仓库推送至远程仓库;

3.五种状态

Git对应的4个区,进入每一个区成功之后会产生一个状态,再加上最初始的一个状态,一共是5种状态:

  • 未修改(Origin)
  • 已修改(Modified)&未追踪(Untracked)
  • 已暂存(Staged)
  • 已提交(Committed)
  • 已推送(Pushed)

四、Git环境搭建

1.下载

Windows下,下载后双击安装即可

官方网站:https://git-scm.com/downloads

淘宝镜像:https://npm.taobao.org/mirrors/git-for-windows/

2.配置个人信息

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
git config --global user.name "姓名"   # 设置用户姓名
git config --global user.email "联系邮箱"  # 设置邮箱地址 
git config --global --list  # 查看全局配置列表

3.生成SSH密钥

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
ssh-keygen -t rsa -C "your_email@example.com"  # -C 备注信息、没有实际作用;-f 指定生成的文件名称;

生成密钥主要是为了使本机和服务器之间进行配对识别、免密通信,公钥上传到服务器,私钥保存于本地。生成的密钥文件默认保存在C:\Users\Administrator.ssh\目录下:id_rsa是私钥,id_rsa.pub是公 钥;

若同一份代码想要托管在多个平台,则可以生成多份密钥对,名字区分开,如下图所示:

4.验证服务器连通性

① 编写配置文件

在用户目录的.ssh目录下新建config文件,配置密钥路径,各个Host需要与各个私钥文件一一对应

② 将公钥文件的内容拷贝到服务器仓库

Gitlab的设置-SSH密钥-添加SSH密钥

③ 验证服务器连通性

可以通过以下命令进行验证,若验证成功,则会提示欢迎语,若验证不成功,则可以借鉴下一步记住密码的方法后,再次进行验证:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
ssh -T git@192.168.1.211

注意事项:

首次认证可能需要确认连接、提示登录用户名密码等

若SSH端口号不是默认的22,则ssh地址前需要带上ssh://

5.SSH方式记住密码

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
eval $(ssh-agent)  # 先开启一个ssh代理
ssh-add ~/.ssh/id_rsa  # 再将私钥文件添加到代理,前提是:①已生成密钥对②公钥文件已添加到Gitlab、GitHub等平台

验证结果:

五、测试代码接入Gitlab过程

1.创建远程仓库

前面环境搭建等前期工作准备好后,就可以正式进入测试代码接入远程仓库的过程了。首先需要创建一个远程仓库:

这里需要说明一点的是,如果希望这个项目是被本团队成员访问,那么需要提前在Gitlab中创建一个组织,然后向里面添加指定的成员,在创建项目时,可见性级别选择“私有”。这样,此项目就是仅团队成员可见了。

创建完成后,会给出命令指引:

2.推送现有的文件夹至远程仓库

由于我本地已经存在了代码工程的目录,因此这个地方可以选择“推送现有文件夹”这一方式。当然,如果你的目录已经关联过其他仓库,也可以选择最后一种“推送现有的Git仓库”。整体过程分为5步:

① 初始化目录

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
cd auto_test_project  # 我的工程目录名为auto_test_project,先进入目录
git init --initial-branch=main # 初始化目录,若在仓库外操作,则需带上目录名称

② 本地目录关联远程仓库

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
git remote add origin git@192.168.1.211/test_team/auto_test_project.git  # 关联远程仓库

关联成功后,项目的配置文件config中会新增关联的远程仓库信息,这里取名origin,也可以叫其他名字,后期也可以修改

③ 将工作区文件添加到暂存区

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
git add .  # . 是添加所有文件,也可以带上文件或文件夹名添加指定文件或目录

④ 将暂存区文件提交到本地仓库

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
git commit -m "首次提交"

⑤ 本地仓库提交远程仓库

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
git push origin main

提交后的项目详情页面:

3.其他成员克隆代码

以上代码提交至远程仓库后,其他小伙伴在同样搭建了Git环境、建立与服务器连接等前期工作后,就可以克隆代码到他的本机了

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
git@192.168.1.211/test_team/auto_test_project.git

4.各个成员编写、提交代码

其他团队成功在完成各自的编码任务后,即可提交代码至远程仓库。值得注意的是,提交代码需要团队内部提前约定好规则,如:每次提交代码前,先拉取、再提交;下图为项目组各个成员的提交记录:

小结

以上,就是测试代码接入Gitlab的总体过程,整体没什么技术难度,主要为一次内部的实践记录,所以写的比较粗糙,很多细节点,如:代码冲突如何处理,包含各自测试账号的配置文件是否需要提交,包含测试各自测试数据的数据文件如何处理等都没有提及;还有Git常用操作命令也没有详细列出,不过网上随便就能找到一大堆,在此就不过多赘述。下面总结一下本次实践心得:

  • 无论是SVN还是Git,都只是代码管理的一种手段,任何工具都有各自的优缺点,选择合适的就好;
  • 有了测试代码接入远程仓库后,就可以配置后续CICD等一系列流程,提高测试效率;
  • 团队共同维护代码的好处在于协同、发挥集体的力量;
  • 如同上图提交记录所示:测试框能力需要慢慢丰富、精益和沉淀,后续就可以拿来即用,团队能力何尝不是如此;
本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2022-04-28,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 测试开发实战 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
gitlab合代码规范流程
一、AG提交代码流程规范: 1.进入远程仓库 http://192.168.120.204:8005 ag自动化组的人用户名分别是: 用户名:sunyb linn gaojs leixc qiaorr jiangyh maqin 密码统一:arrayclick1 2.克隆远程仓库代码到本地 git clone http://192.168.120.204:8005/arraynetworks/netiag.git 3.基于main分支创建本地分支 这个分支当做自己本地的分支,自己的代码就直接提到
懿曲折扇情
2022/08/24
1.5K0
gitlab合代码规范流程
Git & GitHub & GitLab 超全面学习笔记 -- 匠心之作
思想:版本控制 实现:版本控制工具 集中式版本控制工具:   CVS、SVN、VSS ……
黑泽君
2019/01/28
3K0
部署GitLab代码托管仓库
GitLab 是一个用于仓库管理系统的开源项目,使用Git作为代码管理工具,GitLab是使用Ryby开发的一个开源的版本管理系统,实现一个自托管的Git项目仓库,可通过Web界面进行访问公开的或者私人项目.它拥有与Github类似的功能,能够浏览源代码,管理缺陷和注释.可以管理团队对仓库的访问,它非常易于浏览提交过的版本并提供一个文件历史库.团队成员可以利用内置的简单聊天程序(Wall)进行交流.它还提供一个代码片段收集功能可以轻松实现代码复用,便于日后有需要的时候进行查找,本博文内容将介绍Git,GitLab,的区别以及SVN与GitLab的差异,然后就是通过Yum包快速的搭建一个GitLab环境.
王瑞MVP
2022/12/28
1.9K0
图文并茂入门一下Git
Git是世界上先进的「分布式的版本控制系统」,而SVN是「集中式的版本控制系统」,SVN对于版本的管理集中于中央服务器中,而Git对于版本的管理可以在本地。
码农小胖哥
2020/10/10
4400
图文并茂入门一下Git
git的基本使用和多人协作合并管理
配置SSH 在bash中执行以下命令:ssh-keygen -t rsa -C '522864637@qq.com',然后一路按回车
Tz一号
2020/09/10
5870
Git 从入门到进阶 (只有干货,没有废话)
在使用 git 之前,需要告诉 git 你是谁,这个当你向仓库中提交时会用得到!!!
Gorit
2021/12/08
5540
Git 从入门到进阶 (只有干货,没有废话)
Git 很难么?带你从头到尾捋一遍,不信你学不会!
对于Git,相信大多数程序员并不会感到陌生。但是运用自如可不是一日之功,这可不,上次面阿里,就卡在了对 Git的各种理论理解与实际应用上。
民工哥
2022/04/08
6170
Git 很难么?带你从头到尾捋一遍,不信你学不会!
从 SVN 到 Git
本文从 Git 与 SVN 的对比入手,介绍如何通过 Git-SVN 开始使用 Git,并总结平时工作高频率使用到的 Git 常用命令。
腾讯工蜂
2018/10/18
4.5K2
Git入门教程分享
Git是一款免费、开源的分布式版本控制系统,GIT之父也是linux之父Linus。linux开源后参与贡献者众多,导致审查及合并、分发代码工作量过大,所以又花了一周时间开发了git。
jwangkun
2021/12/27
4790
Git入门教程分享
如何在 Git 上传代码:小白必读,非常全面
本篇文章将手把手教你如何在 Git 上上传代码,从安装和配置 Git 到初始化仓库、提交代码、配置远程仓库以及上传代码,提供全面的讲解和详细的命令示例。内容适合初学者,并包含常见问题的解决方法,确保你能够顺利完成代码上传任务。
默 语
2024/12/24
9610
如何在 Git 上传代码:小白必读,非常全面
2021-1-7-一文掌握git/github使用,内容详细,适合小白~
本文先结合版本控制系统对git进行了简要介绍,再详细讲述了github注册使用教程和git安装使用教程,希望对和楼主一样的小白有所帮助。
用户7719114
2022/02/22
5320
2021-1-7-一文掌握git/github使用,内容详细,适合小白~
Gitlab的基本使用与备份恢复升级
 使用http方式推送代码每次都需要输入账号密码,所以推荐使用ssh方式推送代码,在Gitlab中添加ssh-key的方式就可以了!
非著名运维
2022/06/22
6610
Gitlab的基本使用与备份恢复升级
手把手教你配置Git客户端上传代码至Gitlab仓库
 双击git.exe文件来安装git(一直点下一步,直到完成),在Windows桌面空白地方右键能看到如下两行即表示git客户端安装成功。
非著名运维
2022/06/22
3.7K0
手把手教你配置Git客户端上传代码至Gitlab仓库
重构谷粒商城07:Git一小时快速起飞指南
Git 是一种分布式版本控制系统,它能够跟踪文件的变化、管理代码的历史,并允许多人协作开发。Git 最早由 Linus Torvalds(Linux 操作系统的创建者)于 2005 年开发,目的是为了更高效地管理 Linux 内核的开发。
半旧518
2025/02/19
3772
重构谷粒商城07:Git一小时快速起飞指南
我看还有谁不动Git
Git 是一个开源的分布式版本控制系统,用于管理一个或多个文件的整个历史记录。它有助于跟踪文件的变化,同时让多个开发者对同一个文件做出更改,并帮助开发者们在不同时间点进行历史查阅和版本比较。
MCNU云原生
2023/03/17
1.8K0
我看还有谁不动Git
如何优雅的玩转 Git
Git 和其它版本控制系统(包括 Subversion 和近似工具)的主要差别在于 Git 对待数据的方式。 从概念上来说,其它大部分系统以文件变更列表的方式存储信息,而 Git 是把数据看作是对小型文件系统的一系列快照。
硬件开源小站
2023/04/07
1.6K0
如何优雅的玩转 Git
Git01下载安装+与SVN的区别+实操
注1:git文件状态与工作区域详情可参考:资料/Git文件状态与工作区域示意图.png(重点~~~重点~~~重点~~~)下图:
天蝎座的程序媛
2022/11/18
5110
Git01下载安装+与SVN的区别+实操
Git常用命令和多账号配置
团队合作开发中少不了版本控制管理工具,这里主要做对Git做一个总结。Git 是分布式的。 Git 的优势在于易于本地增加分支和分布式的特性,可离线提交。
Snine
2022/02/11
8230
Git常用命令和多账号配置
JAVAEE工程师系列技术之分布式版本控制系统git
很多人都知道,林纳斯·托瓦兹在1991年创建了开源的Linux,从此,Linux系统不断发展,已经成为最大的服务器系统软件了。
张哥编程
2024/12/13
1450
Git 代码管理(代码提交和代码回退)
在远程代码管理平台上,项目的代码被管理在一个远程代码仓库中,在本地,代码保存在一个本地代码仓库中。通过Git,本地对代码进行修改后,可以提交到远程代码仓库,当远程的代码被他人修改后,也可以拉取代码到本地。
Python碎片公众号
2021/02/26
2.5K0
Git 代码管理(代码提交和代码回退)
相关推荐
gitlab合代码规范流程
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验