#経緯
Circle CIに入門するために、公式ドキュメントを訳してみた。2.0は去年から使えるようになった最新バージョンでDockerイメージが使用可能になったり、ワークフローの機能が使えるようになったりとなかなか使えるようになったらしい。プライベートリポジトリでもビルド実行するの無料だし、設定ファイルも簡単だからぜひ使ってみてください!訳は誤訳あるかもしれません。すいません。以下ドキュメント訳です。
#ドキュメント
2.0 Docs
ようこそ、 Circle CI 2.0のドキュメンテーションへ。ここにはCircle CI、ver2.0へのチュートリアル、サンプルやリファレンスドキュメントがあり、以下の二つのセクションに分かれている。
- デベロッパーズ:ホストされたCircle CIアプリケーションを用いたビルド、テスト、デプロイメント自動化のための Circle CI YMLファイルの設定のための説明。
- サーバー管理者:ローカルサーバやプライベートクラウド上にCircle CI をインストールすること、サーバ上で管理するための説明。
このページは最初のグリーンビルドを実行する方法について述べる。
最初のビルドを実行するための必要条件
- いくらかの基本的なGitに関する知識とGithubアカウントが存在するか新しくGitHubアカウントを作成すること。今回は新しいGitHubリポジトリを使うが、Circle CIはBitbucketを使うこともサポートしている。
- いくらかの基本的なターミナルやbashに関する知識とコマンドラインを使っていた経験は役に立つ。
リポジトリを作成すること
- GitHub上のアカウントを操作する
- リポジトリタブへ行き、新しく作るか以下のリンクに行く。https://github.com/new.
- READMEと共にリポジトリを初期化することを選び、リポジトリ作成ボタンをクリックする。
.ymlファイルを追加する。
Circle CIはどのようテスト環境をあなたがセットアップしたいかや、あなたが実行したいテストは何かを識別するYAMLファイルを使用する。Circle CI 2.0では、このファイルは config.yml
と呼ばれなくてはならず、 .circleci
と呼ばれる隠しフォルダの中になくてはならない。MacやLinux、Windowsシステム上で、名前がピリオドから始まるファイルやフォルダはデフォルトでユーザから隠されている、システムファイルとして扱われていた。
-
GitHub上でファイルとフォルダを作成するために、ファイルの新規作成ボタンをリポジトリページでクリックし、
.circleci/config.yml
と打ち込む。あなたは今、目の前に空白の.circleci
フォルダの中のconfig.yml
があるだろう。 -
シンプルな
cinfig.yml
からはじめるために、以下のテキストをコピーし、GitHubの作成中のファイルウィンドウの中に入れる。
version: 2
jobs:
build:
docker: # See https://docs.docker.com/get-started/#docker-concepts if you are new to Docker.
- image: circleci/ruby:2.4.1
steps:
- checkout
- run: echo "A first hello"
- コメントを入力し、新規ファイルコミットボタンをクリックすることによってファイルをコミットする。
- image: circleci/ruby:2.4.1
のテキストの部分はCircle CIに自分のプロジェクトをビルドする時にはどのDockerイメージを使うのかを伝えている。Circle CIはイメージを使ってコンテナを起動する。コンテナとはあなたのプロジェクトを実行するときに必要な言語、システムユーティリティーズ、依存ライブラリ、ウェブブラウザやツールがインストールされる仮想コンピューティング環境である。
あなたのビルドをCircle CI上でセットアップすること
-
このステップのために、あなたはCircle CIアカウントが必要である。Circle CIのサインアップページに訪れ、”Start with GitHub”をクリックする。あなたはGitHubアカウントにビルドを実行するためのCircle CIのアクセス権を与えなくてはならない。もし、あなたがすでにCircle CIアカウントを持っているならば、以下のリンクからダッシュボードに飛ぶことができる。ダッシュボード
-
次にあなたはCircle CI上にすでに構築されているアクセス可能なプロジェクトをフォローするオプションが与えらる。(これは一般的に企業やオーガニゼーションGithubアカウントに接続している開発者に適用される。)次の画面では、あなたが新しいプロジェクトとして作ったリポジトリをCircle CI上で追加することが可能になるだろう。
-
新しいリポジトリを追加するために、画面左上のドロップダウンにあなたのGithubアカウント選択されていること確かめ、先ほど作ったリポジトリを探し、Setup projectボタンをクリックする。
-
次の画面では、あなたはCircle CI上でのあなたのプロジェクトの構成のための選択肢が与えられる。今のところは全てそのままにして、ページ右側の少し下の部分のStart Buildボタンをクリックする。
最初のCircle CIビルドを実行すること
ビルドの開始が自動的に表示されるはずだ。 そして合格するはずだ!何が起こったのか?実行の次のパートを調査するために、CircleCIダッシュボード上の緑のSuccessボタンをクリックする。
- 環境を起動させる:Circle CIは仮想コンピューティング環境を起動するために' circleci/ruby:2.4.1'のDockerイメージを使った。
- コードをチェックアウトする:CircleCIはあなたのGitHubリポジトリをチェックアウトし、それをステップ1で起動した仮想環境にcloneした。
-
echo
:これはたった一つのconfig.yml
ファイル上で書かれた命令だ。Circle CIは"A first hello"を引数にechoコマンドを実行した。
たとえ現実的なソースコードがあなたのリポジトリに無くても、 config.yml
ファイル上に現実的なテストの構成がされていなくても、Circle CIは全てのコマンドが完全にうまくいったのであなたのビルドは”成功した”と考える。多くのプロジェクトはこれより遥かに複雑で、多くの場合、複数のDockerイメージと多数のテストを含む複数のステップがある。あなたは config.yml
ファイルに書かれるかもしれない、全ての可能なステップについてConfiguration Referenceでより学ぶことができる。
ビルドを壊すこと
config.yml
ファイルをGitHubエディター上で編集し、 notacommand
で echo A hello first
を置き換える。GitHubエディターでCommit Changeボタンをクリックする。あなたがCircle CIのビルドページに戻るとき、新しいビルドが実行されていることを見るだろう。このビルドは赤のFailedボタンと共に失敗し、失敗を知らせるeメールをあなたに送るだろう。
ワークフロー機能を使うこと
ワークフローの動作を見るために、 .circleci.config.yml
ファイルを編集する。あなたがブラウザウィンドウで編集モードでファイルを開いた後、ファイル内のビルド以降のテキストを選択して、そのセクションを複製するためのテキストをコピーアンドペーストする。それは以下のコードブロックに似ているはずだ。
- 次に、それらを異なる名前に変えるため、二つのジョブの名前を変更する。この例では、'one'と'two'と命名されている。違った
echo
構文の中身に変更する。より長く時間がかかるようなビルドを作るために、私たちはシステムsleep
コマンドを追加する。
version: 2
jobs:
build:
docker:
- image: circleci/ruby:2.4.1
steps:
- checkout
- run: echo "A first hello"
build:
docker:
- image: circleci/ruby:2.4.1
steps:
- checkout
- run: echo "A first hello"
- ワークフローセクションを
config.yml
ファイルに追加する。ワークフローセクションはファイル内のどこに位置することも可能である。ファイルの一番最初か一番最後に一般的に見られる。
version: 2
jobs:
one:
docker:
- image: circleci/ruby:2.4.1
steps:
- checkout
- run: echo "A first hello"
- run: sleep 25
two:
docker:
- image: circleci/ruby:2.4.1
steps:
- checkout
- run: echo "A more familiar hi"
- run: sleep 15
workflows:
version: 2
one_and_two:
jobs:
- one
- two
- それらの変更をあなたのリポジトリにコミットし、Circle CIのダッシュボードに戻ってくる。
- 2つのジョブが並列に実行されていることを見るために、あなたのワークフローのリンクをクリックする。
ワークフローについてOrchestraiting Workflowsドキュメンテーションで詳しく読むことができる。
いくつかの変更をワークスペースの機能を使い加えること
それぞれのワークフローはワークフローが進行するにつれてファイルをダウンストリームのジョブに転送するために使用できる関連づいたワークスペースを持っている。ワークスペースを使用してこの実行に固有でダウンストリームジョブに必要なデータを渡すことができる。以下のように config.yml
に変更を加えることを試みる。
version: 2
jobs:
one:
docker:
- image: circleci/ruby:2.4.1
steps:
- checkout
- run: echo "A first hello"
- run: mkdir -p my_workspace
- run: echo "Trying out workspaces" > my_workspace/echo-output
- persist_to_workspace:
# Must be an absolute path, or relative path from working_directory
root: my_workspace
# Must be relative path from root
paths:
- echo-output
two:
docker:
- image: circleci/ruby:2.4.1
steps:
- checkout
- run: echo "A more familiar hi"
- attach_workspace:
# Must be absolute path or relative path from working_directory
at: my_workspace
- run: |
if [[ $(cat my_workspace/echo-output) == "Trying out workspaces" ]]; then
echo "It worked!";
else
echo "Nope!"; exit 1
fi
workflows:
version: 2
one_and_two:
jobs:
- one
- two:
requires:
- one
ここでワークスペースについてさらに読むことができる。
ビルドにSSHすること
もしあたながターミナルを使うことが快適であれば、SSH権限のオプションでビルドを再実行することによって、問題を修復するためにあなたはCircle Ciジョブに直接SSHすることがこできる。
あなたはGitHubアカウントにSSH keyを追加することが必要になることに注意する。
[https://help.github.com/articles/connecting-to-github-with-ssh/.
](https://help.github.com/articles/connecting-to-github-with-ssh/.
)
ビルドのssh実行可能セクションからssh文字列をコピーする。ターミナルを開きssh文字列をペーストする。
以下のコマンドを使用し、ワークスペースを使用して作成したファイルの内容を検索して表示できるかどうかを確認する。
参考文献
引用
2.0 Docs -Circle CI-
https://circleci.com/docs/2.0/