지속적인 통합-테스트
지속적인 통합의 주요 기능 중 하나는 on-going testingCI 서버에서 빌드 한 모든 코드를 보유합니다. CI 서버에서 빌드를 수행 한 후에는 필요한 코드를 테스트하기 위해 테스트 케이스가 제자리에 있는지 확인해야합니다. 모든 CI 서버에는 단위 테스트 케이스를 실행하는 기능이 있습니다.CI suite. 에.Net, 단위 테스트는 .Net framework 동일한 것을 CI 서버에도 통합 할 수 있습니다.
이 장에서는 테스트 케이스를 정의하는 방법을 .Net빌드가 완료된 후 TeamCity 서버에서이 테스트 케이스를 실행하도록합니다. 이를 위해 먼저 샘플 프로젝트에 대해 정의 된 단위 테스트가 있는지 확인해야합니다.
이를 위해서는 다음 단계를 최대한주의하여 따라야합니다.
Step 1− 솔루션에 새 클래스를 추가해 보겠습니다. 유닛 테스트에서 사용할 수 있습니다. 이 클래스는 "연속 통합"문자열을 보유하는 이름 변수를 갖습니다. 이 문자열은 웹 페이지에 표시됩니다. Simple Project를 마우스 오른쪽 버튼으로 클릭하고 메뉴 옵션을 선택합니다.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>
이러한 변경 사항에 대해 코드가 제대로 작동하는지 확인하기 위해 Visual Studio에서 코드를 실행할 수 있습니다. 컴파일이 완료되면 다음 출력이 표시됩니다.
Step 6− 이제 단위 테스트를 프로젝트에 추가 할 차례입니다. 오른쪽 클릭Solution 메뉴 옵션을 선택하십시오 Add → New Project.
Step 7 − 다음으로 이동 Test 오른쪽에서 Unit Test Project. 이름 지정DemoTest 확인을 클릭합니다.
Step 8 − 귀하의 Demo Test project, Simple 프로젝트 및 필요한 항목에 대한 참조를 추가해야합니다. testing assemblies. 프로젝트를 마우스 오른쪽 버튼으로 클릭하고 메뉴 옵션을 선택하십시오.Add Reference.
Step 9 − 다음 화면이 나타나면 프로젝트로 이동하여 Simple Reference 확인을 클릭합니다.
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.
테스트를 실행하면 Visual Studio의 왼쪽에 테스트가 성공적으로 실행 된 것을 볼 수 있습니다.
TeamCity 내에서 지속적인 테스트 활성화 – 이제 모든 테스트 사례가 준비되었으므로이를 Team City 서버에 통합 할 때입니다.
Step 13−이를 위해 프로젝트 구성에서 빌드 단계를 생성해야합니다. 프로젝트 홈으로 이동하여 구성 설정 편집을 클릭하십시오.
step 14 − 그런 다음 빌드 단계 → MS 빌드로 이동하여 다음 스크린 샷과 같이 빌드 단계 추가를 클릭합니다.
다음 화면이 나타나면 다음 값을 추가하십시오.
Visual Studio 테스트로 러너 유형을 선택합니다.
선택적 테스트 단계 이름을 입력하십시오.
테스트 엔진 유형을 다음과 같이 선택하십시오. VSTest.
테스트 엔진 버전을 다음과 같이 선택하십시오. VSTest2013.
테스트 파일 이름에서 위치를 다음과 같이 제공하십시오. DemoTest\bin\Debug\DemoTest.dll - 기억 DemoTest단위 테스트가 포함 된 프로젝트의 이름입니다. 그만큼DemoTest.dll 첫 번째 빌드 단계에서 생성됩니다.
화면 끝에서 사용할 수있는 저장을 클릭합니다.
이제 프로젝트에 대한 2 개의 빌드 단계가 있습니다. 첫 번째는 애플리케이션 코드와 테스트 프로젝트를 빌드하는 빌드 단계입니다. 다음은 테스트 케이스를 실행하는 데 사용됩니다.
Step 15− 이제 전체 빌드 프로세스가 트리거 될 수 있도록 Git에서 모든 코드를 체크인 할 때입니다. 유일한 차이점은 이번에는git add 과 git commit 명령에서 Demo parent folder 다음 스크린 샷에 표시된대로.
이제 빌드가 트리거되면 테스트가 통과되었음을 알리는 초기 출력이 표시됩니다.
Step 16 − 테스트 통과 결과를 클릭하고 테스트 탭으로 이동하면 UnitTest1이 실행되었고 통과되었음을 확인할 수 있습니다.