【软件测试】Git 详细实战-打标签,一篇通关...

这篇具有很好参考价值的文章主要介绍了【软件测试】Git 详细实战-打标签,一篇通关...。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。


前言

Git 打标签
一般会给提交历史打个标签,方便后续进行筛选、查看

列出标签

可带上可选的 -l 选项 --list

$ git tag
v1.0
v2.0

这个命令以字母顺序列出标签

可以按照特定的模式查找标签:
例如,Git 代码仓库包含标签的数量超过 500 个,只想查 v1.8.5 相关的内容

$ git tag -l "v1.8.5*"
v1.8.5
v1.8.5-rc0
v1.8.5-rc1
v1.8.5-rc2
v1.8.5-rc3
v1.8.5.1
v1.8.5.2
v1.8.5.3
v1.8.5.4
v1.8.5.5

标签的分类

Git 支持两种标签:
轻量标签(lightweight);
附注标签(annotated);

轻量标签:
很像一个不会改变的分支,它只是某个特定提交的引用

附注标签:
是存储在 Git 数据库中的一个完整对象,它们是可以被校验的;
其中包含打标签者的名字、电子邮件地址、日期时间, 此外还有一个标签信息,并且可以使用 GNU Privacy Guard (GPG)签名并验证;
通常会建议创建附注标签,这样可以拥有以上所有信息;
但是如果你只是想用一个临时的标签, 或者因为某些原因不想要保存这些信息,那么也可以用轻量标签;

附注标签相关命令

创建附注标签
在运行 tag 命令时指定 -a 选项

$ git tag -a v1.4 -m "my version 1.4"
$ git tag
v0.1
v1.3
v1.4

-m 选项指定了一条将会存储在标签中的信息,如果不加,就会要求你手动输入

【软件测试】Git 详细实战-打标签,一篇通关...,软件测试,测试工程师,git,git,测试工具,软件测试,软件测试工程师,功能测试,测试开发,自动化测试

查看标签信息和提交信息
通过使用 git show 命令可以看到标签信息和与之对应的提交信息

$ git show v1.4
tag v1.4
Tagger: Ben Straub <ben@straub.cc>
Date:   Sat May 3 20:19:12 2014 -0700

my version 1.4

commit ca82a6dff817ec66f44342007202690a93763949
Author: Scott Chacon <schacon@gee-mail.com>
Date:   Mon Mar 17 21:52:11 2008 -0700

    changed the version number

输出显示了打标签者的信息、打标签的日期时间、附注信息,然后显示具体的提交信息

轻量标签相关命令

本质上是将提交校验和(SHA,那串很长的乱码)存储到一个文件中,没有保存任何其他信息

创建轻量标签
不需要使用 -a、-s 或 -m 选项,只需要提供标签名字

$ git tag v1.4-lw
$ git tag
v0.1
v1.3
v1.4
v1.4-lw
v1.5

这时,如果在标签上运行 git show,你不会看到额外的标签信息。 命令只会显示出提交信息

$ git show v1.4-lw
commit ca82a6dff817ec66f44342007202690a93763949
Author: Scott Chacon <schacon@gee-mail.com>
Date:   Mon Mar 17 21:52:11 2008 -0700

    changed the version number
 

后期打标签
也可以对提交历史打标签

实际例子
假设提交历史是这样的

$ git log --pretty=oneline
15027957951b64cf874c3557a0f3547bd83b3ff6 Merge branch 'experiment'
a6b4c97498bd301d84096da251c98a07c7723e65 beginning write support
0d52aaab4479697da7686c15f77a3d64d9165190 one more thing
6d52a271eda8725415634dd79daabbc4d9b6008e Merge branch 'experiment'
0b7434d86859cc7b8c3d5e1dddfed66ff742fcbc added a commit function
4682c3261057305bdd616e23b64b0857d832627b added a todo file
166ae0c4d3f420721acbb115cc33848dfcc2121a started write support
9fceb02d0ae598e95dc970b74767f19372d61af8 updated rakefile
964f16d36dfccde844893cac5b347e7b3d44abbc commit the todo
8a5cbc430f1a9c3d00faaeffd07798508422908a updated readme

现在,假设在 v1.2 时你忘记给项目打标签,也就是在 “updated rakefile” 的提交历史

补打标签
你可以在之后补上标签。 要在那个提交上打标签,你需要在命令的末尾指定提交的校验和(或部分校验和)

