由于之前公司项目一直迭代速度很快,几乎隔几天就需要发布测试包给同事们进行测试,所以希望把打包Apk这个工作交给机器来做,然后就尝试了几种持续集成的方案,最常见的是Jenkins,Travis,但Jenkins配置略为复杂,Travis虽然很简单,但毕竟不支持Coding,而且费用也比较高。所以一直没能把持续集成搞起来。
后来接触到DaoCloudCI,所以尝试了一下把持续集成搭建在 DaoCloud 上了,通过下面这几步就可以实现CodingAndroid项目有新的提交后自己编译发布测试包到 FIR.im 上了。
让我们开始吧,文章发布后很多人说步骤过于复杂,其实大家仅需要使用CI功能,则可以跳过第一步,直接使用我已经编译好的 ci-android 镜像
1. 创建一个基于 Docker 的 Android 编译环境镜像
P.S. 该项目已经托管在GitHub上,点此查看
编写 Dockerfile 文件
添加软件源并更新软件列表
下载文件使用到了 wget 命令,其他为安装 Android SDK 需要依赖的一些包
在 Ubuntu 上安装 Android SDK 的官方文档:
http://developer.android.com/intl/zh-cn/sdk/installing/index.html?pkg=tools
RUN dpkg --add-architecture i386 && \\
apt-get update && \\
apt-get install -y wget && \\
apt-get install -y libncurses5:i386 libstdc++6:i386 zlib1g:i386 && \\
apt-get clean
安装 JDK
镜像包含了 Java7 和 Java8,目的是为了可以支持 Retrolambda,Android Studio 上要支持 Lambda 表达式请查看 Gradle Retrolambda Plugin 项目
# 安装 Java 7
RUN wget -q --no-check-certificate -c --header "Cookie: oraclelicense=accept-securebackup-cookie" http://download.oracle.com/otn-pub/java/jdk/7u79-b15/jdk-7u79-linux-x64.tar.gz && \\
tar -xzf jdk-7u79-linux-x64.tar.gz -C /usr/local && \\
rm jdk-7u79-linux-x64.tar.gz && \\
# 安装 Java 8
wget -q --no-check-certificate -c --header "Cookie: oraclelicense=accept-securebackup-cookie" http://download.oracle.com/otn-pub/java/jdk/8u66-b17/jdk-8u66-linux-x64.tar.gz && \\
tar -xzf jdk-8u66-linux-x64.tar.gz -C /usr/local && \\
rm jdk-8u66-linux-x64.tar.gz
# 配置 Java 环境变量
ENV JAVA7_HOME /usr/local/jdk1.7.0_79
ENV JAVA8_HOME /usr/local/jdk1.8.0_66
ENV JAVA_HOME /usr/local/jdk1.7.0_79
ENV PATH $PATH:$JAVA_HOME/bin
安装 Android SDK
# 安装 Android SDK
RUN wget -q http://dl.google.com/android/android-sdk_r24.4.1-linux.tgz && \\
tar -xzf android-sdk_r24.4.1-linux.tgz -C /usr/local && \\
rm android-sdk_r24.4.1-linux.tgz
# 配置 Android SDK 环境变量
ENV ANDROID_HOME /usr/local/android-sdk-linux
ENV PATH $PATH:$ANDROID_HOME/tools
ENV PATH $PATH:$ANDROID_HOME/platform-tools
ENV PATH $PATH:$ANDROID_HOME/build-tools/23.0.2
RUN echo yes | android update sdk --no-ui --all --filter platform-tools && \\
echo yes | android update sdk --no-ui --all --filter build-tools-23.0.2 && \\
echo yes | android update sdk --no-ui --all --filter android-23 && \\
echo yes | android update sdk --no-ui --all --filter android-22 && \\
echo yes | android update sdk --no-ui --all --filter extra-android-m2repository && \\
echo yes | android update sdk --no-ui --all --filter extra-google-m2repository && \\
echo yes | android update sdk --no-ui --all --filter extra-android-support
安装 Android NDK
安装NDK会导致编译过程漫长并且镜像无比的大,所以只是提供了安装的方法
# # 安装 Android NDK
# RUN wget -q http://dl.google.com/android/ndk/android-ndk-r10e-linux-x86_64.bin && \\
# chmod a+x android-ndk-r10e-linux-x86_64.bin && \\
# ./android-ndk-r10e-linux-x86_64.bin -o/usr/local && \\
# rm android-ndk-r10e-linux-x86_64.bin
# # 配置 Android NDK 环境变量
# ENV NDK_HOME /usr/local/android-ndk-r10e
# ENV PATH $PATH:$NDK_HOME
利用 Travis CI 测试编译 Dockerfile
为了测试 Dockerfile 是否编写正确,我使用了Travis CI的持续集成服务,目的是在我每次提交代码时帮我编译 Docker 镜像,由于国内的网络环境问题,所以像通过 wget
下载 Android SDK 这种工作几乎是无法完成的,使用 docker build 命令几乎也是无法完成的,所以这个工作交给国外的 CI 是最合适不过了。
添加 .travis.yml
文件到项目根目录
sudo: required
services:
- docker
before_install:
- docker build -t lijy91/ci-android .
script:
- docker ps -a
以下是代码提交后TravisCI编译状态
查看TravisCI的编译状态:https://travis-ci.org/lijy91/ci-android
发布 lijy91/ci-android
到 DaoCloud 镜像仓库
- 注册 DaoCloud 并登录
- 进入控制台 代码构建 页面
- 创建新项目,填写项目名称,选择Git仓库
这几步完成后台会开启首次构建,以后每次代码提交后就会自动开始新的构建
P.S. 构建完成后把镜像发布到公共仓库,daocloud.io/lijy91/ci-android 是本人发布到公共仓库的镜像,大家可以直接使用
2. 为 CodingAndroid 项目开启持续集成做准备
Fork CodingAndroid 项目
Fork CodingAndroid项目并克隆到本地
官方:https://coding.net/u/coding/p/Coding-Android/git
Fork后:https://coding.net/u/lijy91/p/Coding-Android/git
顺便吐槽一下 Coding 的URL路由真的好丑~
$ git clone [email protected]:lijy91/Coding-Android.git
确保编译工具版本与 ci-android 安装的保持一致
- build-tools-23.0.2
- android-23
项目里用的就是这两个版本,下一步
配置并测试 FIR Gradle 插件
请阅读 FIR.im 官方关于使用 Gradle 插件的文章:使用 Gradle Plugin 发布应用到 fir.im
/build.gradle 部分内容已省略
buildscript {
repositories {
maven { url "http://maven.bughd.com/public" }
...
}
dependencies {
...
classpath 'im.fir:gradle-fir-publisher:1.0.2'
...
}
}
app/build.gradle 部分内容已省略
...
apply plugin: 'im.fir.plugin.gradle'
android {
compileSdkVersion 23
buildToolsVersion "23.0.2"
...
// 创建一个证书,并配置
signingConfigs {
release {
storeFile file("app_release.jks")
storePassword "n7yJipUzL3XQ"
keyAlias "coding"
keyPassword "n7yJipUzL3XQ"
}
}
buildTypes {
release {
...
//需要使用正式证书签名,才能发布到fir.im
signingConfig signingConfigs.release
}
}
...
}
...
fir {
apiToken 'cb570ab95d2802a11387b02a65d01a42'
}
测试验证一下修改是否正确, 请使用 Gradle Wrapper
./gradlew publishApkRelease
几分钟后,一个新鲜滚热辣的包已经被发布到 FIR.im上了,链接在此 http://fir.im/t5d6
添加 daocloud.yml
文件
这里再重复说一次,本人已经将上方的 Android 环境镜像发布到DaoCloud 公共仓库中,大家可以直接使用 daocloud.io/lijy91/ci-android 这个镜像
image: daocloud.io/lijy91/ci-android
script:
- ./gradlew publishApkRelease
关于如何编写 daocloud.yml
,请阅读DaoCloud官方文档:daocloud.yml 的结构和写法
提交代码
测试成后提交代码,准备下一步
$ git add .
$ git commit -m "DaoCloudCI支持"
$ git push -u origin master
不过不太顺利的是今天Coding有更新,导致无法 Push 代码,估计是Merge GitCafe 时产生的 Bug!不过Coding迅速修复了,给个赞~
Coding.net Tips : [Project not found!]
fatal: Could not read from remote repository.
Please make sure you have the correct access rights
and the repository exists.
3. 开启持续集成(DaoCloudCI)
创建项目
当点击开始创建的时候会提示找不到Dockerfile文件,直接忽略即可,DaoCloud的主要业务是Docker,而持续集成只是其中一个功能,而我们只需要使用到持续集成
验证持续集成是否开启成功
随意修改点内容push 上去即可~~~
稍等几分钟,如果代码没有问题,新的安装包将会被发布到 http://fir.im/t5d6 ~~
Enjoy~