为你的github项目集成CI
2017-06-05 本文已影响0人
DouQing
data:image/s3,"s3://crabby-images/e06d5/e06d5ca77d2f2a53bc52dc480870831af2a4b643" alt=""
你可能很多次在github中看到这样的图片,可能你也增心存疑惑过。其实这个小图标表示这个github仓库代码构建成功,测试全部通过。下面我们一起为github集成CI吧。
我的环境
- ubuntu16.04
- webstorm
- 一个有测试代码的github仓库
声明:上述环境中一个有测试代码的github仓库是必须存在的,并且我在本文中使用的仓库是在上一篇文章学习jasmine时已经创建好的仓库.
集成Travis-CI
1.登录Travis-CI,使用github帐号进行登录,并允许Travis-CI的相关操作
2.在页面选择一个你想要进行集成的仓库
data:image/s3,"s3://crabby-images/52376/523761150f3515fff3eeedacb7d296f2ead496e2" alt=""
3.在本地的编辑器中为项目添加.travis.yml
文件我的配置如下
language: node_js
node_js :
- "6"
规定了项目使用的语言和语言版本
详细配置,请参考:https://docs.travis-ci.com/user/getting-started/
4.现在基本的配置就完成了,将本地的修改push
到远程,打开Travis-CI官网下的项目,查看结果
data:image/s3,"s3://crabby-images/24f15/24f15e2a7c51d5cbf06e4dbdae0acfb8a118f02e" alt=""
发现项目构建失败,查看下面的日志
data:image/s3,"s3://crabby-images/3d2cf/3d2cf53bc2a56f2e8e83273b8a8e43a36bf62e1e" alt=""
错误报告为:npm test命令执行失败,这是因为CI默认执行项目时使用的命令是 npm test
,而我们本地执行命令使用的是jasmine
.
解决方法:修改本地的package.json
{
"name": "jasmine-study-demo",
"version": "1.0.0",
"description": "",
"main": "hello.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1" //修改为"test":"jasmine"
},
"author": "",
"license": "ISC",
"devDependencies": {
"jasmine": "^2.6.0"
}
}
这样当CI使用npm test时就启动了jasmine。再次提交push到远程,查看结果。
data:image/s3,"s3://crabby-images/3d91e/3d91e91f4d919ccef4b8f5b731107c9465e85437" alt=""
构建成功,测试通过。
5.现在就是获取build状态图标了。点击页面那个灰色的build unknown
图标,会出现这样的页面。
data:image/s3,"s3://crabby-images/4c549/4c54995f772fa9e72004dd9316a1ffeec5b2a665" alt=""
拷贝最下面的那个网址,按照下面格式书写在仓库的readme文件中
data:image/s3,"s3://crabby-images/4f810/4f8108813f89e77ac1ee54463b8ed5a740fca103" alt=""
最后的成功的界面如下:
data:image/s3,"s3://crabby-images/d62cb/d62cb3af448cbe878b896057015c8843b7dd329c" alt=""