NBuilder .NET (개발자를 위한 작동 방식)
NBuilder는 테스트 데이터 생성을 간소화하는 .NET 라이브러리입니다. 개발자는 유창한 인터페이스를 통해 복잡한 객체 그래프를 손쉽게 생성할 수 있습니다. 이는 인기 있는 테스트 프레임워크와의 유연성, 효율성 및 원활한 통합을 제공합니다. 이 기사에서는 NBuilder의 기능, 설치 방법, 실제 코드 예제를 사용하여 그 기능을 시연하는 방법을 탐구할 것입니다.

NBuilder의 기능
- NBuilder는 테스트 및 모킹 목적으로 객체 생성을 단순화하기 위해 설계된 C# 오픈 소스 .NET 라이브러리입니다. 개발자는 다양한 데이터 유형을 기반으로 기본 제공 또는 사용자 정의 입력을 통해 객체를 신속하게 생성할 수 있습니다.
- 이는 단위 테스트, 기능 테스트 및 통합 테스트에 특히 유용합니다.
- 이는 .NET 내장 데이터 유형과 복잡한 객체를 테스트하는 필수 패키지 중 하나입니다.
- 무작위 데이터 생성을 위해 사용됩니다. 이 오픈 소스 프로젝트에 기여할 수 있습니다.
- NBuilder를 사용하면 기본 속성을 쉽게 재정의하고 사용자 정의 구성을 작성할 수 있습니다.
NBuilder 설치
NuGet 패키지 관리자 콘솔에서 NBuilder를 설치하려면 다음 명령을 사용하세요.
Install-Package NBuilder
위 명령은 모든 종속성을 포함하여 NBuilder를 설치할 것입니다.

NBuilder 사용법
NBuilder는 실시간으로 객체를 생성하는 유창한 방법을 제공합니다. 객체를 생성하는 간단한 예제부터 시작해 보겠습니다.
여기에 Person 모델 클래스 소스 코드가 있습니다.
class Person
{
public int Id { get; set; }
public string Name { get; set; }
public string Email { get; set; }
public bool IsMarried { get; set; }
}
class Person
{
public int Id { get; set; }
public string Name { get; set; }
public string Email { get; set; }
public bool IsMarried { get; set; }
}
Friend Class Person
Public Property Id() As Integer
Public Property Name() As String
Public Property Email() As String
Public Property IsMarried() As Boolean
End Class
예제 1: 기본 값으로 Person 객체 생성
// Create a new person object with default values using NBuilder
var person = Builder<Person>
.CreateNew()
.Build();
// By default, NBuilder can provide values like
// Id = 1, Name = Name1, Email = Email1, IsMarried = false
// Create a new person object with default values using NBuilder
var person = Builder<Person>
.CreateNew()
.Build();
// By default, NBuilder can provide values like
// Id = 1, Name = Name1, Email = Email1, IsMarried = false
' Create a new person object with default values using NBuilder
Dim person = Builder(Of Person) .CreateNew().Build()
' By default, NBuilder can provide values like
' Id = 1, Name = Name1, Email = Email1, IsMarried = false
샘플 이미지

예제 2: 사용자 정의 빌더로 객체 생성
NBuilder를 사용하여 사용자 정의 속성이 있는 Person 객체를 생성하고 구성하는 방법의 예는 다음과 같습니다:
// Initialize a custom builder for the Person object with specific values
var customPersonBuilder = Builder<Person>.CreateNew()
.With(p => p.Name = "Tom")
.With(p => p.Email = "Tom@email.com");
// Build the custom person object with the specified properties
var objTom = customPersonBuilder.Build();
// Initialize a custom builder for the Person object with specific values
var customPersonBuilder = Builder<Person>.CreateNew()
.With(p => p.Name = "Tom")
.With(p => p.Email = "Tom@email.com");
// Build the custom person object with the specified properties
var objTom = customPersonBuilder.Build();
' Initialize a custom builder for the Person object with specific values
Dim customPersonBuilder = Builder(Of Person).CreateNew().With(Sub(p) p.Name = "Tom").With(Sub(p) p.Email = "Tom@email.com")
' Build the custom person object with the specified properties
Dim objTom = customPersonBuilder.Build()
위 코드는 사용자 정의 속성이 있는 새 Person 객체를 생성합니다. Person 객체에 대한 customPersonBuilder를 초기화하여 Name을 "Tom", Email을 "Tom@email.com"으로 설정합니다. 마지막으로 객체를 빌드하여 objTom에 할당합니다.
예제 3: 기본 값으로 Person 객체 목록 생성
// Create a list of 10 Person objects with default values using NBuilder
var personList = Builder<Person>
.CreateListOfSize(10)
.Build();
// Create a list of 10 Person objects with default values using NBuilder
var personList = Builder<Person>
.CreateListOfSize(10)
.Build();
' Create a list of 10 Person objects with default values using NBuilder
Dim personList = Builder(Of Person) .CreateListOfSize(10).Build()
샘플 이미지

