Skip to content

Commit

Permalink
wip
Browse files Browse the repository at this point in the history
  • Loading branch information
david-driscoll committed Nov 11, 2023
1 parent 6ce1c6f commit 14a334b
Show file tree
Hide file tree
Showing 5 changed files with 67 additions and 55 deletions.
6 changes: 5 additions & 1 deletion src/AspNetCore.Testing/LaunchPadExtension.cs
Original file line number Diff line number Diff line change
Expand Up @@ -55,7 +55,11 @@ public IHostBuilder Configure(IHostBuilder builder)
builder.ConfigureRocketSurgery(z => z.ForTesting(_testAssemblyReference, _loggerFactory));
builder.ConfigureLogging((context, loggingBuilder) => loggingBuilder.Services.AddSingleton(_loggerFactory));
builder.ConfigureServices(s => s.AddSingleton<TestServer>(z => (TestServer)z.GetRequiredService<IServer>()));
builder.ConfigureServices(s => s.AddHttpLogging(options => options.LoggingFields = HttpLoggingFields.All));
builder.ConfigureServices(s => s.AddHttpLogging(
options =>
{
options.LoggingFields = HttpLoggingFields.All;
}));

return builder;
}
Expand Down
60 changes: 59 additions & 1 deletion src/AspNetCore.Testing/LaunchPadWebAppFixture.cs
Original file line number Diff line number Diff line change
Expand Up @@ -86,10 +86,15 @@ protected virtual void Dispose(bool disposing)
class AppFixtureLoggerFactory : ILoggerFactory
{
private ILoggerFactory? _innerLoggerFactory;
private List<DeferredLogger> _deferredLoggers = new();

public void SetLoggerFactory(ILoggerFactory loggerFactory)
{
_innerLoggerFactory = loggerFactory;
foreach (var logger in _deferredLoggers)
{
logger.SetLogger(loggerFactory.CreateLogger(logger.CategoryName));
}
}

public void Dispose()
Expand All @@ -104,7 +109,60 @@ public void AddProvider(ILoggerProvider provider)

public ILogger CreateLogger(string categoryName)
{
return _innerLoggerFactory?.CreateLogger(categoryName) ?? NullLogger.Instance;
return _innerLoggerFactory?.CreateLogger(categoryName) ?? AddDeferredLogger(categoryName);
}

private DeferredLogger AddDeferredLogger(string categoryName)
{
var logger = new DeferredLogger(categoryName);
_deferredLoggers.Add(logger);
return logger;
}
}

class DeferredLogger : ILogger
{
public string CategoryName { get; }
private List<(LogLevel logLevel, EventId eventId, string text)> _deferredLogs = new();
private ILogger? _logger;

public DeferredLogger(string categoryName)
{
CategoryName = categoryName;
}

public void Log<TState>(LogLevel logLevel, EventId eventId, TState state, Exception? exception, Func<TState, Exception?, string> formatter)
{
if (_logger is null)
{
_deferredLogs.Add((logLevel, eventId, formatter(state, exception)));
return;
}
_logger.Log(logLevel, eventId, state, exception, formatter);
}

public bool IsEnabled(LogLevel logLevel)
{
return _logger?.IsEnabled(logLevel) ?? true;
}

public IDisposable? BeginScope<TState>(TState state) where TState : notnull
{
return _logger?.BeginScope(state);
}

public void SetLogger(ILogger logger)
{
_logger = logger;
foreach (var log in _deferredLogs)
{
#pragma warning disable CA1848
#pragma warning disable CA2254
// ReSharper disable once TemplateIsNotCompileTimeConstantProblem
_logger.Log(log.logLevel, log.eventId, log.text);
#pragma warning restore CA2254
#pragma warning restore CA1848
}
}
}

Expand Down
1 change: 0 additions & 1 deletion test/Sample.Graphql.Tests/Helpers/GraphQlExtension.cs
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,6 @@ public Task Start(IAlbaHost host)

public IHostBuilder Configure(IHostBuilder builder)
{
new TemporaryGraphQlExtension().Configure(builder);
builder.ConfigureServices(
z => z
.AddW3CLogging(z => { })
Expand Down
52 changes: 0 additions & 52 deletions test/Sample.Graphql.Tests/Helpers/TemporaryGraphQlExtension.cs

This file was deleted.

Original file line number Diff line number Diff line change
Expand Up @@ -530,6 +530,9 @@ enum SortEnumType {
"The `@specifiedBy` directive is used within the type system definition language to provide a URL for specifying the behavior of custom scalar definitions."
directive @specifiedBy("The specifiedBy URL points to a human-readable specification. This field will only read a result for scalar types." url: String!) on SCALAR

"The @tag directive is used to applies arbitrary string\nmetadata to a schema location. Custom tooling can use\nthis metadata during any step of the schema delivery flow,\nincluding composition, static analysis, and documentation.\n \n\ninterface Book {\n id: ID! @tag(name: \"your-value\")\n title: String!\n author: String!\n}"
directive @tag("The name of the tag." name: String!) repeatable on SCHEMA | SCALAR | OBJECT | FIELD_DEFINITION | ARGUMENT_DEFINITION | INTERFACE | UNION | ENUM | ENUM_VALUE | INPUT_OBJECT | INPUT_FIELD_DEFINITION

"A coordinate is an array of positions."
scalar Coordinates

Expand Down

0 comments on commit 14a334b

Please sign in to comment.