C#/단위테스트
Blazor - bUnit 컴포넌트 이벤트 핸들러 테스트
범범조조
2022. 11. 30. 22:11
개요
- bUnit 을 이용하여 Blazor 컴포넌트 단위의 단위 테스트 하는 방법에 대해서 정리 진행합니다.
- 그 중에서, 컴포넌트 내의 발생되는 이벤트 핸들러를 테스트 하는 방법에 대해서 알아봅니다.
테스트 컴포넌트 생성
- 우선 테스트를 진행하기 위해서 TestComponent.razor 파일을 생성 후 아래와 같이 코드를 추가합니다.
- HTML 영역에는 단락을 나타내는 p 태그가 있고, p 태그 내용은 Button 컴포넌트의 Click 유무를 True, False 로 체크하여 출력해주는 역할이니다.
- button 태그에는
@onclick
클릭 이벤트가 있고, OnClick 이벤트 핸들러를 호출하도록 하였습니다. - 아래와 같은 구조에서 Click 이 일어났을 때의 상황을 단위테스트 진행합니다.
<p>Button clicked: @buttonClicked</p>
<button @onclick="OnClick">Click me</button>
@code {
bool buttonClicked = false;
void OnClick() => buttonClicked = true;
}
단위 테스트 코드
using Bunit;
using bUnitSample.Pages;
namespace bUnitTest
{
public class UnitTest1
{
[Fact]
public void TestComponent()
{
// Arrange
using var ctx = new TestContext();
var cut = ctx.RenderComponent<TestComponent>();
var paraElm = cut.Find("p");
// Act
cut.Find("button").Click();
var paraElmText = paraElm.TextContent;
// Assert
paraElmText.MarkupMatches("Button clicked: True");
}
}
}
- 1차적으로
var cut = ctx.RenderComponent<TestComponent>();
코드를 통해 TestComponent 전체 렌더링 요소들을 가져옵니디ㅏ. - 다음으로
var paraElm = cut.Find("p");
코드에서 p 태그 요소만 찾아옵니다. - Act 영역에서
cut.Find("button").Click();
button 태그를 찾아서 Click 이벤트를 발생시킵니다. - Click 이벤트가 발생되면, Click 상태가 Fase -> True 로 변경됨에 따라서 우리가 최종적으로 Assert 할 대상의 내용이
paraElmText.MarkupMatches("Button clicked: True");
와 같게 되는 것입니다.
728x90