여기에 personList는 기본값이 있는 10개의 객체가 있으며 이를 출력합니다.
// Creating a list of 10 Person objects with default values
var personList = Builder<Person>
.CreateListOfSize(10)
.Build();
// Print details of each Person object in the list
foreach (var person in personList)
{
Console.WriteLine($"{person.Id}, {person.Name}, {person.Email}, {person.IsMarried}");
}
// Creating a list of 10 Person objects with default values
var personList = Builder<Person>
.CreateListOfSize(10)
.Build();
// Print details of each Person object in the list
foreach (var person in personList)
{
Console.WriteLine($"{person.Id}, {person.Name}, {person.Email}, {person.IsMarried}");
}
' Creating a list of 10 Person objects with default values
Dim personList = Builder(Of Person) .CreateListOfSize(10).Build()
' Print details of each Person object in the list
For Each person In personList
Console.WriteLine($"{person.Id}, {person.Name}, {person.Email}, {person.IsMarried}")
Next person

예제 4: 생성된 객체 사용자 정의
가끔 생성되는 객체를 사용자 정의해야 할 수도 있습니다. 또한 With() 메서드를 사용하여 객체의 값을 사용자 정의할 수 있습니다.
// Customize properties for all Person objects in the list
var personList = Builder<Person>
.CreateListOfSize(10)
.All()
.With(p => p.Name = "Kim")
.With(p => p.Email = "abc@email.com")
.With(p => p.IsMarried = false)
.Build();
// Customize properties for all Person objects in the list
var personList = Builder<Person>
.CreateListOfSize(10)
.All()
.With(p => p.Name = "Kim")
.With(p => p.Email = "abc@email.com")
.With(p => p.IsMarried = false)
.Build();
' Customize properties for all Person objects in the list
Dim personList = Builder(Of Person) .CreateListOfSize(10).All().With(Sub(p) p.Name = "Kim").With(Sub(p) p.Email = "abc@email.com").With(Sub(p) p.IsMarried = False).Build()
이것은 각 객체에 기본 값을 Name = "Kim", Email = "abc@email.com", IsMarried = false로 덮어쓰는 personList을 생성합니다.
예제 5: 현실적인 무작위 데이터로 Person 객체 목록 생성
Person 목록에서 현실적인 데이터 값을 얻기 위해 Faker Library .NET을 사용하여 현실적인 데이터를 생성할 수 있습니다.
// Creating a list of Person objects with random yet realistic values using Faker
var personList = Builder<Person>
.CreateListOfSize(10)
.All()
.With(p => p.Name = Faker.Name.FullName())
.With(p => p.Id = Faker.RandomNumber.Next(20, 60))
.Build();
// Creating a list of Person objects with random yet realistic values using Faker
var personList = Builder<Person>
.CreateListOfSize(10)
.All()
.With(p => p.Name = Faker.Name.FullName())
.With(p => p.Id = Faker.RandomNumber.Next(20, 60))
.Build();
' Creating a list of Person objects with random yet realistic values using Faker
Dim personList = Builder(Of Person) .CreateListOfSize(10).All().With(Sub(p) p.Name = Faker.Name.FullName()).With(Sub(p) p.Id = Faker.RandomNumber.Next(20, 60)).Build()
예제 6: 순차 데이터로 Person 객체 목록 생성
순차적인 데이터로 객체를 생성해야 할 때가 있습니다. NBuilder .NET은 Do 메서드를 사용하여 이를 촉진합니다.
// Creating a list of 10 sequential Person objects using NBuilder
var personList = Builder<Person>.CreateListOfSize(10)
.All()
.Do((p, i) => p.Id = 501 + i)
.Do((p, i) => p.Name = $"Person {i + 1}")
.Build();
// Creating a list of 10 sequential Person objects using NBuilder
var personList = Builder<Person>.CreateListOfSize(10)
.All()
.Do((p, i) => p.Id = 501 + i)
.Do((p, i) => p.Name = $"Person {i + 1}")
.Build();
' Creating a list of 10 sequential Person objects using NBuilder
Dim personList = Builder(Of Person).CreateListOfSize(10).All().Do(Sub(p, i) p.Id = 501 + i).Do(Sub(p, i) p.Name = $"Person {i + 1}").Build()
여기서 All() 메서드는 메모리에 생성된 10개의 Person 객체 모두에 후속 작업이 적용되도록 보장합니다. Do() 메서드는 각 Person 객체에 대해 Action 대리자를 실행합니다. 이 설정은 501부터 순차적으로 Id 속성을 할당하며, 또한 각 사람을 "Person 1"부터 "Person 10"까지 순차적으로 이름 짓습니다.

