C#/단위테스트

Blazor 단위테스트 - bUnit

범범조조 2022. 11. 29. 21:03


개요

  • bUnit 은 Blazor 컴포넌트 테스트 라이브러리입니다.
  • 목표는 포괄적이고 안정적인 단위테스트를 쉽게 작성하도록 도와주는 것 입니다.
  • bUnit 을 사용하여 다음을 수행할 수 있습니다.
    • C# 또는 Razor 구문을 사용하여 테스트 중인 구성 요소 설정 및 정의
    • 시맨틱 HTML 비교기를 사용하여 결과 확인
    • 구성 요소와 상호 작용하고 검사하며 이벤트 핸들러를 트리거합니다.
    • 테스트 중인 구성 요소에 매개 변수, 계단식 값 전달 및 서비스 주입
    • Mock IJSRuntime, Blazor 인증 및 권한 부여 등
  • bUnit 은 일반 단위 테스트와 동일한 방식으로 Blazor 구성 요소 테스트를 실행하는 xUnit, NUnit 및 MSTest 와 같은 기존 단위 테스트 프레임워크 위에 구축됩니다.
  • bUnit은 일반적으로 실행하는 데 몇 초가 걸리는 브라우저 기반 UI 테스트와 비교하여 밀리초 안에 테스트를 실행합니다.

bUnit 테스트 예제

  • 먼저 bUnit 을 사용하기 위해서는 Blazor Server 앱 프로젝트 하나를 생성합니다.

  • Blazor Server 앱 프로젝트를 생성하게 되면, 기본적으로 여러개의 Page View 가 생성됩니다.
  • 여기서 Counter 페이지의 내용을 가지고 bUnit 테스트 코드를 작성할 예정입니다.


Counter.razor

  • 우리가 bUnit 으로 테스트 진행할 Counter.razor 페이지의 코드는 다음과 같습니다.
  • Counter.razor 페이지는 간단히 버튼 클릭 시, currentCount 값이 1씩 증가되어 화면이 표시해 주는 페이지 입니다.
  • 해당 페이지에서 Count 값을 계산하는 내용 즉 <p role="status">Current count: @currentCount</p> 해당 태그 내용을 bUnit 을 이용하여 단위 테스트를 진행해 보도록 하겠습니다.
@page "/counter"

<PageTitle>Counter</PageTitle>

<h1>Counter</h1>

<p role="status">Current count: @currentCount</p>

<button class="btn btn-primary" @onclick="IncrementCount">Click me</button>

@code {
    private int currentCount = 0;

    private void IncrementCount()
    {
        currentCount++;
    }
}

xUnit 테스트 프로젝트 생성

  • bUnit 을 테스트하기에 앞서, xUnit 테스트 프로젝트 생성 진행합니다.
  • xUnit 이 아닌, NUnit 혹은 MSTest 를 이용하여 프로젝트 생성해도 무관합니다.


xUnit 테스트 프로젝트에 Blazor 샘플 프로젝트 참조

  • 앞서 xUnit 테스트 프로젝트를 생성하였습니다.
  • 우리가 할 작업은, Blazor 샘플 프로젝트 안에 있는 Counter.razor 컴포넌트의 일부를 단위테스트 하려는 것입니다.
  • 때문에 xUnit 테스트 프로젝트에 Blazor 샘플 프로젝트 를 참조 시켜주어야 합니다.

  • 위와 같이 프로젝트가 정상적으로 참조 된 것을 확인할 수 있습니다.

bUnit NuGet Package 설치

  • 다음으로 NuGet Package 에서 bUnit NuGet Package 를 설치해줍니다.


테스트코드 작성

  • 이제 bUnit 을 사용하기 위한 준비 작업을 모두 마쳤습니다.
  • 앞서 Counter.razor 페이지를 테스트 하기 위해서 아래와 같이 테스트 코드를 작성하였습니다.
using Bunit;
using bUnitSample.Pages;

namespace bUnitTest
{
    public class UnitTest1
    {
        [Fact]
        public void CounterShouldIncrementWhenClicked()
        {
            // Arrange
            using var ctx = new TestContext();
            var cut = ctx.RenderComponent<Counter>();
            var paraElm = cut.Find("p");

            // Act
            cut.Find("button").Click();
            var paraElmText = paraElm.TextContent;

            // Assert
            paraElmText.MarkupMatches("Current count: 1");
        }
    }
}
  • 이 테스트는 bUnit의 테스트 컨텍스트를 사용 하여 메서드 Counter로 구성 요소 를 렌더링합니다.
  • RenderComponent그런 다음 구성 요소가 렌더링한 버튼을 찾아 Find및 Click메서드를 사용하여 클릭합니다.
  • 마지막으로 단락(

    ) 요소를 찾고 MarkupMatches 메서드에 전달된 예상 태그와 일치하는지 확인합니다.


테스트 결과

  • 테스트 실행 결과, 정상적으로 단위 테스트가 진행된 것을 확인할 수 있습니다.

728x90