See the version list below for details.
dotnet add package SmartTests --version 1.11.0
NuGet\Install-Package SmartTests -Version 1.11.0
<PackageReference Include="SmartTests" Version="1.11.0" />
paket add SmartTests --version 1.11.0
#r "nuget: SmartTests, 1.11.0"
// Install SmartTests as a Cake Addin #addin nuget:?package=SmartTests&version=1.11.0 // Install SmartTests as a Cake Tool #tool nuget:?package=SmartTests&version=1.11.0
We all know how unit testing is important for non-regression of our softwares.
We all know that TDD (Test Driven Development) enables us to have better code and better management of the development process.
Fortunately, it is very easy to learn Testing Frameworks and to write unit tests technically.
BUT, it is very hard to think the good way to write unit test:
- How do I know how many tests to write?
- More, how do I know which cases we have to test?
- According to our Act code, it is very easy to assert that:
- A property changed, but how do we know if any other unexpected side effect occurred?
- A property changed, but how do we know if our test is still correct if anyone changed our Setup? For example, by giving the value you want to set as the initial value of your object?
- How can we show the expected effect of the Act code as we generally use hard coded values (because it is easier to code)?
- Finally, how can we do high level testing without multiple lines of code?
What is Smart Tests
Smart Tests is a library and a Visual Studio Analyzer to respond to all these questions... and more!
- The Act line of your test is instantly identifiable.
- You express your Act logical intent and the Analyzer will display all missing tests.
- You can use smarter assertions than the ones provided by usual Testing Frameworks as Smart Tests knows what is your Act and when it is run.
- You ensure that a PropertyChanged event is raised with only one line of code.
- You ensure that any event is raised with only one line of code.
- You ensure that an object didn't changed at all with only one line of code.
- You ensure that your property set is effective by checking its value after is not equal to its value before with only one line of code.
- You show each effect of your Act code relatively its previous value with only one line of code.
For now, it supports C# with NUnit, xunit or MSTests.
However, it will very easy to add other Testing Frameworks (you only write a very simple sub-class). You can also extend smart assertions in a very easily way.
|Product||Versions Compatible and additional computed target framework versions.|
|.NET||net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed.|
|.NET Core||netcoreapp1.0 was computed. netcoreapp1.1 was computed. netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed.|
|.NET Standard||netstandard1.0 is compatible. netstandard1.1 was computed. netstandard1.2 was computed. netstandard1.3 was computed. netstandard1.4 was computed. netstandard1.5 was computed. netstandard1.6 was computed. netstandard2.0 was computed. netstandard2.1 was computed.|
|.NET Framework||net45 was computed. net451 was computed. net452 was computed. net46 was computed. net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed.|
|MonoAndroid||monoandroid was computed.|
|MonoMac||monomac was computed.|
|MonoTouch||monotouch was computed.|
|Tizen||tizen30 was computed. tizen40 was computed. tizen60 was computed.|
|Universal Windows Platform||uap was computed. uap10.0 was computed.|
|Windows Phone||wp8 was computed. wp81 was computed. wpa81 was computed.|
|Windows Store||netcore was computed. netcore45 was computed. netcore451 was computed.|
|Xamarin.iOS||xamarinios was computed.|
|Xamarin.Mac||xamarinmac was computed.|
|Xamarin.TVOS||xamarintvos was computed.|
|Xamarin.WatchOS||xamarinwatchos was computed.|
- NETStandard.Library (>= 1.6.1)
NuGet packages (1)
Showing the top 1 NuGet packages that depend on SmartTests:
An analyzer to find missing tests for tests written with SmartTests.
This package is not used by any popular GitHub repositories.
A brand new [example project](https://github.com/LudovicDubois/SmartTests/tree/master/Examples) with lots of explanations. Learn how to maximize Smart Tests usage.
- [`Throw`](Assertions/throw.md) Smart Assertion exist now. This enables you to ensure the expected exception is thrown and following Smart Assertions are done.
- When an exception is thrown somewhere, we try to run all the `AfterAct` methods for which the `BeforeAct` method was called. However, the first exception is reported.
- [`NotChangedExcept()`](Assertions/notchanged.md#NotChangedExceptAct()) Smart Assertion method is renamed `NotChangedExceptAct` to better reflect what is excepted.
- [`Optional`](Criteria/Optional.md) criteria added, with two values: `Present` and `Absent`.
- Act Result is now accessible from `Act<T>.Result` property. Making it accessible from within the Smart Assertion implementations.
And some bug fixes:
- `NotChangedAssertion` do not try to save/verify indexers.
- No need to specify a Property Name when testing `NotRaised_PropertyChanged`.
- Random generators for floating point numbers have better values, but is no more well distributed.