예제 7: Xunit를 사용하여 단위 테스트와 NBuilder
NBuilder는 .NET에서 테스트 환경에서 크게 사용되며, 개발자가 테스트를 위해 현실적이고 다양한 데이터 세트를 생성할 필요가 있습니다. 이것은 복잡한 객체로 테스트를 쉽게 유지 관리할 수 있으며, 효율적이고 유연한 테스트 데이터 생성을 원하는 분들을 위해 람다 표현식과 대리자 함수를 사용하여 사용자 정의 초기화 논리를 정의할 수 있습니다.
단위 테스트를 위한 모델 클래스와 서비스
class Person
{
public int Id { get; set; }
public string Name { get; set; }
public string Email { get; set; }
public bool IsMarried { get; set; }
}
class PersonService
{
public string GetPersonEmail(Person person)
{
return person.Email;
}
}
class Person
{
public int Id { get; set; }
public string Name { get; set; }
public string Email { get; set; }
public bool IsMarried { get; set; }
}
class PersonService
{
public string GetPersonEmail(Person person)
{
return person.Email;
}
}
Friend Class Person
Public Property Id() As Integer
Public Property Name() As String
Public Property Email() As String
Public Property IsMarried() As Boolean
End Class
Friend Class PersonService
Public Function GetPersonEmail(ByVal person As Person) As String
Return person.Email
End Function
End Class
여기서 Person 클래스는 여러 속성을 가지고 있으며, 이러한 속성으로는 Id, Name, Email, IsMarried가 있습니다. 반면, PersonService는 주어진 Person의 이메일을 반환하는 GetPersonEmail() 메서드를 포함합니다.
테스트 클래스와 테스트 데이터
using Xunit;
public class PersonTests
{
[Fact]
public void GetPersonEmail_ReturnCorrectEmail()
{
// Arrange
var service = new PersonService();
string expectedEmail = "Tom@email.com";
// Create a person with specific name and email using NBuilder
var person = Builder<Person>.CreateNew()
.With(p => p.Name = "Tom")
.With(p => p.Email = "Tom@email.com")
.Build();
// Act
var actualEmail = service.GetPersonEmail(person);
// Assert
Assert.Equal(expectedEmail, actualEmail);
}
}
using Xunit;
public class PersonTests
{
[Fact]
public void GetPersonEmail_ReturnCorrectEmail()
{
// Arrange
var service = new PersonService();
string expectedEmail = "Tom@email.com";
// Create a person with specific name and email using NBuilder
var person = Builder<Person>.CreateNew()
.With(p => p.Name = "Tom")
.With(p => p.Email = "Tom@email.com")
.Build();
// Act
var actualEmail = service.GetPersonEmail(person);
// Assert
Assert.Equal(expectedEmail, actualEmail);
}
}
Imports Xunit
Public Class PersonTests
<Fact>
Public Sub GetPersonEmail_ReturnCorrectEmail()
' Arrange
Dim service = New PersonService()
Dim expectedEmail As String = "Tom@email.com"
' Create a person with specific name and email using NBuilder
Dim person = Builder(Of Person).CreateNew().With(Sub(p) p.Name = "Tom").With(Sub(p) p.Email = "Tom@email.com").Build()
' Act
Dim actualEmail = service.GetPersonEmail(person)
' Assert
Assert.Equal(expectedEmail, actualEmail)
End Sub
End Class
이 단위 테스트는 PersonService 클래스의 GetPersonEmail 메서드가 예상 이메일 "Tom@email.com"을 가진 Person 객체의 이메일 주소를 올바르게 반환하는지 검증합니다. 테스트 데이터를 설정하고 메소드를 실행한 뒤 실제 결과가 예상 결과와 일치하는지 확인하기 위해 Arrange-Act-Assert 패턴을 사용합니다.
NBuilder와 IronPDF 통합
IronPDF 알아보기는 .NET 애플리케이션 내에서 HTML에서 PDF 생성을 위한 강력한 C# 라이브러리입니다. 직관적인 API 덕분에 개발자는 송장, 보고서 또는 인터랙티브 양식을 생성할 때 프로젝트에 PDF 기능을 원활하게 통합할 수 있습니다.

