Extensions.Logging.ListOfString
4.2.0-preview
dotnet add package Extensions.Logging.ListOfString --version 4.2.0-preview
NuGet\Install-Package Extensions.Logging.ListOfString -Version 4.2.0-preview
<PackageReference Include="Extensions.Logging.ListOfString" Version="4.2.0-preview" />
<PackageVersion Include="Extensions.Logging.ListOfString" Version="4.2.0-preview" />
<PackageReference Include="Extensions.Logging.ListOfString" />
paket add Extensions.Logging.ListOfString --version 4.2.0-preview
#r "nuget: Extensions.Logging.ListOfString, 4.2.0-preview"
#:package Extensions.Logging.ListOfString@4.2.0-preview
#addin nuget:?package=Extensions.Logging.ListOfString&version=4.2.0-preview&prerelease
#tool nuget:?package=Extensions.Logging.ListOfString&version=4.2.0-preview&prerelease
Extensions.Logging.ListOfString logs to a list of string so you can test your logging.
If your components depend on an ILogger<T>
use Microsoft.Extensions.Logging.LoggerFactory
to make one:
ILoggerFactory factory=new LoggerFactory.AddProvider(new StringListLoggerProvider())
var logger= factory.CreateLogger<Test1>();
...tests... ;
StringListLogger.Instance
.LoggedLines
.ShouldContain(x=>x.Matches("kilroy was here"));
or
var loggedLines = new List<string>();
var logger= new LoggerFactory().AddStringListLogger(loggedLines).CreateLogger("Test2");
...tests... ;
loggedLines.ShouldContain(x=>x.Matches("kilroy was here too."));
Or if a component only depends on an ILogger
, it's much simpler. You don't need the factory or provider:
var uut = new MyComponent( StringListLogger.Instance );
... tests ...
StringListLogger.Instance
.LoggedLines
.ShouldContain(x=>x.Matches("kilroy was here"));
Or if you are using Microsoft.Extensions.DependencyInjection
in your test suite then:
public StringListLogger Log = new();
...
ServiceCollection.AddLogging(
lb => lb
/* .AddConfiguration(Configuration.GetSection("Logging")) */
.AddProvider(new StringListLoggerProvider(Log))
/* .AddConsole() */
);
...tests...
Log.LoggedLines.ShouldContain(x=>x.Matches("kilroy was here"));
For tests running in parallel, each one creating a new LoggerFactory and LoggerProvider, don't rely on the shared StringListLogger.Instance. Follow the above example, passing a known instance to the LoggerProvider.
This is for Microsoft.Extensions.Logging.Abstractions. For Serilog, see https://www.nuget.org/packages/Serilog.Sinks.ListOfString/
Part of https://www.nuget.org/packages/TestBase . TestBase gives you a flying start to unit testing with fluent assertions that are easy to extend, and tools for testing with dependencies on AspNetMvc, HttpClient, Ado.Net, Streams and Loggers.
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. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.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.1 is compatible. 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 | 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 1.1
- Microsoft.Extensions.Logging.Abstractions (>= 1.1.2)
- NETStandard.Library (>= 1.6.1)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last Updated |
---|---|---|
4.2.0-preview | 168 | 5/7/2025 |
4.1.3 | 255 | 11/28/2024 |
4.1.2.5 | 11,675 | 10/23/2018 |
4.0.8 | 2,598 | 3/23/2018 |
ChangeLog
--------
4.2.0 Added StringListLoggerProvider.Instance so that parallel running tests using
LoggerFactory and LoggerProviders can each have their own Instance.
4.1.3.0 fix: StringListLogger.Instance should always be initialized
4.1.2.5 Make Scopes public so it's assertable
4.0.9.0 Removed dependency on net4 version of Mono.Linq.Expressions
4.0.8.0 Separated Serilog.Sinks.ListOfString and Extensions.Logging.StringListLogger
4.0.7.0 Added TestBase.FakeHttpClient. Added Should(predicate,...) as synonym of ShouldHave(predicate,...)
4.0.6.2 TestBase.Mvc can run controller actions on aspnetcore using controller.WithControllerContext()
4.0.5.2 TestBase.Mvc partially ported to netstandard20 / AspNetCore
4.0.4.1 StreamShoulds
4.0.3.0 StringListLogger as MS Logger and as Serilogger