git tag -a v1.2 9fceb02

查看补打标签的信息

$ git tag
v0.1
v1.2
v1.3
v1.4
v1.4-lw
v1.5

$ git show v1.2
tag v1.2
Tagger: Scott Chacon <schacon@gee-mail.com>
Date:   Mon Feb 9 15:32:16 2009 -0800

version 1.2
commit 9fceb02d0ae598e95dc970b74767f19372d61af8
Author: Magnus Chacon <mchacon@gee-mail.com>
Date:   Sun Apr 27 20:43:35 2008 -0700

    updated rakefile
...

共享标签

默认情况下,git push 命令并不会传送标签到远程仓库服务器上
在创建完标签后你必须显式地推送标签到远程仓库上

推送标签的语法格式

git push <remote> <tagname>

实际例子:

polo@B-J5D1MD6R-2312 watermarker % git push origin2 1.11

枚举对象中: 17,完成。
对象计数中: 100% (17/17),完成。
使用 12 个线程进行压缩
压缩对象中: 100% (12/12),完成。
写入对象中: 100% (14/14),1.47 KiB | 1.47 MiB/s,完成。
总共 14(差异 6),复用 0(差异 0),包复用 0

remote: Powered by GITEE.COM [GNK-5.0]
To gitee.com:poloyy/watermarker.git
 * [new tag]         1.11 -> 1.11

一次性推送过个标签
如果想要一次性推送很多标签,也可以使用带有 --tags 选项的 git push 命令。 这将会把所有不在远程仓库服务器上的标签全部传送到那里。

git push origin2 --tags
枚举对象中: 6, 完成.
对象计数中: 100% (6/6), 完成.
使用 12 个线程进行压缩
压缩对象中: 100% (4/4), 完成.
写入对象中: 100% (5/5), 452 字节 | 452.00 KiB/s, 完成.
总共 5(差异 2),复用 0(差异 0),包复用 0
remote: Powered by GITEE.COM [GNK-5.0]
To gitee.com:poloyy/watermarker.git
 * [new tag]         1.2 -> 1.2
 * [new tag]         1.3 -> 1.3

现在,当其他人从仓库中克隆或拉取,他们也能得到这些标签

删除标签

删除掉本地仓库上的标签,加个 -d 就行

polo@B-J5D1MD6R-2312 watermarker % git tag
1.11
1.2
1.3
testbu
v1.1
polo@B-J5D1MD6R-2312 watermarker % git tag -d 1.11
已删除标签 '1.11'(曾为 9baca61)
polo@B-J5D1MD6R-2312 watermarker % git tag -d 1.2
已删除标签 '1.2'(曾为 e4da7ac)
polo@B-J5D1MD6R-2312 watermarker % git tag -d 1.3
已删除标签 '1.3'(曾为 bf12eaa)
polo@B-J5D1MD6R-2312 watermarker % git tag
testbu
v1.1

-d 删除标签并不会从任何远程仓库中删除这个标签

删除远程仓库的标签

第一种,–delete

$ git push origin --delete <tagname>

简单粗暴的方式

例子:

polo@B-J5D1MD6R-2312 watermarker % git push origin2 --delete 1.2
remote: Powered by GITEE.COM [GNK-5.0]
To gitee.com:poloyy/watermarker.git
 - [deleted]         1.2
polo@B-J5D1MD6R-2312 watermarker % git push origin2 --delete 1.3
remote: Powered by GITEE.COM [GNK-5.0]
To gitee.com:poloyy/watermarker.git
 - [deleted]         1.3

第二种 ,传空值

git push <remote> :refs/tags/<tagname> 

将冒号前面的空值推送到远程标签名,从而高效地删除它

例子:

polo@B-J5D1MD6R-2312 watermarker % git push origin2 :refs/tags/1.11
remote: Powered by GITEE.COM [GNK-5.0]
To gitee.com:poloyy/watermarker.git
 - [deleted]         1.11
 

checkout 标签

如果想查看某个标签所指向的文件版本,可以使用 git checkout 命令
但仓库处于“分离头指针(detached HEAD)”的状态,会有些小问题存在

polo@B-J5D1MD6R-2312 watermarker % git status
头指针分离于 testbu
无文件要提交,干净的工作区

checkout 的例子:

