Releases: bUnit-dev/bUnit
1.17.2
- Submit buttons and input fields now no longer cause a form submit when they have the
@onclick:preventDefault
attribute. By @JelleHissink.
1.16.2
- Changed semantic comparer to handle elements parsed outside their proper context, e.g. an
<path>
element parsed without being inside a<svg>
element. The semantic comparer will now be able to treat those as regular elements and thus be able to compare correctly to other elements of the same type and with the same node name. By @egil.
1.15.5
- Upgrade AngleSharp.Diffing to 0.17.1
1.14.4
Added
- Added
IMemoryCache
by default to the Services container. By @linkdotnet.
Fixed
- Added support in
FakeNavigationManager
to handle umlauts. - Fixed a bug where attribute values did not get escaped. Reported by @brettwinters. Fixed by @linkdotnet.
1.13.5
This release contains a bunch of small tweaks and fixes.
1.12.6
Fixed
- The created HTML contained encoded strings. Reported by @tobiasbrandstaedter. Fixed by @linkdotnet.
1.11.7
Added
- Added the
StateFromJson
method to theNavigationHistory
type, to make it easy to deserialize navigation state stored as JSON during a call toNavigationManager.NavigateTo
, e.g. as seen with the newInteractiveRequestOptions
type available in .NET 7. By @linkdotnet and @egil.
1.10.14
Added
-
Added new test double
FakeWebAssemblyHostEnvironment
that implementsIWebAssemblyHostEnvironment
. By @KristofferStrube. -
Added
Bind
method to parameter builder that makes it easier to emulate the@bind-Value
syntax in C#-based tests.When writing tests in razor files, the
@bind-
directive can be directly applied like this:<MyComponent @bind-Value="myParam"></MyComponent>
The same expression in C# syntax is more verbose like this:
RenderComponent<MyComponent>(ps => ps .Add(c => c.Value, value) .Add(c => c.ValueChanged, newValue => value = newValue) .Add(c => c.ValueExpression, () => value));
With the new
Bind
method this can be done in one method:RenderComponent<MyComponent>(ps => ps .Bind(c => c.Value, value, newValue => value = newValue, () => value));
By @linkdotnet and @egil.
-
Added support for
NavigationLock
, which allows user code to intercept and prevent navigation. By @linkdotnet and @egil.
Fixed
JSInterop.VerifyInvoke
reported the wrong number of actual invocations of a given identifier. Reported by @otori. Fixed by @linkdotnet.
1.9.8
Changed
WaitForAssertion
method is now marked as an assertion method with the[AssertionMethod]
attribute. This makes certain analyzers like SonarSource's Tests should include assertions happy. By @egil.
Fixes
-
A race condition existed between
WaitForState
/WaitForAssertion
andFindComponents
, if the first used the latter. Reported by @rmihael, @SviatoslavK, and @RaphaelMarcouxCTRL. Fixed by @egil and @linkdotnet. -
Triggering of event handlers now runs entirely inside the renderers synchronization context, avoiding race condition between elements in the DOM tree being updated by the renderer and the event triggering logic traversing the DOM tree to find event handlers to trigger. Reported by @FlukeFan. Fixed by @egil.
1.8.15
Added
- Added test helpers that make it much easier to pass files to the
InputFile
component. Learn more in the documentation. By @egil and @linkdotnet.
Changed
Htmlizer
usesStringBuilder
instead ofList<string>
to reduce allocations and improve render speed. By @linkdotnet.
Fixes
-
TestServiceProvider
now implementsIAsyncDisposable
. This meansTestContext.Dispose()
now calls the async disposable method as well as the non-async version on the service provider. It does however not block or await the task returned, since that can lead to deadlocks.To await the disposal of async services registered in the
TestContext.Services
container, do the following:- Create a new type that derives from
TestContext
and which implementIAsyncDisposable
. - In the
DisposeAsync()
method, callServices.DisposeAsync()
. - Override the
Dispose
and have it only callServices.Dispose()
.
- Create a new type that derives from