IronPDF 설치
NuGet 패키지 관리자 콘솔을 열고 다음 명령어를 실행하세요:
Install-Package IronPdf
5명의 Person 객체 리스트 채우기
// Generating instances of the Person class with NBuilder
var people = Builder<Person>.CreateListOfSize(5).Build();
// Generating instances of the Person class with NBuilder
var people = Builder<Person>.CreateListOfSize(5).Build();
' Generating instances of the Person class with NBuilder
Dim people = Builder(Of Person).CreateListOfSize(5).Build()
IronPDF를 사용하여 PDF 문서 생성
이 코드는 IronPDF 라이선스 키를 설정하고 Person 객체 목록에서 HTML 콘텐츠를 생성합니다.
// Setting the IronPDF license key
IronPdf.License.LicenseKey = "Your-License-Key";
// Building HTML content from Person object list
var htmlContent = "<h1>Person List</h1>";
foreach (var person in people)
{
htmlContent += $"<p>Id: {person.Id}, Name: {person.Name}, Email: {person.Email}, IsMarried: {person.IsMarried}</p>";
}
// Setting the IronPDF license key
IronPdf.License.LicenseKey = "Your-License-Key";
// Building HTML content from Person object list
var htmlContent = "<h1>Person List</h1>";
foreach (var person in people)
{
htmlContent += $"<p>Id: {person.Id}, Name: {person.Name}, Email: {person.Email}, IsMarried: {person.IsMarried}</p>";
}
' Setting the IronPDF license key
IronPdf.License.LicenseKey = "Your-License-Key"
' Building HTML content from Person object list
Dim htmlContent = "<h1>Person List</h1>"
For Each person In people
htmlContent &= $"<p>Id: {person.Id}, Name: {person.Name}, Email: {person.Email}, IsMarried: {person.IsMarried}</p>"
Next person
IronPdf.License.LicenseKey는 IronPDF의 기능을 활성화하기 위해 특정 라이선스 키로 설정됩니다. HTML 콘텐츠는 people 목록에 대해 반복하면서 각 Person 객체의 세부사항(ID, Name, Email, IsMarried)을 HTML 구조에 추가하여 동적으로 구성됩니다.
IronPDF를 사용하여 PDF 문서로 Person 리스트 렌더링
이 코드는 IronPDF의 ChromePdfRenderer를 사용하여 HTML 콘텐츠를 PDF 문서로 변환합니다.
// Rendering HTML content into a PDF document using IronPDF
var renderer = new ChromePdfRenderer();
var pdfDoc = renderer.RenderHtmlAsPdf(htmlContent);
pdfDoc.SaveAs("PersonList.pdf");
// Rendering HTML content into a PDF document using IronPDF
var renderer = new ChromePdfRenderer();
var pdfDoc = renderer.RenderHtmlAsPdf(htmlContent);
pdfDoc.SaveAs("PersonList.pdf");
' Rendering HTML content into a PDF document using IronPDF
Dim renderer = New ChromePdfRenderer()
Dim pdfDoc = renderer.RenderHtmlAsPdf(htmlContent)
pdfDoc.SaveAs("PersonList.pdf")
ChromePdfRenderer는 htmlContent에 저장된 HTML 콘텐츠를 PDF 문서로 렌더링하기 위해 인스턴스화됩니다. 생성된 PDF 문서는 "PersonList.pdf"라는 이름으로 파일 시스템에 저장됩니다.
출력
아래는 IronPDF로 생성된 PersonList의 출력입니다. 기본값을 가진 다섯 명의 사람이 포함되어 있습니다.