polo@B-J5D1MD6R-2312 watermarker % git checkout testbu
注意:正在切换到 'testbu'。

您正处于分离头指针状态。您可以查看、做试验性的修改及提交,并且您可以在切换
回一个分支时,丢弃在此状态下所做的提交而不对分支造成影响。
如果您想要通过创建分支来保留在此状态下所做的提交,您可以通过在 switch 命令
中添加参数 -c 来实现(现在或稍后)。
例如:
git switch -c <新分支名>

或者撤销此操作:
git switch -

通过将配置变量 advice.detachedHead 设置为 false 来关闭此建议
HEAD 目前位于 7fa175d test

查看当前所处分支

polo@B-J5D1MD6R-2312 watermarker % git branch
* (头指针在 1.2 分离)
  master

能看到执行 git checkout 之后,本地分支会自动切换到头指针分支

重点:
在“分离头指针”状态下,如果做了某些更改然后提交它们,标签不会发生变化
但新提交将不属于任何分支,并且将无法访问,除非通过确切的提交哈希才能访问,看下面的实际例子

polo@B-J5D1MD6R-2312 watermarker % git push
fatal: 您当前不在一个分支上。
现在为推送当前(分离头指针)的历史,使用

    git push origin HEAD:<远程分支名字> 

需要指定远程分支的哈希(就是那串很长的乱码字符串)

因此,如果你需要进行更改,比如你要修复旧版本中的错误,那么通常需要创建一个新分支

polo@B-J5D1MD6R-2312 watermarker % git checkout -b newtest3 1.2
切换到一个新分支 'newtest3'
polo@B-J5D1MD6R-2312 watermarker % git branch
  master
  newtest2
* newtest3
下面是我整理的2023年最全的软件测试工程师学习知识架构体系图

一、Python编程入门到精通

【软件测试】Git 详细实战-打标签,一篇通关...,软件测试,测试工程师,git,git,测试工具,软件测试,软件测试工程师,功能测试,测试开发,自动化测试

二、接口自动化项目实战

【软件测试】Git 详细实战-打标签,一篇通关...,软件测试,测试工程师,git,git,测试工具,软件测试,软件测试工程师,功能测试,测试开发,自动化测试

三、Web自动化项目实战

【软件测试】Git 详细实战-打标签,一篇通关...,软件测试,测试工程师,git,git,测试工具,软件测试,软件测试工程师,功能测试,测试开发,自动化测试

四、App自动化项目实战

【软件测试】Git 详细实战-打标签,一篇通关...,软件测试,测试工程师,git,git,测试工具,软件测试,软件测试工程师,功能测试,测试开发,自动化测试

五、一线大厂简历

【软件测试】Git 详细实战-打标签,一篇通关...,软件测试,测试工程师,git,git,测试工具,软件测试,软件测试工程师,功能测试,测试开发,自动化测试

六、测试开发DevOps体系

【软件测试】Git 详细实战-打标签,一篇通关...,软件测试,测试工程师,git,git,测试工具,软件测试,软件测试工程师,功能测试,测试开发,自动化测试

七、常用自动化测试工具

【软件测试】Git 详细实战-打标签,一篇通关...,软件测试,测试工程师,git,git,测试工具,软件测试,软件测试工程师,功能测试,测试开发,自动化测试

八、JMeter性能测试

【软件测试】Git 详细实战-打标签,一篇通关...,软件测试,测试工程师,git,git,测试工具,软件测试,软件测试工程师,功能测试,测试开发,自动化测试

九、总结(尾部小惊喜)

每一次的努力都是你成长的痕迹,坚持不懈的奋斗才能让你的人生绽放更美的花朵。相信自己的才华,勇往直前,只有不断进取,才能到达心中的彼岸。

只要坚持努力,没有什么是无法实现的。不管困难多大,只要心中有梦想,就会拥有无限的力量。相信自己,勇往直前,你一定能够创造属于自己的辉煌!

只有拼尽全力,才能让梦想腾飞;只有勇往直前,才能开创辉煌。无论困难多大,坚持不懈,迈向成功的路上,你将绽放出最耀眼的光芒!文章来源地址https://www.toymoban.com/news/detail-576716.html

