首页
/ BDDfy 技术文档

BDDfy 技术文档

2024-12-28 05:43:24作者:魏侃纯Zoe

1. 安装指南

BDDfy 是一个简单易用的 BDD(行为驱动开发)框架,支持自定义和扩展。要使用 BDDfy,您需要先安装 TestStack.BDDfy NuGet 包。在您的项目中选择“管理 NuGet 包”,然后搜索并安装 TestStack.BDDfy

安装命令如下:

Install-Package TestStack.BDDfy

如果您是第一次使用 BDDfy,可以安装示例 NuGet 包来查看完整的示例项目:

Install-Package TestStack.BDDfy.Samples

2. 项目的使用说明

BDDfy 的使用非常灵活,可以与任何测试框架配合使用,甚至可以完全不使用测试框架,直接应用于 POCO(普通类)。

下面是一个使用 BDDfy 的基本示例:

[Story(
    AsA = "账户持有者",
    IWant = "我想从 ATM 取款",
    SoThat = "这样我可以在银行关闭时取钱")]
public class AccountHasInsufficientFund
{
    private Card _card;
    private Atm _atm;

    [Given(StepText = "账户余额为 $10")]
    void GivenAccountHasEnoughBalance()
    {
        _card = new Card(true, 10);
    }

    void AndGivenTheCardIsValid()
    {
    }

    void AndGivenTheMachineContainsEnoughMoney()
    {
        _atm = new Atm(100);
    }

    void WhenTheAccountHolderRequests20()
    {
        _atm.RequestMoney(_card, 20);
    }

    void ThenTheAtmShouldNotDispenseAnyMoney()
    {
        Assert.AreEqual(0, _atm.DispenseValue);
    }

    void AndTheAtmShouldSayThereAreInsufficientFunds()
    {
        Assert.AreEqual(DisplayMessage.InsufficientFunds, _atm.Message);
    }

    void AndTheCardShouldBeReturned()
    {
        Assert.IsFalse(_atm.CardIsRetained);
    }

    [Fact]
    public void Execute()
    {
        this.BDDfy();
    }
}

执行上述代码后,会在控制台和输出文件夹中生成一个 HTML 格式的报告。

3. 项目API使用文档

BDDfy 提供了丰富的 API 以支持定制和扩展。以下是一个使用 Fluent API 的例子:

[Fact]
public void CardHasBeenDisabled()
{
    this.Given(s => s.GivenTheCardIsDisabled())
        .When(s => s.WhenTheAccountHolderRequests(20))
        .Then(s => s.CardIsRetained(true), "ATM 应该保留卡片")
            .And(s => s.AndTheAtmShouldSayTheCardHasBeenRetained())
        .BDDfy(htmlReportName: "ATM");
}

以上代码生成报告如下:

场景:卡片已被禁用
给定卡片已被禁用
当账户持有者请求 20
那么ATM应该保留卡片
并且ATM应显示卡片已被保留

BDDfy 的所有操作都是可扩展和可定制的。

4. 项目安装方式

项目的安装方式已在“安装指南”中详细说明,主要通过 NuGet 包管理器进行安装。

登录后查看全文
热门项目推荐

项目优选

收起
kernelkernel
deepin linux kernel
C
24
9
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
9
1
leetcodeleetcode
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
64
19
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
392
3.88 K
flutter_flutterflutter_flutter
暂无简介
Dart
671
156
giteagitea
喝着茶写代码!最易用的自托管一站式代码托管平台,包含Git托管,代码审查,团队协作,软件包和CI/CD。
Go
23
0
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
JavaScript
260
322
ops-mathops-math
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
661
311
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.2 K
654
rainbondrainbond
无需学习 Kubernetes 的容器平台,在 Kubernetes 上构建、部署、组装和管理应用,无需 K8s 专业知识,全流程图形化管理
Go
15
1