결론
결론적으로, NBuilder는 .NET에서 테스트 데이터를 생성하고 복잡한 객체 그래프를 만들며 테스트 프로세스의 효율성을 높이는 강력하고 유연한 도구입니다. IronPDF와 통합하여 개발자는 프로젝트에서 유용하다고 느끼는 사람들을 위해 PDF 생성 기능을 쉽게 확장할 수 있습니다. NBuilder와 IronPDF는 함께 개발 워크플로우를 크게 향상시켜, 테스트와 문서 생성을 원활하고 효율적으로 만듭니다.
자주 묻는 질문
NBuilder를 사용하여 .NET에서 테스트 데이터를 어떻게 생성할 수 있습니까?
NBuilder는 개발자가 복잡한 객체 그래프와 테스트 데이터를 손쉽게 생성할 수 있도록 하는 유창한 인터페이스를 제공합니다. CreateNew() 및 CreateListOfSize()와 같은 메서드를 사용하여 기본값 또는 사용자 정의 값을 가진 단일 객체나 객체 목록을 생성할 수 있습니다.
.NET 프로젝트에 NBuilder를 어떻게 설치하나요?
NBuilder를 설치하려면 NuGet 패키지 관리자 콘솔에서 Install-Package NBuilder 명령을 사용하면 됩니다. 이 명령은 NBuilder와 그에 필요한 종속성을 다운로드하여 설치합니다.
NBuilder를 사용하여 무작위 및 순차 데이터를 생성할 수 있습니까?
네, NBuilder는 무작위 및 순차 데이터 생성을 지원합니다. With() 메서드를 사용하여 무작위 값을 가진 객체 속성을 사용자 정의하거나 Do()를 사용하여 속성을 순차적으로 설정할 수 있습니다.
NBuilder를 IronPDF와 통합하는 이점은 무엇입니까?
NBuilder를 IronPDF와 통합하면 개발자가 복잡한 테스트 데이터를 만들고 이를 PDF로 출력할 수 있습니다. 이를 통해 테스트 데이터에서 동적 PDF 생성을 가능하게 하여 .NET 애플리케이션의 개발 워크플로우를 간소화할 수 있습니다.
NBuilder가 단위 테스트에서 어떻게 도움을 주나요?
NBuilder는 개발자가 현실적인 테스트 데이터를 신속하게 생성할 수 있도록 하여 단위 테스트에서 가치가 있습니다. 이를 통해 복잡한 객체 그래프가 있는 테스트 시나리오의 설정을 간소화하여 테스트를 더 유지 가능하고 효과적으로 만듭니다.
NBuilder에서 유창한 인터페이스를 사용하는 장점은 무엇입니까?
NBuilder의 유창한 인터페이스는 개발자가 읽기 쉽고 간결한 방식으로 복잡한 객체 그래프를 생성하기 위한 메서드 호출을 연쇄할 수 있도록 합니다. 이를 통해 테스트 데이터를 생성할 때 코드 명확성이 향상되고 보일러 플레이트 코드가 줄어듭니다.
NBuilder로 객체 목록을 어떻게 생성할 수 있나요?
NBuilder의 CreateListOfSize() 메소드를 사용하여 객체 목록을 생성할 수 있습니다. 예를 들어, Builder는 10개의 Person 객체 목록을 생성합니다.
NBuilder 사용을 위한 몇 가지 문제 해결 팁은 무엇인가요?
NBuilder가 NuGet을 통해 올바르게 설치되었는지 확인하고 프로젝트 참조가 최신인지 검토하십시오. 문제가 발생하면, NBuilder GitHub 저장소나 커뮤니티 포럼을 확인하여 유용한 인사이트와 해결책을 찾을 수 있습니다.




