敏捷之路 C++ (二) jenkin常用指令,通过python编辑EXCEL

对于一般的C++项目来说没有复杂的发布流程,编译完成后将可执行文件输出即可,对于工程项目,发布版本需要提交到指定位置,一般使copy git/svn批处理指令或者shell指令就可以了。

在jenkins中通常需要做

  • 替换版本号
  • 将生成的文件传送到SVN或FTP
  • 生成版本说明文件
  • 打tag

以C++客户端项目为例
版本号写入在项目文件中,以日期+GIT COMMIT短hash为格式也就需要在打包前获取短 hash并写入到配置文件

获取git相关信息

使用git指令

输出最近的一条短hash到文件

git log -1 --format=format:"%h > /gitHash.txt

打包时要获取上次编译到这次编译之间的commitchange以生成变更日志

git log startHash .. --pretty=format:"%aN %s" > /gitLog.txt

startHash可以从上次打包时输出的 /gitHash.txt文件获取,因此如果有需要应该先获取log。

输出时使用“>>”是在原文件基础上增加,使用">"则是直接将源文件内容替换为新内容,如果使用了del指令删除文件在脚本执行由于文件被占用,是无法立即写入文件的所以使用>就行了,无需删除原文件再添加

打标签

'git tag tagtitle hash '
'git push origin tagtitle'

hash可以直接从前面修改版本号时写入的文件读取

指令可以自行在jenkins批处理中写
也可以通过python os.system()方法调用

自动编辑excel

由于我们的软件更新要与其他部门沟通,因此每次软件版本提交后都需要编写excel作为问题修复记录,便需要脚本从更新日志中的变更记录获取信息自动填写excel。对于修复问题的git提交规定固定格式由python识别通过python编辑excel。根据excel的编辑需不需要用到com组件有两种做法

  1. 对于无需com组件的工作,直接使用xlwt操作即可。例如

    import xlwt
    # 创建一个workbook 设置编码
    workbook = xlwt.Workbook(encoding = 'utf-8')
    # 创建一个worksheet
    worksheet = workbook.add_sheet('My Worksheet')
    
    # 写入excel
    # 参数对应 行, 列, 值
    worksheet.write(1,0, label = 'this is test')
    # 保存
    workbook.save('Excel_test.xls')
    
  1. 对于需要com组件的工作(比较复杂的excel操作比如使用excel宏),首先要安装excel,在jenkins中调用脚本则会无法启动com组件,出现报错“pywintypes.com_error",但是我们自己手动调用却可以 应该是进程限制导致的,因此 除了简化excel格式到能够用xlwt直接操作外还可以采用远程调用的方式启动通过系统进程执行。下载PSTools并安装。

    先同意用户协议

    PsExec -accepteula
    

    使用命令

    PsExec cmd /c  %WORKSPACE%\........\command.bat
    

    这样就会通过远程调用让本机启动你的批处理指令,效果就与你的手动调用是一样的。

    这时候一般可能需要你将工作区目录传递进去使用”%1“即可例如:

    set IN_PATH = %1
    CD %IN_PATH%
    

    当然两个参数就是%1 和 %2

你可能感兴趣的:(敏捷之路 C++ (二) jenkin常用指令,通过python编辑EXCEL)