mirror of
https://gitee.com/ant-design-blazor/ant-design-blazor.git
synced 2024-12-16 01:41:14 +08:00
ba2c5e51d8
* test: change folder structure and add new TestKit csproj for public testing of AntDesign-based applications * docs: added CN and EN docs about TestKit * fix doc translate * change the directory structure Co-authored-by: Patryk Grzelak <pgrzelak@mutate.app> Co-authored-by: James Yeung <shunjiey@hotmail.com>
104 lines
3.2 KiB
C#
104 lines
3.2 KiB
C#
using Bunit;
|
|
using Xunit;
|
|
|
|
namespace AntDesign.Tests.Button
|
|
{
|
|
public class ButtonTests : AntDesignTestBase
|
|
{
|
|
[Fact]
|
|
public void Renders_an_empty_button()
|
|
{
|
|
var cut = Context.RenderComponent<AntDesign.Button>();
|
|
cut.MarkupMatches(@"
|
|
<button class=""ant-btn ant-btn-default"" id:ignore type=""button"" ant-click-animating-without-extra-node=""false""></button>
|
|
");
|
|
}
|
|
|
|
[Fact]
|
|
public void Renders_a_button_with_contents()
|
|
{
|
|
var cut = Context.RenderComponent<AntDesign.Button>(p =>
|
|
p.AddChildContent("Save")
|
|
);
|
|
|
|
cut.MarkupMatches(@"
|
|
<button class=""ant-btn ant-btn-default"" id:ignore type=""button"" ant-click-animating-without-extra-node=""false"">Save</button>
|
|
");
|
|
}
|
|
|
|
[Fact]
|
|
public void Renders_a_disabled_the_button()
|
|
{
|
|
var cut = Context.RenderComponent<AntDesign.Button>(p =>
|
|
p.Add(x => x.Disabled, true)
|
|
);
|
|
|
|
cut.MarkupMatches(@"
|
|
<button class=""ant-btn ant-btn-default"" id:ignore type=""button"" ant-click-animating-without-extra-node=""false"" disabled></button>
|
|
");
|
|
}
|
|
|
|
[Theory]
|
|
[InlineData(ButtonType.Dashed)]
|
|
[InlineData(ButtonType.Default)]
|
|
[InlineData(ButtonType.Primary)]
|
|
[InlineData(ButtonType.Link)]
|
|
public void Renders_buttons_of_different_types(string type)
|
|
{
|
|
var cut = Context.RenderComponent<AntDesign.Button>(p =>
|
|
p.Add(x => x.Type, type)
|
|
);
|
|
|
|
cut.MarkupMatches($@"
|
|
<button class=""ant-btn ant-btn-{type.ToLower()}"" id:ignore type=""button"" ant-click-animating-without-extra-node=""false""></button>
|
|
");
|
|
}
|
|
|
|
[Fact]
|
|
public void Should_fire_OnClick_when_clicked()
|
|
{
|
|
var clicked = false;
|
|
|
|
var cut = Context.RenderComponent<AntDesign.Button>(p =>
|
|
p.Add(x => x.OnClick, args => clicked = true)
|
|
);
|
|
|
|
var buttonEl = cut.Find("button");
|
|
buttonEl.Click();
|
|
|
|
Assert.True(clicked);
|
|
}
|
|
|
|
[Fact]
|
|
public void Renders_loading_icon()
|
|
{
|
|
var cut = Context.RenderComponent<AntDesign.Button>(p =>
|
|
p.Add(x => x.Loading, true)
|
|
);
|
|
|
|
cut.MarkupMatches(@"
|
|
<button class=""ant-btn ant-btn-default ant-btn-loading"" id:ignore type=""button"" ant-click-animating-without-extra-node=""false"">
|
|
<span diff:ignore></span>
|
|
</button>
|
|
");
|
|
}
|
|
|
|
|
|
[Fact]
|
|
public void Renders_when_type_is_changed()
|
|
{
|
|
var cut = Context.RenderComponent<AntDesign.Button>(p =>
|
|
p.Add(x => x.Type, ButtonType.Default)
|
|
);
|
|
|
|
cut.SetParametersAndRender(p =>
|
|
p.Add(x => x.Type, ButtonType.Dashed)
|
|
);
|
|
|
|
cut.MarkupMatches($@"
|
|
<button class=""ant-btn ant-btn-dashed"" id:ignore type=""button"" ant-click-animating-without-extra-node=""false""></button>
|
|
");
|
|
}
|
|
}
|
|
}
|