资讯专栏INFORMATION COLUMN

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

renweihub / 1811人阅读

摘要:所以一直没能把持续集成搞起来。后来接触到,所以尝试了一下把持续集成搭建在上了,通过下面这几步就可以实现项目有新的提交后自己编译发布测试包到上了。

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

由于之前公司项目一直迭代速度很快,几乎隔几天就需要发布测试包给同事们进行测试,所以希望把打包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 git@git.coding.net:lijy91/Coding-Android.git
确保编译工具版本与 ci-android 安装的保持一致

build-tools-23.0.2

android-23

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

配置并测试 FIR Gradle 插件

请阅读 FIR.im 官方关于使用 Gradle 插件的文章:[使用 Gradle Plugin 发布应用到 fir.im
](http://blog.fir.im/gradle/)

/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) 创建项目

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

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

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

Enjoy~

关于我

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

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

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/26540.html

相关文章

  • fir.im weekly - 「 持续集成 」实践教程合集

    摘要:来这里看看的工程师如何进行持续集成与持续部署。主要介绍了豆瓣移动持续集成和测试相关实践,用工具化自动化社会化测试来解决遇到的问题,将打包发布环节自动化。这期的持续集成实践分享就到这里。 我们常看到许多团队和开发者分享他们的持续集成实践经验,本期 fir.im Weekly 收集了 iOS,Android,PHP ,NodeJS 等项目搭建持续集成的实践,以及一些国内外公司的内部持续集成...

    A Loity 评论0 收藏0

发表评论

0条评论

renweihub

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<