C#/단위테스트
Blazor - bUnit 컴포넌트 서비스 주입 테스트
범범조조
2022. 12. 1. 06:12
참고
개요
- bUnit 을 이용하여 Blazor 컴포넌트 단위의 단위 테스트 하는 방법에 대해서 정리 진행합니다.
- 그 중에서, 컴포넌트 내에서 서비스를 주입받아서 데이터를 처리하는 경우가 있습니다.
- 해당 상황을 가정하여 bUnit 테스트 코드 작성하는 방법에 대해서 알려드립니다.
IDataService 인터페이스 구현
- 테스트를 위해, IDataService 인터페이스 하나를 생성하였습니다.
namespace bUnitSample;
public interface IDataService
{
List<string> GetData();
}
DataService 구현체 구현
- 구현체에서는 IDataService 를 상속받아, GetData() 메서드를 구현하였습니다.
namespace bUnitSample;
public class DataService : IDataService
{
public List<string> GetData() => new List<string> { "Data 1", "Data2" };
}
테스트 컴포넌트 작성
- IDataService 를 주입받아서 해당 데이터를 사용하는 테스트 컴포넌트를 하나 생성합니다.
- TestComponent.razor 이름의 컴포넌트를 생성하였고, 아래와 같이 코드를 작성하였습니다.
@inject IDataService DataService;
@if (MyData is null)
{
<p>Retrieving data...</p>
}
else
{
<p>Data retrieved</p>
}
@code {
public List<string> MyData { get; set; }
protected override void OnInitialized()
{
MyData = DataService.GetData();
}
}
테스트 프로젝트 Microsoft.Extensions.DependencyInjection NuGet 추가
- 단위 테스트 코드를 작성하기에 앞서, xUnit 프로젝트에서 DependencyInjection 서비스 주입 관련 테스트를 하기 위해서는
Microsoft.Extensions.DependencyInjection
NuGet Package 를 먼저 설치 해야 합니다.
테스트 방법 1 - Injecting Services
- bUnit 에서 서비스 주입하여 테스트 하는 방법에는 크게 2가지 방법이 있습니다.
- Injeciton Services
- Fallback Service Provider
- 위 2가지 방법이 있고, 먼저
Injection Services
방법의 단위 테스트 코드입니다.
using Bunit;
using bUnitSample;
using bUnitSample.Pages;
using Microsoft.Extensions.DependencyInjection;
namespace bUnitTest
{
public class UnitTest1
{
[Fact]
public void TestComponent()
{
// Arrange
using var ctx = new TestContext();
// Dependency Inject register
ctx.Services.AddSingleton<IDataService>(new DataService());
var cut = ctx.RenderComponent<TestComponent>();
var paraElm = cut.Find("p");
// Act
var paraElmText = paraElm.TextContent;
// Assert
Assert.NotNull(cut.Instance.MyData);
paraElmText.MarkupMatches("Data retrieved");
}
}
}
ctx.Services.AddSingleton<IDataService>(new DataService());
코드와 같이 직접 서비스를 주입하여 단위테스트를 진행하는 방법입니다.- 위와 같이 작성 후, 컴포넌트 테스트 진행하게 되면 테스트 정상 실행됩니다.
- 만약, 서비스가 주입되어 있는 컴포넌트를 테스트 하는데 DI 를 해주지 않으면 단위테스트 중간에 등록되지 않은 서비스가 있다고 에러가 발생하게 됩니다.
테스트 방법 2 - Fallback Service Provider
- bUnit 에서 서비스 주입 테스트 2번째 방법은
Fallback Service Provider
를 이용하는 것입니다. Fallback Service Provider
는 기본 제공 테스트 서비스 공급자에 등록할 수 있습니다.Fallback Service Provider
사용 예제 코드는 아래와 같습니다.
using Bunit;
using bUnitSample;
using bUnitSample.Pages;
namespace bUnitTest
{
public class UnitTest1
{
[Fact]
public void TestComponent()
{
// Arrange
using var ctx = new TestContext();
// Dependency Inject register
ctx.Services.AddFallbackServiceProvider(new FallbackServiceProvider());
var dataService = ctx.Services.GetService<DataService>();
var cut = ctx.RenderComponent<TestComponent>();
var paraElm = cut.Find("p");
// Act
var paraElmText = paraElm.TextContent;
// Assert
Assert.NotNull(dataService);
Assert.NotNull(cut.Instance.MyData);
paraElmText.MarkupMatches("Data retrieved");
}
}
public class FallbackServiceProvider : IServiceProvider
{
public object GetService(Type serviceType)
{
return new DataService();
}
}
}
728x90