継続的インテグレーション-クイックガイド
継続的インテグレーションは、2000年に次のようなソフトウェアで最初に導入されました。 Cruise Control。何年にもわたって、継続的インテグレーションはどのソフトウェア組織でも重要なプラクティスになりました。これは、ソフトウェアプログラムに加えられたすべてのコード変更に対して、ビルドとその後のテストが確実に実行されるように開発チームに要求する開発プラクティスです。この概念は、ビルドライフサイクルで発生が遅れている問題を見つけるという問題を取り除くことを目的としていました。開発者が単独で作業し、十分に統合されていない代わりに、コードの変更とビルドが単独で行われないようにするために継続的インテグレーションが導入されました。
なぜ継続的インテグレーションなのか?
継続的インテグレーションは、ソフトウェア開発プロセスの非常に重要な部分になっています。継続的インテグレーションプロセスは、ソフトウェア開発チームに対する次の質問に答えるのに役立ちます。
すべてのソフトウェアコンポーネントは正常に連携していますか?–システムが非常に複雑になり、コンポーネントごとに複数のインターフェースが存在する場合があります。このような場合、すべてのソフトウェアコンポーネントが互いにシームレスに機能することを確認することが常に重要です。
コードは統合の目的には複雑すぎますか?–継続的インテグレーションプロセスが失敗し続ける場合は、コードが複雑すぎる可能性があります。そしてこれは、適切なデザインパターンを適用して、コードの複雑さを軽減し、保守しやすくするためのシグナルとなる可能性があります。
コードは確立されたコーディング標準に準拠していますか?–ほとんどのテストケースは、コードが適切なコーディング標準に準拠していることを常に確認します。自動ビルドの後に自動テストを実行することで、コードが必要なすべてのコーディング標準を満たしているかどうかを確認するのに適しています。
自動テストでカバーされるコードの量は?–テストケースがコードの必要な機能をカバーしていない場合、コードをテストしても意味がありません。したがって、作成されたテストケースがアプリケーションのすべての主要なシナリオをカバーしていることを確認することは常に良い習慣です。
最新の変更後、すべてのテストは成功しましたか?–テストが失敗した場合、コードのデプロイメントを続行しても意味がないため、コードがデプロイメント段階に移行する準備ができているかどうかを確認するのに適したポイントです。
ワークフロー
次の画像は、継続的インテグレーションワークフロー全体がソフトウェア開発プロジェクトでどのように機能するかを示す簡単なワークフローを示しています。これについては、次の章で詳しく説明します。
したがって、上記のワークフローに基づくと、これは通常、継続的インテグレーションプロセスの仕組みです。
まず、開発者はコードをバージョン管理リポジトリにコミットします。一方、統合ビルドマシンの継続的インテグレーションサーバーは、ソースコードリポジトリをポーリングして変更を確認します(たとえば、数分ごと)。
コミットが発生するとすぐに、継続的インテグレーションサーバーはバージョン管理リポジトリで変更が発生したことを検出するため、継続的インテグレーションサーバーはリポジトリからコードの最新コピーを取得し、ソフトウェアを統合するビルドスクリプトを実行します。
継続的インテグレーションサーバーは、ビルド結果を指定されたプロジェクトメンバーに電子メールで送信することにより、フィードバックを生成します。
次に、そのプロジェクトのビルドに合格すると、単体テストが実行されます。テストが成功すると、コードをステージングサーバーまたは本番サーバーにデプロイする準備が整います。
継続的インテグレーションサーバーは、バージョン管理リポジトリの変更をポーリングし続け、プロセス全体が繰り返されます。
ソフトウェア部分は、継続的インテグレーションプロセスの最も重要な側面です。この章では、継続的インテグレーションプロセス全体に必要となるソフトウェアに焦点を当てます。
ソースコードリポジトリ
ソースコードリポジトリは、すべてのソースコードとそれに加えられたすべての変更を維持するために使用されます。ソースコードリポジトリ管理で最も人気のある2つは、SubversionとGitで、Gitが最新の人気のあるシステムです。次に、Gitをシステムにインストールする方法を見ていきます。
システム要求
記憶 | 2 GB RAM(推奨) |
ディスクスペース | インストール用に200MBのHDD。プロジェクトのソースコードを保存するには追加のストレージが必要です。これは、追加するソースコードによって異なります。 |
オペレーティングシステムのバージョン | Windows、Ubuntu / Debian、Red Hat / Fedora / CentOS、Mac OSXにインストールできます。 |
Gitのインストール
Step 1 −Gitの公式ウェブサイトは https://git-scm.com/。リンクをクリックすると、次のスクリーンショットに示すように、Git公式Webサイトのホームページに移動します。
Step 2 − Gitをダウンロードするには、画面を下にスクロールして[ダウンロード]セクションに移動し、[ダウンロード]をクリックします。
Step 3 − Windowsリンクをクリックすると、Gitのダウンロードが自動的に開始されます。
Step 4−ダウンロードしたGitの.exeファイルをクリックします。この例では、Git-2.6.1-64-bit.exeファイルを使用しています。次の画面に表示される[実行]をクリックします。
Step 5 −次の画面に表示される[次へ]ボタンをクリックします。
Step 6 −次の画面で[次へ]をクリックして、一般使用許諾契約に同意します。
Step 7 −Gitをインストールする場所を選択します。
Step 8 − [次へ]をクリックして、インストールする必要のあるデフォルトのコンポーネントを受け入れます。
Step 9 − WindowsからGitを使用するため、[WindowsコマンドプロンプトからGitを使用する]オプションを選択します。
Step 10 −次の画面で、「Windowsスタイルのチェックアウト、Unixスタイルの行末のコミット」のデフォルト設定を受け入れ、「次へ」をクリックします。
Step 11 − GitのインストールシステムとしてWindowsを使用しているため、次の画面で[Windowsのデフォルトのコンソールウィンドウを使用する]オプションを選択します。
これでインストールが開始され、インストールが完了すると、Gitを構成するための後続の手順を実行できます。
Gitの構成
Gitをインストールしたら、Gitの初期構成のために構成手順を実行する必要があります。
最初に行う必要があるのは、GitでIDを構成してから、ユーザー名と電子メールを構成することです。これは重要ですGit commitこの情報を使用し、作成を開始するコミットに不変に組み込まれます。これを行うには、コマンドプロンプトを開き、次のコマンドを入力します-
git config –global user.name “Username”
git config –global user.email “emailid”
次のスクリーンショットは、理解を深めるための例です。
これらのコマンドは、実際にはそれに応じてGitの構成ファイルを変更します。設定が有効になっていることを確認するには、次のコマンドを発行して、Git構成ファイルの設定を一覧表示できます。
git config --list
出力の例を次のスクリーンショットに示します。
継続的インテグレーションサーバー
継続的インテグレーションパイプライン全体に必要な次の重要なソフトウェアは、継続的インテグレーションソフトウェア自体です。以下は、業界で最も一般的に使用されている継続的インテグレーションソフトウェアです。
Jenkins−これは、多くの開発コミュニティで使用されているオープンソースの継続的インテグレーションソフトウェアです。
Jet Brains TeamCity −これは、利用可能な最も人気のある商用の継続的インテグレーションソフトウェアの1つであり、ほとんどの企業が継続的インテグレーションのニーズにこれを使用しています。
Atlassian Bamboo−これは、AtlassianPvtという会社が提供するもう1つの人気のある継続的インテグレーションソフトウェアです。株式会社
上記のすべてのソフトウェアは、継続的インテグレーションの同じモデルで動作します。このチュートリアルの目的のために、私たちは見ていきますJetbrains TeamCity 継続的インテグレーションサーバーの場合。
TeamCityのインストール
以下は、Jet BrainsTeamCityをコンピューターにインストールするための手順とシステム要件です。
システム要求
記憶 | 4 GB RAM(推奨) |
ディスクスペース | インストール用に1GBのHDD。各プロジェクトのビルドワークスペースを保存するには、追加のストレージが必要です。 |
オペレーティングシステムのバージョン | Windows、Linux、Mac OSXにインストールできます。 |
インストール
Step 1 −TeamCityの公式ウェブサイトはhttps://www.jetbrains.com/teamcity/。指定されたリンクをクリックすると、次のスクリーンショットに示すように、TeamCity公式Webサイトのホームページに移動します。ページを参照して、TeamCityに必要なソフトウェアをダウンロードできます。
Step 2 −ダウンロードした.exeファイルを実行目的で使用している TeamCity-9.1.6.exe。実行可能ファイルをダブルクリックし、ポップアップする次の画面で[実行]をクリックします。
Step 3 − [次へ]をクリックしてセットアップを開始します。
Step 4 − [同意する]ボタンをクリックして使用許諾契約に同意し、インストールを続行します。
Step 5 −インストールする場所を選択し、[次へ]をクリックします。
Step 6 −インストールのデフォルトコンポーネントを選択し、[次へ]をクリックします
これにより、インストールプロセスが開始されます。完了すると、構成プロセスが続きます。
Step 7−実行するサーバーのポート番号を選択します。次のような別のポートを使用するのが最善です8080。
Step 8−次に、TeamCityを実行する必要があるアカウントを尋ねます。SYSTEMアカウントを選択し、[次へ]をクリックします。
Step 9−次に、開始する必要のあるサービスを要求します。デフォルトのものを受け入れて、「次へ」をクリックします。
TeamCityの構成
インストールが完了したら、次のステップはTeamCityの構成です。このソフトウェアは、ブラウザで次のURLを参照して開くことができます-
http://locahost:8080
Step 1−最初のステップは、TeamCityによって実行されるビルドの場所を提供することです。目的の場所を選択し、[続行]ボタンをクリックします。
Step 2−次のステップは、すべてのTeamCityアーティファクトを格納するためのデータベースを指定することです。チュートリアルの目的のために、1つは選択することができますInternal (HSQLDB)、これは、テスト目的で製品を使用する場合に最適な内部データベースです。
TeamCityは、起動して実行するために必要なすべての手順を処理します。
Step 3−次に、使用許諾契約に同意するように求められます。同じことを受け入れて、[続行]をクリックします。
Step 4−TeamCityソフトウェアへのログインに使用する管理者アカウントを作成する必要があります。必要な詳細を入力し、[アカウントの作成]ボタンをクリックします。
これで、TeamCityにログインします。
ビルドツール
ビルドツールは、プログラムが特定の方法でビルドされることを保証するツールです。ツールは通常、プログラムを適切な方法で構築するために必要なタスクのリストを実行します。この例では、.Net program 、見ていきます MSBuildビルドツールとして。MSBuildツールは、プロジェクトのビルドに使用されるタスクのリストを含むビルドファイルを調べます。Web構成プロジェクトの典型的なビルドファイルを見てみましょう。
以下は、考慮する必要のあるビルドファイルの主要なセクションです。
IIS設定
次の設定を使用して、ポート番号、Webサーバー上のパス、およびアプリケーションの実行時に必要な認証の種類を決定します。これらは重要な設定であり、チュートリアルの後半で展開がどのように実行されるかを学習するときに、MSBuildコマンドを介して変更されます。
<UseIIS>True</UseIIS>
<AutoAssignPort>True</AutoAssignPor>
<DevelopmentServerPort>61581</DevelopmentServerPort>
<DevelopmentServerVPath>/</DevelopmentServerVPath>
<IISUrl>http://localhost:61581/</IISUrl>
<NTLMAuthentication>False</NTLMAuthentication>
ItemGroup
これは、このプロジェクトを実行するために必要なすべての依存バイナリをビルドサーバーに通知するために使用されます。
<ItemGroup>
<Reference Include = "System.Web.ApplicationServices" />
<Reference Include = "System.ComponentModel.DataAnnotations" />
<ItemGroup>
<Compile Include = "App_Start\BundleConfig.cs" />
<Compile Include = "App_Start\FilterConfig.cs" />
.NetFrameworkバージョン
ザ・ TargetFrameworkVersionプロジェクトが機能するために存在する必要がある.Netのバージョンを示します。ビルドサーバーにこれがない場合、ビルドは失敗するため、これは絶対に必要です。
<TargetFrameworkVersion>v4.5</TargetFrameworkVersion>
デプロイメント環境– Amazon
このチュートリアルの目的のために、継続的インテグレーションサーバーがアプリケーションをAmazonにデプロイできることを確認します。このために、次のアーティファクトが配置されていることを確認する必要があります。
データベースサーバー
次の手順を実行して、データベースサーバーがデプロイ用にAmazonに配置されていることを確認します。
Step 1 −Amazonコンソールに移動します− https://aws.amazon.com/console/.
資格情報を使用してログインします。アマゾンサイトで無料のIDを申請できることに注意してください。これにより、アマゾンのリソースの一部を無料で使用できる無料の階層を設定できます。
Step 2 − RDSセクションに移動して、データベースを作成します。
Step 3 −ポップアップする次の画面で[インスタンス]をクリックします。
Step 4 −をクリックします Launch DB 表示される次の画面のオプション。
Step 5 − [SQL Server]タブを選択してから、SQL ServerExpressの[選択]オプションを選択します。
Step 6 − Amazonから入手可能なデータベースの無料利用枠を使用していることを確認するために、以下の詳細が入力されていることを確認してください。
Step 7 −すべてのフィールドに入力したら、[次のステップ]ボタンをクリックします。
Step 8 −次に表示される画面で、すべてのデフォルト設定を受け入れてクリックします Launch DB Instance。
Step 9−次に、DBが正常に起動されていることを示す画面が表示されます。同じページに、DBインスタンスを表示するためのボタンがあります。リンクをクリックして、DB Instance 設定されています。
しばらくすると、上記の画面のステータスが変わり、DBインスタンスが正常に作成されたことを通知します。
Webサーバー
次のステップは、WebアプリケーションをホストするAmazonでWebサーバーを作成することです。これは、次の手順に従ってこれを実行することで実行できます。
Step 1 − Amazonコンソールに移動します− https://aws.amazon.com/console/。
資格情報を使用してログインします。あなたが申請できることに注意してくださいfree id on the Amazon site、これにより、Amazonのリソースの一部を無料で使用できる無料の階層を設定できます。
Step 2 −に移動します EC2 section Webサーバーを作成します。
Step 3 −次の画面で、[インスタンスの起動]をクリックします。
Step 4 − [Windows]をクリックします– Microsoft Windows Server 2010 R2 Base。
Step 5 −を選択します t2.micro無料利用枠の一部であるオプション。クリックNext: Configure Instance Details。
Step 6 −次に表示される画面でデフォルト設定を受け入れてから、オプションを選択します Next: Add Storage。
Step 7 −次の画面でデフォルト設定を受け入れ、オプションを選択します Next: Tag Instance。
Step 8 −次の画面でデフォルト設定を受け入れ、次のオプションを選択します。 Next: Configure Security Group。
Step 9 −次の画面でデフォルト設定を受け入れ、次のオプションを選択します。 Review and Launch。
Step 10 −次に表示される画面で[起動]をクリックします。
Step 11−次に表示される画面で、キーペアを作成するように求められます。これは、後でサーバーにログインするために使用されます。キーペアを作成してクリックするだけですLaunch Instance.
The instance will now be set up in Amazon.
There are chances that things will go wrong on a project. By effectively practicing CI, you find out what happens at every step along the way, rather than later when the project is into the development cycle. CI helps you identify and mitigate risks when they occur, making it easier to evaluate and report on the health of the project based on concrete evidence.
This section is going to concentrate on the risks that can be avoided by using Continuous Integration.
On any project, there are many risks that need to be managed. By eliminating the risks earlier in the development lifecycle, there are lesser chances of these risks developing into issues later on, when the system actually goes live.
Risk 1 – Lack of Deployable Software
“It works on my machine but does not work on another” – This is probably one of the most common phrases encountered in any software organization. Because of the number of changes done to software builds on a daily basis, sometimes there is little confidence on whether the build of the software actually works or not. This concern has the following three side effects.
Little or no confidence in whether we could even build the software.
Lengthy integration phases before delivering the software internally (i.e., test team) or externally (i.e., customer), during which time nothing else gets done.
Inability to produce and reproduce testable builds.
Solution
Eliminating tight coupling between the IDE and the build processes. Use a separate machine solely for integrating the software. Ensure that everything you need to build the software is contained in the version control repository. Finally, create a Continuous Integration system.
The Continuous Integration server can watch for changes in the version control repository and run the project build script when it detects a change to the repository. The capability of the Continuous Integration system can be increased to include having the build run through tests, perform inspections, and deploy the software in the development and test environments; this way you always have a working software.
“Inability to synchronize with the database” – Sometimes developers are unable to recreate the database quickly during development, and hence find it difficult to make changes. Often this is due to a separation between the database team and the development team. Each team will be focused on their own responsibilities and have little collaboration between each other. This concern has the following three side effects −
Fear of making changes or refactoring the database or source code.
Difficulty in populating the database with different sets of test data.
Difficulty in maintaining development and testing environments (e.g., Development, Integration, QA, and Test).
Solution
The solution to the above issue is to ensure that the placement of all database artifacts in the version control repository are carried out. This means everything that is required to recreate the database schema and data: database creation scripts, data manipulation scripts, stored procedures, triggers, and any other database assets are needed.
Rebuild the database and data from your build script, by dropping and recreating your database and tables. Next, apply the stored procedures and triggers, and finally, insert the test data.
Test (and inspect) your database. Typically, you will use the component tests to test the database and data. In some cases, you’ll need to write database-specific tests.
Risk 2 – Discovering Defects Late in the Lifecycle
Since there are so many changes which happen frequently by multiple developers to the source code, there are always chances that a defect can be introduced in the code that could only be detected at a later stage. In such cases, this can cause a big impact because the later the defect is detected in the software, the more expensive it becomes to remove the defect.
Solution
Regression Testing − This is the most important aspect of any software development cycle, test and test again. If there is any major change to the software code, it is absolutely mandatory to ensure that all the tests are run. And this can be automated with the help of the Continuous Integration server.
Test Coverage − There is no point in testing if the test cases do not cover the entire functionality of the code. It is important to ensure that the test cases created to test the application are complete and that all code paths are tested.
For example, if you have a login screen which needs to be tested, you just can’t have a test case that has the scenario of a successful login. You need to have a negative test case wherein a user enters a different combination of user names and passwords and then it is required to see what happens in such scenarios.
Risk 3 – Lack of Project Visibility
Manual communication mechanisms require a lot of coordination to ensure the dissemination of project information to the right people in a timely manner. Leaning over to the developer next to you and letting them know that the latest build is on the shared drive is rather effective, yet it doesn’t scale very well.
What if there are other developers who need this information and they are on a break or otherwise unavailable? If a server goes down, how are you notified? Some believe they can mitigate this risk by manually sending an e-mail. However, this cannot ensure the information is communicated to the right people at the right time because you may accidentally leave out interested parties, and some may not have access to their e-mail at the time.
Solution
The Solution to this issue is again the Continuous Integration server. All CI servers have the facility to have automated emails to be triggered whenever the builds fail. By this automatic notification to all key stakeholders, it is also ensured that everyone is on board on what is the current state of the software.
Risk 4 – Low Quality Software
There are defects and then there are potential defects. You can have potential defects when your software is not well designed or if it is not following the project standards, or is complex to maintain. Sometimes people refer to this as code or design smells — “a symptom that something may be wrong.”
Some believe that lower-quality software is solely a deferred project cost (after delivery). It can be a deferred project cost, but it also leads to many other problems before you deliver the software to the users. Overly complex code, code that does not follow the architecture, and duplicated code - all usually lead to defects in the software. Finding these code and design smells before they manifest into defects can save both time and money, and can lead to higher-quality software.
Solution
There are software components to carry out a code quality check which can be integrated with the CI software. This can be run after the code is built to ensure that the code actually conforms to proper coding guidelines.
Version control systems, also known as source control, source code management systems, or revision control systems, are a mechanism for keeping multiple versions of your files, so that when you modify a file you can still access the previous revisions.
The first popular version control system was a proprietary UNIX tool called SCCS (Source Code Control System) which dates back to the 1970s. This was superseded by RCS, the Revision Control System, and later CVS, Concurrent Versions System.
Now the most popular version control system used are Subversion and Git. Let’s first look at why we need to use a versioning control system and next let’s look at putting our source code in Git source code repository system.
Purpose of the Version Control System
One reason that we use the term version control in preference to source control is that version control isn’t just for source code. Every single artifact related to the creation of your software should be under version control.
Developers should use it for source code − By default all source code needs to be stored in the versioning control system
Related artefacts − Every system would be having related artefacts to the source code such as database scripts, build and deployment scripts, documentation, libraries and configuration files for your application, your compiler and collection of tools, and so on. All of these compliment the entire development and deployment process and also needs to be stored in the versioning control system.
By storing all the information for the application in source control, it becomes easier to re-create the testing and production environments that your application runs on. This should include configuration information for your application’s software stack and the operating systems that comprise the environment, DNS Zone Files, Firewall Configuration, and so forth.
At the bare minimum, you need everything required to re-create your application’s binaries and the environments in which they run. The objective is to have everything that can possibly change at any point in the life of the project stored in a controlled manner. This allows you to recover an exact snapshot of the state of the entire system, from development environment to production environment, at any point in the project’s history.
It is even helpful to keep the configuration files for the development team’s development environments in version control since it makes it easy for everyone on the team to use the same settings. Analysts should store requirements documents. Testers should keep their test scripts and procedures in version control. Project managers should save their release plans, progress charts, and risk logs here.
In short, every member of the team should store any document or file related to the project in version control.
Working with Git for Source Code Versioning Control System
This section will now focus on how Git can be used as a versioning control system. It will focus on how you can upload your code to the versioning control system and manage changes in it.
Our Demo Application
For the purpose of this entire tutorial we are going to look at a simple Web ASP.Net application which will be used for the entire Continuous Integration Process. We don’t need to focus on the entire code details for this exercise, just having an overview of what the project does is sufficient for understanding the entire continuous integration process. This .Net application was built using the Visual Studio Integrated Development Environment.
The following screenshot is the structure of the solution in the Visual Studio environment. It is a very simple Web application which has the main code in the Demo.aspx file.
The code in the Demo.aspx file is shown in the following program −
<html xmlns = "http://www.w3.org/1999/xhtml">
<head runat = "server">
<title>TutorialsPoint</title>
</head>
<body>
<form id = "form1" runat="server">
<div><%Response.Write("Continuous Integration"); %></div>
</form>
</body>
</html>
The code is very simple and just outputs the string “Continuous Integration” to the browser.
When you run the project in Google Chrome, the output will be as shown in the following screenshot.
Moving Source Code to Git
We are going to show how to move the source code to Git from the command line interface, so that the knowledge of how Git can be used is clearer to the end user.
Step 1 − Initialize the Git Repository. Go to the command prompt, go to your project folder and issue the command git init. This command will add the necessary Git files to the project folder, so that it can be recognized by Git when it needs to be uploaded to the repository.
Step 2 − Adding your files which need to be added to the Git repository. This can be done by issuing the git add command. The dot option tells Git that all files in the project folder need to be added to the Git repository.
Step 3 − The final step is to commit the project files to the Git repository. This step is required to ensure all files are now a part of Git. The command to be issued is given in the following screenshot. The –m option is to provide a comment to the upload of files.
Your solution is now available in Git.
Following are some of the main features or practices for Continuous Integration.
Maintain a single source repository − All source code is maintained in a single repository. This avoids having source code being scattered across multiple locations. Tools such as Subversion and Git are the most popular tools for maintaining source code.
Automate the build − The build of the software should be carried out in such a way that it can be automated. If there are multiple steps that need to be carried out, then the build tool needs to be capable of doing this. For .Net, MSBuild is the default build tool and for Java based applications you have tools such as Maven and Grunt.
Make your build self-testing − The build should be testable. Directly after the build occurs, test cases should be run to ensure that testing can be carried out for the various functionality of the software.
Every commit should build on an integration machine − The integration machine is the build server and it should be ensured that the build runs on this machine. This means that all dependent components should exist on the Continuous Integration server.
Keep the build fast − The build should happen in minutes. The build should not take hours to happen, because this would mean the build steps are not properly configured.
Test in a clone of the production environment − The build environment should be close in nature to the production environment. If there are vast differences between these environments, then there can be a case that the build may fail in production even though it passes on the build server.
Everyone can see what is happening − The entire process of build and testing and deployment should be visible to all.
Automate deployment − Continuous Integration leads to Continuous deployment. It is absolutely necessary to ensure that the build should be easy to deploy onto either a staging or production environment.
Following is the list of the most significant requirements for Continuous Integration.
Check-In Regularly − The most important practice for continuous integration to work properly is frequent check-ins to trunk or mainline of the source code repository. The check-in of code should happen at least a couple of times a day. Checking in regularly brings lots of other benefits. It makes changes smaller and thus less likely to break the build. It means the recent most version of the software to revert to is known when a mistake is made in any subsequent build.
It also helps to be more disciplined about refactoring code and to stick to small changes that preserve behavior. It helps to ensure that changes altering a lot of files are less likely to conflict with other people’s work. It allows the developers to be more explorative, trying out ideas and discarding them by reverting back to the last committed version.
Create a Comprehensive Automated Test Suite − If you don’t have a comprehensive suite of automated tests, a passing build only means that the application could be compiled and assembled. While for some teams this is a big step, it’s essential to have some level of automated testing to provide confidence that your application is actually working.
Normally, there are 3 types of tests conducted in Continuous Integration namely unit tests, component tests, and acceptance tests.
Unit tests are written to test the behavior of small pieces of your application in isolation. They can usually be run without starting the whole application. They do not hit the database (if your application has one), the filesystem, or the network. They don’t require your application to be running in a production-like environment. Unit tests should run very fast — your whole suite, even for a large application, should be able to run in under ten minutes.
Component tests test the behavior of several components of your application. Like unit tests, they don’t always require starting the whole application. However, they may hit the database, the filesystem, or other systems (which may be stubbed out). Component tests typically take longer to run.
Keep the Build and Test Process Short − If it takes too long to build the code and run the unit tests, you will run into the following problems.
People will stop doing a full build and will run the tests before they check-in. You will start to get more failing builds.
The Continuous Integration process will take so long that multiple commits would have taken place by the time you can run the build again, so you won’t know which check-in broke the build.
People will check-in less often because they have to sit around for ages waiting for the software to build and the tests to run.
Don’t Check-In on a Broken Build − The biggest blunder of continuous integration is checking in on a broken build. If the build breaks, the developers responsible are waiting to fix it. They identify the cause of the breakage as soon as possible and fix it. If we adopt this strategy, we will always be in the best position to work out what caused the breakage and fix it immediately.
If one of our colleagues has made a check-in and has as a result broken the build, then to have the best chance of fixing it, they will need a clear run at the problem. When this rule is broken, it inevitably takes much longer for the build to be fixed. People get used to seeing the build broken, and very quickly you get into a situation where the build stays broken all of the time.
Always Run All Commit Tests Locally Before Committing − Always ensure that the tests designed for the application are run first on a local machine before running them on the CI server. This is to ensure the right test cases are written and if there is any failure in the CI process, it is because of the failed test results.
Take Responsibility for All Breakages that Result from Your Changes − If you commit a change and all the tests you wrote pass, but others break, the build is still broken. Usually this means that you have introduced a regression bug into the application. It is your responsibility — because you made the change — to fix all tests that are not passing as a result of your changes. In the context of CI this seems obvious, but actually it is not a common practice in many projects.
There are a variety of build tools available for a variety of programming languages. Some of the most popular build tools include Ant for Java and MSBuild for .NET. Using a scripting tool designed specifically for building software, instead of a custom set of shell or batch scripts, is the most effective manner for developing a consistent, repeatable build solution.
So why do we need a build process to start with. Well for starters, for a Continuous Integration server, the build process should be easy to work with and should be seamless to implement.
Let’s take a simple example of what a build file can look like for .Net −
<?xml version = "1.0" encoding = "utf-8"?>
<project xmlns = "http://schemas.microsoft.com/developer/msbuild/2003">
<Target Name = "Build">
<Message Text = "Building Project" />
<MSBuild Projects = "project.csproj" Targets = "Build/>"
</Target>
</project>
The following aspects need to be noted about the above code −
A target is specified with a name of the Build. Wherein, a target is a collection of logical steps which need to be performed in a build process. You can have multiple targets and have dependencies between targets.
In our target, we keep an option message which will be shown when the build process starts.
The MSBuild task is used to specify which .Net project needs to be built.
The above example is a case of a very simple build file. In Continuous Integration, it is ensured that this file is kept up-to-date to ensure that the entire build process is seamless.
Building a Solution in .Net
The default build tool for .Net is MSBuild and is something that comes shipped with the .Net framework. Depending on the framework on your system, you will have the relevant MSbuild version available. As an example, if you have the .Net framework installed in the default location, you will find the MSBuild.exe file in the following location −
C:\Windows\Microsoft.NET\Framework\v4.0.30319
Let’s see how we can go about building our sample project. Let’s assume our Sample project is located in a folder called C:\Demo\Simple.
In order to use MSBuild to build the above solution, we need to open the command prompt and use the MSBuild option as shown in the following program.
msbuild C:\Demo\Simple\Simple.csproj
In the above example, csproj is the project file which is specific to .Net. The csproj file contains all the relevant information to ensure that the required information is present for the software to build properly. Following is the screenshot of the output of the MSBuild command.
You don’t need to worry about the output warnings as long as the Build was successful and there were no errors.
Now let’s look at certain aspects of the MSBuild file to see what they mean. These aspects are important to know from a Continuous Integration Cycle.
Build scripts are used to build the solution which will be a part of the entire continuous Integration cycle. Let’s look at the general build script which is created as a part of Visual Studio in .Net for our sample solution. The build script is a pretty big one, even for a simple solution, so we will go through the most important parts of it. By default, the build script will be stored in a file with the same name as the main solution in Visual Studio. So in our case, if you open the file Simple.csproj, you will see all the settings which will be used to build the solution.
Dependency on the MSBuild version used − The following settings will use the MSBuild files installed on the CI server.
<VisualStudioVersion Condition = "'$(VisualStudioVersion)' == ''">10.0</VisualStudioVersion> <VSToolsPath Condition = "'$(VSToolsPath)' == ''">
$(MSBuildExtensionsPath32)\Microsoft\VisualStudio\v$(VisualStudioVersion)
</VSToolsPath>
<TargetFrameworkVersion>v4.5</TargetFrameworkVersion>
<Import Project = "$(MSBuildBinPath)\Microsoft.CSharp.targets" /> <Import Project = "$(VSToolsPath)\WebApplications\
Microsoft.WebApplication.targets" Condition = "'$(VSToolsPath)' ! = ''" /> <Import Project = "$(MSBuildExtensionsPath32)\Microsoft\VisualStudio\v10.0\
WebApplications\Microsoft.WebApplication.targets" Condition = "false" />
What files are required to build the solution properly – The ItemGroup tag will contain all the necessary .Net files which are required for the project to build successfully. These files will need to reside on the build server accordingly.
<ItemGroup>
<Reference Include = "Microsoft.CSharp" />
<Reference Include = "System.Web.DynamicData" />
<Reference Include = "System.Web.Entity" />
<Reference Include = "System.Web.ApplicationServices" />
<Reference Include = "System.ComponentModel.DataAnnotations" />
<Reference Include = "System" />
<Reference Include = "System.Data" />
<Reference Include = "System.Core" />
<Reference Include = "System.Data.DataSetExtensions" />
<Reference Include = "System.Web.Extensions" />
<Reference Include = "System.Xml.Linq" />
<Reference Include = "System.Drawing" />
<Reference Include = "System.Web" />
<Reference Include = "System.Xml" />
<Reference Include = "System.Configuration" />
<Reference Include = "System.Web.Services" />
<Reference Include = "System.EnterpriseServices"/>
</ItemGroup>
What are the Web server settings to be used − When we visit our topic of Continuous Deployment, you will see how MSBuild will be used to override these settings and deploy this to our server of choice.
<UseIIS>True</UseIIS>
<AutoAssignPort>True</AutoAssignPort>
<DevelopmentServerPort>59495</DevelopmentServerPort>
<DevelopmentServerVPath>/</DevelopmentServerVPath>
<IISUrl></IISUrl>
<NTLMAuthentication>False</NTLMAuthentication>
<UseCustomServer>False</UseCustomServer>
The next important step is to ensure that the solution builds on the build server. The first part is a manual step, because before the continuous integration tool is used, we first must ensure that the build gets run on the build server in the same manner as what was done on the client machine. To do this, we must implement the following steps −
Step 1−ソリューションファイル全体をサーバーにコピーします。ビルドサーバーとして使用されるAmazonインスタンスサーバーを作成しました。したがって、全体のサーバーに手動でコピーします.Net サーバーへのソリューション。
Step 2−フレームワークがサーバー上に存在することを確認します。クライアントマシンの.NetFramework 4.0でアプリケーションをコンパイルした場合は、サーバーマシンにもアプリケーションがインストールされていることを確認する必要があります。だからその場所に行くC:\Windows\Microsoft.NET\Framework サーバー上で、目的のフレームワークが存在することを確認します。
Step 3 −サーバーでMSBuildを実行して、何が起こるかを見てみましょう。
わかりました。エラーが発生したようです。継続的インテグレーションには重要な教訓が1つあります。それは、ビルドがビルドサーバーで機能することを確認する必要があるということです。このためには、すべての前提条件ソフトウェアがビルドサーバーにインストールされていることを確認する必要があります。
.Netの場合、というコンポーネントをインストールする必要があります Visual Studio Redistributable package。このパッケージには、に必要なすべての必要なファイルが含まれています.Netサーバー上に構築するアプリケーション。それでは、ビルドサーバーで次のインストール手順を実行しましょう。
Step 4 −実行可能ファイルをダブルクリックしてインストールを開始します。
Step 5 −次のステップで、ライセンス条項に同意し、[インストール]をクリックします。
Step 6 − MSBuildを実行するときは、MSBuildを呼び出すときに追加のパラメーターを含める必要があります。 p:VisualStudioversion = 12.0。これにより、MSBuildは前の手順でダウンロードされたファイルを確実に参照します。
これで、ソリューションが適切に構築されていることがわかり、ベースラインプロジェクトがサーバー上で正しく構築されていることもわかります。
次の重要な側面は、ベースラインコードがGitであるソースコードリポジトリ管理サーバーにチェックインされていることを確認することです。これを行うには、次の手順に従う必要があります。
Step 1−リポジトリを初期化してGitにアップロードできるようにします。これはで行われますgitinitコマンド。したがって、プロジェクトフォルダに移動して、git init コマンド。
Step 2−次のステップは、Gitでのファイルのステージングと呼ばれます。これにより、Gitに追加する必要のあるプロジェクトフォルダー内のすべてのファイルが準備されます。あなたはこれをgit add次のスクリーンショットに示すようにコマンド。'。' 表記は、ディレクトリとサブディレクトリ内のすべてのファイルをコミットに含める必要があることを示すために使用されます。
Step 3 −最後のステップは、ファイルをGitリポジトリにコミットすることです。これにより、ファイルは本格的なGitリポジトリになります。
Gitリポジトリにソースコードがあり、すべての初期コードがビルドサーバーで機能するようになったので、継続的インテグレーションサーバーでプロジェクトを作成します。これは、次の手順で実行できます-
Step 1−TeamCityソフトウェアにログインします。継続的インテグレーションサーバーのURLに移動します-http://localhost:8080/login.html。
管理者の資格情報を入力し、サーバーにログインします。
Step 2−ログインすると、ホーム画面が表示されます。クリックCreate Project 新しいプロジェクトを開始します。
Step 3−プロジェクトに名前を付け、[作成]をクリックしてプロジェクトを開始します。この例では、次のスクリーンショットに示すように、プロジェクトに「デモ」という名前を付けています。
Step 4−次のステップは、プロジェクトで使用されるGitリポジトリについて言及することです。継続的インテグレーション環境では、CIサーバーはGit対応のリポジトリからコードを取得する必要があることに注意してください。前の手順で、プロジェクトフォルダーをGit対応のリポジトリにすることはすでに有効にしています。TeamCityでは、VCSルートを作成する必要があります。これについては、VCS Roots プロジェクトのメイン画面で。
Step 5 −次に表示される画面で、 Create VCS root 次のスクリーンショットに示すように。
Step 6 −次に表示される画面で、次の手順を実行します−
VCSのタイプをGitとして言及します。
VCSルートに名前を付けます。これは任意のフレンドリ名にすることができます。名前を次のように付けましたApp。
フェッチURLを次のように指定します C:\Demo\Simple - これは out git 有効なリポジトリ。
画面を下にスクロールすると、[接続のテスト]ボタンが表示されます。それをクリックして、Git対応リポジトリに正常に接続できることを確認します。
Step 7 − [作成]をクリックすると、次の画像に示すようにリポジトリが登録されていることがわかります。
Step 8−次のステップは、プロジェクトのビルドに使用されるビルド構成を作成することです。でプロジェクト画面に移動しますTeamCity → General Settings。[ビルド構成の作成]をクリックします。
Step 9−次の画面で、ビルド構成の名前を指定します。私たちの場合、名前を付けましたDemoBuild 次に、[作成]をクリックします。
Step 10 −次に表示される画面で、を選択するように求められます VCS repositoryこれは前の手順で作成されました。だから名前を選ぶ‘App’ 添付をクリックします。
Step 11−ポップアップする次の画面で、ビルド手順を構成する必要があります。だから 'をクリックconfigure build steps manually'ハイパーリンク。
Step 12 −次のビルド画面で、以下の詳細を入力する必要があります−
ランナータイプをMSBuildとして選択します。
ステップ名にオプションの名前を付けます。
ビルドする必要のあるファイルの名前を指定します。前のセクションでMSbuildを指定すると、通常、次のオプションが表示されます。Simple.csproj。ここでも同じことを指定する必要があります。
MSBuildのバージョンを「MicrosoftBuildTools2013」として選択します。
を選択してください MSBuild ToolsVersion 12.0として。
ページを下にスクロールして、設定を保存します。
Step 13 −次の画面で、[実行]をクリックします。
現在進行中のアプリケーションのビルドが表示されます。
画面が正常に表示されるはずです。これは、ソリューションが適切に構築されていることを示す良い兆候です。
次のスクリーンショットに示すように、ビルドログに移動して、継続的インテグレーションサーバーでカバーされたすべてのステップを確認することもできます。
Gitにベースコードがあり、継続的インテグレーションサーバーへのリンクができたので、いよいよ継続的インテグレーションの最初のステップの実際を見てみましょう。これは、トリガーなどの継続的インテグレーションサーバーでタスクを定義することによって行われます。これにより、継続的インテグレーションプロセス全体が可能な限りシームレスになります。VisualStudioのコードに変更を加えましょう。
Step 1 −に移動します Demo.aspx Visual Studioでページを作成し、ページのタイトルを変更します。
Step 2 −Gitリポジトリにクエリを実行する場合 git status コマンド、あなたは実際にそれを見るでしょう Demo.aspx ファイルが変更されました。
ここで、コードを変更するたびに継続的インテグレーションサーバーのビルドがトリガーされるようにする必要があります。このために、次の変更を行う必要があります。
Step 3 −プロジェクトダッシュボードに移動し、トリガーセクションをクリックして、 Add new trigger。
Step 4 −次に表示される画面で、 VCS trigger、トリガーを作成するために使用されます。これにより、リポジトリへのチェックインが行われたときに、ビルドがトリガーされます。
Step 5 −クリック Show Advanced Options 次のスクリーンショットに示されているオプションが選択されていることを確認します。
Step 6− [保存]をクリックします。次のスクリーンショットに示すように、トリガーが正常に登録されたことがわかります。
Step 7−次に、コードをGitリポジトリにチェックインして、何が起こるかを確認します。それでは、コマンドプロンプトに移動して、git add 変更したファイルをステージングするコマンド。
Step 8 −今すぐ発行 git commit コマンドを実行すると、変更がGitリポジトリにプッシュされます。
Step 9 − [プロジェクトの概要]画面に移動すると、新しいビルドがトリガーされて実行されていることがわかります。
あなたが見たら Change log Tab、が表示されます git comment ビルドをトリガーしました。
もう一度試してみましょう。に別の変更を加えましょうDemo.aspxファイル。実行しましょうgit add コマンドと git commit 次のコミットメッセージを含むコマンド。
TeamCityのプロジェクトダッシュボードでビルドが自動的にトリガーされるのがわかります。
ビルドには成功メッセージが表示されます。
変更がコミットされたときに使用された「Secondcommit」のメッセージが表示されます。 git repository。
これで、継続的インテグレーションプロセスの最初の部分が正常に完了しました。
ビルド失敗通知は、ビルドが失敗するたびにトリガーされるイベントです。ビルドが失敗するたびに、すべてのキーパーソンに通知が送信されます。このような場合に最初に重要なことは、失敗したビルドに時間を費やして、ビルドが確実に成功するようにすることです。次の手順は、ビルド通知がTeamCityに配置されていることを確認するために使用されます。
TeamCityで電子メール通知を設定する手順は次のとおりです。
Step 1− TeamCityで、プロジェクトダッシュボードに移動し、右上隅にある[管理]をクリックします。次に、Email Notifier左側のリンク。このリンクをクリックして、Eメールの一般設定を表示します。
Step 2 −次のステップは、有効な詳細を入力することです SMTP Server。Gmailには無料のSMTP機能があり、誰でも使用できます。したがって、次のスクリーンショットに示すように表示される次の画面にこれらの詳細を入力できます。
- SMTPホスト– smtp.gmail.com
- SMTPポート番号– 465
- からの電子メールメッセージの送信とSMTPログイン–これは有効なGmailIDである必要があります
- SMTPパスワード–そのGmailIDの有効なパスワード
- 安全な接続–これをSSLとして配置
Step 3 −クリック Test Connection設定が正しく機能していることを確認するためだけに。次に、をクリックしますSave 設定を保存します。
Step 4−次のステップは、ユーザーのビルド通知を有効にすることです。最初のタスクは、これらのビルド通知を受信するユーザーを作成することです。プロジェクトダッシュボードに移動し、Users Option。
Step 5−新しいユーザーを作成します。必要なユーザー名とパスワードを入力します。次に、画面の下部にある[ユーザーの作成]ボタンをクリックします。
Step 6 −この新しいユーザーIDとパスワードを使用してTeamCityシステムにログインします。
Step 7−ログインすると、ユーザーの一般設定が表示されます。[メール通知]セクションで、[編集]をクリックします。
Step 8 −次に表示される画面で、 Add new rule。
Step 9 − [新しいルールの追加]で、次の2つのオプションを選択し、[保存]をクリックします。
選択したプロジェクトからのビルド–デモプロジェクトを選択します。
「ビルドに失敗しました」のチェックボックスを有効にします。
これらの2つのオプションを有効にすることで、デモプロジェクトのビルドが失敗するたびに、ユーザーに電子メール通知が送信されます– demouser。
Step 10−次に、間違ったビルドをトリガーして、これが実際に動作することを確認しましょう。Visual Studioで、demo.aspx.cs ファイルを作成し、間違ったコード行を追加します。
Step 11 −次に、Gitからコードをチェックインします。 git add そして git commit。
これで、プロジェクトダッシュボードで、ビルドが自動的にトリガーされ、次のスクリーンショットに示すように、ビルドが失敗したことがわかります。
のGmailIDにログインした場合 demouser、次のスクリーンショットに示すように、実際にはビルド失敗の通知が表示されます。
継続的インテグレーションの重要な側面の1つは、ビルドのパフォーマンスを常に確認し、重要なメトリックを収集し、それらの結果を文書化し、継続的ビルドを通じて継続的フィードバックを生成することです。
これらの指標を設定することの利点は何ですか?
Not Committing Code Enough−開発者がバージョン管理リポジトリにコードを頻繁にコミットしていない場合、その理由は統合ビルドが遅いことが原因である可能性があります。ビルド期間の短縮を開始するには、統合ビルド環境の高レベルの分析を実行して、ボトルネックを特定します。
次に、調査結果を分析して最も適切な改善を決定し、ビルドプロセスに変更を加えて、ビルドの期間を短縮します。最後に、ビルド期間を再評価して、さらに改善が必要かどうかを判断します。
Improve Test Performance− CIシステムが適切に機能している場合でも、統合ビルド時間の大部分は自動テストの実行に費やされます。これらのテストのパフォーマンスを評価および改善すると、ビルド期間を大幅に短縮できます。
Infrastructure Issues−システムインフラストラクチャが原因で、統合ビルドが遅いことに気付く場合があります。おそらく、ネットワークパフォーマンスが遅いか、パフォーマンスの遅い仮想プライベートネットワーク接続があります。
地理的に分散したシステムや信頼性の低いハードウェアまたはソフトウェアも、パフォーマンスの問題を引き起こす可能性があります。インフラストラクチャリソースを調査および改善して、ビルド期間を短縮します。
指標
以下は、継続的インテグレーションサーバーで利用できるいくつかのメトリックです。
TeamCityが提供するものを見てみましょう-
メトリックの最も単純な形式の1つは、プロジェクトダッシュボードで使用できるものです。ここで重要な要素は、各ビルドの期間に注意することです。各ビルドの期間がビルド中のコードに不釣り合いに増加し始めた場合、これは問題になる可能性があります。したがって、これは取得できるフィードバックの1つであり、これの原因として、CIサーバーのリソースが不足しており、サーバーの容量を増やす必要がある可能性があります。
TeamCityには、CIサーバーが実際にインフラストラクチャに関して何らかの問題を抱えているかどうかを確認する機能があります。の中にadmin dashboard TeamCityでは、をクリックすることができます Disk Usage 各ビルドで消費されているディスク容量を確認します。
さらに詳細が必要な場合、TeamCityには diagnostics button、に関する詳細情報を提供できます CPU and Memory CIサーバーによって利用されています。
ビルドメトリックの詳細ビュー
特定のプロジェクトのビルドの詳細なビューを経時的に表示したい場合は、プロジェクトビルドの一部として利用できます。プロジェクトビルド画面で、統計画面に移動します。これにより、ビルドの実行状況に関するさまざまな統計とグラフが表示されます。
継続的インテグレーションの重要な機能の1つは、 on-going testingCIサーバーによってビルドされるすべてのコードを保持します。CIサーバーによってビルドが実行された後、必要なコードをテストするためにテストケースが適切に配置されていることを確認する必要があります。すべてのCIサーバーには、単体テストケースを実行する機能があります。CI suite。に.Net、ユニットテストはに組み込まれている機能です .Net framework 同じことをCIサーバーに組み込むこともできます。
この章では、でテストケースを定義する方法を説明します。 .Netビルドが完了したら、TeamCityサーバーにこのテストケースを実行させます。このために、最初に、サンプルプロジェクトに単体テストが定義されていることを確認する必要があります。
これを行うには、次の手順に細心の注意を払って従う必要があります。
Step 1−ユニットテストで使用される新しいクラスをソリューションに追加しましょう。このクラスには、文字列「継続的インテグレーション」を保持する名前変数があります。この文字列はWebページに表示されます。シンプルプロジェクトを右クリックして、メニューオプションを選択しますAdd → Class。
Step 2 −クラスの名前を次のように指定します Tutorial.cs 画面の下部にある[追加]ボタンをクリックします。
Step 3− Tutorial.csファイルを開き、次のコードを追加します。このコードは、という文字列を作成するだけですName、およびコンストラクタで、名前を文字列値に次のように割り当てます。 Continuous Integration。
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
namespace Simple {
public class Tutorial {
public String Name;
public Tutorial() {
Name = "Continuous Integration";
}
}
}
Step 4 −私たちに変更を加えましょう Demo.aspx.csこの新しいクラスを使用するファイル。このファイルのコードを次のコードで更新します。したがって、このコードは、上記で作成したクラスの新しいインスタンスを作成します。
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
namespace Simple {
public partial class Demo : System.Web.UI.Page {
Tutorial tp = new Tutorial();
protected void Page_Load(object sender, EventArgs e) {
tp.Name = "Continuous Integration";
}
}
}
Step 5 −私たちの demo.aspx ファイル、参照してみましょう tp.Name で作成された変数 aspx.cs ファイル。
<%@ Page Language = "C#" AutoEventWireup = "true"
CodeBehind = "Demo.aspx.cs" Inherits = "Simple.Demo" %>
<!DOCTYPE html>
<html xmlns = "http://www.w3.org/1999/xhtml">
<head runat = "server">
<title>TutorialsPoint1</title>
</head>
<body>
<form id = "form1" runat = "server">
<div>
<% = tp.Name%>)
</div>
</form>
</body>
</html>
これらの変更でコードが正常に機能することを確認するために、VisualStudioでコードを実行できます。コンパイルが完了すると、次の出力が得られるはずです。
Step 6−次に、ユニットテストをプロジェクトに追加します。右クリックSolution メニューオプションを選択します Add → New Project。
Step 7 −に移動 Test 右側で、を選択します Unit Test Project。次のように名前を付けますDemoTest 次に、[OK]をクリックします。
Step 8 −あなたの中で Demo Test project、Simpleプロジェクトと必要なものへの参照を追加する必要があります testing assemblies。プロジェクトを右クリックして、メニューオプションを選択しますAdd Reference。
Step 9 −次に表示される画面で、[プロジェクト]に移動し、[ Simple Reference [OK]をクリックします。
Step 10 −クリック Add Reference もう一度、アセンブリに移動して入力します Web検索ボックスで。次に、の参照を追加しますSystem.Web。
Step 11 −で Unit Test file、次のコードを追加します。このコードは、Tutorialクラスに文字列名変数があることを確認します。また、名前は「継続的インテグレーション」の値と等しくなければならないという事実も主張します。これが私たちの簡単なテストケースになります。
using System;
using Microsoft.VisualStudio.TestTools.UnitTesting;
using Microsoft.VisualStudio.TestTools.UnitTesting.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using Simple;
namespace DemoTest {
[TestClass]
public class UnitTest1 {
[TestMethod]
public void TestMethod1() {
Tutorial tp = new Tutorial();
Assert.AreEqual(tp.Name, "Continuous Integration");
}
}
}
Step 12− Visual Studioでテストを実行して、機能することを確認しましょう。Visual Studioで、メニューオプションを選択しますTest → Run → All Tests。
テストを実行すると、VisualStudioの左側でテストが正常に実行されたことがわかります。
TeamCity内での継続的テストの有効化–すべてのテストケースが整ったので、これらをTeamCityサーバーに統合します。
Step 13−このために、プロジェクト構成でビルドステップを作成する必要があります。プロジェクトのホームに移動し、[構成設定の編集]をクリックします。
step 14 −次に、[ビルドステップ]→[MSビルド]に移動し、次のスクリーンショットに示すように[ビルドステップの追加]をクリックします。
表示される次の画面で、次の値を追加します-
VisualStudioテストとしてランナータイプを選択します。
オプションのテストステップ名を入力します。
テストエンジンのタイプを次のように選択します VSTest。
テストエンジンのバージョンを次のように選択します VSTest2013。
テストファイル名で、場所を次のように指定します DemoTest\bin\Debug\DemoTest.dll –覚えておいてください DemoTestユニットテストを含むプロジェクトの名前です。ザ・DemoTest.dll 最初のビルドステップで生成されます。
画面の最後に表示される[保存]をクリックします。
これで、プロジェクトの2つのビルドステップがあります。最初は、アプリケーションコードとテストプロジェクトをビルドするビルドステップです。そして、次はテストケースを実行するために使用されます。
Step 15−ビルドプロセス全体をトリガーできるように、Gitですべてのコードをチェックインするときが来ました。唯一の違いは今回です、あなたは実行する必要がありますgit add そして git commit からのコマンド Demo parent folder 次のスクリーンショットに示すように。
ビルドがトリガーされると、テストに合格したことを示す初期出力が表示されます。
Step 16 − [合格したテストの結果]をクリックして[テスト]タブに移動すると、UnitTest1が実行され、合格したことがわかります。
継続的検査は、実際のテストが実行される前に、コードに対して実行される検査の自動コードレビューのプロセスです。ソフトウェアの検査とテストには微妙な違いがあります。テストは動的であり、機能をテストするためにソフトウェアを実行します。インスペクションは、事前定義されたルールのセットに基づいてコードを分析します。
インスペクター(または静的および動的分析ツール)は、チームが順守する必要のある特定された標準(通常はコーディングまたは設計メトリック)によって指示されます。検査対象の例には、コーディングの「文法」標準、アーキテクチャの階層化の順守、コードの複製などが含まれます。
継続的な検査により、発見から修正までの時間が短縮されます。利用可能な継続的な検査ツールがいくつかあります。この例では、を使用しますNCover 3.xTeamCityと統合されています。継続検査をどのように実行できるか、そしてそれが私たちのために何ができるかを見てみましょう。
NCoverをダウンロードしてインストールする
NCoverは、ダウンロードしてインストールする必要がある別個の製品です。NCoverをダウンロードするには、次のリンクをクリックして32ビットインストーラーをダウンロードしてください-http://www.ncover.com/info/download.
ダウンロードしたインストーラーを実行し、インストーラーの起動後に[次へ]をクリックします。
使用許諾契約に同意し、[次へ]をクリックします。
デフォルトのコンポーネントを受け入れて、「次へ」をクリックします。
[インストール]ボタンをクリックして、インストールを開始します。
[完了]ボタンをクリックして、インストールを完了します。
に移動して、NCoverインストールを初めて起動します。 C:\Program Files (x86)\NCover\ NCover.Explorer.exe。トライアルキーを初めてインストールするだけで済みます。これは簡単なプロセスです。
NCoverを使用するようにTeamCityでプロジェクトを構成する
Step 1 −プロジェクトのホーム画面に移動し、[構成設定の編集]をクリックします。
Step 2 − [ビルドステップ]に移動し、[編集]をクリックして TestStep。継続検査は、定義されている単体テストと一緒に実行する必要があります。
Step 3 − .Net Coverageセクションで、をクリックします。 .Net Coverage Tool。次に、次の設定を選択します。
- .NetカバレッジツールをNCover(3.x)として選択します
- x86としてのプラットフォーム
- v4.0としてのバージョン
- C:\ Program Files(x86)\ NCoverとしてのNCoverへのパス
- 他の設定はそのままにしておきます
Step 4 − [保存]をクリックします。
Step 5 −プロジェクトのメイン画面に移動し、[実行]をクリックします。
Step 6−ビルドが実行されたら、「合格したテスト」をクリックします。これで、コードカバレッジ画面が表示され、多くのメトリックインジケーターが表示されます。
Step 7 − [コードカバレッジ]タブをクリックして、コード分析の詳細を取得できるようになりました。
Step 8 −をクリックします fullcoveragereport.html。これで、実施された検査に関する完全な包括的なレポートが得られます。.Net code。
継続的なデータベース統合は、プロジェクトのバージョン管理リポジトリに変更が適用されるたびに、データベースとテストデータを再構築するプロセスです。
データベース統合では、通常、データベース統合に関連するすべてのアーティファクト-
- バージョン管理システムに常駐する必要があります。
- 厳密さをテストし、ポリシーコンプライアンスを検査できます。
- ビルドスクリプトを使用して生成できます。
継続的なデータベース統合に関与できるアクティビティは、次のいずれかになります。
Drop a Database −データベースを削除し、関連するデータを削除して、同じ名前で新しいデータベースを作成できるようにします。
Create a new Database −データ定義言語(DDL)を使用して新しいデータベースを作成します。
Insert the Initial Data −配信時にシステムに含まれると予想される初期データ(ルックアップテーブルなど)を挿入します。
Migrate Database and Data −データベーススキーマとデータを定期的に移行します(既存のデータベースに基づいてシステムを作成している場合)。
Modify Column Attributes −要件とリファクタリングに基づいて、テーブルの列の属性と制約を変更します。
Modify Test Data −複数の環境で必要に応じてテストデータを変更します。
したがって、Continuous Databaseの例では、次の手順を実行します。
MS SQLServerデータベースと対応するテーブルを作成します。
SQL Server ManagementStudioからスクリプトを作成します。このデータベーススクリプトは、データベースにテーブルを設定するために使用されます。
このデータベースにアクセスするためのコードをASP.Netプロジェクトに記述します。
このスクリプトを実行するために、TeamCityのプロジェクトにステップを作成します。
スクリプトをGitにチェックインします。
前のセクションで作成したAWSデータベースでこれを行う手順。
Step 1− MS SQLServerデータベースと対応するテーブルを作成します。SQL Server Management Studioを開いて、簡単なデータベースとテーブルを作成しましょう。データベースを右クリックして、New Database.
Step 2 − Name it as Demodb and click OK
Step 3 − In the new database, right-click and create a new table.
Step 4 − You can add your desired columns to the table.
Step 5 − Save the table and name it as Demotb.
Step 6 − Now right-click on the table and choose the menu option Script Table as → Drop and Create to → File.
Step 7 − Save the file to the demo project folder as Sample.sql.
This is what the database script would look like. It would first drop an existing table if present and then re-create the table.
USE [Demodb]
GO
/****** Object: Table [dbo].[Demotb] Script Date: 3/22/2016 7:03:25 AM
******
DROP TABLE [dbo].[Demotb]
GO
/****** Object: Table [dbo].[Demotb] Script Date: 3/22/2016 7:03:25 AM
******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE TABLE [dbo].[Demotb](
[TutorialName] [nvarchar](max) NULL,
[TutorialID] [smallint] NULL
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]
GO
Step 8 − Now let’s quickly change our ASP.Net code to refer to the new database.
Step 9 − In the Tutorial.cs file in your Demo project, add the following lines of code. These lines of code will connect to your database, take the Server version and store the version name in the Name variable. We can display this Name variable in our Demo.aspx.cs file through a Response.write command.
using System;
using System.Collections.Generic;
using System.Data.SqlClient;
using System.Linq;
using System.Web;
namespace Simple {
public class Tutorial {
public String Name;
public Tutorial() {
string connectionString = "Data Source = WIN-50GP30FGO75;
Initial Catalog = Demodb;
Integrated Security = true;";
using (SqlConnection connection = new SqlConnection()) {
connection.ConnectionString = connectionString;
connection.Open();
Name = connection.ServerVersion;
connection.Close();
}
}
}
}
Step 10 − Add the following code to the Demo.aspx.cs file to ensure that it displays the SQL Server version.
using System;
using System.Collections.Generic;
using System.Data.SqlClient;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
namespace Simple {
public partial class Demo : System.Web.UI.Page {
Tutorial tp = new Tutorial();
protected void Page_Load(object sender, EventArgs e){
Response.Write(tp.Name);
}
}
}
Now if we run the code, you will get the following output in the browser.
Step 11 − Now let us add our step in TeamCity which will invoke the database script. Go to your project dashboard and click Edit Configuration Settings.
Step 12 − Go to Build Steps and click Add build step.
Choose the following options (Note that MS SQL Server client should be installed on the CI Server).
Runner type should be the Command Line.
Give an optional Step Name.
Run should be Executable with parameters.
Command executable should be C:\Program Files\Microsoft SQL Server\110\Tools\Binn\sqlcmd.exe
Command parameters should be -S WIN-50GP30FGO75 -i Sample.sql. Where –S gives the name of the SQL Server instance.
Step 13 − Click Save.
Now what needs to be ensured is the build order. You have to ensure the build order is as follows.
Step 14 − You can change the build order by choosing the option to reorder build steps.
The database setup should be first – So this will be used to recreate your database from fresh.
Next is the build of your application.
Finally your test setup.
Step 15 − Now run the git add and git commit command so that the Sample.sql file is checked into Git. This will trigger a build automatically. And this build should pass.
You now have a full-fledged build cycle with a continuous database integration aspect as well in your cycle. In the next section, let’s take this further and look at Continuous Deployment.
Now that you have done this with a local SQL Server, we can repeat the same steps for a AWS MS SQL Server which was created in one of the earlier sections. To connect to a Microsoft SQL Server, you need to connect via the following convention.
Step 16 − First see what is the name assigned to your database instance in AWS. When you log-in to the AWS, go to the RDS section under the database section.
Step 17 − Click on DB Instances in the next screen that comes up.
step 18 − Click on your database and make a note of the endpoint. In the following screenshot, it is demodb.cypphcv1d87e.ap-southeast-1.rds.amazonaws.com:1433
Step 19 − Now to connect to the database from SQL Server Management Studio, you need to specify the connection as demodb.cypphcv1d87e.ap-southeast-1.rds.amazonaws.com,1433 (Note the comma used between instance name and port no).
The following screenshot shows a successful connection to the database.
Then you can repeat all the same steps. The Sqlcmd command will be as follows −
This same command can be replaced in the Database build step in TeamCity. When you execute the sqlcmd command, the table will be created automatically in your SQL Server database in AWS.
Automated builds and repeatable builds. Automated tests and repeatable tests. Test categories and test frequencies. Continuous inspections. Continuous database integration. These string of tasks in creating an effective CI environment primarily enables one key benefit: releasing working software at any point in time, in any environment.
In our previous chapters, we have accomplished all of the following segments −
- Created our code.
- Ensured a proper build in TeamCity.
- Created a Database Integration process.
- Conducted successful testing.
Now the only thing remaining is to carry out an automated deployment, so that our entire process is complete.
For an automated deployment in our case, we need to follow these steps −
In our deployment server, ensure that IIS is installed.
Ensure that IIS user is given access to our database.
Create a publish profile which will be used to publish the site when it is built.
Ensure we change our MSBuild command to do an automatic deployment.
Automate TeamCity to do an automatic publish.
Do a git commit to ensure all your files are in Git.
Step 1 − Configure a local IIS Server. If you have a local or remote IIS Server, the following configuration can be carried out to deploy our application. It’s always a good practice to see if a deployment can be done manually before it is done in an automated fashion.
Step 2 − On a Windows 2012 server, go to your Server Manager and click on Add Roles and Features.
Step 3 − Click Next on the following screen that comes up.
Step 4 − Choose roles-based or feature-based installation on the next screen and click Next.
Step 5 − Select the default server and click Next.
Step 6 − Choose the Web server role and click Next.
Step 7 − In the next screen that comes up, click Next.
Step 8 − Click Next again on the following screen that appears.
Step 9 − In the next screen that pops up, click Next.
Step 10 − In the final screen, you can click the Install button to install the IIS.
Once you have IIS installed, you can open it by opening the Internet Information Services.
Step 11 − Click Application Pools, you will see a pool with the name of DefaultAppPool. This needs to have access to SQL Server in the next step.
Step 12 − If we need to connect a ASP.Net application to a MS SQL Server application, we have to give access to the default application pool to the SQL Server instance, so that it can connect to our Demodb database.
Step 13 − Open SQL Server Management Studio. Go to Logins, right-click and choose the menu option New Login.
In the next screen, update the following parameters and click OK.
- Login name as IIS APPPOOL\DefaultAppPool.
- Default database – This should be our database, which is demodb.
Step 14 − Creating a Publish Profile. The publish profile is used in Visual Studio to create a deployment package that can then be used with MS Build and in any CI Server accordingly. To do this, from Visual Studio, right-click on the project and click the menu option of Publish
Step 15 − In the next screen that comes up, choose to create a new Publish profile, give it a name – DemoDeployment. Then click the Next button.
In the ensuing screen that shows up, add the following values −
- Choose the Publish method as Web Deploy.
- Enter the server as localhost.
- Enter the site name as Default Web Site/Demo.
- Put the destination url as http://localhost/Demo
Then click the Next button.
Step 16 − In the next screen, click Next.
Step 17 − In the final screen that comes up, click the Publish button.
Now if you go to the C:\Demo\Simple\Properties\PublishProfiles location of your project, you will see a new publish profile xml file created. This publish profile file will have all the details required to publish your application to the local IIS server.
Step 18 − Now let’s customize our MSBuild command and use the above publish profile and see what happens. In our MSBuild command, we specify the following parameters −
Deploy on Build is true – this will trigger an automatic deployment once a successful build is done.
We are then mentioning to use the Publish profile which was used in the above step.
The Visual Studio version is just to be mentioned to the MSBuild deployment capability on what is the version of the Visual Studio being used.
When you run the above command, MSBuild will trigger a build and deployment process. What you will note that, it is deploying it to our Default Website in our IIS Server.
Now if we browse to the site – http://localhost/Demo/Demo.aspx we will see the following output, which means that the MSBuild did a successful deployment to our website.
Step 19 − Automating through TeamCity – Now it is time to add a task to our TeamCity server to automatically use MSBuild to deploy our application, based on the above mentioned steps.
Step 20 − Go to your project dashboard and click Edit Configuration Settings.
Step 21 − Go to Build Steps and click Add a Build step.
Choose the following options −
The runner type should be MSBuild
Give an optional Step name
Enter the build path as Simple/Simple.csproj
Keep the MSBuild version as Microsoft Build Tools 2013
Keep the MSBuild Toolsversion as 12.0
Put the command line as /p:DeployOnBuild = true /p:PublishProfile = DemoDeployement /p:VisualStudioVersion = 12.0
Step 22 − Click Save.
Make sure that in the build steps, the Deploy step is the last step in the chain.
Step 23 − Now let’s do a final git commit, to ensure all the files are in Git and can be used by TeamCity.
Congratulations, you have successfully set up a complete Continuous Integration Cycle for your application, which can be run at any point in time.
Let’s have a final review of the best practices of Continuous Integration based on all the lessons we have learnt so far −
Maintain a code repository − This is the most basic step. In all our examples, everything is maintained in a Git repository right from the code base to the Publish profiles, to the database scripts. It must always be ensured that everything is kept in the code repository.
Automate the build − We have seen how to use MSBuild to automate a build along with using a publish profile. This is again a key step in the continuous Integration process.
Make the build self-testing − Ensure that you can test the build by keeping unit test cases in place and these test cases should be in such a way that it can be run by the Continuous Integration server.
Everyone commits to the baseline every day − This is a key principle of Continuous Integration. There is no point staying till the end of the entire process to see who breaks the build.
Every commit (to baseline) should be built − Every commit made to the application, needs to be successfully built. If the build fails for whatever reason, then the code needs to be changed to ensure the build passes.
Keep the build fast − If the build is slow, then it would indicate a problem in the entire Continuous Integration process. Ensure that the builds are always limited to a duration, preferably should never go beyond 10 minutes.
Everyone can see the results of the latest build − The TeamCity dashboard gives everyone a view of all the builds, which have either passed or failed. This gives a good insight to all the people who are involved in the Continuous Integration process.