Blazor 怎么做单元测试

admin 百科 12
Blazor组件单元测试核心是用bUnit搭配xUnit/NUnit,不依赖浏览器和DOM,专注逻辑、渲染与交互验证;需新建xUnit项目、引用客户端项目、安装bUnit包、启用可空引用类型,继承TestContext或封装基类,聚焦参数渲染、事件交互、子组件投影三类场景,结合DOM输出与实例状态断言。

Blazor 怎么做单元测试-第1张图片-佛山资讯网

Blazor 组件单元测试核心是用 bUnit 搭配 xUnit(或 NUnit),不跑浏览器、不依赖 DOM,专注验证组件逻辑、渲染输出和交互行为。关键不在“能不能测”,而在于“怎么搭得轻、写得清、断言得准”。

搭测试项目:三步到位

新建 xUnit 测试项目,引用待测的 Blazor 客户端项目,并添加 bUnit:

  • 用 CLI:dotnet new xunit -n MyApp.Tests,再 dotnet add reference ../src/MyApp.Client
  • 加 bUnit 包:dotnet add package bunit --version 1.24.2(推荐稳定版)
  • 确保测试项目启用可空引用类型(<nullable>enable</nullable>),与被测组件保持一致

写测试类:继承 TestContext 或自定义基类

不用从零初始化上下文,直接用 bUnit 提供的 TestContext

  • 最简写法:var ctx = new TestContext();,然后 ctx.RenderComponent<mycomponent>()</mycomponent>
  • 若用 BootstrapBlazor 等封装库,继承 BootstrapBlazorTestBase,它已预配置服务(如本地化、缓存、路由)
  • 需注入服务时,在 ctx.Services 中注册模拟实现,例如 ctx.Services.AddSingleton<iweatherservice>(new MockWeatherService())</iweatherservice>

测什么?聚焦三个真实场景

别堆覆盖率,优先覆盖用户能感知的行为:

标签: html bootstrap 浏览器 app 路由 本地化

发布评论 0条评论)

还木有评论哦,快来抢沙发吧~