【问题标题】:How to open a blazored modal with bunit?如何用 bunit 打开一个炫酷的模态?
【发布时间】:2021-07-26 14:37:01
【问题描述】:

我想用 bunit 测试一个模态是否打开。问题是,模态不会被渲染。如何用 bunit 打开一个炫酷的 modal?

在我的被测组件中创建模态:

<div style="display: flex; justify-content: flex-end">
    <button class="btn btn-success
                   btn-lg"
                   id="openModalButton"
                  @onclick="CheckOpenModal">
                Hinzufügen
    </button>
</div>
@code 
{
    [CascadingParameter] public IModalService Modal { get; set; }

    private async Task OpenModalForCreation()
    {
        List<string> ParameterA = new List<string>();

        var parameters = new ModalParameters();
        parameters.Add(nameof(CreationModal.ParameterA), ParameterA);

        Modal.Show<CreationModal>("Create something", parameters);
    }
}

我的测试类:

public class PrivateMachinesCompTest : TestContext
{     
    public CompTest()
    {
            Services.AddBlazoredModal();
    }
    [Fact]
    public void CheckOpenModal()
    {
        modalService = new ModalService();
        var cut = RenderComponent<ComponentUnderTest>(parameters => parameters
                .AddCascadingValue(modalService));
        var openModalButton = cut.Find("#openModalButton");
        openModalButton.Click();
        cut.MarkupMatches("Create something");
    }

【问题讨论】:

    标签: modal-dialog blazor bunit


    【解决方案1】:

    问题在于您没有渲染实际进行渲染的组件。只传递IModalService 是不行的。

    我的方法是创建一个模拟 IModalService 并断言其上的预期方法已被调用。

    【讨论】:

    • 有效!我仍然想知道是否可以渲染两个组件并一起测试它们(因为它只是一个模式)还是这是不好的做法?
    • 当然可以一次性渲染两者。是否值得取决于模型逻辑的实现方式。
    • 如果是最佳实践。这取决于,但在这种情况下,我将只测试模态服务已被调用,然后进行单独的测试,在该测试中我呈现模态并验证它是否按预期呈现。但是,我是第 3 方模态组件,然后我想确保我不编写测试它的测试,因为当第 3 模型组件更改时我将不得不维护我的测试。我喜欢假设我使用的第 3 方的东西已经过其开发人员的测试 :)
    猜你喜欢
    • 2014-05-23
    • 1970-01-01
    • 2013-04-18
    • 1970-01-01
    • 2012-01-31
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多