首页
/ BDDfy 技术文档

BDDfy 技术文档

2024-12-28 06:15:27作者:魏侃纯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 包管理器进行安装。

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

热门内容推荐

最新内容推荐

项目优选

收起
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
136
187
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
881
521
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
361
381
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
181
264
kernelkernel
deepin linux kernel
C
22
5
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
7
0
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.09 K
0
note-gennote-gen
一款跨平台的 Markdown AI 笔记软件,致力于使用 AI 建立记录和写作的桥梁。
TSX
83
4
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
613
60
open-eBackupopen-eBackup
open-eBackup是一款开源备份软件,采用集群高扩展架构,通过应用备份通用框架、并行备份等技术,为主流数据库、虚拟化、文件系统、大数据等应用提供E2E的数据备份、恢复等能力,帮助用户实现关键数据高效保护。
HTML
118
78