对于一般的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组件有两种做法
-
对于无需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')
-
对于需要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