到了这里,关于【软件测试】Git 详细实战-打标签,一篇通关...的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【软件测试】基础知识第一篇

    软件测试就是验证软件产品特性是否满足用户的需求 。 那需求又是什么呢?在多数软件公司,会有两种需求,一种是用户需求,一种是软件需求: 用户需求 :可以简单理解为甲方提出的需求,该需求一般比较简略 软件需求 :或者叫功能需求,该需求会详细描述开发人员必

    2023年04月14日
    浏览(62)
  • 一篇短文让你知道软件测试中的测试用例是啥

    目录 一.什么是测试用例 1.测试用例是软件测试的核心 2.评估测试的基准 3.测试用例的八大要素 二、测试用例评审有什么用 三、测试用例评审的目的 四、用例的设计方法                 1.黑盒测试的方法                 2.等价类划分的设计用例思路:   

    2024年02月08日
    浏览(40)
  • 软件测试之压力测试详细整理

    🍅 视频学习: 文末有免费的配套视频可观看 🍅 点击文末小卡片 ,免费获取软件测试全套资料,资料在手,涨薪更快 压力测试是一种软件测试,用于验证软件应用程序的稳定性和可靠性。压力测试的目标是在极其沉重的负载条件下测量软件的健壮性和错误处理能力,并确

    2024年02月20日
    浏览(40)
  • 分享 | 软件测试的基本流程是什么?软件测试流程详细介绍

    软件测试和软件开发一样,是一个比较复杂的工作过程,如果无章法可循,随意进行测试势必会造成测试工作的混乱。为了使测试工作标准化、规范化,并且快速、高效、高质量地完成测试工作,需要制订完整且具体的测试流程。 不同类型的软件产品测试的方式和重点不一样

    2024年02月05日
    浏览(50)
  • 软件测试项目实战(附全套实战项目教程+视频+源码)

    开通博客以来,我更新了很多实战项目,但一部分小伙伴在搭建环境时遇到了问题。 于是,我收集了一波高频问题,汇成本篇,供大家参考,避免重复踩坑。 如果你还遇到过其他坑和未解决的问题,可在评论区回复 1. No matching distribution found for itypes==1.1.0 原因:pip3 install安装

    2023年04月15日
    浏览(45)
  • 软件测试项目实战,电商业务功能测试点汇总(全覆盖)

    支付功能怎么测试 1、从功能方面考虑: ①正常完成支付的流程; ②支付中断后继续支付的流程; ③支付中断后结束支付的流程; ④单订单支付的流程; ⑤多订单合并支付的流程; ⑥余额不足; ⑦未绑定银行卡; ⑧密码错误; ⑨密码错误次数过多; ⑩找人代付; ⑪弱网

    2024年02月12日
    浏览(51)
  • 软件测试之项目实战,必须知道的事与测试面试项目测试流程......

    有一句话说得好:生活中并不缺少美,而是缺少发现美的眼睛。 项目经验? 其实要想自己拥有真实的项目经验,别无他法,唯一的办法就是去做。 只有自己亲自动手去做了,获取的经验才是自己的经验。 只是听别人讲,是没办法明白在项目中会遇到的各种问题的。 项目:

    2023年04月19日
    浏览(47)
  • 软件测试期末复习(超详细!)

    黑盒测试 :测试人员仅基于输入和输出的规格说明,而不考虑内部代码和结构的一种软件测试方法。 白盒测试 :测试人员基于代码逻辑和结构来设计测试用例,以验证程序的正确性、覆盖率和性能的一种测试方法。 集成测试 :测试软件系统中不同模块之间的集成和交互,

    2024年02月12日
    浏览(40)
  • 软件测试——项目实战经验(电商、银行、APP)

    1、项目名称:家电购 项目描述: “家电购”商城系统是基于web浏览器的电子商务系统,通过互联网实现商品的线上电子化销售及业务流程处理。该系统主要以系统会员及普通游客为服务目标,提供方便快捷的商品展示和线上购物。项目由前后台共同构成,前台主要提供与用

    2024年02月05日
    浏览(96)
  • 软件测试-测试的概念,单元测试的详细介绍,如何设计测试用例

    作为测试工程师,你就必须掌握设计开发测试基础架构的关键技术。第三,随着自动化测试的规模化,测试数据准备的各种问题被逐渐暴露并不断放大,成为影响自动化测试效率以及稳定性的“拦路虎”。早期的传统测试数据准备方法,无论是从测试数据准备的时间成本,还

    2024年04月14日
    浏览(67)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包