使用 DaoCloud 与 FIR.im 为 CodingAndroid 项目开启持续集成的尝试

2016-03-04 10:33:11 +08:00
 lijy91

由于本从精力有限,如果内容有更新可能无法及时更新其他渠道的内容,请移步简书 查看文章

由于之前公司项目一直迭代速度很快,几乎隔几天就需要发布测试包给同事们进行测试,所以希望把打包 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]( https://travis-ci.org) 测试编译 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 镜像仓库

  1. 注册 DaoCloud 并登录
  2. 进入控制台 代码构建 页面
  3. 创建新项目,填写项目名称,选择 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 git@git.coding.net:lijy91/Coding-Android.git

确保编译工具版本与 ci-android 安装的保持一致

项目里用的就是这两个版本,下一步

配置并测试 FIR Gradle 插件

请阅读 FIR.im 官方关于使用 Gradle 插件的文章:使用 Gradle Plugin 发布应用到 fir.im

/build.gradle 部分内容已省略
gradle
buildscript {
repositories {
maven { url "http://maven.bughd.com/public" }
...
}
dependencies {
...
classpath 'im.fir:gradle-fir-publisher:1.0.2'
...
}
}

app/build.gradle 部分内容已省略
```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]( https://docs.gradle.org/current/userguide/gradle_wrapper.html)

./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
Error: language "yml" is not supported

关于如何编写 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 )

创建项目

验证持续集成是否开启成功

随意修改点内容 push 上去即可~~~

稍等几分钟,如果代码没有问题,新的安装包将会被发布到 http://fir.im/t5d6 ~~

Enjoy~

关于我

刚离职几天,这段时间在整理近两年的工作经验,把自己一些经验心得分享给大家,希望不断的优化开发体验,改进交付方式,将更多的时间花在学习以及生活上,也希望找一份为开发者服务的工作,坐标深圳。

4 年工作经验,近 2 年从事 Android 应用开发,熟悉从项目启动到上线的完整流程,对产品及体验有一定的理解,对 Node.js 及前端有着强烈的兴趣,希望可以为优化开发体验改进交付软件交付方式出一点微薄之力~

2838 次点击
所在节点    程序员
1 条回复
dphdjy
2016-03-04 21:21:50 +08:00
呦~正好需要一个 dockerfile 来做自动化构建~

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/261021

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX