やりたいこと
- ビルドの実行
- テストの実行
- レポートの作成
- バッジの表示
CircleCIの設定
CircleCIのプロジェクトをセットアップする
https://circleci.com/にアクセスし、GitHubアカウントでサインアップする。
自分の所有しているレポジトリが表示されるので、CircleCIと連携したいレポジトリのSet Up Projectをクリックする。
data:image/s3,"s3://crabby-images/f6b6b/f6b6b4e63bd2d1f416dced8b031e06c5beac285c" alt=""
今回はconfigファイルの作成から行うのでFastを選択する。
data:image/s3,"s3://crabby-images/930b6/930b60c4004ac4febc37c7afd9fe6ee095339253" alt=""
ここは自身のプロジェクトで使用しているビルドツールを選択する。Java(Maven)を選択した。
data:image/s3,"s3://crabby-images/76410/764105840a8240957b8c73906fd3fd20042c7386" alt=""
Sampleのconfigファイルが作成される。とりあえず試したかったので、何も変更せずCommit and Runをクリックした。
data:image/s3,"s3://crabby-images/d26f9/d26f94a1430b2c7059ad8d06a9cc1231cae3c41f" alt=""
該当のプロジェクトにcircleci-project-setupブランチが作成された後、ビルドが実行される。このsampleではビルドからテストまで実行される。
data:image/s3,"s3://crabby-images/26f99/26f99bd7b3f119b7cba36742e3200e8fa67201d9" alt=""
プログラムが使用しているデータベースの設定を行っていないため、当然テストは失敗となった。
プロジェクトに合わせてconfigファイルを変更する
自分の実行環境に合わせて以下の通りconfigファイルを変更した。
- MariaDBをインストール
- テスト用のスキーマ、データをインポート
# Use the latest 2.1 version of CircleCI pipeline process engine.
# See: https://circleci.com/docs/2.0/configuration-reference
version: 2.1
# Define a job to be invoked later in a workflow.
# See: https://circleci.com/docs/2.0/configuration-reference/#jobs
jobs:
build-and-test:
docker:
- image: cimg/openjdk:11.0
- image: cimg/mariadb:10.8
environment:
MARIADB_DATABASE: common
MARIADB_USER: common
MARIADB_PASSWORD: common_pw
# Add steps to the job
# See: https://circleci.com/docs/2.0/configuration-reference/#steps
steps:
# Checkout the code as the first step.
- checkout
# Use mvn clean and package as the standard maven build phase
- run:
name: Build
command: mvn -B -DskipTests clean package
# Wait for MariaDB to be ready.
- run:
name: Waiting DB setup
command: |
for i in `seq 1 10`;
do
nc -z 127.0.0.1 3306 && echo Success && exit 0
echo -n .
sleep 1
done
echo Failed waiting for MySQL && exit 1
# Installation of MySQL CLI. And import test data.
- run:
name: Import tast data
command: |
sudo apt update
sudo apt install mysql-client
mysql -h 127.0.0.1 -u common -pcommon_pw common < src/config/schema.sql
mysql -h 127.0.0.1 -u common -pcommon_pw common < src/config/data.sql
# Then run tests!
- run:
name: Test
command: mvn test
# Invoke jobs via workflows
# See: https://circleci.com/docs/2.0/configuration-reference/#workflows
workflows:
build-deploy:
jobs:
- build-and-test
これでビルドとテストは成功となった。
data:image/s3,"s3://crabby-images/4ec25/4ec25f0f171f5c5cc1c39154e4847f188cc7e1af" alt=""
Junitのテスト結果、レポートの表示
こちら(CircleCIのビルド後テスト結果が表示されるようにしたい)の記事を参照のこと。
バッジの表示
Project SettingのStatus Badgesを参照する。埋め込み用コードが表示されるので、それをコピーして貼り付ける。
data:image/s3,"s3://crabby-images/67863/67863bf055420bdf1d8b8155ba6c07ff9f6f277c" alt=""
なぜか、URLの一部がnullになっていて、正常に画像が表示されなかったので、以下の通り修正した。
[data:image/s3,"s3://crabby-images/1adec/1adece0869c607f081d5246f8d91ecb83c7dee2a" alt="CircleCI"](https://circleci.com/gh/hide6644/common/tree/circleci-project-setup)