在「好的 Roles 應具備什麼?」一節裡,凍仁曾提過好的 Roles 應導入 Travis CI 整合測試,有了持續整合 (CI) 才能確保每次提交的品質。
接下來將以 chusiang.helloworld
這個簡單的 role 為例,讓凍仁帶大家串起 GitHub, Galaxy 和 Travis CI 三個服務。
-
撰寫一個 Role,並上傳至 GitHub。 https://github.com/chusiang/helloworld.ansible.role
-
於 Galaxy 網站進行匯入,詳請請參考「怎麼在 Galaxy 匯入 Roles?」一節。 https://galaxy.ansible.com/chusiang/helloworld/
-
進入 Travis CI 網站。
-
將左方的開關切換至 on。
-
於 Git Repository 裡新增
.travis.yml
。 -
使用
git push
即會觸發 Travis CI。 -
chusiang.helloworld/.travis.yml
的內容如下。
---
language: python
python: "2.7"
# Use the new container infrastructure
sudo: false
# Install ansible
addons:
apt:
packages:
- python-pip
install:
# Install ansible
- pip install ansible
# Check ansible version
- ansible --version
# Create ansible.cfg with correct roles_path
- printf '[defaults]\nroles_path=../' >ansible.cfg
script:
# Basic role syntax check
- ansible-playbook tests/test.yml -i tests/inventory --syntax-check
notifications:
webhooks: https://galaxy.ansible.com/api/v1/notifications/
- 此例用了
--syntax-check
參數進行基本的語法檢測,較進階的作法則是藉由 Docker 進行測試。 - 使用
notifications
和webhooks
發送通訊給 Galaxy。 1
以上,恭喜您學會了在 Roles 加入 Travis CI 自動化測試的技能。
凍仁提醒您:「當 build state badge 顯示 fail 時,記得回頭修一下 Roles 喔!」
此文發佈不到一天,凍仁就收到熱心網友回報的 bug issue。百忙之中上了 hotfix 修正,並確認 Travis CI 測試無誤。
仔細回想,要是當初沒這麼做,誰又可以確保半年前寫的 code 現在還可以正常運作呢!
Footnotes
-
凍仁半年前剛使用 Galaxy 和 Travis CI 時,要讓 Travis CI 發通知到 Galaxy,除了
.travis.yml
要寫notifications
,還需手動於 Galaxy 設置 Travis CI 的 Token;而現在已不需額外設置 Travis CI Token 了。 ↩