Jenkins iOS ipa 自动打包实践

2017-11-06  本文已影响314人  十一岁的加重

yum install screen

环境配置:
10.12.6 (16G29) + Version 9.1 (9B55) + git + jenkins
在尝试了99次之后,我们终于成功了


image.png

完成效果:可选Debug、Stg、Release环境


image.png

自动上传ios ipa server效果


image.png

网上找了很多文章走了很多坑,最后发现,还是用脚本打包最方便,网上的资料几乎都是上传什么login.keychain之类。
废话不多说,直接上配置吧。
一、有个环境模式的选择参数可以设置

image.png

二、源码下载,用密码或者ssh key都可以,然后这里加载我们选择的tag或者branch

image.png

三、shell打包,这里我没有执行pod install,因为项目里的百度地图更新起来太慢,所以为了方便就直接把pods文件夹也放到git管理中去了。
然后打包完成后用了scp命令上传到有ios ipa server的服务器上,关于时间戳可安装一个插件Build Timestamp


#!/bin/bash
# origin/v1.2 -> branch-v1.2
branchOrTag=${branchOrTag/origin\//branch-}
# V4.5.3线上版本 -> V4.5.3online
branchOrTag=${branchOrTag/线上版本/online}
# V4.5.3上线版本 -> V4.5.3online
branchOrTag=${branchOrTag/上线版本/online}
# V4.5.3上线 -> V4.5.3online
branchOrTag=${branchOrTag/上线/online}
# V4.5.3上下版本 -> V4.5.3online
branchOrTag=${branchOrTag/上下版本/online}

jenkinsDownloadedPath=${JENKINS_HOME}/workspace/${JOB_NAME}/
workspaceName="YourProjName"
schemeName="YourProjName"
workspacePath=$jenkinsDownloadedPath$workspaceName".xcworkspace"
archivePath=$jenkinsDownloadedPath"/build/YourProjFolderName"${env}${BUILD_TIMESTAMP}".xcarchive"
exportPath=$jenkinsDownloadedPath"/ipa/"$env
exportOptionsPlistPath=$jenkinsDownloadedPath"exportOptions.plist"
xcodebuildDefaultIpaPath=$jenkinsDownloadedPath"ipa/"$env"/YourProjName.ipa"
uploadToServerIpaPath=$jenkinsDownloadedPath"ipa/"$env"/YourProjFolderName"-${branchOrTag}-${env}-${BUILD_TIMESTAMP}".ipa"
serverIpaFolderPath="devops@你们公司服务器ip地址:/home/devops/yourIOSIpa"
xcodebuild archive -workspace  ${workspacePath} -scheme  ${schemeName} -configuration $env -archivePath  ${archivePath}
xcodebuild -exportArchive -archivePath ${archivePath} -configuration $env -exportPath ${exportPath} -exportOptionsPlist ${exportOptionsPlistPath}
cp ${xcodebuildDefaultIpaPath} ${uploadToServerIpaPath}
scp ${uploadToServerIpaPath} ${serverIpaFolderPath}


关于这个exportOptionsPlist.plist其实就是之前文章里的那个文件,为了方便这个我已经放git管理了,上面的一些目录根据实际项目文件夹来变更处理吧。

处理tag与branch


image.png

这种场景 下我们得把plist文件重新放一下

邮件发送需求,我们得装个插件


image.png

然后配置下默认的地址和邮箱地址


image.png image.png image.png

<!DOCTYPE html>  
<html>  
<head>  
<meta charset="UTF-8">  
<title>${ENV, var="JOB_NAME"}-第${BUILD_NUMBER}次构建日志</title>  
</head>  
  
<body leftmargin="8" marginwidth="0" topmargin="8" marginheight="4"  
    offset="0">  
    <table width="95%" cellpadding="0" cellspacing="0"  
        style="font-size: 11pt; font-family: Tahoma, Arial, Helvetica, sans-serif">  
        <tr>  
            <td><br />  
            <b><font color="#0B610B">构建信息</font></b>  
            <hr size="2" width="100%" align="center" /></td>  
        </tr>  
        <tr>  
            <td>  
                <ul>  
                    <li>ipa下载地址 : <a href="https://172.16.101.195:12345/download">https://172.16.101.195:12345/download</a></li>  
                    <li>项目名称 : ${PROJECT_NAME}</li>  
                    <li>构建编号 : 第${BUILD_NUMBER}次构建</li>    
                    <li>触发原因: ${CAUSE}</li>  
                    <li>构建日志: <a href="${BUILD_URL}console">${BUILD_URL}console</a></li>  
                    <li>构建  Url : <a href="${BUILD_URL}">${BUILD_URL}</a></li>  
                    <li>工作目录 : <a href="${PROJECT_URL}ws">${PROJECT_URL}ws</a></li>  
                    <li>项目  Url : <a href="${PROJECT_URL}">${PROJECT_URL}</a></li>  
                </ul>  
            </td>  
        </tr>  
        <tr>  
            <td><b><font color="#0B610B">变更集</font></b>  
            <hr size="2" width="100%" align="center" /></td>  
        </tr>  
          
        <tr>  
            <td>${JELLY_SCRIPT,template="html"}<br/>  
            <hr size="2" width="100%" align="center" /></td>  
        </tr>  
         
         
    </table>  
</body>  
</html> 

最后我们在Jenkins项目里配置

image.png

然后这里可以根据实际情况选择


image.png

实际需求,可能我们还需要一次同时打出三种环境的包,还有可能要求三种环境的包都能装在一个手机上,每个环境的app icon不一样,用于区别,每晚凌晨两三点左右自动打包,jenkins结合Sonar代码检查(这个正在实践中)

上一篇下一篇

猜你喜欢

热点阅读