Adding support for .NET 8.0 LTS, renaming private fields to start with underscore
This commit is contained in:
@@ -78,6 +78,17 @@ dotnet_naming_rule.parameters_locals_must_be_camel_case.symbols = parameters_loc
|
|||||||
dotnet_naming_rule.parameters_locals_must_be_camel_case.style = camel_case_style
|
dotnet_naming_rule.parameters_locals_must_be_camel_case.style = camel_case_style
|
||||||
dotnet_naming_rule.parameters_locals_must_be_camel_case.severity = warning
|
dotnet_naming_rule.parameters_locals_must_be_camel_case.severity = warning
|
||||||
|
|
||||||
|
# Name all private fields starting with underscore
|
||||||
|
dotnet_naming_rule.private_members_with_underscore.symbols = private_fields
|
||||||
|
dotnet_naming_rule.private_members_with_underscore.style = prefix_underscore
|
||||||
|
dotnet_naming_rule.private_members_with_underscore.severity = suggestion
|
||||||
|
|
||||||
|
dotnet_naming_symbols.private_fields.applicable_kinds = field
|
||||||
|
dotnet_naming_symbols.private_fields.applicable_accessibilities = private
|
||||||
|
|
||||||
|
dotnet_naming_style.prefix_underscore.capitalization = camel_case
|
||||||
|
dotnet_naming_style.prefix_underscore.required_prefix = _
|
||||||
|
|
||||||
[*.cs]
|
[*.cs]
|
||||||
csharp_preferred_modifier_order = public, private, protected, internal, static, extern, new, virtual, abstract, sealed, override, readonly, unsafe, volatile, async:suggestion
|
csharp_preferred_modifier_order = public, private, protected, internal, static, extern, new, virtual, abstract, sealed, override, readonly, unsafe, volatile, async:suggestion
|
||||||
|
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
# The image should use the same version as the UnitTests are
|
# The image should use the same version as the UnitTests are
|
||||||
image: mcr.microsoft.com/dotnet/sdk:6.0
|
image: mcr.microsoft.com/dotnet/sdk:8.0
|
||||||
|
|
||||||
variables:
|
variables:
|
||||||
TZ: Europe/Berlin
|
TZ: Europe/Berlin
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
<Project Sdk="Microsoft.NET.Sdk">
|
<Project Sdk="Microsoft.NET.Sdk">
|
||||||
|
|
||||||
<PropertyGroup>
|
<PropertyGroup>
|
||||||
<TargetFramework>net6.0</TargetFramework>
|
<TargetFrameworks>net6.0;net8.0</TargetFrameworks>
|
||||||
<LangVersion>10.0</LangVersion>
|
<LangVersion>10.0</LangVersion>
|
||||||
|
|
||||||
<NrtTagMatch>asp/v[0-9]*</NrtTagMatch>
|
<NrtTagMatch>asp/v[0-9]*</NrtTagMatch>
|
||||||
|
|||||||
@@ -45,13 +45,13 @@ namespace Microsoft.AspNetCore.Authorization
|
|||||||
if (isAllowAnonymous)
|
if (isAllowAnonymous)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (!context.HttpContext.Request.Headers.ContainsKey("Authorization"))
|
if (!context.HttpContext.Request.Headers.TryGetValue("Authorization", out var authHeaderValue))
|
||||||
{
|
{
|
||||||
SetAuthenticateRequest(context);
|
SetAuthenticateRequest(context);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
var authHeader = AuthenticationHeaderValue.Parse(context.HttpContext.Request.Headers["Authorization"]);
|
var authHeader = AuthenticationHeaderValue.Parse(authHeaderValue);
|
||||||
byte[] decoded = Convert.FromBase64String(authHeader.Parameter);
|
byte[] decoded = Convert.FromBase64String(authHeader.Parameter);
|
||||||
string plain = Encoding.UTF8.GetString(decoded);
|
string plain = Encoding.UTF8.GetString(decoded);
|
||||||
|
|
||||||
@@ -84,22 +84,22 @@ namespace Microsoft.AspNetCore.Authorization
|
|||||||
: validator.Realm
|
: validator.Realm
|
||||||
: Realm;
|
: Realm;
|
||||||
|
|
||||||
context.HttpContext.Response.Headers["WWW-Authenticate"] = "Basic";
|
context.HttpContext.Response.Headers.WWWAuthenticate = "Basic";
|
||||||
if (!string.IsNullOrWhiteSpace(realm))
|
if (!string.IsNullOrWhiteSpace(realm))
|
||||||
context.HttpContext.Response.Headers["WWW-Authenticate"] = $"Basic realm=\"{realm.Trim().Replace("\"", "")}\"";
|
context.HttpContext.Response.Headers.WWWAuthenticate = $"Basic realm=\"{realm.Trim().Replace("\"", "")}\"";
|
||||||
|
|
||||||
context.HttpContext.Response.StatusCode = StatusCodes.Status401Unauthorized;
|
context.HttpContext.Response.StatusCode = StatusCodes.Status401Unauthorized;
|
||||||
context.Result = new StatusCodeResult(StatusCodes.Status401Unauthorized);
|
context.Result = new StatusCodeResult(StatusCodes.Status401Unauthorized);
|
||||||
}
|
}
|
||||||
|
|
||||||
private async Task<ClaimsPrincipal> TrySetHttpUser(AuthorizationFilterContext context)
|
private static async Task<ClaimsPrincipal> TrySetHttpUser(AuthorizationFilterContext context)
|
||||||
{
|
{
|
||||||
var logger = context.HttpContext.RequestServices.GetService<ILogger<BasicAuthenticationAttribute>>();
|
var logger = context.HttpContext.RequestServices.GetService<ILogger<BasicAuthenticationAttribute>>();
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
if (context.HttpContext.Request.Headers.ContainsKey("Authorization"))
|
if (context.HttpContext.Request.Headers.TryGetValue("Authorization", out var authHeaderValue))
|
||||||
{
|
{
|
||||||
var authHeader = AuthenticationHeaderValue.Parse(context.HttpContext.Request.Headers["Authorization"]);
|
var authHeader = AuthenticationHeaderValue.Parse(authHeaderValue);
|
||||||
byte[] decoded = Convert.FromBase64String(authHeader.Parameter);
|
byte[] decoded = Convert.FromBase64String(authHeader.Parameter);
|
||||||
string plain = Encoding.UTF8.GetString(decoded);
|
string plain = Encoding.UTF8.GetString(decoded);
|
||||||
|
|
||||||
|
|||||||
@@ -50,7 +50,7 @@ namespace Microsoft.AspNetCore.Mvc.Filters
|
|||||||
|
|
||||||
private const string VerificationUrl = "https://www.google.com/recaptcha/api/siteverify";
|
private const string VerificationUrl = "https://www.google.com/recaptcha/api/siteverify";
|
||||||
|
|
||||||
private string privateKey;
|
private string _privateKey;
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Executes the validattion in background.
|
/// Executes the validattion in background.
|
||||||
@@ -61,9 +61,9 @@ namespace Microsoft.AspNetCore.Mvc.Filters
|
|||||||
public override async Task OnActionExecutionAsync(ActionExecutingContext context, ActionExecutionDelegate next)
|
public override async Task OnActionExecutionAsync(ActionExecutingContext context, ActionExecutionDelegate next)
|
||||||
{
|
{
|
||||||
var configuration = context.HttpContext.RequestServices.GetService<IConfiguration>();
|
var configuration = context.HttpContext.RequestServices.GetService<IConfiguration>();
|
||||||
privateKey = configuration?.GetValue<string>("Google:ReCaptcha:PrivateKey");
|
_privateKey = configuration?.GetValue<string>("Google:ReCaptcha:PrivateKey");
|
||||||
|
|
||||||
if (string.IsNullOrWhiteSpace(privateKey))
|
if (string.IsNullOrWhiteSpace(_privateKey))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
await DoValidation(context).ConfigureAwait(false);
|
await DoValidation(context).ConfigureAwait(false);
|
||||||
@@ -90,7 +90,7 @@ namespace Microsoft.AspNetCore.Mvc.Filters
|
|||||||
using var httpClient = new HttpClient();
|
using var httpClient = new HttpClient();
|
||||||
var param = new Dictionary<string, string>
|
var param = new Dictionary<string, string>
|
||||||
{
|
{
|
||||||
{ "secret", privateKey },
|
{ "secret", _privateKey },
|
||||||
{ "response", token }
|
{ "response", token }
|
||||||
};
|
};
|
||||||
var response = await httpClient.PostAsync(VerificationUrl, new FormUrlEncodedContent(param)).ConfigureAwait(false);
|
var response = await httpClient.PostAsync(VerificationUrl, new FormUrlEncodedContent(param)).ConfigureAwait(false);
|
||||||
|
|||||||
@@ -1,9 +1,9 @@
|
|||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Net;
|
using System.Net;
|
||||||
using Microsoft.AspNetCore.Http;
|
using Microsoft.AspNetCore.Http;
|
||||||
using Microsoft.AspNetCore.HttpOverrides;
|
|
||||||
using Microsoft.Extensions.Configuration;
|
using Microsoft.Extensions.Configuration;
|
||||||
using Microsoft.Extensions.DependencyInjection;
|
using Microsoft.Extensions.DependencyInjection;
|
||||||
|
using IPNetwork = Microsoft.AspNetCore.HttpOverrides.IPNetwork;
|
||||||
|
|
||||||
namespace Microsoft.AspNetCore.Mvc.Filters
|
namespace Microsoft.AspNetCore.Mvc.Filters
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -1,9 +1,9 @@
|
|||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Net;
|
using System.Net;
|
||||||
using Microsoft.AspNetCore.Http;
|
using Microsoft.AspNetCore.Http;
|
||||||
using Microsoft.AspNetCore.HttpOverrides;
|
|
||||||
using Microsoft.Extensions.Configuration;
|
using Microsoft.Extensions.Configuration;
|
||||||
using Microsoft.Extensions.DependencyInjection;
|
using Microsoft.Extensions.DependencyInjection;
|
||||||
|
using IPNetwork = Microsoft.AspNetCore.HttpOverrides.IPNetwork;
|
||||||
|
|
||||||
namespace Microsoft.AspNetCore.Mvc.Filters
|
namespace Microsoft.AspNetCore.Mvc.Filters
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -2,6 +2,7 @@
|
|||||||
using System.Net;
|
using System.Net;
|
||||||
using Microsoft.AspNetCore.Http;
|
using Microsoft.AspNetCore.Http;
|
||||||
using Microsoft.AspNetCore.HttpOverrides;
|
using Microsoft.AspNetCore.HttpOverrides;
|
||||||
|
using IPNetwork = Microsoft.AspNetCore.HttpOverrides.IPNetwork;
|
||||||
|
|
||||||
namespace Microsoft.AspNetCore.Builder
|
namespace Microsoft.AspNetCore.Builder
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -12,7 +12,7 @@ namespace Microsoft.AspNetCore.Http
|
|||||||
public static class HttpContextExtensions
|
public static class HttpContextExtensions
|
||||||
{
|
{
|
||||||
// Search these additional headers for a remote client ip address.
|
// Search these additional headers for a remote client ip address.
|
||||||
private static readonly string[] defaultIpHeaderNames = new[]
|
private static readonly string[] _defaultIpHeaderNames = new[]
|
||||||
{
|
{
|
||||||
"Cf-Connecting-Ip", // set by Cloudflare
|
"Cf-Connecting-Ip", // set by Cloudflare
|
||||||
"X-Real-IP", // wide-spread alternative to X-Forwarded-For
|
"X-Real-IP", // wide-spread alternative to X-Forwarded-For
|
||||||
@@ -51,8 +51,8 @@ namespace Microsoft.AspNetCore.Http
|
|||||||
string forwardedForAddress = null;
|
string forwardedForAddress = null;
|
||||||
|
|
||||||
var headerNames = string.IsNullOrWhiteSpace(ipHeaderName)
|
var headerNames = string.IsNullOrWhiteSpace(ipHeaderName)
|
||||||
? defaultIpHeaderNames
|
? _defaultIpHeaderNames
|
||||||
: new[] { ipHeaderName }.Concat(defaultIpHeaderNames);
|
: new[] { ipHeaderName }.Concat(_defaultIpHeaderNames);
|
||||||
foreach (string headerName in headerNames)
|
foreach (string headerName in headerNames)
|
||||||
{
|
{
|
||||||
if (!httpContext.Request.Headers.ContainsKey(headerName))
|
if (!httpContext.Request.Headers.ContainsKey(headerName))
|
||||||
@@ -67,9 +67,15 @@ namespace Microsoft.AspNetCore.Http
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!string.IsNullOrWhiteSpace(forwardedForAddress) && IPAddress.TryParse(forwardedForAddress, out var remoteAddress))
|
if (!string.IsNullOrWhiteSpace(forwardedForAddress) && IPAddress.TryParse(forwardedForAddress, out var remoteAddress))
|
||||||
return remoteAddress.IsIPv4MappedToIPv6 ? remoteAddress.MapToIPv4() : remoteAddress;
|
{
|
||||||
|
return remoteAddress.IsIPv4MappedToIPv6
|
||||||
|
? remoteAddress.MapToIPv4()
|
||||||
|
: remoteAddress;
|
||||||
|
}
|
||||||
|
|
||||||
return httpContext.Connection.RemoteIpAddress;
|
return httpContext.Connection.RemoteIpAddress.IsIPv4MappedToIPv6
|
||||||
|
? httpContext.Connection.RemoteIpAddress.MapToIPv4()
|
||||||
|
: httpContext.Connection.RemoteIpAddress;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
|||||||
@@ -15,11 +15,11 @@ namespace Microsoft.AspNetCore.Mvc.ModelBinding
|
|||||||
/// <typeparam name="TModel">The type of the model.</typeparam>
|
/// <typeparam name="TModel">The type of the model.</typeparam>
|
||||||
/// <typeparam name="TProperty">The type of the property.</typeparam>
|
/// <typeparam name="TProperty">The type of the property.</typeparam>
|
||||||
/// <param name="modelState">The <see cref="ModelStateDictionary"/> instance.</param>
|
/// <param name="modelState">The <see cref="ModelStateDictionary"/> instance.</param>
|
||||||
/// <param name="model">The model. Only used to infer the model type.</param>
|
/// <param name="_">The model. Only used to infer the model type.</param>
|
||||||
/// <param name="keyExpression">The <see cref="MemberExpression"/> that specifies the property.</param>
|
/// <param name="keyExpression">The <see cref="MemberExpression"/> that specifies the property.</param>
|
||||||
/// <param name="errorMessage">The error message to add.</param>
|
/// <param name="errorMessage">The error message to add.</param>
|
||||||
/// <exception cref="InvalidOperationException">No member expression provided.</exception>
|
/// <exception cref="InvalidOperationException">No member expression provided.</exception>
|
||||||
public static void AddModelError<TModel, TProperty>(this ModelStateDictionary modelState, TModel model, Expression<Func<TModel, TProperty>> keyExpression, string errorMessage)
|
public static void AddModelError<TModel, TProperty>(this ModelStateDictionary modelState, TModel _, Expression<Func<TModel, TProperty>> keyExpression, string errorMessage)
|
||||||
{
|
{
|
||||||
if (modelState is null)
|
if (modelState is null)
|
||||||
throw new ArgumentNullException(nameof(modelState));
|
throw new ArgumentNullException(nameof(modelState));
|
||||||
|
|||||||
@@ -12,9 +12,9 @@ namespace Microsoft.AspNetCore.Mvc.ModelBinding
|
|||||||
[System.Diagnostics.CodeAnalysis.ExcludeFromCodeCoverage]
|
[System.Diagnostics.CodeAnalysis.ExcludeFromCodeCoverage]
|
||||||
public class InvariantFloatingPointModelBinder : IModelBinder
|
public class InvariantFloatingPointModelBinder : IModelBinder
|
||||||
{
|
{
|
||||||
private readonly NumberStyles supportedNumberStyles;
|
private readonly NumberStyles _supportedNumberStyles;
|
||||||
private readonly ILogger logger;
|
private readonly ILogger _logger;
|
||||||
private readonly CultureInfo cultureInfo;
|
private readonly CultureInfo _cultureInfo;
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Initializes a new instance of <see cref="InvariantFloatingPointModelBinder"/>.
|
/// Initializes a new instance of <see cref="InvariantFloatingPointModelBinder"/>.
|
||||||
@@ -24,10 +24,10 @@ namespace Microsoft.AspNetCore.Mvc.ModelBinding
|
|||||||
/// <param name="loggerFactory">The <see cref="ILoggerFactory"/>.</param>
|
/// <param name="loggerFactory">The <see cref="ILoggerFactory"/>.</param>
|
||||||
public InvariantFloatingPointModelBinder(NumberStyles supportedStyles, CultureInfo cultureInfo, ILoggerFactory loggerFactory)
|
public InvariantFloatingPointModelBinder(NumberStyles supportedStyles, CultureInfo cultureInfo, ILoggerFactory loggerFactory)
|
||||||
{
|
{
|
||||||
this.cultureInfo = cultureInfo ?? throw new ArgumentNullException(nameof(cultureInfo));
|
_cultureInfo = cultureInfo ?? throw new ArgumentNullException(nameof(cultureInfo));
|
||||||
|
|
||||||
supportedNumberStyles = supportedStyles;
|
_supportedNumberStyles = supportedStyles;
|
||||||
logger = loggerFactory?.CreateLogger<InvariantFloatingPointModelBinder>();
|
_logger = loggerFactory?.CreateLogger<InvariantFloatingPointModelBinder>();
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <inheritdoc />
|
/// <inheritdoc />
|
||||||
@@ -36,15 +36,15 @@ namespace Microsoft.AspNetCore.Mvc.ModelBinding
|
|||||||
if (bindingContext == null)
|
if (bindingContext == null)
|
||||||
throw new ArgumentNullException(nameof(bindingContext));
|
throw new ArgumentNullException(nameof(bindingContext));
|
||||||
|
|
||||||
logger?.AttemptingToBindModel(bindingContext);
|
_logger?.AttemptingToBindModel(bindingContext);
|
||||||
string modelName = bindingContext.ModelName;
|
string modelName = bindingContext.ModelName;
|
||||||
var valueProviderResult = bindingContext.ValueProvider.GetValue(modelName);
|
var valueProviderResult = bindingContext.ValueProvider.GetValue(modelName);
|
||||||
if (valueProviderResult == ValueProviderResult.None)
|
if (valueProviderResult == ValueProviderResult.None)
|
||||||
{
|
{
|
||||||
logger?.FoundNoValueInRequest(bindingContext);
|
_logger?.FoundNoValueInRequest(bindingContext);
|
||||||
|
|
||||||
// no entry
|
// no entry
|
||||||
logger?.DoneAttemptingToBindModel(bindingContext);
|
_logger?.DoneAttemptingToBindModel(bindingContext);
|
||||||
return Task.CompletedTask;
|
return Task.CompletedTask;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -56,7 +56,7 @@ namespace Microsoft.AspNetCore.Mvc.ModelBinding
|
|||||||
try
|
try
|
||||||
{
|
{
|
||||||
string value = valueProviderResult.FirstValue;
|
string value = valueProviderResult.FirstValue;
|
||||||
var culture = cultureInfo ?? valueProviderResult.Culture;
|
var culture = _cultureInfo ?? valueProviderResult.Culture;
|
||||||
|
|
||||||
object model;
|
object model;
|
||||||
if (string.IsNullOrWhiteSpace(value))
|
if (string.IsNullOrWhiteSpace(value))
|
||||||
@@ -66,15 +66,15 @@ namespace Microsoft.AspNetCore.Mvc.ModelBinding
|
|||||||
}
|
}
|
||||||
else if (type == typeof(float))
|
else if (type == typeof(float))
|
||||||
{
|
{
|
||||||
model = float.Parse(value, supportedNumberStyles, culture);
|
model = float.Parse(value, _supportedNumberStyles, culture);
|
||||||
}
|
}
|
||||||
else if (type == typeof(double))
|
else if (type == typeof(double))
|
||||||
{
|
{
|
||||||
model = double.Parse(value, supportedNumberStyles, culture);
|
model = double.Parse(value, _supportedNumberStyles, culture);
|
||||||
}
|
}
|
||||||
else if (type == typeof(decimal))
|
else if (type == typeof(decimal))
|
||||||
{
|
{
|
||||||
model = decimal.Parse(value, supportedNumberStyles, culture);
|
model = decimal.Parse(value, _supportedNumberStyles, culture);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@@ -113,7 +113,7 @@ namespace Microsoft.AspNetCore.Mvc.ModelBinding
|
|||||||
// Conversion failed.
|
// Conversion failed.
|
||||||
}
|
}
|
||||||
|
|
||||||
logger?.DoneAttemptingToBindModel(bindingContext);
|
_logger?.DoneAttemptingToBindModel(bindingContext);
|
||||||
return Task.CompletedTask;
|
return Task.CompletedTask;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -19,24 +19,44 @@ namespace AMWD.Common.AspNetCore.Security.BasicAuthentication
|
|||||||
[System.Diagnostics.CodeAnalysis.ExcludeFromCodeCoverage]
|
[System.Diagnostics.CodeAnalysis.ExcludeFromCodeCoverage]
|
||||||
public class BasicAuthenticationHandler : AuthenticationHandler<AuthenticationSchemeOptions>
|
public class BasicAuthenticationHandler : AuthenticationHandler<AuthenticationSchemeOptions>
|
||||||
{
|
{
|
||||||
private readonly ILogger logger;
|
private readonly ILogger _logger;
|
||||||
private readonly IBasicAuthenticationValidator validator;
|
private readonly IBasicAuthenticationValidator _validator;
|
||||||
|
|
||||||
|
#if NET8_0_OR_GREATER
|
||||||
|
/// <summary>
|
||||||
|
/// Initializes a new instance of the <see cref="BasicAuthenticationHandler"/> class.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="options">The monitor for the options instance.</param>
|
||||||
|
/// <param name="logger">The <see cref="ILoggerFactory"/>.</param>
|
||||||
|
/// <param name="encoder">The <see cref="UrlEncoder"/>.</param>
|
||||||
|
/// <param name="validator">An basic autentication validator implementation.</param>
|
||||||
|
public BasicAuthenticationHandler(IOptionsMonitor<AuthenticationSchemeOptions> options, ILoggerFactory logger, UrlEncoder encoder, IBasicAuthenticationValidator validator)
|
||||||
|
: base(options, logger, encoder)
|
||||||
|
{
|
||||||
|
_logger = logger.CreateLogger<BasicAuthenticationHandler>();
|
||||||
|
_validator = validator;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if NET6_0
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Initializes a new instance of the <see cref="BasicAuthenticationHandler"/> class.
|
/// Initializes a new instance of the <see cref="BasicAuthenticationHandler"/> class.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="options">The authentication scheme options.</param>
|
/// <param name="options" > The monitor for the options instance.</param>
|
||||||
/// <param name="loggerFactory">The logger factory.</param>
|
/// <param name="logger">The <see cref="ILoggerFactory"/>.</param>
|
||||||
/// <param name="encoder">The URL encoder.</param>
|
/// <param name="encoder">The <see cref="UrlEncoder"/>.</param>
|
||||||
/// <param name="clock">The system clock.</param>
|
/// <param name="clock">The <see cref="ISystemClock"/>.</param>
|
||||||
/// <param name="validator">An basic autentication validator implementation.</param>
|
/// <param name="validator">An basic autentication validator implementation.</param>
|
||||||
public BasicAuthenticationHandler(IOptionsMonitor<AuthenticationSchemeOptions> options, ILoggerFactory loggerFactory, UrlEncoder encoder, ISystemClock clock, IBasicAuthenticationValidator validator)
|
public BasicAuthenticationHandler(IOptionsMonitor<AuthenticationSchemeOptions> options, ILoggerFactory logger, UrlEncoder encoder, ISystemClock clock, IBasicAuthenticationValidator validator)
|
||||||
: base(options, loggerFactory, encoder, clock)
|
: base(options, logger, encoder, clock)
|
||||||
{
|
{
|
||||||
logger = loggerFactory.CreateLogger<BasicAuthenticationHandler>();
|
_logger = logger.CreateLogger<BasicAuthenticationHandler>();
|
||||||
this.validator = validator;
|
_validator = validator;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
/// <inheritdoc/>
|
/// <inheritdoc/>
|
||||||
protected override async Task<AuthenticateResult> HandleAuthenticateAsync()
|
protected override async Task<AuthenticateResult> HandleAuthenticateAsync()
|
||||||
{
|
{
|
||||||
@@ -44,13 +64,13 @@ namespace AMWD.Common.AspNetCore.Security.BasicAuthentication
|
|||||||
if (endpoint?.Metadata?.GetMetadata<IAllowAnonymous>() != null)
|
if (endpoint?.Metadata?.GetMetadata<IAllowAnonymous>() != null)
|
||||||
return AuthenticateResult.NoResult();
|
return AuthenticateResult.NoResult();
|
||||||
|
|
||||||
if (!Request.Headers.ContainsKey("Authorization"))
|
if (!Request.Headers.TryGetValue("Authorization", out var authHeaderValue))
|
||||||
return AuthenticateResult.Fail("Authorization header missing");
|
return AuthenticateResult.Fail("Authorization header missing");
|
||||||
|
|
||||||
ClaimsPrincipal principal;
|
ClaimsPrincipal principal;
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
var authHeader = AuthenticationHeaderValue.Parse(Request.Headers["Authorization"]);
|
var authHeader = AuthenticationHeaderValue.Parse(authHeaderValue);
|
||||||
string plain = Encoding.UTF8.GetString(Convert.FromBase64String(authHeader.Parameter));
|
string plain = Encoding.UTF8.GetString(Convert.FromBase64String(authHeader.Parameter));
|
||||||
|
|
||||||
// See: https://www.rfc-editor.org/rfc/rfc2617, page 6
|
// See: https://www.rfc-editor.org/rfc/rfc2617, page 6
|
||||||
@@ -58,11 +78,11 @@ namespace AMWD.Common.AspNetCore.Security.BasicAuthentication
|
|||||||
string password = plain[(username.Length + 1)..];
|
string password = plain[(username.Length + 1)..];
|
||||||
|
|
||||||
var ipAddress = Context.GetRemoteIpAddress();
|
var ipAddress = Context.GetRemoteIpAddress();
|
||||||
principal = await validator.ValidateAsync(username, password, ipAddress, Context.RequestAborted).ConfigureAwait(false);
|
principal = await _validator.ValidateAsync(username, password, ipAddress, Context.RequestAborted).ConfigureAwait(false);
|
||||||
}
|
}
|
||||||
catch (Exception ex)
|
catch (Exception ex)
|
||||||
{
|
{
|
||||||
logger.LogError(ex, $"Handling the Basic Authentication failed: {ex.Message}");
|
_logger.LogError(ex, $"Handling the Basic Authentication failed: {ex.Message}");
|
||||||
return AuthenticateResult.Fail("Authorization header invalid");
|
return AuthenticateResult.Fail("Authorization header invalid");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -13,8 +13,8 @@ namespace AMWD.Common.AspNetCore.Security.BasicAuthentication
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
public class BasicAuthenticationMiddleware
|
public class BasicAuthenticationMiddleware
|
||||||
{
|
{
|
||||||
private readonly RequestDelegate next;
|
private readonly RequestDelegate _next;
|
||||||
private readonly IBasicAuthenticationValidator validator;
|
private readonly IBasicAuthenticationValidator _validator;
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Initializes a new instance of the <see cref="BasicAuthenticationMiddleware"/> class.
|
/// Initializes a new instance of the <see cref="BasicAuthenticationMiddleware"/> class.
|
||||||
@@ -23,8 +23,8 @@ namespace AMWD.Common.AspNetCore.Security.BasicAuthentication
|
|||||||
/// <param name="validator">A basic authentication validator.</param>
|
/// <param name="validator">A basic authentication validator.</param>
|
||||||
public BasicAuthenticationMiddleware(RequestDelegate next, IBasicAuthenticationValidator validator)
|
public BasicAuthenticationMiddleware(RequestDelegate next, IBasicAuthenticationValidator validator)
|
||||||
{
|
{
|
||||||
this.next = next;
|
_next = next;
|
||||||
this.validator = validator;
|
_validator = validator;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@@ -37,7 +37,7 @@ namespace AMWD.Common.AspNetCore.Security.BasicAuthentication
|
|||||||
{
|
{
|
||||||
if (!httpContext.Request.Headers.ContainsKey("Authorization"))
|
if (!httpContext.Request.Headers.ContainsKey("Authorization"))
|
||||||
{
|
{
|
||||||
SetAuthenticateRequest(httpContext, validator.Realm);
|
SetAuthenticateRequest(httpContext, _validator.Realm);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -51,14 +51,14 @@ namespace AMWD.Common.AspNetCore.Security.BasicAuthentication
|
|||||||
string username = plain.Split(':').First();
|
string username = plain.Split(':').First();
|
||||||
string password = plain[(username.Length + 1)..];
|
string password = plain[(username.Length + 1)..];
|
||||||
|
|
||||||
var principal = await validator.ValidateAsync(username, password, httpContext.GetRemoteIpAddress(), httpContext.RequestAborted).ConfigureAwait(false);
|
var principal = await _validator.ValidateAsync(username, password, httpContext.GetRemoteIpAddress(), httpContext.RequestAborted).ConfigureAwait(false);
|
||||||
if (principal == null)
|
if (principal == null)
|
||||||
{
|
{
|
||||||
SetAuthenticateRequest(httpContext, validator.Realm);
|
SetAuthenticateRequest(httpContext, _validator.Realm);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
await next.Invoke(httpContext).ConfigureAwait(false);
|
await _next.Invoke(httpContext).ConfigureAwait(false);
|
||||||
}
|
}
|
||||||
catch (Exception ex)
|
catch (Exception ex)
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -10,9 +10,9 @@ namespace AMWD.Common.AspNetCore.Security.PathProtection
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
public class ProtectedPathMiddleware
|
public class ProtectedPathMiddleware
|
||||||
{
|
{
|
||||||
private readonly RequestDelegate next;
|
private readonly RequestDelegate _next;
|
||||||
private readonly PathString path;
|
private readonly PathString _path;
|
||||||
private readonly string policyName;
|
private readonly string _policyName;
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Initializes a new instance of the <see cref="ProtectedPathExtensions"/> class.
|
/// Initializes a new instance of the <see cref="ProtectedPathExtensions"/> class.
|
||||||
@@ -21,9 +21,9 @@ namespace AMWD.Common.AspNetCore.Security.PathProtection
|
|||||||
/// <param name="options">The options to configure the middleware.</param>
|
/// <param name="options">The options to configure the middleware.</param>
|
||||||
public ProtectedPathMiddleware(RequestDelegate next, ProtectedPathOptions options)
|
public ProtectedPathMiddleware(RequestDelegate next, ProtectedPathOptions options)
|
||||||
{
|
{
|
||||||
this.next = next;
|
_next = next;
|
||||||
path = options.Path;
|
_path = options.Path;
|
||||||
policyName = options.PolicyName;
|
_policyName = options.PolicyName;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@@ -35,16 +35,16 @@ namespace AMWD.Common.AspNetCore.Security.PathProtection
|
|||||||
/// <returns>An awaitable task.</returns>
|
/// <returns>An awaitable task.</returns>
|
||||||
public async Task InvokeAsync(HttpContext httpContext, IAuthorizationService authorizationService)
|
public async Task InvokeAsync(HttpContext httpContext, IAuthorizationService authorizationService)
|
||||||
{
|
{
|
||||||
if (httpContext.Request.Path.StartsWithSegments(path))
|
if (httpContext.Request.Path.StartsWithSegments(_path))
|
||||||
{
|
{
|
||||||
var result = await authorizationService.AuthorizeAsync(httpContext.User, null, policyName).ConfigureAwait(false);
|
var result = await authorizationService.AuthorizeAsync(httpContext.User, null, _policyName).ConfigureAwait(false);
|
||||||
if (!result.Succeeded)
|
if (!result.Succeeded)
|
||||||
{
|
{
|
||||||
await httpContext.ChallengeAsync().ConfigureAwait(false);
|
await httpContext.ChallengeAsync().ConfigureAwait(false);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
await next.Invoke(httpContext).ConfigureAwait(false);
|
await _next.Invoke(httpContext).ConfigureAwait(false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -21,7 +21,7 @@ namespace Microsoft.AspNetCore.Razor.TagHelpers
|
|||||||
[HtmlAttributeName("class")]
|
[HtmlAttributeName("class")]
|
||||||
public string CssClass { get; set; }
|
public string CssClass { get; set; }
|
||||||
|
|
||||||
private IDictionary<string, bool> classValues;
|
private IDictionary<string, bool> _classValues;
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Gets or sets a dictionary containing all conditional class names and a boolean condition
|
/// Gets or sets a dictionary containing all conditional class names and a boolean condition
|
||||||
@@ -32,11 +32,11 @@ namespace Microsoft.AspNetCore.Razor.TagHelpers
|
|||||||
{
|
{
|
||||||
get
|
get
|
||||||
{
|
{
|
||||||
return classValues ??= new Dictionary<string, bool>(StringComparer.OrdinalIgnoreCase);
|
return _classValues ??= new Dictionary<string, bool>(StringComparer.OrdinalIgnoreCase);
|
||||||
}
|
}
|
||||||
set
|
set
|
||||||
{
|
{
|
||||||
classValues = value;
|
_classValues = value;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -48,7 +48,7 @@ namespace Microsoft.AspNetCore.Razor.TagHelpers
|
|||||||
/// <param name="output">A stateful HTML element used to generate an HTML tag.</param>
|
/// <param name="output">A stateful HTML element used to generate an HTML tag.</param>
|
||||||
public override void Process(TagHelperContext context, TagHelperOutput output)
|
public override void Process(TagHelperContext context, TagHelperOutput output)
|
||||||
{
|
{
|
||||||
var items = classValues.Where(e => e.Value).Select(e => e.Key).ToList();
|
var items = _classValues.Where(e => e.Value).Select(e => e.Key).ToList();
|
||||||
if (!string.IsNullOrEmpty(CssClass))
|
if (!string.IsNullOrEmpty(CssClass))
|
||||||
items.Insert(0, CssClass);
|
items.Insert(0, CssClass);
|
||||||
|
|
||||||
|
|||||||
@@ -18,8 +18,8 @@ namespace Microsoft.AspNetCore.Razor.TagHelpers
|
|||||||
[HtmlTargetElement("script")]
|
[HtmlTargetElement("script")]
|
||||||
public class IntegrityHashTagHelper : TagHelper
|
public class IntegrityHashTagHelper : TagHelper
|
||||||
{
|
{
|
||||||
private readonly IWebHostEnvironment env;
|
private readonly IWebHostEnvironment _env;
|
||||||
private readonly string hostUrl;
|
private readonly string _hostUrl;
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Initializes a new instance of the <see cref="IntegrityHashTagHelper"/> class.
|
/// Initializes a new instance of the <see cref="IntegrityHashTagHelper"/> class.
|
||||||
@@ -28,8 +28,8 @@ namespace Microsoft.AspNetCore.Razor.TagHelpers
|
|||||||
/// <param name="configuration">The application configuration.</param>
|
/// <param name="configuration">The application configuration.</param>
|
||||||
public IntegrityHashTagHelper(IWebHostEnvironment env, IConfiguration configuration)
|
public IntegrityHashTagHelper(IWebHostEnvironment env, IConfiguration configuration)
|
||||||
{
|
{
|
||||||
this.env = env;
|
_env = env;
|
||||||
hostUrl = configuration.GetValue("ASPNETCORE_APPL_URL", "http://localhost/");
|
_hostUrl = configuration.GetValue("ASPNETCORE_APPL_URL", "http://localhost/");
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@@ -84,8 +84,8 @@ namespace Microsoft.AspNetCore.Razor.TagHelpers
|
|||||||
{
|
{
|
||||||
using var client = new HttpClient();
|
using var client = new HttpClient();
|
||||||
|
|
||||||
if (!string.IsNullOrWhiteSpace(hostUrl))
|
if (!string.IsNullOrWhiteSpace(_hostUrl))
|
||||||
client.DefaultRequestHeaders.Referrer = new Uri(hostUrl);
|
client.DefaultRequestHeaders.Referrer = new Uri(_hostUrl);
|
||||||
|
|
||||||
var response = await client.GetAsync(source).ConfigureAwait(false);
|
var response = await client.GetAsync(source).ConfigureAwait(false);
|
||||||
fileBytes = await response.Content.ReadAsByteArrayAsync().ConfigureAwait(false);
|
fileBytes = await response.Content.ReadAsByteArrayAsync().ConfigureAwait(false);
|
||||||
@@ -103,12 +103,12 @@ namespace Microsoft.AspNetCore.Razor.TagHelpers
|
|||||||
if (source.StartsWith("/"))
|
if (source.StartsWith("/"))
|
||||||
source = source[1..];
|
source = source[1..];
|
||||||
|
|
||||||
if (source.Contains("?"))
|
if (source.Contains('?'))
|
||||||
source = source[..source.IndexOf("?")];
|
source = source[..source.IndexOf("?")];
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
string path = Path.Combine(env.WebRootPath, source);
|
string path = Path.Combine(_env.WebRootPath, source);
|
||||||
fileBytes = await File.ReadAllBytesAsync(path).ConfigureAwait(false);
|
fileBytes = await File.ReadAllBytesAsync(path).ConfigureAwait(false);
|
||||||
}
|
}
|
||||||
catch
|
catch
|
||||||
@@ -118,7 +118,7 @@ namespace Microsoft.AspNetCore.Razor.TagHelpers
|
|||||||
}
|
}
|
||||||
|
|
||||||
string type;
|
string type;
|
||||||
byte[] hashBytes = new byte[0];
|
byte[] hashBytes = Array.Empty<byte>();
|
||||||
switch (IntegrityStrength)
|
switch (IntegrityStrength)
|
||||||
{
|
{
|
||||||
case 512:
|
case 512:
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
<Project Sdk="Microsoft.NET.Sdk">
|
<Project Sdk="Microsoft.NET.Sdk">
|
||||||
|
|
||||||
<PropertyGroup>
|
<PropertyGroup>
|
||||||
<TargetFramework>net6.0</TargetFramework>
|
<TargetFrameworks>net6.0;net8.0</TargetFrameworks>
|
||||||
<LangVersion>10.0</LangVersion>
|
<LangVersion>10.0</LangVersion>
|
||||||
|
|
||||||
<NrtTagMatch>efc/v[0-9]*</NrtTagMatch>
|
<NrtTagMatch>efc/v[0-9]*</NrtTagMatch>
|
||||||
@@ -21,11 +21,18 @@
|
|||||||
<None Include="../README.md" Pack="true" PackagePath="/" />
|
<None Include="../README.md" Pack="true" PackagePath="/" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|
||||||
<ItemGroup>
|
<ItemGroup Condition="'$(TargetFramework)' == 'net6.0'">
|
||||||
<PackageReference Include="Microsoft.EntityFrameworkCore" Version="6.0.23" />
|
<PackageReference Include="Microsoft.EntityFrameworkCore" Version="6.0.25" />
|
||||||
<PackageReference Include="Microsoft.EntityFrameworkCore.Relational" Version="6.0.23" />
|
<PackageReference Include="Microsoft.EntityFrameworkCore.Relational" Version="6.0.25" />
|
||||||
<PackageReference Include="Microsoft.Extensions.Configuration" Version="6.0.1" />
|
<PackageReference Include="Microsoft.Extensions.Configuration" Version="6.0.1" />
|
||||||
<PackageReference Include="Microsoft.Extensions.Configuration.Binder" Version="6.0.0" />
|
<PackageReference Include="Microsoft.Extensions.Configuration.Binder" Version="6.0.0" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|
||||||
|
<ItemGroup Condition="'$(TargetFramework)' == 'net8.0'">
|
||||||
|
<PackageReference Include="Microsoft.EntityFrameworkCore" Version="8.0.0" />
|
||||||
|
<PackageReference Include="Microsoft.EntityFrameworkCore.Relational" Version="8.0.0" />
|
||||||
|
<PackageReference Include="Microsoft.Extensions.Configuration" Version="8.0.0" />
|
||||||
|
<PackageReference Include="Microsoft.Extensions.Configuration.Binder" Version="8.0.0" />
|
||||||
|
</ItemGroup>
|
||||||
|
|
||||||
</Project>
|
</Project>
|
||||||
|
|||||||
@@ -33,6 +33,8 @@ namespace System
|
|||||||
: base(message, innerException)
|
: base(message, innerException)
|
||||||
{ }
|
{ }
|
||||||
|
|
||||||
|
#if NET6_0
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Initializes a new instance of the <see cref="DatabaseProviderException"/> class with serialized data.
|
/// Initializes a new instance of the <see cref="DatabaseProviderException"/> class with serialized data.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@@ -43,5 +45,7 @@ namespace System
|
|||||||
protected DatabaseProviderException(SerializationInfo info, StreamingContext context)
|
protected DatabaseProviderException(SerializationInfo info, StreamingContext context)
|
||||||
: base(info, context)
|
: base(info, context)
|
||||||
{ }
|
{ }
|
||||||
|
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -24,6 +24,7 @@ namespace Microsoft.EntityFrameworkCore
|
|||||||
/// <param name="optionsAction">An action to set additional options.</param>
|
/// <param name="optionsAction">An action to set additional options.</param>
|
||||||
/// <param name="cancellationToken">The cancellation token.</param>
|
/// <param name="cancellationToken">The cancellation token.</param>
|
||||||
/// <returns>true on success, otherwise false or an exception is thrown.</returns>
|
/// <returns>true on success, otherwise false or an exception is thrown.</returns>
|
||||||
|
[System.Diagnostics.CodeAnalysis.SuppressMessage("Usage", "CA2208")]
|
||||||
public static async Task<bool> ApplyMigrationsAsync(this DatabaseFacade database, Action<DatabaseMigrationOptions> optionsAction, CancellationToken cancellationToken = default)
|
public static async Task<bool> ApplyMigrationsAsync(this DatabaseFacade database, Action<DatabaseMigrationOptions> optionsAction, CancellationToken cancellationToken = default)
|
||||||
{
|
{
|
||||||
if (database == null)
|
if (database == null)
|
||||||
|
|||||||
@@ -10,14 +10,14 @@ namespace AMWD.Common.EntityFrameworkCore.Extensions
|
|||||||
public static class ModelConfigurationBuilderExtensions
|
public static class ModelConfigurationBuilderExtensions
|
||||||
{
|
{
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Adds converters for the <see cref="DateOnly"/> and <see cref="TimeOnly"/> datatypes introduced with .NET 6.0.
|
/// Adds converters for the <see cref="DateOnly"/> datatype introduced with .NET 6.0.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <remarks>
|
/// <remarks>
|
||||||
/// As of 2022-06-04 only required for Microsoft SQL server on .NET 6.0.
|
/// As of 2022-06-04 only required for Microsoft SQL server on .NET 6.0.
|
||||||
/// </remarks>
|
/// </remarks>
|
||||||
/// <param name="builder">The <see cref="ModelConfigurationBuilder"/> instance.</param>
|
/// <param name="builder">The <see cref="ModelConfigurationBuilder"/> instance.</param>
|
||||||
/// <returns>The <see cref="ModelConfigurationBuilder"/> instance after applying the converters.</returns>
|
/// <returns>The <see cref="ModelConfigurationBuilder"/> instance after applying the converters.</returns>
|
||||||
public static ModelConfigurationBuilder AddDateOnlyTimeOnlyConverters(this ModelConfigurationBuilder builder)
|
public static ModelConfigurationBuilder AddDateOnlyConverters(this ModelConfigurationBuilder builder)
|
||||||
{
|
{
|
||||||
builder.Properties<DateOnly>()
|
builder.Properties<DateOnly>()
|
||||||
.HaveConversion<DateOnlyConverter>()
|
.HaveConversion<DateOnlyConverter>()
|
||||||
@@ -26,6 +26,19 @@ namespace AMWD.Common.EntityFrameworkCore.Extensions
|
|||||||
.HaveConversion<NullableDateOnlyConverter>()
|
.HaveConversion<NullableDateOnlyConverter>()
|
||||||
.HaveColumnType("date");
|
.HaveColumnType("date");
|
||||||
|
|
||||||
|
return builder;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Adds converters for the <see cref="TimeOnly"/> datatype introduced with .NET 6.0.
|
||||||
|
/// </summary>
|
||||||
|
/// <remarks>
|
||||||
|
/// As of 2022-06-04 only required for Microsoft SQL server on .NET 6.0.
|
||||||
|
/// </remarks>
|
||||||
|
/// <param name="builder">The <see cref="ModelConfigurationBuilder"/> instance.</param>
|
||||||
|
/// <returns>The <see cref="ModelConfigurationBuilder"/> instance after applying the converters.</returns>
|
||||||
|
public static ModelConfigurationBuilder AddTimeOnlyConverters(this ModelConfigurationBuilder builder)
|
||||||
|
{
|
||||||
builder.Properties<TimeOnly>()
|
builder.Properties<TimeOnly>()
|
||||||
.HaveConversion<TimeOnlyConverter>()
|
.HaveConversion<TimeOnlyConverter>()
|
||||||
.HaveColumnType("time");
|
.HaveColumnType("time");
|
||||||
|
|||||||
3
AMWD.Common.EntityFrameworkCore/GlobalSuppressions.cs
Normal file
3
AMWD.Common.EntityFrameworkCore/GlobalSuppressions.cs
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
using System.Diagnostics.CodeAnalysis;
|
||||||
|
|
||||||
|
[assembly: SuppressMessage("Usage", "CA2254")]
|
||||||
@@ -12,7 +12,7 @@ namespace AMWD.Common.Test
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
public class TcpClientMoq
|
public class TcpClientMoq
|
||||||
{
|
{
|
||||||
private readonly Mock<NetworkStream> streamMock;
|
private readonly Mock<NetworkStream> _streamMock;
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Initializes a new instance of the <see cref="TcpClientMoq"/> class.
|
/// Initializes a new instance of the <see cref="TcpClientMoq"/> class.
|
||||||
@@ -22,8 +22,8 @@ namespace AMWD.Common.Test
|
|||||||
Callbacks = new();
|
Callbacks = new();
|
||||||
Response = new byte[0];
|
Response = new byte[0];
|
||||||
|
|
||||||
streamMock = new();
|
_streamMock = new();
|
||||||
streamMock
|
_streamMock
|
||||||
.Setup(s => s.WriteAsync(It.IsAny<byte[]>(), It.IsAny<int>(), It.IsAny<int>(), It.IsAny<CancellationToken>()))
|
.Setup(s => s.WriteAsync(It.IsAny<byte[]>(), It.IsAny<int>(), It.IsAny<int>(), It.IsAny<CancellationToken>()))
|
||||||
.Callback<byte[], int, int, CancellationToken>((buffer, offset, count, _) =>
|
.Callback<byte[], int, int, CancellationToken>((buffer, offset, count, _) =>
|
||||||
{
|
{
|
||||||
@@ -39,7 +39,7 @@ namespace AMWD.Common.Test
|
|||||||
Callbacks.Add(callback);
|
Callbacks.Add(callback);
|
||||||
})
|
})
|
||||||
.Returns(Task.CompletedTask);
|
.Returns(Task.CompletedTask);
|
||||||
streamMock
|
_streamMock
|
||||||
.Setup(s => s.Write(It.IsAny<byte[]>(), It.IsAny<int>(), It.IsAny<int>()))
|
.Setup(s => s.Write(It.IsAny<byte[]>(), It.IsAny<int>(), It.IsAny<int>()))
|
||||||
.Callback<byte[], int, int>((buffer, offset, count) =>
|
.Callback<byte[], int, int>((buffer, offset, count) =>
|
||||||
{
|
{
|
||||||
@@ -55,7 +55,7 @@ namespace AMWD.Common.Test
|
|||||||
Callbacks.Add(callback);
|
Callbacks.Add(callback);
|
||||||
});
|
});
|
||||||
|
|
||||||
streamMock
|
_streamMock
|
||||||
.Setup(s => s.ReadAsync(It.IsAny<byte[]>(), It.IsAny<int>(), It.IsAny<int>(), It.IsAny<CancellationToken>()))
|
.Setup(s => s.ReadAsync(It.IsAny<byte[]>(), It.IsAny<int>(), It.IsAny<int>(), It.IsAny<CancellationToken>()))
|
||||||
.Callback<byte[], int, int, CancellationToken>((buffer, offset, count, _) =>
|
.Callback<byte[], int, int, CancellationToken>((buffer, offset, count, _) =>
|
||||||
{
|
{
|
||||||
@@ -63,7 +63,7 @@ namespace AMWD.Common.Test
|
|||||||
Array.Copy(bytes, 0, buffer, offset, Math.Min(bytes.Length, count));
|
Array.Copy(bytes, 0, buffer, offset, Math.Min(bytes.Length, count));
|
||||||
})
|
})
|
||||||
.ReturnsAsync(Response?.Length ?? 0);
|
.ReturnsAsync(Response?.Length ?? 0);
|
||||||
streamMock
|
_streamMock
|
||||||
.Setup(s => s.Read(It.IsAny<byte[]>(), It.IsAny<int>(), It.IsAny<int>()))
|
.Setup(s => s.Read(It.IsAny<byte[]>(), It.IsAny<int>(), It.IsAny<int>()))
|
||||||
.Callback<byte[], int, int>((buffer, offset, count) =>
|
.Callback<byte[], int, int>((buffer, offset, count) =>
|
||||||
{
|
{
|
||||||
@@ -75,7 +75,7 @@ namespace AMWD.Common.Test
|
|||||||
Mock = new();
|
Mock = new();
|
||||||
Mock
|
Mock
|
||||||
.Setup(c => c.GetStream())
|
.Setup(c => c.GetStream())
|
||||||
.Returns(streamMock.Object);
|
.Returns(_streamMock.Object);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@@ -107,28 +107,28 @@ namespace AMWD.Common.Test
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="times">Number of calls.</param>
|
/// <param name="times">Number of calls.</param>
|
||||||
public void VerifyWriteAsync(Times times)
|
public void VerifyWriteAsync(Times times)
|
||||||
=> streamMock.Verify(s => s.WriteAsync(It.IsAny<byte[]>(), It.IsAny<int>(), It.IsAny<int>(), It.IsAny<CancellationToken>()), times);
|
=> _streamMock.Verify(s => s.WriteAsync(It.IsAny<byte[]>(), It.IsAny<int>(), It.IsAny<int>(), It.IsAny<CancellationToken>()), times);
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Verifies the number of calls writing synchronous to the stream.
|
/// Verifies the number of calls writing synchronous to the stream.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="times">Number of calls.</param>
|
/// <param name="times">Number of calls.</param>
|
||||||
public void VerifyWriteSync(Times times)
|
public void VerifyWriteSync(Times times)
|
||||||
=> streamMock.Verify(s => s.Write(It.IsAny<byte[]>(), It.IsAny<int>(), It.IsAny<int>()), times);
|
=> _streamMock.Verify(s => s.Write(It.IsAny<byte[]>(), It.IsAny<int>(), It.IsAny<int>()), times);
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Verifies the number of calls reading asynchronous from the stream.
|
/// Verifies the number of calls reading asynchronous from the stream.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="times">Number of calls.</param>
|
/// <param name="times">Number of calls.</param>
|
||||||
public void VerifyReadAsync(Times times)
|
public void VerifyReadAsync(Times times)
|
||||||
=> streamMock.Verify(s => s.ReadAsync(It.IsAny<byte[]>(), It.IsAny<int>(), It.IsAny<int>(), It.IsAny<CancellationToken>()), times);
|
=> _streamMock.Verify(s => s.ReadAsync(It.IsAny<byte[]>(), It.IsAny<int>(), It.IsAny<int>(), It.IsAny<CancellationToken>()), times);
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Verifies the number of calls reading synchronous from the stream.
|
/// Verifies the number of calls reading synchronous from the stream.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="times">Number of calls.</param>
|
/// <param name="times">Number of calls.</param>
|
||||||
public void VerifyReadSync(Times times)
|
public void VerifyReadSync(Times times)
|
||||||
=> streamMock.Verify(s => s.Read(It.IsAny<byte[]>(), It.IsAny<int>(), It.IsAny<int>()), times);
|
=> _streamMock.Verify(s => s.Read(It.IsAny<byte[]>(), It.IsAny<int>(), It.IsAny<int>()), times);
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Represents the placed TCP request.
|
/// Represents the placed TCP request.
|
||||||
|
|||||||
@@ -12,9 +12,9 @@ namespace AMWD.Common.Cli
|
|||||||
{
|
{
|
||||||
#region Private data
|
#region Private data
|
||||||
|
|
||||||
private string[] args;
|
private string[] _args;
|
||||||
private List<Argument> parsedArguments;
|
private List<Argument> _parsedArguments;
|
||||||
private readonly List<Option> options = new();
|
private readonly List<Option> _options = new();
|
||||||
|
|
||||||
#endregion Private data
|
#endregion Private data
|
||||||
|
|
||||||
@@ -138,7 +138,7 @@ namespace AMWD.Common.Cli
|
|||||||
/// <param name="argsString">The string that contains the entire command line.</param>
|
/// <param name="argsString">The string that contains the entire command line.</param>
|
||||||
public void ReadArgs(string argsString)
|
public void ReadArgs(string argsString)
|
||||||
{
|
{
|
||||||
args = ParseArgsString(argsString);
|
_args = ParseArgsString(argsString);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion Custom arguments line parsing
|
#endregion Custom arguments line parsing
|
||||||
@@ -164,7 +164,7 @@ namespace AMWD.Common.Cli
|
|||||||
public Option RegisterOption(string name, int parameterCount)
|
public Option RegisterOption(string name, int parameterCount)
|
||||||
{
|
{
|
||||||
var option = new Option(name, parameterCount);
|
var option = new Option(name, parameterCount);
|
||||||
options.Add(option);
|
_options.Add(option);
|
||||||
return option;
|
return option;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -178,7 +178,7 @@ namespace AMWD.Common.Cli
|
|||||||
/// <param name="args">The command line arguments.</param>
|
/// <param name="args">The command line arguments.</param>
|
||||||
public void Parse(string[] args)
|
public void Parse(string[] args)
|
||||||
{
|
{
|
||||||
this.args = args ?? throw new ArgumentNullException(nameof(args));
|
_args = args ?? throw new ArgumentNullException(nameof(args));
|
||||||
Parse();
|
Parse();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -188,19 +188,19 @@ namespace AMWD.Common.Cli
|
|||||||
public void Parse()
|
public void Parse()
|
||||||
{
|
{
|
||||||
// Use args of the current process if no other source was given
|
// Use args of the current process if no other source was given
|
||||||
if (args == null)
|
if (_args == null)
|
||||||
{
|
{
|
||||||
args = Environment.GetCommandLineArgs();
|
_args = Environment.GetCommandLineArgs();
|
||||||
if (args.Length > 0)
|
if (_args.Length > 0)
|
||||||
{
|
{
|
||||||
// Skip myself (args[0])
|
// Skip myself (args[0])
|
||||||
args = args.Skip(1).ToArray();
|
_args = _args.Skip(1).ToArray();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Clear/reset data
|
// Clear/reset data
|
||||||
parsedArguments = new();
|
_parsedArguments = new();
|
||||||
foreach (var option in options)
|
foreach (var option in _options)
|
||||||
{
|
{
|
||||||
option.IsSet = false;
|
option.IsSet = false;
|
||||||
option.SetCount = 0;
|
option.SetCount = 0;
|
||||||
@@ -210,7 +210,7 @@ namespace AMWD.Common.Cli
|
|||||||
var comparison = IsCaseSensitive
|
var comparison = IsCaseSensitive
|
||||||
? StringComparison.Ordinal
|
? StringComparison.Ordinal
|
||||||
: StringComparison.OrdinalIgnoreCase;
|
: StringComparison.OrdinalIgnoreCase;
|
||||||
var argumentWalker = new EnumerableWalker<string>(args);
|
var argumentWalker = new EnumerableWalker<string>(_args);
|
||||||
bool optMode = true;
|
bool optMode = true;
|
||||||
foreach (string arg in argumentWalker.Cast<string>())
|
foreach (string arg in argumentWalker.Cast<string>())
|
||||||
{
|
{
|
||||||
@@ -232,11 +232,11 @@ namespace AMWD.Common.Cli
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Find the option with complete name match
|
// Find the option with complete name match
|
||||||
var option = options.FirstOrDefault(o => o.Names.Any(n => n.Equals(optName, comparison)));
|
var option = _options.FirstOrDefault(o => o.Names.Any(n => n.Equals(optName, comparison)));
|
||||||
if (option == null)
|
if (option == null)
|
||||||
{
|
{
|
||||||
// Try to complete the name to a unique registered option
|
// Try to complete the name to a unique registered option
|
||||||
var matchingOptions = options.Where(o => o.Names.Any(n => n.StartsWith(optName, comparison))).ToList();
|
var matchingOptions = _options.Where(o => o.Names.Any(n => n.StartsWith(optName, comparison))).ToList();
|
||||||
if (AutoCompleteOptions && matchingOptions.Count > 1)
|
if (AutoCompleteOptions && matchingOptions.Count > 1)
|
||||||
throw new Exception("Invalid option, completion is not unique: " + arg);
|
throw new Exception("Invalid option, completion is not unique: " + arg);
|
||||||
|
|
||||||
@@ -283,16 +283,16 @@ namespace AMWD.Common.Cli
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
parsedArguments.Add(argument);
|
_parsedArguments.Add(argument);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
parsedArguments.Add(new Argument(null, new[] { arg }));
|
_parsedArguments.Add(new Argument(null, new[] { arg }));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
var missingOption = options.FirstOrDefault(o => o.IsRequired && !o.IsSet);
|
var missingOption = _options.FirstOrDefault(o => o.IsRequired && !o.IsSet);
|
||||||
if (missingOption != null)
|
if (missingOption != null)
|
||||||
throw new Exception("Missing required option: /" + missingOption.Names[0]);
|
throw new Exception("Missing required option: /" + missingOption.Names[0]);
|
||||||
}
|
}
|
||||||
@@ -312,10 +312,10 @@ namespace AMWD.Common.Cli
|
|||||||
{
|
{
|
||||||
get
|
get
|
||||||
{
|
{
|
||||||
if (parsedArguments == null)
|
if (_parsedArguments == null)
|
||||||
Parse();
|
Parse();
|
||||||
|
|
||||||
return parsedArguments.ToArray();
|
return _parsedArguments.ToArray();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -330,10 +330,10 @@ namespace AMWD.Common.Cli
|
|||||||
{
|
{
|
||||||
get
|
get
|
||||||
{
|
{
|
||||||
if (parsedArguments == null)
|
if (_parsedArguments == null)
|
||||||
Parse();
|
Parse();
|
||||||
|
|
||||||
return parsedArguments
|
return _parsedArguments
|
||||||
.Where(a => a.Option != null)
|
.Where(a => a.Option != null)
|
||||||
.Select(a => a.Option)
|
.Select(a => a.Option)
|
||||||
.ToArray();
|
.ToArray();
|
||||||
@@ -351,10 +351,10 @@ namespace AMWD.Common.Cli
|
|||||||
{
|
{
|
||||||
get
|
get
|
||||||
{
|
{
|
||||||
if (parsedArguments == null)
|
if (_parsedArguments == null)
|
||||||
Parse();
|
Parse();
|
||||||
|
|
||||||
return parsedArguments
|
return _parsedArguments
|
||||||
.Where(a => a.Option == null)
|
.Where(a => a.Option == null)
|
||||||
.Select(a => a.Value)
|
.Select(a => a.Value)
|
||||||
.ToArray();
|
.ToArray();
|
||||||
|
|||||||
@@ -11,8 +11,8 @@ namespace AMWD.Common.Cli
|
|||||||
internal class EnumerableWalker<T> : IEnumerable<T>
|
internal class EnumerableWalker<T> : IEnumerable<T>
|
||||||
where T : class
|
where T : class
|
||||||
{
|
{
|
||||||
private readonly IEnumerable<T> array;
|
private readonly IEnumerable<T> _array;
|
||||||
private IEnumerator<T> enumerator;
|
private IEnumerator<T> _enumerator;
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Initialises a new instance of the <see cref="EnumerableWalker{T}"/> class.
|
/// Initialises a new instance of the <see cref="EnumerableWalker{T}"/> class.
|
||||||
@@ -20,13 +20,13 @@ namespace AMWD.Common.Cli
|
|||||||
/// <param name="array">The array to walk though.</param>
|
/// <param name="array">The array to walk though.</param>
|
||||||
public EnumerableWalker(IEnumerable<T> array)
|
public EnumerableWalker(IEnumerable<T> array)
|
||||||
{
|
{
|
||||||
this.array = array ?? throw new ArgumentNullException(nameof(array));
|
_array = array ?? throw new ArgumentNullException(nameof(array));
|
||||||
}
|
}
|
||||||
|
|
||||||
IEnumerator<T> IEnumerable<T>.GetEnumerator()
|
IEnumerator<T> IEnumerable<T>.GetEnumerator()
|
||||||
{
|
{
|
||||||
enumerator = array.GetEnumerator();
|
_enumerator = _array.GetEnumerator();
|
||||||
return enumerator;
|
return _enumerator;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@@ -35,8 +35,8 @@ namespace AMWD.Common.Cli
|
|||||||
/// <returns>The enumerator.</returns>
|
/// <returns>The enumerator.</returns>
|
||||||
public IEnumerator GetEnumerator()
|
public IEnumerator GetEnumerator()
|
||||||
{
|
{
|
||||||
enumerator = array.GetEnumerator();
|
_enumerator = _array.GetEnumerator();
|
||||||
return enumerator;
|
return _enumerator;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@@ -45,9 +45,9 @@ namespace AMWD.Common.Cli
|
|||||||
/// <returns>The next item.</returns>
|
/// <returns>The next item.</returns>
|
||||||
public T GetNext()
|
public T GetNext()
|
||||||
{
|
{
|
||||||
if (enumerator.MoveNext())
|
if (_enumerator.MoveNext())
|
||||||
{
|
{
|
||||||
return enumerator.Current;
|
return _enumerator.Current;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -17,7 +17,7 @@ namespace Newtonsoft.Json
|
|||||||
/// <summary>
|
/// <summary>
|
||||||
/// Common JSON serializer settings.
|
/// Common JSON serializer settings.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
private static readonly JsonSerializerSettings jsonSerializerSettings = new()
|
private static readonly JsonSerializerSettings _jsonSerializerSettings = new()
|
||||||
{
|
{
|
||||||
ContractResolver = new CamelCasePropertyNamesContractResolver(),
|
ContractResolver = new CamelCasePropertyNamesContractResolver(),
|
||||||
Culture = CultureInfo.InvariantCulture
|
Culture = CultureInfo.InvariantCulture
|
||||||
@@ -32,7 +32,7 @@ namespace Newtonsoft.Json
|
|||||||
public static void DeserializeJson<T>(this T target, string json)
|
public static void DeserializeJson<T>(this T target, string json)
|
||||||
{
|
{
|
||||||
if (!string.IsNullOrWhiteSpace(json))
|
if (!string.IsNullOrWhiteSpace(json))
|
||||||
JsonConvert.PopulateObject(json, target, jsonSerializerSettings);
|
JsonConvert.PopulateObject(json, target, _jsonSerializerSettings);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@@ -42,7 +42,7 @@ namespace Newtonsoft.Json
|
|||||||
/// <param name="json">The JSON string to read the values from.</param>
|
/// <param name="json">The JSON string to read the values from.</param>
|
||||||
/// <returns>A new instance of <typeparamref name="T"/> with the deserialized values.</returns>
|
/// <returns>A new instance of <typeparamref name="T"/> with the deserialized values.</returns>
|
||||||
public static T DeserializeJson<T>(this string json)
|
public static T DeserializeJson<T>(this string json)
|
||||||
=> JsonConvert.DeserializeObject<T>(json, jsonSerializerSettings);
|
=> JsonConvert.DeserializeObject<T>(json, _jsonSerializerSettings);
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Deserializes a JSON string into a new instance or using the fallback value.
|
/// Deserializes a JSON string into a new instance or using the fallback value.
|
||||||
@@ -55,7 +55,7 @@ namespace Newtonsoft.Json
|
|||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
return JsonConvert.DeserializeObject<T>(json, jsonSerializerSettings);
|
return JsonConvert.DeserializeObject<T>(json, _jsonSerializerSettings);
|
||||||
}
|
}
|
||||||
catch
|
catch
|
||||||
{
|
{
|
||||||
@@ -83,7 +83,7 @@ namespace Newtonsoft.Json
|
|||||||
jw.QuoteChar = '\'';
|
jw.QuoteChar = '\'';
|
||||||
|
|
||||||
jw.Formatting = indented ? Formatting.Indented : Formatting.None;
|
jw.Formatting = indented ? Formatting.Indented : Formatting.None;
|
||||||
var serializer = useCamelCase ? JsonSerializer.Create(jsonSerializerSettings) : JsonSerializer.CreateDefault();
|
var serializer = useCamelCase ? JsonSerializer.Create(_jsonSerializerSettings) : JsonSerializer.CreateDefault();
|
||||||
|
|
||||||
serializer.Error += (s, a) =>
|
serializer.Error += (s, a) =>
|
||||||
{
|
{
|
||||||
@@ -107,7 +107,7 @@ namespace Newtonsoft.Json
|
|||||||
if (obj == null)
|
if (obj == null)
|
||||||
return null;
|
return null;
|
||||||
|
|
||||||
var serializer = JsonSerializer.Create(jsonSerializerSettings);
|
var serializer = JsonSerializer.Create(_jsonSerializerSettings);
|
||||||
return JObject.FromObject(obj, serializer);
|
return JObject.FromObject(obj, serializer);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -121,7 +121,7 @@ namespace Newtonsoft.Json
|
|||||||
if (array == null)
|
if (array == null)
|
||||||
return null;
|
return null;
|
||||||
|
|
||||||
var serializer = JsonSerializer.Create(jsonSerializerSettings);
|
var serializer = JsonSerializer.Create(_jsonSerializerSettings);
|
||||||
return JArray.FromObject(array, serializer);
|
return JArray.FromObject(array, serializer);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -58,30 +58,30 @@
|
|||||||
|
|
||||||
private struct DisposableReadWriteLock : IDisposable
|
private struct DisposableReadWriteLock : IDisposable
|
||||||
{
|
{
|
||||||
private readonly ReaderWriterLockSlim rwLock;
|
private readonly ReaderWriterLockSlim _rwLock;
|
||||||
private LockMode lockMode;
|
private LockMode _lockMode;
|
||||||
|
|
||||||
public DisposableReadWriteLock(ReaderWriterLockSlim rwLock, LockMode lockMode)
|
public DisposableReadWriteLock(ReaderWriterLockSlim rwLock, LockMode lockMode)
|
||||||
{
|
{
|
||||||
this.rwLock = rwLock;
|
_rwLock = rwLock;
|
||||||
this.lockMode = lockMode;
|
_lockMode = lockMode;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void Dispose()
|
public void Dispose()
|
||||||
{
|
{
|
||||||
if (lockMode == LockMode.Read)
|
if (_lockMode == LockMode.Read)
|
||||||
rwLock.ExitReadLock();
|
_rwLock.ExitReadLock();
|
||||||
|
|
||||||
if (lockMode == LockMode.Upgradable && rwLock.IsWriteLockHeld) // Upgraded with EnterWriteLock alone
|
if (_lockMode == LockMode.Upgradable && _rwLock.IsWriteLockHeld) // Upgraded with EnterWriteLock alone
|
||||||
rwLock.ExitWriteLock();
|
_rwLock.ExitWriteLock();
|
||||||
|
|
||||||
if (lockMode == LockMode.Upgradable)
|
if (_lockMode == LockMode.Upgradable)
|
||||||
rwLock.ExitUpgradeableReadLock();
|
_rwLock.ExitUpgradeableReadLock();
|
||||||
|
|
||||||
if (lockMode == LockMode.Write)
|
if (_lockMode == LockMode.Write)
|
||||||
rwLock.ExitWriteLock();
|
_rwLock.ExitWriteLock();
|
||||||
|
|
||||||
lockMode = LockMode.None;
|
_lockMode = LockMode.None;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -177,10 +177,7 @@ namespace System
|
|||||||
|
|
||||||
if (isValid && nameservers?.Any() == true)
|
if (isValid && nameservers?.Any() == true)
|
||||||
{
|
{
|
||||||
var dnsClientType = Type.GetType("DNS.Client.DnsClient, DNS");
|
var dnsClientType = Type.GetType("DNS.Client.DnsClient, DNS") ?? throw new DllNotFoundException("The DNS NuGet package is required: https://www.nuget.org/packages/DNS/7.0.0");
|
||||||
if (dnsClientType == null)
|
|
||||||
throw new DllNotFoundException("The DNS NuGet package is required: https://www.nuget.org/packages/DNS/7.0.0");
|
|
||||||
|
|
||||||
var recordTypeType = Type.GetType("DNS.Protocol.RecordType, DNS");
|
var recordTypeType = Type.GetType("DNS.Protocol.RecordType, DNS");
|
||||||
var resolveMethodInfo = dnsClientType.GetMethod("Resolve", new[] { typeof(string), recordTypeType, typeof(CancellationToken) });
|
var resolveMethodInfo = dnsClientType.GetMethod("Resolve", new[] { typeof(string), recordTypeType, typeof(CancellationToken) });
|
||||||
|
|
||||||
|
|||||||
@@ -24,13 +24,13 @@ namespace AMWD.Common.Logging
|
|||||||
{
|
{
|
||||||
#region Fields
|
#region Fields
|
||||||
|
|
||||||
private bool isDisposed = false;
|
private bool _isDisposed = false;
|
||||||
private readonly CancellationTokenSource cancellationTokenSource = new();
|
private readonly CancellationTokenSource _cancellationTokenSource = new();
|
||||||
|
|
||||||
private readonly StreamWriter fileWriter;
|
private readonly StreamWriter _fileWriter;
|
||||||
private readonly Task writeTask;
|
private readonly Task _writeTask;
|
||||||
|
|
||||||
private readonly AsyncQueue<QueueItem> queue = new();
|
private readonly AsyncQueue<QueueItem> _queue = new();
|
||||||
|
|
||||||
#endregion Fields
|
#endregion Fields
|
||||||
|
|
||||||
@@ -45,8 +45,8 @@ namespace AMWD.Common.Logging
|
|||||||
public FileLogger(string file, bool append = false, Encoding encoding = null)
|
public FileLogger(string file, bool append = false, Encoding encoding = null)
|
||||||
{
|
{
|
||||||
FileName = file;
|
FileName = file;
|
||||||
fileWriter = new StreamWriter(FileName, append, encoding ?? Encoding.UTF8);
|
_fileWriter = new StreamWriter(FileName, append, encoding ?? Encoding.UTF8);
|
||||||
writeTask = Task.Run(() => WriteFileAsync(cancellationTokenSource.Token));
|
_writeTask = Task.Run(() => WriteFileAsync(_cancellationTokenSource.Token));
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@@ -148,7 +148,7 @@ namespace AMWD.Common.Logging
|
|||||||
/// <inheritdoc cref="ILogger.BeginScope{TState}(TState)" />
|
/// <inheritdoc cref="ILogger.BeginScope{TState}(TState)" />
|
||||||
public IDisposable BeginScope<TState>(TState state)
|
public IDisposable BeginScope<TState>(TState state)
|
||||||
{
|
{
|
||||||
if (isDisposed)
|
if (_isDisposed)
|
||||||
throw new ObjectDisposedException(GetType().FullName);
|
throw new ObjectDisposedException(GetType().FullName);
|
||||||
|
|
||||||
return ScopeProvider?.Push(state) ?? NullScope.Instance;
|
return ScopeProvider?.Push(state) ?? NullScope.Instance;
|
||||||
@@ -157,7 +157,7 @@ namespace AMWD.Common.Logging
|
|||||||
/// <inheritdoc cref="ILogger.IsEnabled(LogLevel)" />
|
/// <inheritdoc cref="ILogger.IsEnabled(LogLevel)" />
|
||||||
public bool IsEnabled(LogLevel logLevel)
|
public bool IsEnabled(LogLevel logLevel)
|
||||||
{
|
{
|
||||||
if (isDisposed)
|
if (_isDisposed)
|
||||||
throw new ObjectDisposedException(GetType().FullName);
|
throw new ObjectDisposedException(GetType().FullName);
|
||||||
|
|
||||||
return logLevel >= MinLevel;
|
return logLevel >= MinLevel;
|
||||||
@@ -166,7 +166,7 @@ namespace AMWD.Common.Logging
|
|||||||
/// <inheritdoc cref="ILogger.Log{TState}(LogLevel, EventId, TState, Exception, Func{TState, Exception, string})" />
|
/// <inheritdoc cref="ILogger.Log{TState}(LogLevel, EventId, TState, Exception, Func{TState, Exception, string})" />
|
||||||
public void Log<TState>(LogLevel logLevel, EventId eventId, TState state, Exception exception, Func<TState, Exception, string> formatter)
|
public void Log<TState>(LogLevel logLevel, EventId eventId, TState state, Exception exception, Func<TState, Exception, string> formatter)
|
||||||
{
|
{
|
||||||
if (isDisposed)
|
if (_isDisposed)
|
||||||
throw new ObjectDisposedException(GetType().FullName);
|
throw new ObjectDisposedException(GetType().FullName);
|
||||||
|
|
||||||
if (!IsEnabled(logLevel))
|
if (!IsEnabled(logLevel))
|
||||||
@@ -197,13 +197,13 @@ namespace AMWD.Common.Logging
|
|||||||
/// <inheritdoc cref="IDisposable.Dispose" />
|
/// <inheritdoc cref="IDisposable.Dispose" />
|
||||||
public void Dispose()
|
public void Dispose()
|
||||||
{
|
{
|
||||||
if (!isDisposed)
|
if (!_isDisposed)
|
||||||
{
|
{
|
||||||
isDisposed = true;
|
_isDisposed = true;
|
||||||
|
|
||||||
cancellationTokenSource.Cancel();
|
_cancellationTokenSource.Cancel();
|
||||||
writeTask.GetAwaiter().GetResult();
|
_writeTask.GetAwaiter().GetResult();
|
||||||
fileWriter.Dispose();
|
_fileWriter.Dispose();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -213,7 +213,7 @@ namespace AMWD.Common.Logging
|
|||||||
|
|
||||||
private void WriteMessage(string name, LogLevel logLevel, int eventId, string message, Exception exception)
|
private void WriteMessage(string name, LogLevel logLevel, int eventId, string message, Exception exception)
|
||||||
{
|
{
|
||||||
queue.Enqueue(new QueueItem
|
_queue.Enqueue(new QueueItem
|
||||||
{
|
{
|
||||||
Timestamp = UseUtcTimestamp ? DateTime.UtcNow : DateTime.Now,
|
Timestamp = UseUtcTimestamp ? DateTime.UtcNow : DateTime.Now,
|
||||||
Name = name,
|
Name = name,
|
||||||
@@ -236,7 +236,7 @@ namespace AMWD.Common.Logging
|
|||||||
QueueItem[] items;
|
QueueItem[] items;
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
items = await queue.DequeueAvailableAsync(cancellationToken: token).ConfigureAwait(false);
|
items = await _queue.DequeueAvailableAsync(cancellationToken: token).ConfigureAwait(false);
|
||||||
}
|
}
|
||||||
catch (OperationCanceledException)
|
catch (OperationCanceledException)
|
||||||
{
|
{
|
||||||
@@ -302,10 +302,10 @@ namespace AMWD.Common.Logging
|
|||||||
|
|
||||||
sb.Append(message.Replace("\n", "\n" + timestampPadding + logLevelPadding));
|
sb.Append(message.Replace("\n", "\n" + timestampPadding + logLevelPadding));
|
||||||
|
|
||||||
await fileWriter.WriteLineAsync(sb.ToString()).ConfigureAwait(false);
|
await _fileWriter.WriteLineAsync(sb.ToString()).ConfigureAwait(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
await fileWriter.FlushAsync().ConfigureAwait(false);
|
await _fileWriter.FlushAsync().ConfigureAwait(false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -12,10 +12,10 @@ namespace System.Collections.Generic
|
|||||||
{
|
{
|
||||||
#region Fields
|
#region Fields
|
||||||
|
|
||||||
private readonly Queue<T> queue;
|
private readonly Queue<T> _queue;
|
||||||
|
|
||||||
private TaskCompletionSource<bool> dequeueTcs = new();
|
private TaskCompletionSource<bool> _dequeueTcs = new();
|
||||||
private TaskCompletionSource<bool> availableTcs = new();
|
private TaskCompletionSource<bool> _availableTcs = new();
|
||||||
|
|
||||||
#endregion Fields
|
#endregion Fields
|
||||||
|
|
||||||
@@ -27,7 +27,7 @@ namespace System.Collections.Generic
|
|||||||
[ExcludeFromCodeCoverage]
|
[ExcludeFromCodeCoverage]
|
||||||
public AsyncQueue()
|
public AsyncQueue()
|
||||||
{
|
{
|
||||||
queue = new Queue<T>();
|
_queue = new Queue<T>();
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@@ -40,7 +40,7 @@ namespace System.Collections.Generic
|
|||||||
[ExcludeFromCodeCoverage]
|
[ExcludeFromCodeCoverage]
|
||||||
public AsyncQueue(IEnumerable<T> collection)
|
public AsyncQueue(IEnumerable<T> collection)
|
||||||
{
|
{
|
||||||
queue = new Queue<T>();
|
_queue = new Queue<T>();
|
||||||
Enqueue(collection);
|
Enqueue(collection);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -52,7 +52,7 @@ namespace System.Collections.Generic
|
|||||||
[ExcludeFromCodeCoverage]
|
[ExcludeFromCodeCoverage]
|
||||||
public AsyncQueue(int capacity)
|
public AsyncQueue(int capacity)
|
||||||
{
|
{
|
||||||
queue = new Queue<T>(capacity);
|
_queue = new Queue<T>(capacity);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion Constructors
|
#endregion Constructors
|
||||||
@@ -67,9 +67,9 @@ namespace System.Collections.Generic
|
|||||||
{
|
{
|
||||||
get
|
get
|
||||||
{
|
{
|
||||||
lock (queue)
|
lock (_queue)
|
||||||
{
|
{
|
||||||
return queue.Count;
|
return _queue.Count;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -84,9 +84,9 @@ namespace System.Collections.Generic
|
|||||||
[ExcludeFromCodeCoverage]
|
[ExcludeFromCodeCoverage]
|
||||||
public void Clear()
|
public void Clear()
|
||||||
{
|
{
|
||||||
lock (queue)
|
lock (_queue)
|
||||||
{
|
{
|
||||||
queue.Clear();
|
_queue.Clear();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -98,9 +98,9 @@ namespace System.Collections.Generic
|
|||||||
[ExcludeFromCodeCoverage]
|
[ExcludeFromCodeCoverage]
|
||||||
public bool Contains(T item)
|
public bool Contains(T item)
|
||||||
{
|
{
|
||||||
lock (queue)
|
lock (_queue)
|
||||||
{
|
{
|
||||||
return queue.Contains(item);
|
return _queue.Contains(item);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -115,9 +115,9 @@ namespace System.Collections.Generic
|
|||||||
[ExcludeFromCodeCoverage]
|
[ExcludeFromCodeCoverage]
|
||||||
public void CopyTo(T[] array, int arrayIndex)
|
public void CopyTo(T[] array, int arrayIndex)
|
||||||
{
|
{
|
||||||
lock (queue)
|
lock (_queue)
|
||||||
{
|
{
|
||||||
queue.CopyTo(array, arrayIndex);
|
_queue.CopyTo(array, arrayIndex);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -129,9 +129,9 @@ namespace System.Collections.Generic
|
|||||||
[ExcludeFromCodeCoverage]
|
[ExcludeFromCodeCoverage]
|
||||||
public T Dequeue()
|
public T Dequeue()
|
||||||
{
|
{
|
||||||
lock (queue)
|
lock (_queue)
|
||||||
{
|
{
|
||||||
return queue.Dequeue();
|
return _queue.Dequeue();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -141,11 +141,11 @@ namespace System.Collections.Generic
|
|||||||
/// <param name="item">The object to add to the <see cref="AsyncQueue{T}"/>. The value can be null for reference types.</param>
|
/// <param name="item">The object to add to the <see cref="AsyncQueue{T}"/>. The value can be null for reference types.</param>
|
||||||
public void Enqueue(T item)
|
public void Enqueue(T item)
|
||||||
{
|
{
|
||||||
lock (queue)
|
lock (_queue)
|
||||||
{
|
{
|
||||||
queue.Enqueue(item);
|
_queue.Enqueue(item);
|
||||||
SetToken(dequeueTcs);
|
SetToken(_dequeueTcs);
|
||||||
SetToken(availableTcs);
|
SetToken(_availableTcs);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -157,9 +157,9 @@ namespace System.Collections.Generic
|
|||||||
[ExcludeFromCodeCoverage]
|
[ExcludeFromCodeCoverage]
|
||||||
public T Peek()
|
public T Peek()
|
||||||
{
|
{
|
||||||
lock (queue)
|
lock (_queue)
|
||||||
{
|
{
|
||||||
return queue.Peek();
|
return _queue.Peek();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -170,9 +170,9 @@ namespace System.Collections.Generic
|
|||||||
[ExcludeFromCodeCoverage]
|
[ExcludeFromCodeCoverage]
|
||||||
public T[] ToArray()
|
public T[] ToArray()
|
||||||
{
|
{
|
||||||
lock (queue)
|
lock (_queue)
|
||||||
{
|
{
|
||||||
return queue.ToArray();
|
return _queue.ToArray();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -182,9 +182,9 @@ namespace System.Collections.Generic
|
|||||||
[ExcludeFromCodeCoverage]
|
[ExcludeFromCodeCoverage]
|
||||||
public void TrimExcess()
|
public void TrimExcess()
|
||||||
{
|
{
|
||||||
lock (queue)
|
lock (_queue)
|
||||||
{
|
{
|
||||||
queue.TrimExcess();
|
_queue.TrimExcess();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -203,21 +203,21 @@ namespace System.Collections.Generic
|
|||||||
while (true)
|
while (true)
|
||||||
{
|
{
|
||||||
TaskCompletionSource<bool> internalDequeueTcs;
|
TaskCompletionSource<bool> internalDequeueTcs;
|
||||||
lock (queue)
|
lock (_queue)
|
||||||
{
|
{
|
||||||
if (queue.Count > 0)
|
if (_queue.Count > 0)
|
||||||
{
|
{
|
||||||
int count = queue.Count;
|
int count = _queue.Count;
|
||||||
if (maxCount > 0 && count > maxCount)
|
if (maxCount > 0 && count > maxCount)
|
||||||
count = maxCount;
|
count = maxCount;
|
||||||
|
|
||||||
var items = new T[count];
|
var items = new T[count];
|
||||||
for (int i = 0; i < count; i++)
|
for (int i = 0; i < count; i++)
|
||||||
items[i] = queue.Dequeue();
|
items[i] = _queue.Dequeue();
|
||||||
|
|
||||||
return items;
|
return items;
|
||||||
}
|
}
|
||||||
internalDequeueTcs = ResetToken(ref dequeueTcs);
|
internalDequeueTcs = ResetToken(ref _dequeueTcs);
|
||||||
}
|
}
|
||||||
|
|
||||||
await WaitAsync(internalDequeueTcs, cancellationToken).ConfigureAwait(false);
|
await WaitAsync(internalDequeueTcs, cancellationToken).ConfigureAwait(false);
|
||||||
@@ -238,17 +238,17 @@ namespace System.Collections.Generic
|
|||||||
while (true)
|
while (true)
|
||||||
{
|
{
|
||||||
TaskCompletionSource<bool> internalDequeueTcs;
|
TaskCompletionSource<bool> internalDequeueTcs;
|
||||||
lock (queue)
|
lock (_queue)
|
||||||
{
|
{
|
||||||
if (count <= queue.Count)
|
if (count <= _queue.Count)
|
||||||
{
|
{
|
||||||
var items = new T[count];
|
var items = new T[count];
|
||||||
for (int i = 0; i < count; i++)
|
for (int i = 0; i < count; i++)
|
||||||
items[i] = queue.Dequeue();
|
items[i] = _queue.Dequeue();
|
||||||
|
|
||||||
return items;
|
return items;
|
||||||
}
|
}
|
||||||
internalDequeueTcs = ResetToken(ref dequeueTcs);
|
internalDequeueTcs = ResetToken(ref _dequeueTcs);
|
||||||
}
|
}
|
||||||
|
|
||||||
await WaitAsync(internalDequeueTcs, cancellationToken).ConfigureAwait(false);
|
await WaitAsync(internalDequeueTcs, cancellationToken).ConfigureAwait(false);
|
||||||
@@ -265,12 +265,12 @@ namespace System.Collections.Generic
|
|||||||
while (true)
|
while (true)
|
||||||
{
|
{
|
||||||
TaskCompletionSource<bool> internalDequeueTcs;
|
TaskCompletionSource<bool> internalDequeueTcs;
|
||||||
lock (queue)
|
lock (_queue)
|
||||||
{
|
{
|
||||||
if (queue.Count > 0)
|
if (_queue.Count > 0)
|
||||||
return queue.Dequeue();
|
return _queue.Dequeue();
|
||||||
|
|
||||||
internalDequeueTcs = ResetToken(ref dequeueTcs);
|
internalDequeueTcs = ResetToken(ref _dequeueTcs);
|
||||||
}
|
}
|
||||||
|
|
||||||
await WaitAsync(internalDequeueTcs, cancellationToken).ConfigureAwait(false);
|
await WaitAsync(internalDequeueTcs, cancellationToken).ConfigureAwait(false);
|
||||||
@@ -285,12 +285,12 @@ namespace System.Collections.Generic
|
|||||||
public async Task WaitAsync(CancellationToken cancellationToken = default)
|
public async Task WaitAsync(CancellationToken cancellationToken = default)
|
||||||
{
|
{
|
||||||
TaskCompletionSource<bool> internalAvailableTcs;
|
TaskCompletionSource<bool> internalAvailableTcs;
|
||||||
lock (queue)
|
lock (_queue)
|
||||||
{
|
{
|
||||||
if (queue.Count > 0)
|
if (_queue.Count > 0)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
internalAvailableTcs = ResetToken(ref availableTcs);
|
internalAvailableTcs = ResetToken(ref _availableTcs);
|
||||||
}
|
}
|
||||||
|
|
||||||
await WaitAsync(internalAvailableTcs, cancellationToken).ConfigureAwait(false);
|
await WaitAsync(internalAvailableTcs, cancellationToken).ConfigureAwait(false);
|
||||||
@@ -347,10 +347,10 @@ namespace System.Collections.Generic
|
|||||||
/// <returns>true if item is successfully removed; otherwise, false. This method also returns false if item was not found in the <see cref="AsyncQueue{T}"/>.</returns>
|
/// <returns>true if item is successfully removed; otherwise, false. This method also returns false if item was not found in the <see cref="AsyncQueue{T}"/>.</returns>
|
||||||
public bool Remove(T item)
|
public bool Remove(T item)
|
||||||
{
|
{
|
||||||
lock (queue)
|
lock (_queue)
|
||||||
{
|
{
|
||||||
var copy = new Queue<T>(queue);
|
var copy = new Queue<T>(_queue);
|
||||||
queue.Clear();
|
_queue.Clear();
|
||||||
|
|
||||||
bool found = false;
|
bool found = false;
|
||||||
int count = copy.Count;
|
int count = copy.Count;
|
||||||
@@ -359,7 +359,7 @@ namespace System.Collections.Generic
|
|||||||
var element = copy.Dequeue();
|
var element = copy.Dequeue();
|
||||||
if (found)
|
if (found)
|
||||||
{
|
{
|
||||||
queue.Enqueue(element);
|
_queue.Enqueue(element);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -369,7 +369,7 @@ namespace System.Collections.Generic
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
queue.Enqueue(element);
|
_queue.Enqueue(element);
|
||||||
}
|
}
|
||||||
|
|
||||||
return found;
|
return found;
|
||||||
@@ -382,19 +382,19 @@ namespace System.Collections.Generic
|
|||||||
/// <param name="collection">The objects to add to the <see cref="AsyncQueue{T}"/>.</param>
|
/// <param name="collection">The objects to add to the <see cref="AsyncQueue{T}"/>.</param>
|
||||||
public void Enqueue(IEnumerable<T> collection)
|
public void Enqueue(IEnumerable<T> collection)
|
||||||
{
|
{
|
||||||
lock (queue)
|
lock (_queue)
|
||||||
{
|
{
|
||||||
bool hasElements = false;
|
bool hasElements = false;
|
||||||
foreach (var element in collection)
|
foreach (var element in collection)
|
||||||
{
|
{
|
||||||
hasElements = true;
|
hasElements = true;
|
||||||
queue.Enqueue(element);
|
_queue.Enqueue(element);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hasElements)
|
if (hasElements)
|
||||||
{
|
{
|
||||||
SetToken(dequeueTcs);
|
SetToken(_dequeueTcs);
|
||||||
SetToken(availableTcs);
|
SetToken(_availableTcs);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -8,9 +8,12 @@ namespace System.Security.Cryptography
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
public class CryptographyHelper
|
public class CryptographyHelper
|
||||||
{
|
{
|
||||||
private static int saltLength = 8;
|
// "readonly" not added due to UnitTests
|
||||||
|
#pragma warning disable IDE0044 // Add "readonly" modifier
|
||||||
|
private static int _saltLength = 8;
|
||||||
|
#pragma warning restore IDE0044 // Add "readonly" modifier
|
||||||
|
|
||||||
private readonly string masterKeyFile;
|
private readonly string _masterKeyFile;
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Initializes a new instance of the <see cref="CryptographyHelper"/> class.
|
/// Initializes a new instance of the <see cref="CryptographyHelper"/> class.
|
||||||
@@ -18,17 +21,17 @@ namespace System.Security.Cryptography
|
|||||||
/// <param name="keyFile">The (absolute) path to the crypto key file. On <c>null</c> the file 'crypto.key' at the executing assembly location will be used.</param>
|
/// <param name="keyFile">The (absolute) path to the crypto key file. On <c>null</c> the file 'crypto.key' at the executing assembly location will be used.</param>
|
||||||
public CryptographyHelper(string keyFile = null)
|
public CryptographyHelper(string keyFile = null)
|
||||||
{
|
{
|
||||||
masterKeyFile = keyFile;
|
_masterKeyFile = keyFile;
|
||||||
|
|
||||||
if (string.IsNullOrWhiteSpace(masterKeyFile))
|
if (string.IsNullOrWhiteSpace(_masterKeyFile))
|
||||||
masterKeyFile = "crypto.key";
|
_masterKeyFile = "crypto.key";
|
||||||
|
|
||||||
if (!Path.IsPathRooted(masterKeyFile))
|
if (!Path.IsPathRooted(_masterKeyFile))
|
||||||
masterKeyFile = Path.Combine(AppContext.BaseDirectory, masterKeyFile);
|
_masterKeyFile = Path.Combine(AppContext.BaseDirectory, _masterKeyFile);
|
||||||
|
|
||||||
string pw = File.Exists(masterKeyFile) ? File.ReadAllText(masterKeyFile) : null;
|
string pw = File.Exists(_masterKeyFile) ? File.ReadAllText(_masterKeyFile) : null;
|
||||||
if (string.IsNullOrWhiteSpace(pw))
|
if (string.IsNullOrWhiteSpace(pw))
|
||||||
File.WriteAllText(masterKeyFile, GetRandomString(64));
|
File.WriteAllText(_masterKeyFile, GetRandomString(64));
|
||||||
}
|
}
|
||||||
|
|
||||||
#region Instance methods
|
#region Instance methods
|
||||||
@@ -46,8 +49,7 @@ namespace System.Security.Cryptography
|
|||||||
/// <returns>The decrypted data.</returns>
|
/// <returns>The decrypted data.</returns>
|
||||||
public byte[] DecryptAes(byte[] cipher, string password = null)
|
public byte[] DecryptAes(byte[] cipher, string password = null)
|
||||||
{
|
{
|
||||||
if (password == null)
|
password ??= File.ReadAllText(_masterKeyFile);
|
||||||
password = File.ReadAllText(masterKeyFile);
|
|
||||||
|
|
||||||
return AesDecrypt(cipher, password);
|
return AesDecrypt(cipher, password);
|
||||||
}
|
}
|
||||||
@@ -63,8 +65,7 @@ namespace System.Security.Cryptography
|
|||||||
/// <returns>The encrypted data (cipher).</returns>
|
/// <returns>The encrypted data (cipher).</returns>
|
||||||
public byte[] EncryptAes(byte[] plain, string password = null)
|
public byte[] EncryptAes(byte[] plain, string password = null)
|
||||||
{
|
{
|
||||||
if (password == null)
|
password ??= File.ReadAllText(_masterKeyFile);
|
||||||
password = File.ReadAllText(masterKeyFile);
|
|
||||||
|
|
||||||
return AesEncrypt(plain, password);
|
return AesEncrypt(plain, password);
|
||||||
}
|
}
|
||||||
@@ -110,8 +111,7 @@ namespace System.Security.Cryptography
|
|||||||
/// <returns>The decrypted data.</returns>
|
/// <returns>The decrypted data.</returns>
|
||||||
public byte[] DecryptTripleDes(byte[] cipher, string password = null)
|
public byte[] DecryptTripleDes(byte[] cipher, string password = null)
|
||||||
{
|
{
|
||||||
if (password == null)
|
password ??= File.ReadAllText(_masterKeyFile);
|
||||||
password = File.ReadAllText(masterKeyFile);
|
|
||||||
|
|
||||||
return TripleDesDecrypt(cipher, password);
|
return TripleDesDecrypt(cipher, password);
|
||||||
}
|
}
|
||||||
@@ -127,8 +127,7 @@ namespace System.Security.Cryptography
|
|||||||
/// <returns>The encrypted data (cipher).</returns>
|
/// <returns>The encrypted data (cipher).</returns>
|
||||||
public byte[] EncryptTripleDes(byte[] plain, string password = null)
|
public byte[] EncryptTripleDes(byte[] plain, string password = null)
|
||||||
{
|
{
|
||||||
if (password == null)
|
password ??= File.ReadAllText(_masterKeyFile);
|
||||||
password = File.ReadAllText(masterKeyFile);
|
|
||||||
|
|
||||||
return TripleDesEncrypt(plain, password);
|
return TripleDesEncrypt(plain, password);
|
||||||
}
|
}
|
||||||
@@ -183,8 +182,8 @@ namespace System.Security.Cryptography
|
|||||||
/// <returns>The decrypted data.</returns>
|
/// <returns>The decrypted data.</returns>
|
||||||
public static byte[] AesDecrypt(byte[] cipher, string password)
|
public static byte[] AesDecrypt(byte[] cipher, string password)
|
||||||
{
|
{
|
||||||
byte[] salt = new byte[saltLength];
|
byte[] salt = new byte[_saltLength];
|
||||||
Array.Copy(cipher, salt, saltLength);
|
Array.Copy(cipher, salt, _saltLength);
|
||||||
|
|
||||||
using var gen = new Rfc2898DeriveBytes(password, salt);
|
using var gen = new Rfc2898DeriveBytes(password, salt);
|
||||||
using var aes = Aes.Create();
|
using var aes = Aes.Create();
|
||||||
@@ -197,7 +196,7 @@ namespace System.Security.Cryptography
|
|||||||
using var ms = new MemoryStream();
|
using var ms = new MemoryStream();
|
||||||
using var cs = new CryptoStream(ms, aes.CreateDecryptor(), CryptoStreamMode.Write);
|
using var cs = new CryptoStream(ms, aes.CreateDecryptor(), CryptoStreamMode.Write);
|
||||||
|
|
||||||
cs.Write(cipher, saltLength, cipher.Length - saltLength);
|
cs.Write(cipher, _saltLength, cipher.Length - _saltLength);
|
||||||
cs.FlushFinalBlock();
|
cs.FlushFinalBlock();
|
||||||
|
|
||||||
return ms.ToArray();
|
return ms.ToArray();
|
||||||
@@ -224,7 +223,7 @@ namespace System.Security.Cryptography
|
|||||||
/// <returns>The encrypted data (cipher).</returns>
|
/// <returns>The encrypted data (cipher).</returns>
|
||||||
public static byte[] AesEncrypt(byte[] plain, string password)
|
public static byte[] AesEncrypt(byte[] plain, string password)
|
||||||
{
|
{
|
||||||
byte[] salt = GetRandomBytes(saltLength);
|
byte[] salt = GetRandomBytes(_saltLength);
|
||||||
|
|
||||||
using var gen = new Rfc2898DeriveBytes(password, salt);
|
using var gen = new Rfc2898DeriveBytes(password, salt);
|
||||||
using var aes = Aes.Create();
|
using var aes = Aes.Create();
|
||||||
@@ -269,8 +268,8 @@ namespace System.Security.Cryptography
|
|||||||
/// <returns>The decrypted data.</returns>
|
/// <returns>The decrypted data.</returns>
|
||||||
public static byte[] TripleDesDecrypt(byte[] cipher, string password)
|
public static byte[] TripleDesDecrypt(byte[] cipher, string password)
|
||||||
{
|
{
|
||||||
byte[] salt = new byte[saltLength];
|
byte[] salt = new byte[_saltLength];
|
||||||
Array.Copy(cipher, salt, saltLength);
|
Array.Copy(cipher, salt, _saltLength);
|
||||||
|
|
||||||
using var gen = new Rfc2898DeriveBytes(password, salt);
|
using var gen = new Rfc2898DeriveBytes(password, salt);
|
||||||
using var tdes = TripleDES.Create();
|
using var tdes = TripleDES.Create();
|
||||||
@@ -283,7 +282,7 @@ namespace System.Security.Cryptography
|
|||||||
using var ms = new MemoryStream();
|
using var ms = new MemoryStream();
|
||||||
using var cs = new CryptoStream(ms, tdes.CreateDecryptor(), CryptoStreamMode.Write);
|
using var cs = new CryptoStream(ms, tdes.CreateDecryptor(), CryptoStreamMode.Write);
|
||||||
|
|
||||||
cs.Write(cipher, saltLength, cipher.Length - saltLength);
|
cs.Write(cipher, _saltLength, cipher.Length - _saltLength);
|
||||||
cs.FlushFinalBlock();
|
cs.FlushFinalBlock();
|
||||||
|
|
||||||
return ms.ToArray();
|
return ms.ToArray();
|
||||||
@@ -297,7 +296,7 @@ namespace System.Security.Cryptography
|
|||||||
/// <returns>The encrypted data (cipher).</returns>
|
/// <returns>The encrypted data (cipher).</returns>
|
||||||
public static byte[] TripleDesEncrypt(byte[] plain, string password)
|
public static byte[] TripleDesEncrypt(byte[] plain, string password)
|
||||||
{
|
{
|
||||||
byte[] salt = GetRandomBytes(saltLength);
|
byte[] salt = GetRandomBytes(_saltLength);
|
||||||
|
|
||||||
using var gen = new Rfc2898DeriveBytes(password, salt);
|
using var gen = new Rfc2898DeriveBytes(password, salt);
|
||||||
using var tdes = TripleDES.Create();
|
using var tdes = TripleDES.Create();
|
||||||
|
|||||||
@@ -15,9 +15,9 @@ namespace AMWD.Common.Utilities
|
|||||||
{
|
{
|
||||||
#region Data
|
#region Data
|
||||||
|
|
||||||
private Timer timer;
|
private Timer _timer;
|
||||||
|
|
||||||
private bool nextRunPending;
|
private bool _nextRunPending;
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// The synchronisation object.
|
/// The synchronisation object.
|
||||||
@@ -130,13 +130,13 @@ namespace AMWD.Common.Utilities
|
|||||||
tcs = CreateTcs();
|
tcs = CreateTcs();
|
||||||
}
|
}
|
||||||
IsWaitingToRun = true;
|
IsWaitingToRun = true;
|
||||||
if (timer != null)
|
if (_timer != null)
|
||||||
{
|
{
|
||||||
timer.Change(Delay, Timeout.InfiniteTimeSpan);
|
_timer.Change(Delay, Timeout.InfiniteTimeSpan);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
timer = new Timer(OnTimerCallback, null, Delay, Timeout.InfiniteTimeSpan);
|
_timer = new Timer(OnTimerCallback, null, Delay, Timeout.InfiniteTimeSpan);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -152,9 +152,9 @@ namespace AMWD.Common.Utilities
|
|||||||
lock (syncLock)
|
lock (syncLock)
|
||||||
{
|
{
|
||||||
IsWaitingToRun = false;
|
IsWaitingToRun = false;
|
||||||
nextRunPending = false;
|
_nextRunPending = false;
|
||||||
timer?.Dispose();
|
_timer?.Dispose();
|
||||||
timer = null;
|
_timer = null;
|
||||||
if (!IsRunning)
|
if (!IsRunning)
|
||||||
{
|
{
|
||||||
localTcs = tcs;
|
localTcs = tcs;
|
||||||
@@ -179,13 +179,13 @@ namespace AMWD.Common.Utilities
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
IsWaitingToRun = true;
|
IsWaitingToRun = true;
|
||||||
if (timer != null)
|
if (_timer != null)
|
||||||
{
|
{
|
||||||
timer.Change(TimeSpan.Zero, Timeout.InfiniteTimeSpan);
|
_timer.Change(TimeSpan.Zero, Timeout.InfiniteTimeSpan);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
timer = new Timer(OnTimerCallback, null, TimeSpan.Zero, Timeout.InfiniteTimeSpan);
|
_timer = new Timer(OnTimerCallback, null, TimeSpan.Zero, Timeout.InfiniteTimeSpan);
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@@ -256,7 +256,7 @@ namespace AMWD.Common.Utilities
|
|||||||
{
|
{
|
||||||
tcs = CreateTcs();
|
tcs = CreateTcs();
|
||||||
IsWaitingToRun = true;
|
IsWaitingToRun = true;
|
||||||
timer = new Timer(OnTimerCallback, null, Delay, Timeout.InfiniteTimeSpan);
|
_timer = new Timer(OnTimerCallback, null, Delay, Timeout.InfiniteTimeSpan);
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -285,7 +285,7 @@ namespace AMWD.Common.Utilities
|
|||||||
if (IsRunning)
|
if (IsRunning)
|
||||||
{
|
{
|
||||||
// Currently running, remember and do nothing for now
|
// Currently running, remember and do nothing for now
|
||||||
nextRunPending = true;
|
_nextRunPending = true;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
IsRunning = true;
|
IsRunning = true;
|
||||||
@@ -308,12 +308,12 @@ namespace AMWD.Common.Utilities
|
|||||||
{
|
{
|
||||||
runAgain = false;
|
runAgain = false;
|
||||||
IsRunning = false;
|
IsRunning = false;
|
||||||
nextRunPending = false;
|
_nextRunPending = false;
|
||||||
localTcs = tcs;
|
localTcs = tcs;
|
||||||
if (!IsWaitingToRun)
|
if (!IsWaitingToRun)
|
||||||
{
|
{
|
||||||
timer?.Dispose();
|
_timer?.Dispose();
|
||||||
timer = null;
|
_timer = null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
exceptionHandler?.Invoke(ex);
|
exceptionHandler?.Invoke(ex);
|
||||||
@@ -322,16 +322,16 @@ namespace AMWD.Common.Utilities
|
|||||||
{
|
{
|
||||||
lock (syncLock)
|
lock (syncLock)
|
||||||
{
|
{
|
||||||
runAgain = nextRunPending;
|
runAgain = _nextRunPending;
|
||||||
IsRunning = runAgain;
|
IsRunning = runAgain;
|
||||||
nextRunPending = false;
|
_nextRunPending = false;
|
||||||
if (!runAgain)
|
if (!runAgain)
|
||||||
{
|
{
|
||||||
if (!IsWaitingToRun)
|
if (!IsWaitingToRun)
|
||||||
{
|
{
|
||||||
localTcs = tcs;
|
localTcs = tcs;
|
||||||
timer?.Dispose();
|
_timer?.Dispose();
|
||||||
timer = null;
|
_timer = null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -403,19 +403,19 @@ namespace AMWD.Common.Utilities
|
|||||||
/// <typeparam name="TResult">The type of the result value.</typeparam>
|
/// <typeparam name="TResult">The type of the result value.</typeparam>
|
||||||
protected class TaskCompletionSourceWrapper<TResult> : TaskCompletionSourceWrapper
|
protected class TaskCompletionSourceWrapper<TResult> : TaskCompletionSourceWrapper
|
||||||
{
|
{
|
||||||
private readonly TaskCompletionSource<TResult> tcs;
|
private readonly TaskCompletionSource<TResult> _tcs;
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Gets the <see cref="Task{TResult}"/> of the <see cref="TaskCompletionSource{TResult}"/>.
|
/// Gets the <see cref="Task{TResult}"/> of the <see cref="TaskCompletionSource{TResult}"/>.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public override Task Task => tcs.Task;
|
public override Task Task => _tcs.Task;
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Initializes a new instance of the <see cref="TaskCompletionSourceWrapper{TResult}"/> class.
|
/// Initializes a new instance of the <see cref="TaskCompletionSourceWrapper{TResult}"/> class.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public TaskCompletionSourceWrapper()
|
public TaskCompletionSourceWrapper()
|
||||||
{
|
{
|
||||||
tcs = new TaskCompletionSource<TResult>();
|
_tcs = new TaskCompletionSource<TResult>();
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@@ -424,13 +424,13 @@ namespace AMWD.Common.Utilities
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="result">The result value to bind to this <see cref="Task{TResult}"/>.</param>
|
/// <param name="result">The result value to bind to this <see cref="Task{TResult}"/>.</param>
|
||||||
/// <seealso cref="TaskCompletionSource{TResult}.TrySetResult(TResult)"/>
|
/// <seealso cref="TaskCompletionSource{TResult}.TrySetResult(TResult)"/>
|
||||||
public void TrySetResult(TResult result) => tcs.TrySetResult(result);
|
public void TrySetResult(TResult result) => _tcs.TrySetResult(result);
|
||||||
|
|
||||||
/// <inheritdoc/>
|
/// <inheritdoc/>
|
||||||
public override void TrySetException(Exception exception) => tcs.TrySetException(exception);
|
public override void TrySetException(Exception exception) => _tcs.TrySetException(exception);
|
||||||
|
|
||||||
/// <inheritdoc/>
|
/// <inheritdoc/>
|
||||||
public override void TrySetCanceled() => tcs.TrySetCanceled();
|
public override void TrySetCanceled() => _tcs.TrySetCanceled();
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion Internal TaskCompletionSourceWrapper classes
|
#endregion Internal TaskCompletionSourceWrapper classes
|
||||||
|
|||||||
@@ -150,7 +150,7 @@ namespace AMWD.Common.Utilities
|
|||||||
if (addressFamily != AddressFamily.Unspecified && ipAddress.AddressFamily != addressFamily)
|
if (addressFamily != AddressFamily.Unspecified && ipAddress.AddressFamily != addressFamily)
|
||||||
return null;
|
return null;
|
||||||
|
|
||||||
return ipAddress;
|
return ipAddress.IsIPv4MappedToIPv6 ? ipAddress.MapToIPv4() : ipAddress;
|
||||||
}
|
}
|
||||||
|
|
||||||
return null;
|
return null;
|
||||||
|
|||||||
@@ -4,6 +4,7 @@
|
|||||||
|
|
||||||
<AppendTargetFrameworkToOutputPath>true</AppendTargetFrameworkToOutputPath>
|
<AppendTargetFrameworkToOutputPath>true</AppendTargetFrameworkToOutputPath>
|
||||||
<CopyRefAssembliesToPublishDirectory>false</CopyRefAssembliesToPublishDirectory>
|
<CopyRefAssembliesToPublishDirectory>false</CopyRefAssembliesToPublishDirectory>
|
||||||
|
<IncludeSourceRevisionInInformationalVersion>false</IncludeSourceRevisionInInformationalVersion>
|
||||||
<GenerateDocumentationFile>true</GenerateDocumentationFile>
|
<GenerateDocumentationFile>true</GenerateDocumentationFile>
|
||||||
|
|
||||||
<IncludeSymbols>true</IncludeSymbols>
|
<IncludeSymbols>true</IncludeSymbols>
|
||||||
@@ -33,7 +34,7 @@
|
|||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<PackageReference Include="AMWD.NetRevisionTask" Version="1.0.0">
|
<PackageReference Include="AMWD.NetRevisionTask" Version="1.1.0">
|
||||||
<PrivateAssets>all</PrivateAssets>
|
<PrivateAssets>all</PrivateAssets>
|
||||||
<IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets>
|
<IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets>
|
||||||
</PackageReference>
|
</PackageReference>
|
||||||
|
|||||||
@@ -22,28 +22,28 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
[System.Diagnostics.CodeAnalysis.ExcludeFromCodeCoverage]
|
[System.Diagnostics.CodeAnalysis.ExcludeFromCodeCoverage]
|
||||||
public class BasicAuthenticationAttributeTests
|
public class BasicAuthenticationAttributeTests
|
||||||
{
|
{
|
||||||
private Mock<IHeaderDictionary> requestHeaderMock;
|
private Mock<IHeaderDictionary> _requestHeaderMock;
|
||||||
private Mock<IHeaderDictionary> responseHeaderMock;
|
private Mock<IHeaderDictionary> _responseHeaderMock;
|
||||||
|
|
||||||
private Mock<HttpRequest> requestMock;
|
private Mock<HttpRequest> _requestMock;
|
||||||
private Mock<HttpResponse> responseMock;
|
private Mock<HttpResponse> _responseMock;
|
||||||
|
|
||||||
private Mock<HttpContext> contextMock;
|
private Mock<HttpContext> _contextMock;
|
||||||
|
|
||||||
private Dictionary<string, string> requestHeaders;
|
private Dictionary<string, string> _requestHeaders;
|
||||||
private string validatorRealm;
|
private string _validatorRealm;
|
||||||
private ClaimsPrincipal validatorResult;
|
private ClaimsPrincipal _validatorResult;
|
||||||
|
|
||||||
private string responseHeaderAuthCallback;
|
private string _responseHeaderAuthCallback;
|
||||||
|
|
||||||
[TestInitialize]
|
[TestInitialize]
|
||||||
public void InitializeTest()
|
public void InitializeTest()
|
||||||
{
|
{
|
||||||
requestHeaders = new Dictionary<string, string>();
|
_requestHeaders = [];
|
||||||
validatorRealm = null;
|
_validatorRealm = null;
|
||||||
validatorResult = null;
|
_validatorResult = null;
|
||||||
|
|
||||||
responseHeaderAuthCallback = null;
|
_responseHeaderAuthCallback = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
@@ -55,7 +55,7 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
Username = "user",
|
Username = "user",
|
||||||
Password = "password"
|
Password = "password"
|
||||||
};
|
};
|
||||||
requestHeaders.Add("Authorization", $"Basic {Convert.ToBase64String(Encoding.UTF8.GetBytes($"{attribute.Username}:{attribute.Password}"))}");
|
_requestHeaders.Add("Authorization", $"Basic {Convert.ToBase64String(Encoding.UTF8.GetBytes($"{attribute.Username}:{attribute.Password}"))}");
|
||||||
|
|
||||||
var context = GetContext();
|
var context = GetContext();
|
||||||
|
|
||||||
@@ -64,7 +64,7 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
|
|
||||||
// assert
|
// assert
|
||||||
Assert.IsNull(context.Result);
|
Assert.IsNull(context.Result);
|
||||||
Assert.IsTrue(string.IsNullOrWhiteSpace(responseHeaderAuthCallback));
|
Assert.IsTrue(string.IsNullOrWhiteSpace(_responseHeaderAuthCallback));
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
@@ -72,8 +72,8 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
var attribute = new BasicAuthenticationAttribute();
|
var attribute = new BasicAuthenticationAttribute();
|
||||||
requestHeaders.Add("Authorization", $"Basic {Convert.ToBase64String(Encoding.UTF8.GetBytes($"{attribute.Username}:{attribute.Password}"))}");
|
_requestHeaders.Add("Authorization", $"Basic {Convert.ToBase64String(Encoding.UTF8.GetBytes($"{attribute.Username}:{attribute.Password}"))}");
|
||||||
validatorResult = new ClaimsPrincipal();
|
_validatorResult = new ClaimsPrincipal();
|
||||||
|
|
||||||
var context = GetContext(hasValidator: true);
|
var context = GetContext(hasValidator: true);
|
||||||
|
|
||||||
@@ -82,7 +82,7 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
|
|
||||||
// assert
|
// assert
|
||||||
Assert.IsNull(context.Result);
|
Assert.IsNull(context.Result);
|
||||||
Assert.IsTrue(string.IsNullOrWhiteSpace(responseHeaderAuthCallback));
|
Assert.IsTrue(string.IsNullOrWhiteSpace(_responseHeaderAuthCallback));
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
@@ -101,7 +101,7 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
|
|
||||||
// assert
|
// assert
|
||||||
Assert.IsNull(context.Result);
|
Assert.IsNull(context.Result);
|
||||||
Assert.IsTrue(string.IsNullOrWhiteSpace(responseHeaderAuthCallback));
|
Assert.IsTrue(string.IsNullOrWhiteSpace(_responseHeaderAuthCallback));
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
@@ -123,8 +123,8 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
Assert.IsTrue(context.Result is StatusCodeResult);
|
Assert.IsTrue(context.Result is StatusCodeResult);
|
||||||
Assert.AreEqual(401, ((StatusCodeResult)context.Result).StatusCode);
|
Assert.AreEqual(401, ((StatusCodeResult)context.Result).StatusCode);
|
||||||
|
|
||||||
Assert.IsFalse(string.IsNullOrWhiteSpace(responseHeaderAuthCallback));
|
Assert.IsFalse(string.IsNullOrWhiteSpace(_responseHeaderAuthCallback));
|
||||||
Assert.AreEqual("Basic", responseHeaderAuthCallback);
|
Assert.AreEqual("Basic", _responseHeaderAuthCallback);
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
@@ -147,8 +147,8 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
Assert.IsTrue(context.Result is StatusCodeResult);
|
Assert.IsTrue(context.Result is StatusCodeResult);
|
||||||
Assert.AreEqual(401, ((StatusCodeResult)context.Result).StatusCode);
|
Assert.AreEqual(401, ((StatusCodeResult)context.Result).StatusCode);
|
||||||
|
|
||||||
Assert.IsFalse(string.IsNullOrWhiteSpace(responseHeaderAuthCallback));
|
Assert.IsFalse(string.IsNullOrWhiteSpace(_responseHeaderAuthCallback));
|
||||||
Assert.AreEqual("Basic realm=\"re:alm\"", responseHeaderAuthCallback);
|
Assert.AreEqual("Basic realm=\"re:alm\"", _responseHeaderAuthCallback);
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
@@ -160,7 +160,7 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
Username = "user",
|
Username = "user",
|
||||||
Password = "password"
|
Password = "password"
|
||||||
};
|
};
|
||||||
requestHeaders.Add("Authorization", $"Basic {Convert.ToBase64String(Encoding.UTF8.GetBytes($"{attribute.Username}a:{attribute.Password}"))}");
|
_requestHeaders.Add("Authorization", $"Basic {Convert.ToBase64String(Encoding.UTF8.GetBytes($"{attribute.Username}a:{attribute.Password}"))}");
|
||||||
var context = GetContext();
|
var context = GetContext();
|
||||||
|
|
||||||
// act
|
// act
|
||||||
@@ -171,8 +171,8 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
Assert.IsTrue(context.Result is StatusCodeResult);
|
Assert.IsTrue(context.Result is StatusCodeResult);
|
||||||
Assert.AreEqual(401, ((StatusCodeResult)context.Result).StatusCode);
|
Assert.AreEqual(401, ((StatusCodeResult)context.Result).StatusCode);
|
||||||
|
|
||||||
Assert.IsFalse(string.IsNullOrWhiteSpace(responseHeaderAuthCallback));
|
Assert.IsFalse(string.IsNullOrWhiteSpace(_responseHeaderAuthCallback));
|
||||||
Assert.AreEqual("Basic", responseHeaderAuthCallback);
|
Assert.AreEqual("Basic", _responseHeaderAuthCallback);
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
@@ -184,7 +184,7 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
Username = "user",
|
Username = "user",
|
||||||
Password = "password"
|
Password = "password"
|
||||||
};
|
};
|
||||||
requestHeaders.Add("Authorization", $"Basic {Convert.ToBase64String(Encoding.UTF8.GetBytes($"{attribute.Username}:{attribute.Password}a"))}");
|
_requestHeaders.Add("Authorization", $"Basic {Convert.ToBase64String(Encoding.UTF8.GetBytes($"{attribute.Username}:{attribute.Password}a"))}");
|
||||||
var context = GetContext();
|
var context = GetContext();
|
||||||
|
|
||||||
// act
|
// act
|
||||||
@@ -195,8 +195,8 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
Assert.IsTrue(context.Result is StatusCodeResult);
|
Assert.IsTrue(context.Result is StatusCodeResult);
|
||||||
Assert.AreEqual(401, ((StatusCodeResult)context.Result).StatusCode);
|
Assert.AreEqual(401, ((StatusCodeResult)context.Result).StatusCode);
|
||||||
|
|
||||||
Assert.IsFalse(string.IsNullOrWhiteSpace(responseHeaderAuthCallback));
|
Assert.IsFalse(string.IsNullOrWhiteSpace(_responseHeaderAuthCallback));
|
||||||
Assert.AreEqual("Basic", responseHeaderAuthCallback);
|
Assert.AreEqual("Basic", _responseHeaderAuthCallback);
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
@@ -207,7 +207,7 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
{
|
{
|
||||||
Realm = "attribute"
|
Realm = "attribute"
|
||||||
};
|
};
|
||||||
requestHeaders.Add("Authorization", $"Basic {Convert.ToBase64String(Encoding.UTF8.GetBytes($"{attribute.Username}:{attribute.Password}"))}");
|
_requestHeaders.Add("Authorization", $"Basic {Convert.ToBase64String(Encoding.UTF8.GetBytes($"{attribute.Username}:{attribute.Password}"))}");
|
||||||
var context = GetContext(hasValidator: true);
|
var context = GetContext(hasValidator: true);
|
||||||
|
|
||||||
// act
|
// act
|
||||||
@@ -218,17 +218,17 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
Assert.IsTrue(context.Result is StatusCodeResult);
|
Assert.IsTrue(context.Result is StatusCodeResult);
|
||||||
Assert.AreEqual(401, ((StatusCodeResult)context.Result).StatusCode);
|
Assert.AreEqual(401, ((StatusCodeResult)context.Result).StatusCode);
|
||||||
|
|
||||||
Assert.IsFalse(string.IsNullOrWhiteSpace(responseHeaderAuthCallback));
|
Assert.IsFalse(string.IsNullOrWhiteSpace(_responseHeaderAuthCallback));
|
||||||
Assert.AreEqual("Basic realm=\"attribute\"", responseHeaderAuthCallback);
|
Assert.AreEqual("Basic realm=\"attribute\"", _responseHeaderAuthCallback);
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
public async Task ShouldAskOnValidatorWithRealmOnValidator()
|
public async Task ShouldAskOnValidatorWithRealmOnValidator()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
validatorRealm = "validator";
|
_validatorRealm = "validator";
|
||||||
var attribute = new BasicAuthenticationAttribute();
|
var attribute = new BasicAuthenticationAttribute();
|
||||||
requestHeaders.Add("Authorization", $"Basic {Convert.ToBase64String(Encoding.UTF8.GetBytes($"{attribute.Username}:{attribute.Password}"))}");
|
_requestHeaders.Add("Authorization", $"Basic {Convert.ToBase64String(Encoding.UTF8.GetBytes($"{attribute.Username}:{attribute.Password}"))}");
|
||||||
var context = GetContext(hasValidator: true);
|
var context = GetContext(hasValidator: true);
|
||||||
|
|
||||||
// act
|
// act
|
||||||
@@ -239,8 +239,8 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
Assert.IsTrue(context.Result is StatusCodeResult);
|
Assert.IsTrue(context.Result is StatusCodeResult);
|
||||||
Assert.AreEqual(401, ((StatusCodeResult)context.Result).StatusCode);
|
Assert.AreEqual(401, ((StatusCodeResult)context.Result).StatusCode);
|
||||||
|
|
||||||
Assert.IsFalse(string.IsNullOrWhiteSpace(responseHeaderAuthCallback));
|
Assert.IsFalse(string.IsNullOrWhiteSpace(_responseHeaderAuthCallback));
|
||||||
Assert.AreEqual("Basic realm=\"validator\"", responseHeaderAuthCallback);
|
Assert.AreEqual("Basic realm=\"validator\"", _responseHeaderAuthCallback);
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
@@ -248,7 +248,7 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
var attribute = new BasicAuthenticationAttribute();
|
var attribute = new BasicAuthenticationAttribute();
|
||||||
requestHeaders.Add("Authorization", $"Basic {Convert.ToBase64String(Encoding.UTF8.GetBytes($"{attribute.Username}"))}");
|
_requestHeaders.Add("Authorization", $"Basic {Convert.ToBase64String(Encoding.UTF8.GetBytes($"{attribute.Username}"))}");
|
||||||
var context = GetContext();
|
var context = GetContext();
|
||||||
|
|
||||||
// act
|
// act
|
||||||
@@ -262,34 +262,38 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
|
|
||||||
private AuthorizationFilterContext GetContext(bool isAnonymousAllowed = false, bool hasValidator = false)
|
private AuthorizationFilterContext GetContext(bool isAnonymousAllowed = false, bool hasValidator = false)
|
||||||
{
|
{
|
||||||
requestHeaderMock = new Mock<IHeaderDictionary>();
|
_requestHeaderMock = new Mock<IHeaderDictionary>();
|
||||||
foreach (var header in requestHeaders)
|
foreach (var header in _requestHeaders)
|
||||||
{
|
{
|
||||||
requestHeaderMock
|
StringValues outVal = header.Value;
|
||||||
|
_requestHeaderMock
|
||||||
.Setup(h => h.ContainsKey(header.Key))
|
.Setup(h => h.ContainsKey(header.Key))
|
||||||
.Returns(true);
|
.Returns(true);
|
||||||
requestHeaderMock
|
_requestHeaderMock
|
||||||
.Setup(h => h[header.Key])
|
.Setup(h => h[header.Key])
|
||||||
.Returns(header.Value);
|
.Returns(header.Value);
|
||||||
|
_requestHeaderMock
|
||||||
|
.Setup(h => h.TryGetValue(header.Key, out outVal))
|
||||||
|
.Returns(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
responseHeaderMock = new Mock<IHeaderDictionary>();
|
_responseHeaderMock = new Mock<IHeaderDictionary>();
|
||||||
responseHeaderMock
|
_responseHeaderMock
|
||||||
.SetupSet(h => h["WWW-Authenticate"] = It.IsAny<StringValues>())
|
.SetupSet(h => h.WWWAuthenticate = It.IsAny<StringValues>())
|
||||||
.Callback<string, StringValues>((key, value) =>
|
.Callback<StringValues>((value) =>
|
||||||
{
|
{
|
||||||
responseHeaderAuthCallback = value;
|
_responseHeaderAuthCallback = value;
|
||||||
});
|
});
|
||||||
|
|
||||||
requestMock = new Mock<HttpRequest>();
|
_requestMock = new Mock<HttpRequest>();
|
||||||
requestMock
|
_requestMock
|
||||||
.Setup(r => r.Headers)
|
.Setup(r => r.Headers)
|
||||||
.Returns(requestHeaderMock.Object);
|
.Returns(_requestHeaderMock.Object);
|
||||||
|
|
||||||
responseMock = new Mock<HttpResponse>();
|
_responseMock = new Mock<HttpResponse>();
|
||||||
responseMock
|
_responseMock
|
||||||
.Setup(r => r.Headers)
|
.Setup(r => r.Headers)
|
||||||
.Returns(responseHeaderMock.Object);
|
.Returns(_responseHeaderMock.Object);
|
||||||
|
|
||||||
var requestServicesMock = new Mock<IServiceProvider>();
|
var requestServicesMock = new Mock<IServiceProvider>();
|
||||||
|
|
||||||
@@ -298,10 +302,10 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
var validatorMock = new Mock<IBasicAuthenticationValidator>();
|
var validatorMock = new Mock<IBasicAuthenticationValidator>();
|
||||||
validatorMock
|
validatorMock
|
||||||
.Setup(v => v.Realm)
|
.Setup(v => v.Realm)
|
||||||
.Returns(validatorRealm);
|
.Returns(_validatorRealm);
|
||||||
validatorMock
|
validatorMock
|
||||||
.Setup(v => v.ValidateAsync(It.IsAny<string>(), It.IsAny<string>(), It.IsAny<IPAddress>(), It.IsAny<CancellationToken>()))
|
.Setup(v => v.ValidateAsync(It.IsAny<string>(), It.IsAny<string>(), It.IsAny<IPAddress>(), It.IsAny<CancellationToken>()))
|
||||||
.ReturnsAsync(validatorResult);
|
.ReturnsAsync(_validatorResult);
|
||||||
|
|
||||||
requestServicesMock
|
requestServicesMock
|
||||||
.Setup(rs => rs.GetService(typeof(IBasicAuthenticationValidator)))
|
.Setup(rs => rs.GetService(typeof(IBasicAuthenticationValidator)))
|
||||||
@@ -313,20 +317,20 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
.Setup(ci => ci.RemoteIpAddress)
|
.Setup(ci => ci.RemoteIpAddress)
|
||||||
.Returns(IPAddress.Loopback);
|
.Returns(IPAddress.Loopback);
|
||||||
|
|
||||||
contextMock = new Mock<HttpContext>();
|
_contextMock = new Mock<HttpContext>();
|
||||||
contextMock
|
_contextMock
|
||||||
.Setup(c => c.Request)
|
.Setup(c => c.Request)
|
||||||
.Returns(requestMock.Object);
|
.Returns(_requestMock.Object);
|
||||||
contextMock
|
_contextMock
|
||||||
.Setup(c => c.Response)
|
.Setup(c => c.Response)
|
||||||
.Returns(responseMock.Object);
|
.Returns(_responseMock.Object);
|
||||||
contextMock
|
_contextMock
|
||||||
.Setup(c => c.RequestServices)
|
.Setup(c => c.RequestServices)
|
||||||
.Returns(requestServicesMock.Object);
|
.Returns(requestServicesMock.Object);
|
||||||
contextMock
|
_contextMock
|
||||||
.Setup(c => c.Connection)
|
.Setup(c => c.Connection)
|
||||||
.Returns(connectionInfoMock.Object);
|
.Returns(connectionInfoMock.Object);
|
||||||
contextMock
|
_contextMock
|
||||||
.Setup(c => c.RequestAborted)
|
.Setup(c => c.RequestAborted)
|
||||||
.Returns(CancellationToken.None);
|
.Returns(CancellationToken.None);
|
||||||
|
|
||||||
@@ -341,7 +345,7 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
|
|
||||||
return new AuthorizationFilterContext(new ActionContext
|
return new AuthorizationFilterContext(new ActionContext
|
||||||
{
|
{
|
||||||
HttpContext = contextMock.Object,
|
HttpContext = _contextMock.Object,
|
||||||
RouteData = routeDataMock.Object,
|
RouteData = routeDataMock.Object,
|
||||||
ActionDescriptor = actionDescriptor,
|
ActionDescriptor = actionDescriptor,
|
||||||
}, new List<IFilterMetadata>());
|
}, new List<IFilterMetadata>());
|
||||||
|
|||||||
@@ -16,20 +16,20 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
[System.Diagnostics.CodeAnalysis.ExcludeFromCodeCoverage]
|
[System.Diagnostics.CodeAnalysis.ExcludeFromCodeCoverage]
|
||||||
public class IPAllowListAttributeTests
|
public class IPAllowListAttributeTests
|
||||||
{
|
{
|
||||||
private Dictionary<string, string> requestHeaders;
|
private Dictionary<string, string> _requestHeaders;
|
||||||
private Dictionary<object, object> itemsCallback;
|
private Dictionary<object, object> _itemsCallback;
|
||||||
private string configKey;
|
private string _configKey;
|
||||||
private bool configExists;
|
private bool _configExists;
|
||||||
private List<string> allowedIpsConfig;
|
private List<string> _allowedIpsConfig;
|
||||||
|
|
||||||
[TestInitialize]
|
[TestInitialize]
|
||||||
public void InitializeTest()
|
public void InitializeTest()
|
||||||
{
|
{
|
||||||
requestHeaders = new Dictionary<string, string>();
|
_requestHeaders = [];
|
||||||
itemsCallback = new Dictionary<object, object>();
|
_itemsCallback = [];
|
||||||
configKey = null;
|
_configKey = null;
|
||||||
configExists = false;
|
_configExists = false;
|
||||||
allowedIpsConfig = new List<string>();
|
_allowedIpsConfig = [];
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
@@ -48,8 +48,8 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
Assert.IsTrue(context.Result is StatusCodeResult);
|
Assert.IsTrue(context.Result is StatusCodeResult);
|
||||||
Assert.AreEqual(403, ((StatusCodeResult)context.Result).StatusCode);
|
Assert.AreEqual(403, ((StatusCodeResult)context.Result).StatusCode);
|
||||||
|
|
||||||
Assert.AreEqual(1, itemsCallback.Count);
|
Assert.AreEqual(1, _itemsCallback.Count);
|
||||||
Assert.AreEqual(remote, itemsCallback["RemoteAddress"]);
|
Assert.AreEqual(remote, _itemsCallback["RemoteAddress"]);
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
@@ -71,8 +71,8 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
Assert.IsTrue(context.Result is StatusCodeResult);
|
Assert.IsTrue(context.Result is StatusCodeResult);
|
||||||
Assert.AreEqual(403, ((StatusCodeResult)context.Result).StatusCode);
|
Assert.AreEqual(403, ((StatusCodeResult)context.Result).StatusCode);
|
||||||
|
|
||||||
Assert.AreEqual(1, itemsCallback.Count);
|
Assert.AreEqual(1, _itemsCallback.Count);
|
||||||
Assert.AreEqual(remote, itemsCallback["RemoteAddress"]);
|
Assert.AreEqual(remote, _itemsCallback["RemoteAddress"]);
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
@@ -87,8 +87,8 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
|
|
||||||
// assert
|
// assert
|
||||||
Assert.IsNull(context.Result);
|
Assert.IsNull(context.Result);
|
||||||
Assert.AreEqual(1, itemsCallback.Count);
|
Assert.AreEqual(1, _itemsCallback.Count);
|
||||||
Assert.AreEqual(IPAddress.Loopback, itemsCallback["RemoteAddress"]);
|
Assert.AreEqual(IPAddress.Loopback, _itemsCallback["RemoteAddress"]);
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
@@ -109,8 +109,8 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
Assert.IsTrue(context.Result is StatusCodeResult);
|
Assert.IsTrue(context.Result is StatusCodeResult);
|
||||||
Assert.AreEqual(403, ((StatusCodeResult)context.Result).StatusCode);
|
Assert.AreEqual(403, ((StatusCodeResult)context.Result).StatusCode);
|
||||||
|
|
||||||
Assert.AreEqual(1, itemsCallback.Count);
|
Assert.AreEqual(1, _itemsCallback.Count);
|
||||||
Assert.AreEqual(IPAddress.Loopback, itemsCallback["RemoteAddress"]);
|
Assert.AreEqual(IPAddress.Loopback, _itemsCallback["RemoteAddress"]);
|
||||||
}
|
}
|
||||||
|
|
||||||
[DataTestMethod]
|
[DataTestMethod]
|
||||||
@@ -142,22 +142,22 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
Assert.AreEqual(403, ((StatusCodeResult)context.Result).StatusCode);
|
Assert.AreEqual(403, ((StatusCodeResult)context.Result).StatusCode);
|
||||||
}
|
}
|
||||||
|
|
||||||
Assert.AreEqual(1, itemsCallback.Count);
|
Assert.AreEqual(1, _itemsCallback.Count);
|
||||||
Assert.AreEqual(remote, itemsCallback["RemoteAddress"]);
|
Assert.AreEqual(remote, _itemsCallback["RemoteAddress"]);
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
public void ShouldAllowLocalAccessConfig()
|
public void ShouldAllowLocalAccessConfig()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
configKey = "White:List";
|
_configKey = "White:List";
|
||||||
configExists = true;
|
_configExists = true;
|
||||||
allowedIpsConfig.Add("127.0.0.0/8");
|
_allowedIpsConfig.Add("127.0.0.0/8");
|
||||||
allowedIpsConfig.Add("192.168.178.10");
|
_allowedIpsConfig.Add("192.168.178.10");
|
||||||
var attribute = new IPAllowListAttribute
|
var attribute = new IPAllowListAttribute
|
||||||
{
|
{
|
||||||
AllowLocalAccess = true,
|
AllowLocalAccess = true,
|
||||||
ConfigurationKey = configKey
|
ConfigurationKey = _configKey
|
||||||
};
|
};
|
||||||
var context = GetContext();
|
var context = GetContext();
|
||||||
|
|
||||||
@@ -166,22 +166,22 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
|
|
||||||
// assert
|
// assert
|
||||||
Assert.IsNull(context.Result);
|
Assert.IsNull(context.Result);
|
||||||
Assert.AreEqual(1, itemsCallback.Count);
|
Assert.AreEqual(1, _itemsCallback.Count);
|
||||||
Assert.AreEqual(IPAddress.Loopback, itemsCallback["RemoteAddress"]);
|
Assert.AreEqual(IPAddress.Loopback, _itemsCallback["RemoteAddress"]);
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
public void ShouldDenyLocalAccessConfig()
|
public void ShouldDenyLocalAccessConfig()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
configKey = "White:List";
|
_configKey = "White:List";
|
||||||
configExists = true;
|
_configExists = true;
|
||||||
allowedIpsConfig.Add("");
|
_allowedIpsConfig.Add("");
|
||||||
allowedIpsConfig.Add("192.168.178.10");
|
_allowedIpsConfig.Add("192.168.178.10");
|
||||||
var attribute = new IPAllowListAttribute
|
var attribute = new IPAllowListAttribute
|
||||||
{
|
{
|
||||||
AllowLocalAccess = false,
|
AllowLocalAccess = false,
|
||||||
ConfigurationKey = configKey
|
ConfigurationKey = _configKey
|
||||||
};
|
};
|
||||||
var context = GetContext();
|
var context = GetContext();
|
||||||
|
|
||||||
@@ -193,8 +193,8 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
Assert.IsTrue(context.Result is StatusCodeResult);
|
Assert.IsTrue(context.Result is StatusCodeResult);
|
||||||
Assert.AreEqual(403, ((StatusCodeResult)context.Result).StatusCode);
|
Assert.AreEqual(403, ((StatusCodeResult)context.Result).StatusCode);
|
||||||
|
|
||||||
Assert.AreEqual(1, itemsCallback.Count);
|
Assert.AreEqual(1, _itemsCallback.Count);
|
||||||
Assert.AreEqual(IPAddress.Loopback, itemsCallback["RemoteAddress"]);
|
Assert.AreEqual(IPAddress.Loopback, _itemsCallback["RemoteAddress"]);
|
||||||
}
|
}
|
||||||
|
|
||||||
[DataTestMethod]
|
[DataTestMethod]
|
||||||
@@ -203,13 +203,13 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
public void ShouldAllowSpecificAddressConfig(string address)
|
public void ShouldAllowSpecificAddressConfig(string address)
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
configKey = "White:List";
|
_configKey = "White:List";
|
||||||
configExists = true;
|
_configExists = true;
|
||||||
allowedIpsConfig.Add("192.168.178.10");
|
_allowedIpsConfig.Add("192.168.178.10");
|
||||||
var attribute = new IPAllowListAttribute
|
var attribute = new IPAllowListAttribute
|
||||||
{
|
{
|
||||||
AllowLocalAccess = false,
|
AllowLocalAccess = false,
|
||||||
ConfigurationKey = configKey
|
ConfigurationKey = _configKey
|
||||||
};
|
};
|
||||||
var remote = IPAddress.Parse(address);
|
var remote = IPAddress.Parse(address);
|
||||||
var context = GetContext(remote);
|
var context = GetContext(remote);
|
||||||
@@ -229,20 +229,20 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
Assert.AreEqual(403, ((StatusCodeResult)context.Result).StatusCode);
|
Assert.AreEqual(403, ((StatusCodeResult)context.Result).StatusCode);
|
||||||
}
|
}
|
||||||
|
|
||||||
Assert.AreEqual(1, itemsCallback.Count);
|
Assert.AreEqual(1, _itemsCallback.Count);
|
||||||
Assert.AreEqual(remote, itemsCallback["RemoteAddress"]);
|
Assert.AreEqual(remote, _itemsCallback["RemoteAddress"]);
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
public void ShouldDenyOnMissingConfiguration()
|
public void ShouldDenyOnMissingConfiguration()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
configKey = "White:List";
|
_configKey = "White:List";
|
||||||
configExists = false;
|
_configExists = false;
|
||||||
var attribute = new IPAllowListAttribute
|
var attribute = new IPAllowListAttribute
|
||||||
{
|
{
|
||||||
AllowLocalAccess = false,
|
AllowLocalAccess = false,
|
||||||
ConfigurationKey = configKey
|
ConfigurationKey = _configKey
|
||||||
};
|
};
|
||||||
var context = GetContext();
|
var context = GetContext();
|
||||||
|
|
||||||
@@ -254,14 +254,14 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
Assert.IsTrue(context.Result is StatusCodeResult);
|
Assert.IsTrue(context.Result is StatusCodeResult);
|
||||||
Assert.AreEqual(403, ((StatusCodeResult)context.Result).StatusCode);
|
Assert.AreEqual(403, ((StatusCodeResult)context.Result).StatusCode);
|
||||||
|
|
||||||
Assert.AreEqual(1, itemsCallback.Count);
|
Assert.AreEqual(1, _itemsCallback.Count);
|
||||||
Assert.AreEqual(IPAddress.Loopback, itemsCallback["RemoteAddress"]);
|
Assert.AreEqual(IPAddress.Loopback, _itemsCallback["RemoteAddress"]);
|
||||||
}
|
}
|
||||||
|
|
||||||
private ActionExecutingContext GetContext(IPAddress remote = null)
|
private ActionExecutingContext GetContext(IPAddress remote = null)
|
||||||
{
|
{
|
||||||
var requestHeaderMock = new Mock<IHeaderDictionary>();
|
var requestHeaderMock = new Mock<IHeaderDictionary>();
|
||||||
foreach (var header in requestHeaders)
|
foreach (var header in _requestHeaders)
|
||||||
{
|
{
|
||||||
requestHeaderMock
|
requestHeaderMock
|
||||||
.Setup(h => h.ContainsKey(header.Key))
|
.Setup(h => h.ContainsKey(header.Key))
|
||||||
@@ -287,11 +287,11 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
var itemsMock = new Mock<IDictionary<object, object>>();
|
var itemsMock = new Mock<IDictionary<object, object>>();
|
||||||
itemsMock
|
itemsMock
|
||||||
.SetupSet(i => i[It.IsAny<object>()] = It.IsAny<object>())
|
.SetupSet(i => i[It.IsAny<object>()] = It.IsAny<object>())
|
||||||
.Callback<object, object>((key, val) => itemsCallback.Add(key, val));
|
.Callback<object, object>((key, val) => _itemsCallback.Add(key, val));
|
||||||
|
|
||||||
var configurationMock = new Mock<IConfiguration>();
|
var configurationMock = new Mock<IConfiguration>();
|
||||||
var children = new List<IConfigurationSection>();
|
var children = new List<IConfigurationSection>();
|
||||||
foreach (string ipAddress in allowedIpsConfig)
|
foreach (string ipAddress in _allowedIpsConfig)
|
||||||
{
|
{
|
||||||
var csm = new Mock<IConfigurationSection>();
|
var csm = new Mock<IConfigurationSection>();
|
||||||
csm.Setup(cs => cs.Value).Returns(ipAddress);
|
csm.Setup(cs => cs.Value).Returns(ipAddress);
|
||||||
@@ -305,8 +305,8 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
.Returns(children);
|
.Returns(children);
|
||||||
|
|
||||||
configurationMock
|
configurationMock
|
||||||
.Setup(c => c.GetSection(configKey))
|
.Setup(c => c.GetSection(_configKey))
|
||||||
.Returns(configExists ? configSectionMock.Object : null);
|
.Returns(_configExists ? configSectionMock.Object : null);
|
||||||
|
|
||||||
var requestServicesMock = new Mock<IServiceProvider>();
|
var requestServicesMock = new Mock<IServiceProvider>();
|
||||||
requestServicesMock
|
requestServicesMock
|
||||||
|
|||||||
@@ -16,20 +16,20 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
[System.Diagnostics.CodeAnalysis.ExcludeFromCodeCoverage]
|
[System.Diagnostics.CodeAnalysis.ExcludeFromCodeCoverage]
|
||||||
public class IPBlockListAttributeTests
|
public class IPBlockListAttributeTests
|
||||||
{
|
{
|
||||||
private Dictionary<string, string> requestHeaders;
|
private Dictionary<string, string> _requestHeaders;
|
||||||
private Dictionary<object, object> itemsCallback;
|
private Dictionary<object, object> _itemsCallback;
|
||||||
private string configKey;
|
private string _configKey;
|
||||||
private bool configExists;
|
private bool _configExists;
|
||||||
private List<string> restrictedIpsConfig;
|
private List<string> _restrictedIpsConfig;
|
||||||
|
|
||||||
[TestInitialize]
|
[TestInitialize]
|
||||||
public void InitializeTest()
|
public void InitializeTest()
|
||||||
{
|
{
|
||||||
requestHeaders = new Dictionary<string, string>();
|
_requestHeaders = [];
|
||||||
itemsCallback = new Dictionary<object, object>();
|
_itemsCallback = [];
|
||||||
configKey = null;
|
_configKey = null;
|
||||||
configExists = false;
|
_configExists = false;
|
||||||
restrictedIpsConfig = new List<string>();
|
_restrictedIpsConfig = [];
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
@@ -45,8 +45,8 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
|
|
||||||
// assert
|
// assert
|
||||||
Assert.IsNull(context.Result);
|
Assert.IsNull(context.Result);
|
||||||
Assert.AreEqual(1, itemsCallback.Count);
|
Assert.AreEqual(1, _itemsCallback.Count);
|
||||||
Assert.AreEqual(remote, itemsCallback["RemoteAddress"]);
|
Assert.AreEqual(remote, _itemsCallback["RemoteAddress"]);
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
@@ -65,8 +65,8 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
|
|
||||||
// assert
|
// assert
|
||||||
Assert.IsNull(context.Result);
|
Assert.IsNull(context.Result);
|
||||||
Assert.AreEqual(1, itemsCallback.Count);
|
Assert.AreEqual(1, _itemsCallback.Count);
|
||||||
Assert.AreEqual(remote, itemsCallback["RemoteAddress"]);
|
Assert.AreEqual(remote, _itemsCallback["RemoteAddress"]);
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
@@ -85,8 +85,8 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
|
|
||||||
// assert
|
// assert
|
||||||
Assert.IsNull(context.Result);
|
Assert.IsNull(context.Result);
|
||||||
Assert.AreEqual(1, itemsCallback.Count);
|
Assert.AreEqual(1, _itemsCallback.Count);
|
||||||
Assert.AreEqual(IPAddress.Loopback, itemsCallback["RemoteAddress"]);
|
Assert.AreEqual(IPAddress.Loopback, _itemsCallback["RemoteAddress"]);
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
@@ -108,8 +108,8 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
Assert.IsTrue(context.Result is StatusCodeResult);
|
Assert.IsTrue(context.Result is StatusCodeResult);
|
||||||
Assert.AreEqual(403, ((StatusCodeResult)context.Result).StatusCode);
|
Assert.AreEqual(403, ((StatusCodeResult)context.Result).StatusCode);
|
||||||
|
|
||||||
Assert.AreEqual(1, itemsCallback.Count);
|
Assert.AreEqual(1, _itemsCallback.Count);
|
||||||
Assert.AreEqual(IPAddress.Loopback, itemsCallback["RemoteAddress"]);
|
Assert.AreEqual(IPAddress.Loopback, _itemsCallback["RemoteAddress"]);
|
||||||
}
|
}
|
||||||
|
|
||||||
[DataTestMethod]
|
[DataTestMethod]
|
||||||
@@ -141,22 +141,22 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
Assert.IsNull(context.Result);
|
Assert.IsNull(context.Result);
|
||||||
}
|
}
|
||||||
|
|
||||||
Assert.AreEqual(1, itemsCallback.Count);
|
Assert.AreEqual(1, _itemsCallback.Count);
|
||||||
Assert.AreEqual(remote, itemsCallback["RemoteAddress"]);
|
Assert.AreEqual(remote, _itemsCallback["RemoteAddress"]);
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
public void ShouldAllowLocalAccessConfig()
|
public void ShouldAllowLocalAccessConfig()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
configKey = "Black:List";
|
_configKey = "Black:List";
|
||||||
configExists = true;
|
_configExists = true;
|
||||||
restrictedIpsConfig.Add("127.0.0.0/8");
|
_restrictedIpsConfig.Add("127.0.0.0/8");
|
||||||
restrictedIpsConfig.Add("192.168.178.10");
|
_restrictedIpsConfig.Add("192.168.178.10");
|
||||||
var attribute = new IPBlockListAttribute
|
var attribute = new IPBlockListAttribute
|
||||||
{
|
{
|
||||||
BlockLocalAccess = false,
|
BlockLocalAccess = false,
|
||||||
ConfigurationKey = configKey
|
ConfigurationKey = _configKey
|
||||||
};
|
};
|
||||||
var context = GetContext();
|
var context = GetContext();
|
||||||
|
|
||||||
@@ -165,23 +165,23 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
|
|
||||||
// assert
|
// assert
|
||||||
Assert.IsNull(context.Result);
|
Assert.IsNull(context.Result);
|
||||||
Assert.AreEqual(1, itemsCallback.Count);
|
Assert.AreEqual(1, _itemsCallback.Count);
|
||||||
Assert.AreEqual(IPAddress.Loopback, itemsCallback["RemoteAddress"]);
|
Assert.AreEqual(IPAddress.Loopback, _itemsCallback["RemoteAddress"]);
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
public void ShouldBlockLocalAccessConfig()
|
public void ShouldBlockLocalAccessConfig()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
configKey = "Black:List";
|
_configKey = "Black:List";
|
||||||
configExists = true;
|
_configExists = true;
|
||||||
restrictedIpsConfig.Add("");
|
_restrictedIpsConfig.Add("");
|
||||||
restrictedIpsConfig.Add("127.0.0.0/8");
|
_restrictedIpsConfig.Add("127.0.0.0/8");
|
||||||
restrictedIpsConfig.Add("192.168.178.10");
|
_restrictedIpsConfig.Add("192.168.178.10");
|
||||||
var attribute = new IPBlockListAttribute
|
var attribute = new IPBlockListAttribute
|
||||||
{
|
{
|
||||||
BlockLocalAccess = true,
|
BlockLocalAccess = true,
|
||||||
ConfigurationKey = configKey
|
ConfigurationKey = _configKey
|
||||||
};
|
};
|
||||||
var context = GetContext();
|
var context = GetContext();
|
||||||
|
|
||||||
@@ -193,8 +193,8 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
Assert.IsTrue(context.Result is StatusCodeResult);
|
Assert.IsTrue(context.Result is StatusCodeResult);
|
||||||
Assert.AreEqual(403, ((StatusCodeResult)context.Result).StatusCode);
|
Assert.AreEqual(403, ((StatusCodeResult)context.Result).StatusCode);
|
||||||
|
|
||||||
Assert.AreEqual(1, itemsCallback.Count);
|
Assert.AreEqual(1, _itemsCallback.Count);
|
||||||
Assert.AreEqual(IPAddress.Loopback, itemsCallback["RemoteAddress"]);
|
Assert.AreEqual(IPAddress.Loopback, _itemsCallback["RemoteAddress"]);
|
||||||
}
|
}
|
||||||
|
|
||||||
[DataTestMethod]
|
[DataTestMethod]
|
||||||
@@ -203,14 +203,14 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
public void ShouldBlockSpecificAddressConfig(string address)
|
public void ShouldBlockSpecificAddressConfig(string address)
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
configKey = "Black:List";
|
_configKey = "Black:List";
|
||||||
configExists = true;
|
_configExists = true;
|
||||||
restrictedIpsConfig.Add("127.0.0.0/8");
|
_restrictedIpsConfig.Add("127.0.0.0/8");
|
||||||
restrictedIpsConfig.Add("192.168.178.10");
|
_restrictedIpsConfig.Add("192.168.178.10");
|
||||||
var attribute = new IPBlockListAttribute
|
var attribute = new IPBlockListAttribute
|
||||||
{
|
{
|
||||||
BlockLocalAccess = true,
|
BlockLocalAccess = true,
|
||||||
ConfigurationKey = configKey
|
ConfigurationKey = _configKey
|
||||||
};
|
};
|
||||||
var remote = IPAddress.Parse(address);
|
var remote = IPAddress.Parse(address);
|
||||||
var context = GetContext(remote);
|
var context = GetContext(remote);
|
||||||
@@ -230,20 +230,20 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
Assert.IsNull(context.Result);
|
Assert.IsNull(context.Result);
|
||||||
}
|
}
|
||||||
|
|
||||||
Assert.AreEqual(1, itemsCallback.Count);
|
Assert.AreEqual(1, _itemsCallback.Count);
|
||||||
Assert.AreEqual(remote, itemsCallback["RemoteAddress"]);
|
Assert.AreEqual(remote, _itemsCallback["RemoteAddress"]);
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
public void ShouldAllowOnMissingConfiguration()
|
public void ShouldAllowOnMissingConfiguration()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
configKey = "Black:List";
|
_configKey = "Black:List";
|
||||||
configExists = false;
|
_configExists = false;
|
||||||
var attribute = new IPBlockListAttribute
|
var attribute = new IPBlockListAttribute
|
||||||
{
|
{
|
||||||
BlockLocalAccess = true,
|
BlockLocalAccess = true,
|
||||||
ConfigurationKey = configKey
|
ConfigurationKey = _configKey
|
||||||
};
|
};
|
||||||
var context = GetContext();
|
var context = GetContext();
|
||||||
|
|
||||||
@@ -253,14 +253,14 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
// assert
|
// assert
|
||||||
Assert.IsNull(context.Result);
|
Assert.IsNull(context.Result);
|
||||||
|
|
||||||
Assert.AreEqual(1, itemsCallback.Count);
|
Assert.AreEqual(1, _itemsCallback.Count);
|
||||||
Assert.AreEqual(IPAddress.Loopback, itemsCallback["RemoteAddress"]);
|
Assert.AreEqual(IPAddress.Loopback, _itemsCallback["RemoteAddress"]);
|
||||||
}
|
}
|
||||||
|
|
||||||
private ActionExecutingContext GetContext(IPAddress remote = null)
|
private ActionExecutingContext GetContext(IPAddress remote = null)
|
||||||
{
|
{
|
||||||
var requestHeaderMock = new Mock<IHeaderDictionary>();
|
var requestHeaderMock = new Mock<IHeaderDictionary>();
|
||||||
foreach (var header in requestHeaders)
|
foreach (var header in _requestHeaders)
|
||||||
{
|
{
|
||||||
requestHeaderMock
|
requestHeaderMock
|
||||||
.Setup(h => h.ContainsKey(header.Key))
|
.Setup(h => h.ContainsKey(header.Key))
|
||||||
@@ -286,11 +286,11 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
var itemsMock = new Mock<IDictionary<object, object>>();
|
var itemsMock = new Mock<IDictionary<object, object>>();
|
||||||
itemsMock
|
itemsMock
|
||||||
.SetupSet(i => i[It.IsAny<object>()] = It.IsAny<object>())
|
.SetupSet(i => i[It.IsAny<object>()] = It.IsAny<object>())
|
||||||
.Callback<object, object>((key, val) => itemsCallback.Add(key, val));
|
.Callback<object, object>((key, val) => _itemsCallback.Add(key, val));
|
||||||
|
|
||||||
var configurationMock = new Mock<IConfiguration>();
|
var configurationMock = new Mock<IConfiguration>();
|
||||||
var children = new List<IConfigurationSection>();
|
var children = new List<IConfigurationSection>();
|
||||||
foreach (string ipAddress in restrictedIpsConfig)
|
foreach (string ipAddress in _restrictedIpsConfig)
|
||||||
{
|
{
|
||||||
var csm = new Mock<IConfigurationSection>();
|
var csm = new Mock<IConfigurationSection>();
|
||||||
csm.Setup(cs => cs.Value).Returns(ipAddress);
|
csm.Setup(cs => cs.Value).Returns(ipAddress);
|
||||||
@@ -304,8 +304,8 @@ namespace UnitTests.AspNetCore.Attributes
|
|||||||
.Returns(children);
|
.Returns(children);
|
||||||
|
|
||||||
configurationMock
|
configurationMock
|
||||||
.Setup(c => c.GetSection(configKey))
|
.Setup(c => c.GetSection(_configKey))
|
||||||
.Returns(configExists ? configSectionMock.Object : null);
|
.Returns(_configExists ? configSectionMock.Object : null);
|
||||||
|
|
||||||
var requestServicesMock = new Mock<IServiceProvider>();
|
var requestServicesMock = new Mock<IServiceProvider>();
|
||||||
requestServicesMock
|
requestServicesMock
|
||||||
|
|||||||
@@ -12,30 +12,30 @@ namespace UnitTests.AspNetCore.Extensions
|
|||||||
[System.Diagnostics.CodeAnalysis.ExcludeFromCodeCoverage]
|
[System.Diagnostics.CodeAnalysis.ExcludeFromCodeCoverage]
|
||||||
public class HttpContextExtensionsTests
|
public class HttpContextExtensionsTests
|
||||||
{
|
{
|
||||||
private Mock<ISession> sessionMock;
|
private Mock<ISession> _sessionMock;
|
||||||
|
|
||||||
private string tokenFormName;
|
private string _tokenFormName;
|
||||||
private string tokenHeaderName;
|
private string _tokenHeaderName;
|
||||||
private string tokenValue;
|
private string _tokenValue;
|
||||||
|
|
||||||
private Dictionary<string, string> requestHeaders;
|
private Dictionary<string, string> _requestHeaders;
|
||||||
private Dictionary<string, string> requestQueries;
|
private Dictionary<string, string> _requestQueries;
|
||||||
private Dictionary<object, object> items;
|
private Dictionary<object, object> _items;
|
||||||
|
|
||||||
private IPAddress remote;
|
private IPAddress _remote;
|
||||||
|
|
||||||
[TestInitialize]
|
[TestInitialize]
|
||||||
public void InitializeTests()
|
public void InitializeTests()
|
||||||
{
|
{
|
||||||
tokenFormName = null;
|
_tokenFormName = null;
|
||||||
tokenHeaderName = null;
|
_tokenHeaderName = null;
|
||||||
tokenValue = null;
|
_tokenValue = null;
|
||||||
|
|
||||||
requestHeaders = new Dictionary<string, string>();
|
_requestHeaders = [];
|
||||||
requestQueries = new Dictionary<string, string>();
|
_requestQueries = [];
|
||||||
items = new Dictionary<object, object>();
|
_items = [];
|
||||||
|
|
||||||
remote = IPAddress.Loopback;
|
_remote = IPAddress.Loopback;
|
||||||
}
|
}
|
||||||
|
|
||||||
#region Antiforgery
|
#region Antiforgery
|
||||||
@@ -44,9 +44,9 @@ namespace UnitTests.AspNetCore.Extensions
|
|||||||
public void ShouldReturnAntiforgery()
|
public void ShouldReturnAntiforgery()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
tokenFormName = "af-token";
|
_tokenFormName = "af-token";
|
||||||
tokenHeaderName = "af-header";
|
_tokenHeaderName = "af-header";
|
||||||
tokenValue = "security_first";
|
_tokenValue = "security_first";
|
||||||
|
|
||||||
var context = GetContext();
|
var context = GetContext();
|
||||||
|
|
||||||
@@ -54,18 +54,18 @@ namespace UnitTests.AspNetCore.Extensions
|
|||||||
var (formName, headerName, value) = context.GetAntiforgeryToken();
|
var (formName, headerName, value) = context.GetAntiforgeryToken();
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
Assert.AreEqual(tokenFormName, formName);
|
Assert.AreEqual(_tokenFormName, formName);
|
||||||
Assert.AreEqual(tokenHeaderName, headerName);
|
Assert.AreEqual(_tokenHeaderName, headerName);
|
||||||
Assert.AreEqual(tokenValue, value);
|
Assert.AreEqual(_tokenValue, value);
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
public void ShouldReturnAntiforgeryNullService()
|
public void ShouldReturnAntiforgeryNullService()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
tokenFormName = "af-token";
|
_tokenFormName = "af-token";
|
||||||
tokenHeaderName = "af-header";
|
_tokenHeaderName = "af-header";
|
||||||
tokenValue = "security_first";
|
_tokenValue = "security_first";
|
||||||
|
|
||||||
var context = GetContext(hasAntiforgery: false);
|
var context = GetContext(hasAntiforgery: false);
|
||||||
|
|
||||||
@@ -101,7 +101,7 @@ namespace UnitTests.AspNetCore.Extensions
|
|||||||
public void ShouldReturnRemoteAddress()
|
public void ShouldReturnRemoteAddress()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
remote = IPAddress.Parse("1.2.3.4");
|
_remote = IPAddress.Parse("1.2.3.4");
|
||||||
|
|
||||||
var context = GetContext();
|
var context = GetContext();
|
||||||
|
|
||||||
@@ -109,7 +109,7 @@ namespace UnitTests.AspNetCore.Extensions
|
|||||||
var result = context.GetRemoteIpAddress();
|
var result = context.GetRemoteIpAddress();
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
Assert.AreEqual(remote, result);
|
Assert.AreEqual(_remote, result);
|
||||||
}
|
}
|
||||||
|
|
||||||
[DataTestMethod]
|
[DataTestMethod]
|
||||||
@@ -119,9 +119,9 @@ namespace UnitTests.AspNetCore.Extensions
|
|||||||
public void ShouldReturnDefaultHeader(string headerName)
|
public void ShouldReturnDefaultHeader(string headerName)
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
remote = IPAddress.Parse("1.2.3.4");
|
_remote = IPAddress.Parse("1.2.3.4");
|
||||||
var header = IPAddress.Parse("5.6.7.8");
|
var header = IPAddress.Parse("5.6.7.8");
|
||||||
requestHeaders.Add(headerName, header.ToString());
|
_requestHeaders.Add(headerName, header.ToString());
|
||||||
|
|
||||||
var context = GetContext();
|
var context = GetContext();
|
||||||
|
|
||||||
@@ -129,7 +129,7 @@ namespace UnitTests.AspNetCore.Extensions
|
|||||||
var result = context.GetRemoteIpAddress();
|
var result = context.GetRemoteIpAddress();
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
Assert.AreNotEqual(remote, result);
|
Assert.AreNotEqual(_remote, result);
|
||||||
Assert.AreEqual(header, result);
|
Assert.AreEqual(header, result);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -137,12 +137,12 @@ namespace UnitTests.AspNetCore.Extensions
|
|||||||
public void ShouldReturnCustomHeader()
|
public void ShouldReturnCustomHeader()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
remote = IPAddress.Parse("1.2.3.4");
|
_remote = IPAddress.Parse("1.2.3.4");
|
||||||
string headerName = "FooBar";
|
string headerName = "FooBar";
|
||||||
var headerIp = IPAddress.Parse("5.6.7.8");
|
var headerIp = IPAddress.Parse("5.6.7.8");
|
||||||
|
|
||||||
requestHeaders.Add(headerName, headerIp.ToString());
|
_requestHeaders.Add(headerName, headerIp.ToString());
|
||||||
requestHeaders.Add("X-Forwarded-For", remote.ToString());
|
_requestHeaders.Add("X-Forwarded-For", _remote.ToString());
|
||||||
|
|
||||||
var context = GetContext();
|
var context = GetContext();
|
||||||
|
|
||||||
@@ -150,7 +150,7 @@ namespace UnitTests.AspNetCore.Extensions
|
|||||||
var result = context.GetRemoteIpAddress(ipHeaderName: headerName);
|
var result = context.GetRemoteIpAddress(ipHeaderName: headerName);
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
Assert.AreNotEqual(remote, result);
|
Assert.AreNotEqual(_remote, result);
|
||||||
Assert.AreEqual(headerIp, result);
|
Assert.AreEqual(headerIp, result);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -158,8 +158,8 @@ namespace UnitTests.AspNetCore.Extensions
|
|||||||
public void ShouldReturnAddressInvalidHeader()
|
public void ShouldReturnAddressInvalidHeader()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
remote = IPAddress.Parse("1.2.3.4");
|
_remote = IPAddress.Parse("1.2.3.4");
|
||||||
requestHeaders.Add("X-Forwarded-For", "1.2.3:4");
|
_requestHeaders.Add("X-Forwarded-For", "1.2.3:4");
|
||||||
|
|
||||||
var context = GetContext();
|
var context = GetContext();
|
||||||
|
|
||||||
@@ -167,16 +167,16 @@ namespace UnitTests.AspNetCore.Extensions
|
|||||||
var result = context.GetRemoteIpAddress();
|
var result = context.GetRemoteIpAddress();
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
Assert.AreEqual(remote, result);
|
Assert.AreEqual(_remote, result);
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
public void ShouldReturnFirstAddressOnMultipleProxies()
|
public void ShouldReturnFirstAddressOnMultipleProxies()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
remote = IPAddress.Parse("1.2.3.4");
|
_remote = IPAddress.Parse("1.2.3.4");
|
||||||
var header = IPAddress.Parse("5.6.7.8");
|
var header = IPAddress.Parse("5.6.7.8");
|
||||||
requestHeaders.Add("X-Forwarded-For", $"{header}, 111.222.111.222");
|
_requestHeaders.Add("X-Forwarded-For", $"{header}, 111.222.111.222");
|
||||||
|
|
||||||
var context = GetContext();
|
var context = GetContext();
|
||||||
|
|
||||||
@@ -184,7 +184,7 @@ namespace UnitTests.AspNetCore.Extensions
|
|||||||
var result = context.GetRemoteIpAddress();
|
var result = context.GetRemoteIpAddress();
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
Assert.AreNotEqual(remote, result);
|
Assert.AreNotEqual(_remote, result);
|
||||||
Assert.AreEqual(header, result);
|
Assert.AreEqual(header, result);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -192,9 +192,9 @@ namespace UnitTests.AspNetCore.Extensions
|
|||||||
public void ShouldReturnV4AddressOnMapped()
|
public void ShouldReturnV4AddressOnMapped()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
remote = IPAddress.Parse("1.2.3.4");
|
_remote = IPAddress.Parse("1.2.3.4");
|
||||||
var header = IPAddress.Parse("::ffff:127.0.0.1");
|
var header = IPAddress.Parse("::ffff:127.0.0.1");
|
||||||
requestHeaders.Add("X-Forwarded-For", "::ffff:127.0.0.1");
|
_requestHeaders.Add("X-Forwarded-For", "::ffff:127.0.0.1");
|
||||||
|
|
||||||
var context = GetContext();
|
var context = GetContext();
|
||||||
|
|
||||||
@@ -202,7 +202,7 @@ namespace UnitTests.AspNetCore.Extensions
|
|||||||
var result = context.GetRemoteIpAddress();
|
var result = context.GetRemoteIpAddress();
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
Assert.AreNotEqual(remote, result);
|
Assert.AreNotEqual(_remote, result);
|
||||||
Assert.AreNotEqual(header, result);
|
Assert.AreNotEqual(header, result);
|
||||||
Assert.AreEqual(header.MapToIPv4(), result);
|
Assert.AreEqual(header.MapToIPv4(), result);
|
||||||
}
|
}
|
||||||
@@ -215,7 +215,7 @@ namespace UnitTests.AspNetCore.Extensions
|
|||||||
public void ShouldReturnTrueOnLocal()
|
public void ShouldReturnTrueOnLocal()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
remote = IPAddress.Loopback;
|
_remote = IPAddress.Loopback;
|
||||||
|
|
||||||
var context = GetContext();
|
var context = GetContext();
|
||||||
|
|
||||||
@@ -230,7 +230,7 @@ namespace UnitTests.AspNetCore.Extensions
|
|||||||
public void ShouldReturnFalseOnRemote()
|
public void ShouldReturnFalseOnRemote()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
remote = IPAddress.Parse("1.2.3.4");
|
_remote = IPAddress.Parse("1.2.3.4");
|
||||||
|
|
||||||
var context = GetContext();
|
var context = GetContext();
|
||||||
|
|
||||||
@@ -245,9 +245,9 @@ namespace UnitTests.AspNetCore.Extensions
|
|||||||
public void ShouldReturnTrueOnDefaultHeader()
|
public void ShouldReturnTrueOnDefaultHeader()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
remote = IPAddress.Parse("1.2.3.4");
|
_remote = IPAddress.Parse("1.2.3.4");
|
||||||
var headerIp = IPAddress.Loopback;
|
var headerIp = IPAddress.Loopback;
|
||||||
requestHeaders.Add("X-Forwarded-For", headerIp.ToString());
|
_requestHeaders.Add("X-Forwarded-For", headerIp.ToString());
|
||||||
|
|
||||||
var context = GetContext();
|
var context = GetContext();
|
||||||
|
|
||||||
@@ -262,10 +262,10 @@ namespace UnitTests.AspNetCore.Extensions
|
|||||||
public void ShouldReturnTrueOnCustomHeader()
|
public void ShouldReturnTrueOnCustomHeader()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
remote = IPAddress.Parse("1.2.3.4");
|
_remote = IPAddress.Parse("1.2.3.4");
|
||||||
string headerName = "FooBar";
|
string headerName = "FooBar";
|
||||||
var headerIp = IPAddress.Loopback;
|
var headerIp = IPAddress.Loopback;
|
||||||
requestHeaders.Add(headerName, headerIp.ToString());
|
_requestHeaders.Add(headerName, headerIp.ToString());
|
||||||
|
|
||||||
var context = GetContext();
|
var context = GetContext();
|
||||||
|
|
||||||
@@ -281,7 +281,7 @@ namespace UnitTests.AspNetCore.Extensions
|
|||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
var headerIp = IPAddress.Parse("1.2.3.4");
|
var headerIp = IPAddress.Parse("1.2.3.4");
|
||||||
requestHeaders.Add("X-Forwarded-For", headerIp.ToString());
|
_requestHeaders.Add("X-Forwarded-For", headerIp.ToString());
|
||||||
|
|
||||||
var context = GetContext();
|
var context = GetContext();
|
||||||
|
|
||||||
@@ -298,7 +298,7 @@ namespace UnitTests.AspNetCore.Extensions
|
|||||||
// arrange
|
// arrange
|
||||||
string headerName = "FooBar";
|
string headerName = "FooBar";
|
||||||
var headerIp = IPAddress.Parse("1.2.3.4");
|
var headerIp = IPAddress.Parse("1.2.3.4");
|
||||||
requestHeaders.Add(headerName, headerIp.ToString());
|
_requestHeaders.Add(headerName, headerIp.ToString());
|
||||||
|
|
||||||
var context = GetContext();
|
var context = GetContext();
|
||||||
|
|
||||||
@@ -333,8 +333,8 @@ namespace UnitTests.AspNetCore.Extensions
|
|||||||
string request = "abc";
|
string request = "abc";
|
||||||
string query = "def";
|
string query = "def";
|
||||||
|
|
||||||
items.Add("OriginalRequest", request);
|
_items.Add("OriginalRequest", request);
|
||||||
requestQueries.Add("ReturnUrl", query);
|
_requestQueries.Add("ReturnUrl", query);
|
||||||
|
|
||||||
var context = GetContext();
|
var context = GetContext();
|
||||||
|
|
||||||
@@ -351,7 +351,7 @@ namespace UnitTests.AspNetCore.Extensions
|
|||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
string query = "def";
|
string query = "def";
|
||||||
requestQueries.Add("ReturnUrl", query);
|
_requestQueries.Add("ReturnUrl", query);
|
||||||
|
|
||||||
var context = GetContext();
|
var context = GetContext();
|
||||||
|
|
||||||
@@ -376,7 +376,7 @@ namespace UnitTests.AspNetCore.Extensions
|
|||||||
context.ClearSession();
|
context.ClearSession();
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
sessionMock.Verify(s => s.Clear(), Times.Once);
|
_sessionMock.Verify(s => s.Clear(), Times.Once);
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
@@ -389,7 +389,7 @@ namespace UnitTests.AspNetCore.Extensions
|
|||||||
context.ClearSession();
|
context.ClearSession();
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
sessionMock.Verify(s => s.Clear(), Times.Never);
|
_sessionMock.Verify(s => s.Clear(), Times.Never);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion Session
|
#endregion Session
|
||||||
@@ -398,7 +398,7 @@ namespace UnitTests.AspNetCore.Extensions
|
|||||||
{
|
{
|
||||||
// Request
|
// Request
|
||||||
var requestHeaderMock = new Mock<IHeaderDictionary>();
|
var requestHeaderMock = new Mock<IHeaderDictionary>();
|
||||||
foreach (var header in requestHeaders)
|
foreach (var header in _requestHeaders)
|
||||||
{
|
{
|
||||||
requestHeaderMock
|
requestHeaderMock
|
||||||
.Setup(h => h.ContainsKey(header.Key))
|
.Setup(h => h.ContainsKey(header.Key))
|
||||||
@@ -409,7 +409,7 @@ namespace UnitTests.AspNetCore.Extensions
|
|||||||
}
|
}
|
||||||
|
|
||||||
var requestQueryMock = new Mock<IQueryCollection>();
|
var requestQueryMock = new Mock<IQueryCollection>();
|
||||||
foreach (var query in requestQueries)
|
foreach (var query in _requestQueries)
|
||||||
{
|
{
|
||||||
requestQueryMock
|
requestQueryMock
|
||||||
.Setup(h => h.ContainsKey(query.Key))
|
.Setup(h => h.ContainsKey(query.Key))
|
||||||
@@ -434,7 +434,7 @@ namespace UnitTests.AspNetCore.Extensions
|
|||||||
var antiforgeryMock = new Mock<IAntiforgery>();
|
var antiforgeryMock = new Mock<IAntiforgery>();
|
||||||
antiforgeryMock
|
antiforgeryMock
|
||||||
.Setup(af => af.GetAndStoreTokens(It.IsAny<HttpContext>()))
|
.Setup(af => af.GetAndStoreTokens(It.IsAny<HttpContext>()))
|
||||||
.Returns(() => string.IsNullOrWhiteSpace(tokenValue) ? null : new AntiforgeryTokenSet(tokenValue, tokenValue, tokenFormName, tokenHeaderName));
|
.Returns(() => string.IsNullOrWhiteSpace(_tokenValue) ? null : new AntiforgeryTokenSet(_tokenValue, _tokenValue, _tokenFormName, _tokenHeaderName));
|
||||||
|
|
||||||
requestServicesMock
|
requestServicesMock
|
||||||
.Setup(rs => rs.GetService(typeof(IAntiforgery)))
|
.Setup(rs => rs.GetService(typeof(IAntiforgery)))
|
||||||
@@ -448,10 +448,10 @@ namespace UnitTests.AspNetCore.Extensions
|
|||||||
.Returns(IPAddress.Loopback);
|
.Returns(IPAddress.Loopback);
|
||||||
connectionInfoMock
|
connectionInfoMock
|
||||||
.Setup(ci => ci.RemoteIpAddress)
|
.Setup(ci => ci.RemoteIpAddress)
|
||||||
.Returns(remote);
|
.Returns(_remote);
|
||||||
|
|
||||||
// Session
|
// Session
|
||||||
sessionMock = new Mock<ISession>();
|
_sessionMock = new Mock<ISession>();
|
||||||
|
|
||||||
var contextMock = new Mock<HttpContext>();
|
var contextMock = new Mock<HttpContext>();
|
||||||
contextMock
|
contextMock
|
||||||
@@ -465,12 +465,12 @@ namespace UnitTests.AspNetCore.Extensions
|
|||||||
.Returns(connectionInfoMock.Object);
|
.Returns(connectionInfoMock.Object);
|
||||||
contextMock
|
contextMock
|
||||||
.Setup(c => c.Items)
|
.Setup(c => c.Items)
|
||||||
.Returns(items);
|
.Returns(_items);
|
||||||
if (hasSession)
|
if (hasSession)
|
||||||
{
|
{
|
||||||
contextMock
|
contextMock
|
||||||
.Setup(c => c.Session)
|
.Setup(c => c.Session)
|
||||||
.Returns(sessionMock.Object);
|
.Returns(_sessionMock.Object);
|
||||||
}
|
}
|
||||||
|
|
||||||
return contextMock.Object;
|
return contextMock.Object;
|
||||||
|
|||||||
@@ -9,12 +9,12 @@ namespace UnitTests.AspNetCore.Extensions
|
|||||||
[System.Diagnostics.CodeAnalysis.ExcludeFromCodeCoverage]
|
[System.Diagnostics.CodeAnalysis.ExcludeFromCodeCoverage]
|
||||||
public class ModelStateDictionaryExtensionsTests
|
public class ModelStateDictionaryExtensionsTests
|
||||||
{
|
{
|
||||||
private TestModel testModel;
|
private TestModel _testModel;
|
||||||
|
|
||||||
[TestInitialize]
|
[TestInitialize]
|
||||||
public void InitializeTests()
|
public void InitializeTests()
|
||||||
{
|
{
|
||||||
testModel = new TestModel
|
_testModel = new TestModel
|
||||||
{
|
{
|
||||||
ValueA = "A",
|
ValueA = "A",
|
||||||
ValueB = "B",
|
ValueB = "B",
|
||||||
@@ -33,7 +33,7 @@ namespace UnitTests.AspNetCore.Extensions
|
|||||||
var modelState = new ModelStateDictionary();
|
var modelState = new ModelStateDictionary();
|
||||||
|
|
||||||
// act
|
// act
|
||||||
modelState.AddModelError(testModel, m => m.ValueA, "ShitHappens");
|
modelState.AddModelError(_testModel, m => m.ValueA, "ShitHappens");
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
Assert.AreEqual(1, modelState.Count);
|
Assert.AreEqual(1, modelState.Count);
|
||||||
@@ -48,7 +48,7 @@ namespace UnitTests.AspNetCore.Extensions
|
|||||||
var modelState = new ModelStateDictionary();
|
var modelState = new ModelStateDictionary();
|
||||||
|
|
||||||
// act
|
// act
|
||||||
modelState.AddModelError(testModel, m => m.SubModel.SubValueB, "ShitHappens");
|
modelState.AddModelError(_testModel, m => m.SubModel.SubValueB, "ShitHappens");
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
Assert.AreEqual(1, modelState.Count);
|
Assert.AreEqual(1, modelState.Count);
|
||||||
@@ -64,7 +64,7 @@ namespace UnitTests.AspNetCore.Extensions
|
|||||||
ModelStateDictionary modelState = null;
|
ModelStateDictionary modelState = null;
|
||||||
|
|
||||||
// act
|
// act
|
||||||
modelState.AddModelError(testModel, m => m.SubModel.SubValueB, "ShitHappens");
|
modelState.AddModelError(_testModel, m => m.SubModel.SubValueB, "ShitHappens");
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
@@ -75,7 +75,7 @@ namespace UnitTests.AspNetCore.Extensions
|
|||||||
var modelState = new ModelStateDictionary();
|
var modelState = new ModelStateDictionary();
|
||||||
|
|
||||||
// act
|
// act
|
||||||
modelState.AddModelError(testModel, m => m, "ShitHappens");
|
modelState.AddModelError(_testModel, m => m, "ShitHappens");
|
||||||
}
|
}
|
||||||
|
|
||||||
internal class TestModel
|
internal class TestModel
|
||||||
|
|||||||
@@ -10,12 +10,12 @@ namespace UnitTests.AspNetCore.Extensions
|
|||||||
[System.Diagnostics.CodeAnalysis.ExcludeFromCodeCoverage]
|
[System.Diagnostics.CodeAnalysis.ExcludeFromCodeCoverage]
|
||||||
public class SessionExtensionsTests
|
public class SessionExtensionsTests
|
||||||
{
|
{
|
||||||
private Mock<ISession> sessionMock;
|
private Mock<ISession> _sessionMock;
|
||||||
|
|
||||||
private string sessionKey;
|
private string _sessionKey;
|
||||||
private byte[] sessionValue;
|
private byte[] _sessionValue;
|
||||||
|
|
||||||
private TestModel model;
|
private TestModel _model;
|
||||||
|
|
||||||
internal class TestModel
|
internal class TestModel
|
||||||
{
|
{
|
||||||
@@ -27,10 +27,10 @@ namespace UnitTests.AspNetCore.Extensions
|
|||||||
[TestInitialize]
|
[TestInitialize]
|
||||||
public void InitializeTests()
|
public void InitializeTests()
|
||||||
{
|
{
|
||||||
sessionKey = null;
|
_sessionKey = null;
|
||||||
sessionValue = null;
|
_sessionValue = null;
|
||||||
|
|
||||||
model = new TestModel
|
_model = new TestModel
|
||||||
{
|
{
|
||||||
ValueA = "A",
|
ValueA = "A",
|
||||||
ValueB = "B"
|
ValueB = "B"
|
||||||
@@ -41,7 +41,7 @@ namespace UnitTests.AspNetCore.Extensions
|
|||||||
public void ShouldCheckKeyExists()
|
public void ShouldCheckKeyExists()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
sessionKey = "exists";
|
_sessionKey = "exists";
|
||||||
var session = GetSession();
|
var session = GetSession();
|
||||||
|
|
||||||
// act
|
// act
|
||||||
@@ -57,25 +57,25 @@ namespace UnitTests.AspNetCore.Extensions
|
|||||||
public void ShouldGetValue()
|
public void ShouldGetValue()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
sessionKey = "test";
|
_sessionKey = "test";
|
||||||
sessionValue = Encoding.UTF8.GetBytes(JsonConvert.SerializeObject(model));
|
_sessionValue = Encoding.UTF8.GetBytes(JsonConvert.SerializeObject(_model));
|
||||||
var session = GetSession();
|
var session = GetSession();
|
||||||
|
|
||||||
// act
|
// act
|
||||||
var result = session.GetValue<TestModel>(sessionKey);
|
var result = session.GetValue<TestModel>(_sessionKey);
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
Assert.IsNotNull(result);
|
Assert.IsNotNull(result);
|
||||||
Assert.AreEqual(model.ValueA, result.ValueA);
|
Assert.AreEqual(_model.ValueA, result.ValueA);
|
||||||
Assert.AreEqual(model.ValueB, result.ValueB);
|
Assert.AreEqual(_model.ValueB, result.ValueB);
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
public void ShouldGetNull()
|
public void ShouldGetNull()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
sessionKey = "foo";
|
_sessionKey = "foo";
|
||||||
sessionValue = Encoding.UTF8.GetBytes(JsonConvert.SerializeObject(model));
|
_sessionValue = Encoding.UTF8.GetBytes(JsonConvert.SerializeObject(_model));
|
||||||
var session = GetSession();
|
var session = GetSession();
|
||||||
|
|
||||||
// act
|
// act
|
||||||
@@ -89,25 +89,25 @@ namespace UnitTests.AspNetCore.Extensions
|
|||||||
public void ShouldGetValueWithFallback()
|
public void ShouldGetValueWithFallback()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
sessionKey = "test";
|
_sessionKey = "test";
|
||||||
sessionValue = Encoding.UTF8.GetBytes(JsonConvert.SerializeObject(model));
|
_sessionValue = Encoding.UTF8.GetBytes(JsonConvert.SerializeObject(_model));
|
||||||
var session = GetSession();
|
var session = GetSession();
|
||||||
|
|
||||||
// act
|
// act
|
||||||
var result = session.GetValue(sessionKey, new TestModel());
|
var result = session.GetValue(_sessionKey, new TestModel());
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
Assert.IsNotNull(result);
|
Assert.IsNotNull(result);
|
||||||
Assert.AreEqual(model.ValueA, result.ValueA);
|
Assert.AreEqual(_model.ValueA, result.ValueA);
|
||||||
Assert.AreEqual(model.ValueB, result.ValueB);
|
Assert.AreEqual(_model.ValueB, result.ValueB);
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
public void ShouldGetFallback()
|
public void ShouldGetFallback()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
sessionKey = "foo";
|
_sessionKey = "foo";
|
||||||
sessionValue = Encoding.UTF8.GetBytes(JsonConvert.SerializeObject(model));
|
_sessionValue = Encoding.UTF8.GetBytes(JsonConvert.SerializeObject(_model));
|
||||||
var session = GetSession();
|
var session = GetSession();
|
||||||
|
|
||||||
// act
|
// act
|
||||||
@@ -127,33 +127,33 @@ namespace UnitTests.AspNetCore.Extensions
|
|||||||
var session = GetSession();
|
var session = GetSession();
|
||||||
|
|
||||||
// act
|
// act
|
||||||
session.SetValue(key, model);
|
session.SetValue(key, _model);
|
||||||
|
|
||||||
// arrange
|
// arrange
|
||||||
Assert.AreEqual(key, sessionKey);
|
Assert.AreEqual(key, _sessionKey);
|
||||||
Assert.AreEqual(JsonConvert.SerializeObject(model), Encoding.UTF8.GetString(sessionValue));
|
Assert.AreEqual(JsonConvert.SerializeObject(_model), Encoding.UTF8.GetString(_sessionValue));
|
||||||
}
|
}
|
||||||
|
|
||||||
private ISession GetSession()
|
private ISession GetSession()
|
||||||
{
|
{
|
||||||
string[] keys = new[] { sessionKey };
|
string[] keys = [_sessionKey];
|
||||||
|
|
||||||
sessionMock = new Mock<ISession>();
|
_sessionMock = new Mock<ISession>();
|
||||||
sessionMock
|
_sessionMock
|
||||||
.Setup(s => s.TryGetValue(It.IsAny<string>(), out sessionValue))
|
.Setup(s => s.TryGetValue(It.IsAny<string>(), out _sessionValue))
|
||||||
.Returns<string, byte[]>((key, value) => sessionKey == key);
|
.Returns<string, byte[]>((key, value) => _sessionKey == key);
|
||||||
sessionMock
|
_sessionMock
|
||||||
.Setup(s => s.Set(It.IsAny<string>(), It.IsAny<byte[]>()))
|
.Setup(s => s.Set(It.IsAny<string>(), It.IsAny<byte[]>()))
|
||||||
.Callback<string, byte[]>((key, value) =>
|
.Callback<string, byte[]>((key, value) =>
|
||||||
{
|
{
|
||||||
sessionKey = key;
|
_sessionKey = key;
|
||||||
sessionValue = value;
|
_sessionValue = value;
|
||||||
});
|
});
|
||||||
sessionMock
|
_sessionMock
|
||||||
.Setup(s => s.Keys)
|
.Setup(s => s.Keys)
|
||||||
.Returns(keys);
|
.Returns(keys);
|
||||||
|
|
||||||
return sessionMock.Object;
|
return _sessionMock.Object;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -18,26 +18,26 @@ namespace UnitTests.AspNetCore.Security.BasicAuthentication
|
|||||||
[System.Diagnostics.CodeAnalysis.ExcludeFromCodeCoverage]
|
[System.Diagnostics.CodeAnalysis.ExcludeFromCodeCoverage]
|
||||||
public class BasicAuthenticationMiddlewareTests
|
public class BasicAuthenticationMiddlewareTests
|
||||||
{
|
{
|
||||||
private Dictionary<string, string> requestHeaders;
|
private Dictionary<string, string> _requestHeaders;
|
||||||
|
|
||||||
private Dictionary<string, string> responseHeadersCallback;
|
private Dictionary<string, string> _responseHeadersCallback;
|
||||||
private int responseStatusCodeCallback;
|
private int _responseStatusCodeCallback;
|
||||||
|
|
||||||
private string validatorRealm;
|
private string _validatorRealm;
|
||||||
private ClaimsPrincipal validatorResponse;
|
private ClaimsPrincipal _validatorResponse;
|
||||||
private List<(string username, string password, IPAddress ipAddr)> validatorCallback;
|
private List<(string username, string password, IPAddress ipAddr)> _validatorCallback;
|
||||||
|
|
||||||
[TestInitialize]
|
[TestInitialize]
|
||||||
public void InitializeTests()
|
public void InitializeTests()
|
||||||
{
|
{
|
||||||
requestHeaders = new Dictionary<string, string>();
|
_requestHeaders = [];
|
||||||
|
|
||||||
responseHeadersCallback = new Dictionary<string, string>();
|
_responseHeadersCallback = [];
|
||||||
responseStatusCodeCallback = 0;
|
_responseStatusCodeCallback = 0;
|
||||||
|
|
||||||
validatorRealm = null;
|
_validatorRealm = null;
|
||||||
validatorResponse = null;
|
_validatorResponse = null;
|
||||||
validatorCallback = new List<(string username, string password, IPAddress ipAddr)>();
|
_validatorCallback = [];
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
@@ -47,8 +47,8 @@ namespace UnitTests.AspNetCore.Security.BasicAuthentication
|
|||||||
string username = "user";
|
string username = "user";
|
||||||
string password = "pass:word";
|
string password = "pass:word";
|
||||||
|
|
||||||
requestHeaders.Add("Authorization", $"Basic {Convert.ToBase64String(Encoding.UTF8.GetBytes($"{username}:{password}"))}");
|
_requestHeaders.Add("Authorization", $"Basic {Convert.ToBase64String(Encoding.UTF8.GetBytes($"{username}:{password}"))}");
|
||||||
validatorResponse = new ClaimsPrincipal();
|
_validatorResponse = new ClaimsPrincipal();
|
||||||
|
|
||||||
var middleware = GetMiddleware();
|
var middleware = GetMiddleware();
|
||||||
var context = GetContext();
|
var context = GetContext();
|
||||||
@@ -57,13 +57,13 @@ namespace UnitTests.AspNetCore.Security.BasicAuthentication
|
|||||||
await middleware.InvokeAsync(context);
|
await middleware.InvokeAsync(context);
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
Assert.AreEqual(0, responseStatusCodeCallback); // not triggered
|
Assert.AreEqual(0, _responseStatusCodeCallback); // not triggered
|
||||||
Assert.AreEqual(0, responseHeadersCallback.Count);
|
Assert.AreEqual(0, _responseHeadersCallback.Count);
|
||||||
Assert.AreEqual(1, validatorCallback.Count);
|
Assert.AreEqual(1, _validatorCallback.Count);
|
||||||
|
|
||||||
Assert.AreEqual(username, validatorCallback.First().username);
|
Assert.AreEqual(username, _validatorCallback.First().username);
|
||||||
Assert.AreEqual(password, validatorCallback.First().password);
|
Assert.AreEqual(password, _validatorCallback.First().password);
|
||||||
Assert.AreEqual(IPAddress.Loopback, validatorCallback.First().ipAddr);
|
Assert.AreEqual(IPAddress.Loopback, _validatorCallback.First().ipAddr);
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
@@ -77,13 +77,13 @@ namespace UnitTests.AspNetCore.Security.BasicAuthentication
|
|||||||
await middleware.InvokeAsync(context);
|
await middleware.InvokeAsync(context);
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
Assert.AreEqual(401, responseStatusCodeCallback);
|
Assert.AreEqual(401, _responseStatusCodeCallback);
|
||||||
|
|
||||||
Assert.AreEqual(0, validatorCallback.Count);
|
Assert.AreEqual(0, _validatorCallback.Count);
|
||||||
|
|
||||||
Assert.AreEqual(1, responseHeadersCallback.Count);
|
Assert.AreEqual(1, _responseHeadersCallback.Count);
|
||||||
Assert.AreEqual("WWW-Authenticate", responseHeadersCallback.Keys.First());
|
Assert.AreEqual("WWW-Authenticate", _responseHeadersCallback.Keys.First());
|
||||||
Assert.AreEqual("Basic", responseHeadersCallback.Values.First());
|
Assert.AreEqual("Basic", _responseHeadersCallback.Values.First());
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
@@ -93,10 +93,10 @@ namespace UnitTests.AspNetCore.Security.BasicAuthentication
|
|||||||
string username = "user";
|
string username = "user";
|
||||||
string password = "pw";
|
string password = "pw";
|
||||||
|
|
||||||
validatorRealm = "TEST";
|
_validatorRealm = "TEST";
|
||||||
var remote = IPAddress.Parse("1.2.3.4");
|
var remote = IPAddress.Parse("1.2.3.4");
|
||||||
|
|
||||||
requestHeaders.Add("Authorization", $"Basic {Convert.ToBase64String(Encoding.UTF8.GetBytes($"{username}:{password}"))}");
|
_requestHeaders.Add("Authorization", $"Basic {Convert.ToBase64String(Encoding.UTF8.GetBytes($"{username}:{password}"))}");
|
||||||
|
|
||||||
var middleware = GetMiddleware();
|
var middleware = GetMiddleware();
|
||||||
var context = GetContext(remote);
|
var context = GetContext(remote);
|
||||||
@@ -105,16 +105,16 @@ namespace UnitTests.AspNetCore.Security.BasicAuthentication
|
|||||||
await middleware.InvokeAsync(context);
|
await middleware.InvokeAsync(context);
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
Assert.AreEqual(401, responseStatusCodeCallback);
|
Assert.AreEqual(401, _responseStatusCodeCallback);
|
||||||
|
|
||||||
Assert.AreEqual(1, responseHeadersCallback.Count);
|
Assert.AreEqual(1, _responseHeadersCallback.Count);
|
||||||
Assert.AreEqual("WWW-Authenticate", responseHeadersCallback.Keys.First());
|
Assert.AreEqual("WWW-Authenticate", _responseHeadersCallback.Keys.First());
|
||||||
Assert.AreEqual($"Basic realm=\"{validatorRealm}\"", responseHeadersCallback.Values.First());
|
Assert.AreEqual($"Basic realm=\"{_validatorRealm}\"", _responseHeadersCallback.Values.First());
|
||||||
|
|
||||||
Assert.AreEqual(1, validatorCallback.Count);
|
Assert.AreEqual(1, _validatorCallback.Count);
|
||||||
Assert.AreEqual(username, validatorCallback.First().username);
|
Assert.AreEqual(username, _validatorCallback.First().username);
|
||||||
Assert.AreEqual(password, validatorCallback.First().password);
|
Assert.AreEqual(password, _validatorCallback.First().password);
|
||||||
Assert.AreEqual(remote, validatorCallback.First().ipAddr);
|
Assert.AreEqual(remote, _validatorCallback.First().ipAddr);
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
@@ -123,7 +123,7 @@ namespace UnitTests.AspNetCore.Security.BasicAuthentication
|
|||||||
// arrange
|
// arrange
|
||||||
string username = "user";
|
string username = "user";
|
||||||
|
|
||||||
requestHeaders.Add("Authorization", $"Basic {Convert.ToBase64String(Encoding.UTF8.GetBytes($"{username}"))}");
|
_requestHeaders.Add("Authorization", $"Basic {Convert.ToBase64String(Encoding.UTF8.GetBytes($"{username}"))}");
|
||||||
|
|
||||||
var middleware = GetMiddleware();
|
var middleware = GetMiddleware();
|
||||||
var context = GetContext();
|
var context = GetContext();
|
||||||
@@ -132,7 +132,7 @@ namespace UnitTests.AspNetCore.Security.BasicAuthentication
|
|||||||
await middleware.InvokeAsync(context);
|
await middleware.InvokeAsync(context);
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
Assert.AreEqual(500, responseStatusCodeCallback);
|
Assert.AreEqual(500, _responseStatusCodeCallback);
|
||||||
}
|
}
|
||||||
|
|
||||||
private BasicAuthenticationMiddleware GetMiddleware()
|
private BasicAuthenticationMiddleware GetMiddleware()
|
||||||
@@ -141,11 +141,11 @@ namespace UnitTests.AspNetCore.Security.BasicAuthentication
|
|||||||
var validatorMock = new Mock<IBasicAuthenticationValidator>();
|
var validatorMock = new Mock<IBasicAuthenticationValidator>();
|
||||||
validatorMock
|
validatorMock
|
||||||
.Setup(v => v.Realm)
|
.Setup(v => v.Realm)
|
||||||
.Returns(validatorRealm);
|
.Returns(_validatorRealm);
|
||||||
validatorMock
|
validatorMock
|
||||||
.Setup(v => v.ValidateAsync(It.IsAny<string>(), It.IsAny<string>(), It.IsAny<IPAddress>(), It.IsAny<CancellationToken>()))
|
.Setup(v => v.ValidateAsync(It.IsAny<string>(), It.IsAny<string>(), It.IsAny<IPAddress>(), It.IsAny<CancellationToken>()))
|
||||||
.Callback<string, string, IPAddress, CancellationToken>((username, password, ipAddress, _) => validatorCallback.Add((username, password, ipAddress)))
|
.Callback<string, string, IPAddress, CancellationToken>((username, password, ipAddress, _) => _validatorCallback.Add((username, password, ipAddress)))
|
||||||
.ReturnsAsync(validatorResponse);
|
.ReturnsAsync(_validatorResponse);
|
||||||
|
|
||||||
return new BasicAuthenticationMiddleware(nextMock.Object, validatorMock.Object);
|
return new BasicAuthenticationMiddleware(nextMock.Object, validatorMock.Object);
|
||||||
}
|
}
|
||||||
@@ -154,7 +154,7 @@ namespace UnitTests.AspNetCore.Security.BasicAuthentication
|
|||||||
{
|
{
|
||||||
// Request
|
// Request
|
||||||
var requestHeaderMock = new Mock<IHeaderDictionary>();
|
var requestHeaderMock = new Mock<IHeaderDictionary>();
|
||||||
foreach (var header in requestHeaders)
|
foreach (var header in _requestHeaders)
|
||||||
{
|
{
|
||||||
requestHeaderMock
|
requestHeaderMock
|
||||||
.Setup(h => h.ContainsKey(header.Key))
|
.Setup(h => h.ContainsKey(header.Key))
|
||||||
@@ -173,7 +173,7 @@ namespace UnitTests.AspNetCore.Security.BasicAuthentication
|
|||||||
var responseHeaderMock = new Mock<IHeaderDictionary>();
|
var responseHeaderMock = new Mock<IHeaderDictionary>();
|
||||||
responseHeaderMock
|
responseHeaderMock
|
||||||
.SetupSet(h => h[It.IsAny<string>()] = It.IsAny<StringValues>())
|
.SetupSet(h => h[It.IsAny<string>()] = It.IsAny<StringValues>())
|
||||||
.Callback<string, StringValues>((key, value) => responseHeadersCallback[key] = value);
|
.Callback<string, StringValues>((key, value) => _responseHeadersCallback[key] = value);
|
||||||
|
|
||||||
var responseMock = new Mock<HttpResponse>();
|
var responseMock = new Mock<HttpResponse>();
|
||||||
responseMock
|
responseMock
|
||||||
@@ -181,7 +181,7 @@ namespace UnitTests.AspNetCore.Security.BasicAuthentication
|
|||||||
.Returns(responseHeaderMock.Object);
|
.Returns(responseHeaderMock.Object);
|
||||||
responseMock
|
responseMock
|
||||||
.SetupSet(r => r.StatusCode = It.IsAny<int>())
|
.SetupSet(r => r.StatusCode = It.IsAny<int>())
|
||||||
.Callback<int>((code) => responseStatusCodeCallback = code);
|
.Callback<int>((code) => _responseStatusCodeCallback = code);
|
||||||
|
|
||||||
// Connection
|
// Connection
|
||||||
var connectionInfoMock = new Mock<ConnectionInfo>();
|
var connectionInfoMock = new Mock<ConnectionInfo>();
|
||||||
|
|||||||
@@ -14,17 +14,17 @@ namespace UnitTests.AspNetCore.Security.PathProtection
|
|||||||
[System.Diagnostics.CodeAnalysis.ExcludeFromCodeCoverage]
|
[System.Diagnostics.CodeAnalysis.ExcludeFromCodeCoverage]
|
||||||
public class ProtectedPathMiddlewareTests
|
public class ProtectedPathMiddlewareTests
|
||||||
{
|
{
|
||||||
private Mock<RequestDelegate> nextMock;
|
private Mock<RequestDelegate> _nextMock;
|
||||||
private Mock<HttpContext> httpContextMock;
|
private Mock<HttpContext> _httpContextMock;
|
||||||
private Mock<IAuthorizationService> authorizationServiceMock;
|
private Mock<IAuthorizationService> _authorizationServiceMock;
|
||||||
private Mock<IAuthenticationService> authenticationServiceMock;
|
private Mock<IAuthenticationService> _authenticationServiceMock;
|
||||||
|
|
||||||
private ProtectedPathOptions options;
|
private ProtectedPathOptions _options;
|
||||||
|
|
||||||
[TestInitialize]
|
[TestInitialize]
|
||||||
public void InitializeTest()
|
public void InitializeTest()
|
||||||
{
|
{
|
||||||
options = new ProtectedPathOptions
|
_options = new ProtectedPathOptions
|
||||||
{
|
{
|
||||||
Path = "/secure/protected",
|
Path = "/secure/protected",
|
||||||
PolicyName = "Protection"
|
PolicyName = "Protection"
|
||||||
@@ -36,21 +36,21 @@ namespace UnitTests.AspNetCore.Security.PathProtection
|
|||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
var middleware = GetMiddleware();
|
var middleware = GetMiddleware();
|
||||||
var context = GetHttpContext(options.Path);
|
var context = GetHttpContext(_options.Path);
|
||||||
var auth = GetAuthService(true);
|
var auth = GetAuthService(true);
|
||||||
|
|
||||||
// act
|
// act
|
||||||
await middleware.InvokeAsync(context, auth);
|
await middleware.InvokeAsync(context, auth);
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
authorizationServiceMock.Verify(s => s.AuthorizeAsync(It.IsAny<ClaimsPrincipal>(), It.IsAny<object>(), options.PolicyName), Times.Once);
|
_authorizationServiceMock.Verify(s => s.AuthorizeAsync(It.IsAny<ClaimsPrincipal>(), It.IsAny<object>(), _options.PolicyName), Times.Once);
|
||||||
authorizationServiceMock.VerifyNoOtherCalls();
|
_authorizationServiceMock.VerifyNoOtherCalls();
|
||||||
|
|
||||||
authenticationServiceMock.Verify(s => s.ChallengeAsync(It.IsAny<HttpContext>(), It.IsAny<string>(), It.IsAny<AuthenticationProperties>()), Times.Never);
|
_authenticationServiceMock.Verify(s => s.ChallengeAsync(It.IsAny<HttpContext>(), It.IsAny<string>(), It.IsAny<AuthenticationProperties>()), Times.Never);
|
||||||
authenticationServiceMock.VerifyNoOtherCalls();
|
_authenticationServiceMock.VerifyNoOtherCalls();
|
||||||
|
|
||||||
nextMock.Verify(n => n.Invoke(It.IsAny<HttpContext>()), Times.Once);
|
_nextMock.Verify(n => n.Invoke(It.IsAny<HttpContext>()), Times.Once);
|
||||||
nextMock.VerifyNoOtherCalls();
|
_nextMock.VerifyNoOtherCalls();
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
@@ -65,14 +65,14 @@ namespace UnitTests.AspNetCore.Security.PathProtection
|
|||||||
await middleware.InvokeAsync(context, auth);
|
await middleware.InvokeAsync(context, auth);
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
authorizationServiceMock.Verify(s => s.AuthorizeAsync(It.IsAny<ClaimsPrincipal>(), It.IsAny<object>(), options.PolicyName), Times.Never);
|
_authorizationServiceMock.Verify(s => s.AuthorizeAsync(It.IsAny<ClaimsPrincipal>(), It.IsAny<object>(), _options.PolicyName), Times.Never);
|
||||||
authorizationServiceMock.VerifyNoOtherCalls();
|
_authorizationServiceMock.VerifyNoOtherCalls();
|
||||||
|
|
||||||
authenticationServiceMock.Verify(s => s.ChallengeAsync(It.IsAny<HttpContext>(), It.IsAny<string>(), It.IsAny<AuthenticationProperties>()), Times.Never);
|
_authenticationServiceMock.Verify(s => s.ChallengeAsync(It.IsAny<HttpContext>(), It.IsAny<string>(), It.IsAny<AuthenticationProperties>()), Times.Never);
|
||||||
authenticationServiceMock.VerifyNoOtherCalls();
|
_authenticationServiceMock.VerifyNoOtherCalls();
|
||||||
|
|
||||||
nextMock.Verify(n => n.Invoke(It.IsAny<HttpContext>()), Times.Once);
|
_nextMock.Verify(n => n.Invoke(It.IsAny<HttpContext>()), Times.Once);
|
||||||
nextMock.VerifyNoOtherCalls();
|
_nextMock.VerifyNoOtherCalls();
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
@@ -80,27 +80,27 @@ namespace UnitTests.AspNetCore.Security.PathProtection
|
|||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
var middleware = GetMiddleware();
|
var middleware = GetMiddleware();
|
||||||
var context = GetHttpContext(options.Path);
|
var context = GetHttpContext(_options.Path);
|
||||||
var auth = GetAuthService(false);
|
var auth = GetAuthService(false);
|
||||||
|
|
||||||
// act
|
// act
|
||||||
await middleware.InvokeAsync(context, auth);
|
await middleware.InvokeAsync(context, auth);
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
authorizationServiceMock.Verify(s => s.AuthorizeAsync(It.IsAny<ClaimsPrincipal>(), It.IsAny<object>(), options.PolicyName), Times.Once);
|
_authorizationServiceMock.Verify(s => s.AuthorizeAsync(It.IsAny<ClaimsPrincipal>(), It.IsAny<object>(), _options.PolicyName), Times.Once);
|
||||||
authorizationServiceMock.VerifyNoOtherCalls();
|
_authorizationServiceMock.VerifyNoOtherCalls();
|
||||||
|
|
||||||
authenticationServiceMock.Verify(s => s.ChallengeAsync(It.IsAny<HttpContext>(), It.IsAny<string>(), It.IsAny<AuthenticationProperties>()), Times.Once);
|
_authenticationServiceMock.Verify(s => s.ChallengeAsync(It.IsAny<HttpContext>(), It.IsAny<string>(), It.IsAny<AuthenticationProperties>()), Times.Once);
|
||||||
authenticationServiceMock.VerifyNoOtherCalls();
|
_authenticationServiceMock.VerifyNoOtherCalls();
|
||||||
|
|
||||||
nextMock.Verify(n => n.Invoke(It.IsAny<HttpContext>()), Times.Never);
|
_nextMock.Verify(n => n.Invoke(It.IsAny<HttpContext>()), Times.Never);
|
||||||
nextMock.VerifyNoOtherCalls();
|
_nextMock.VerifyNoOtherCalls();
|
||||||
}
|
}
|
||||||
|
|
||||||
private ProtectedPathMiddleware GetMiddleware()
|
private ProtectedPathMiddleware GetMiddleware()
|
||||||
{
|
{
|
||||||
nextMock = new Mock<RequestDelegate>();
|
_nextMock = new Mock<RequestDelegate>();
|
||||||
return new ProtectedPathMiddleware(nextMock.Object, options);
|
return new ProtectedPathMiddleware(_nextMock.Object, _options);
|
||||||
}
|
}
|
||||||
|
|
||||||
private HttpContext GetHttpContext(string requestPath)
|
private HttpContext GetHttpContext(string requestPath)
|
||||||
@@ -110,32 +110,32 @@ namespace UnitTests.AspNetCore.Security.PathProtection
|
|||||||
.Setup(r => r.Path)
|
.Setup(r => r.Path)
|
||||||
.Returns(new PathString(requestPath));
|
.Returns(new PathString(requestPath));
|
||||||
|
|
||||||
authenticationServiceMock = new Mock<IAuthenticationService>();
|
_authenticationServiceMock = new Mock<IAuthenticationService>();
|
||||||
|
|
||||||
var requestServicesMock = new Mock<IServiceProvider>();
|
var requestServicesMock = new Mock<IServiceProvider>();
|
||||||
requestServicesMock
|
requestServicesMock
|
||||||
.Setup(s => s.GetService(typeof(IAuthenticationService)))
|
.Setup(s => s.GetService(typeof(IAuthenticationService)))
|
||||||
.Returns(authenticationServiceMock.Object);
|
.Returns(_authenticationServiceMock.Object);
|
||||||
|
|
||||||
httpContextMock = new Mock<HttpContext>();
|
_httpContextMock = new Mock<HttpContext>();
|
||||||
httpContextMock
|
_httpContextMock
|
||||||
.Setup(c => c.Request)
|
.Setup(c => c.Request)
|
||||||
.Returns(requestMock.Object);
|
.Returns(requestMock.Object);
|
||||||
httpContextMock
|
_httpContextMock
|
||||||
.Setup(c => c.RequestServices)
|
.Setup(c => c.RequestServices)
|
||||||
.Returns(requestServicesMock.Object);
|
.Returns(requestServicesMock.Object);
|
||||||
|
|
||||||
return httpContextMock.Object;
|
return _httpContextMock.Object;
|
||||||
}
|
}
|
||||||
|
|
||||||
private IAuthorizationService GetAuthService(bool success)
|
private IAuthorizationService GetAuthService(bool success)
|
||||||
{
|
{
|
||||||
authorizationServiceMock = new Mock<IAuthorizationService>();
|
_authorizationServiceMock = new Mock<IAuthorizationService>();
|
||||||
authorizationServiceMock
|
_authorizationServiceMock
|
||||||
.Setup(service => service.AuthorizeAsync(It.IsAny<ClaimsPrincipal>(), It.IsAny<object>(), It.IsAny<string>()))
|
.Setup(service => service.AuthorizeAsync(It.IsAny<ClaimsPrincipal>(), It.IsAny<object>(), It.IsAny<string>()))
|
||||||
.ReturnsAsync(() => success ? AuthorizationResult.Success() : AuthorizationResult.Failed());
|
.ReturnsAsync(() => success ? AuthorizationResult.Success() : AuthorizationResult.Failed());
|
||||||
|
|
||||||
return authorizationServiceMock.Object;
|
return _authorizationServiceMock.Object;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,9 +1,4 @@
|
|||||||
using System;
|
using System.Reflection;
|
||||||
using System.Collections.Generic;
|
|
||||||
using System.Linq;
|
|
||||||
using System.Reflection;
|
|
||||||
using System.Text;
|
|
||||||
using System.Threading.Tasks;
|
|
||||||
using Microsoft.AspNetCore.Identity;
|
using Microsoft.AspNetCore.Identity;
|
||||||
using Microsoft.VisualStudio.TestTools.UnitTesting;
|
using Microsoft.VisualStudio.TestTools.UnitTesting;
|
||||||
|
|
||||||
|
|||||||
@@ -41,7 +41,7 @@ namespace UnitTests.Common.Cli
|
|||||||
|
|
||||||
// act
|
// act
|
||||||
parser.ReadArgs("Option1 \"Option 2\"");
|
parser.ReadArgs("Option1 \"Option 2\"");
|
||||||
string[] args = parser.GetType().GetField("args", BindingFlags.NonPublic | BindingFlags.Instance).GetValue(parser) as string[];
|
string[] args = parser.GetType().GetField("_args", BindingFlags.NonPublic | BindingFlags.Instance).GetValue(parser) as string[];
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
Assert.IsNotNull(args);
|
Assert.IsNotNull(args);
|
||||||
@@ -63,7 +63,7 @@ namespace UnitTests.Common.Cli
|
|||||||
parser.RegisterOption("opt3", 2).Required().Single();
|
parser.RegisterOption("opt3", 2).Required().Single();
|
||||||
parser.RegisterOption("opt4").Alias("option4");
|
parser.RegisterOption("opt4").Alias("option4");
|
||||||
|
|
||||||
var options = parser.GetType().GetField("options", BindingFlags.NonPublic | BindingFlags.Instance).GetValue(parser) as List<Option>;
|
var options = parser.GetType().GetField("_options", BindingFlags.NonPublic | BindingFlags.Instance).GetValue(parser) as List<Option>;
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
Assert.IsNotNull(options);
|
Assert.IsNotNull(options);
|
||||||
@@ -163,7 +163,7 @@ namespace UnitTests.Common.Cli
|
|||||||
// arrange
|
// arrange
|
||||||
Argument actionArgument = null;
|
Argument actionArgument = null;
|
||||||
|
|
||||||
string[] args = new[] { "/run", "--opt" };
|
string[] args = ["/run", "--opt"];
|
||||||
var parser = new CommandLineParser();
|
var parser = new CommandLineParser();
|
||||||
parser.RegisterOption("opt").Required();
|
parser.RegisterOption("opt").Required();
|
||||||
parser.RegisterOption("run").Do(arg => actionArgument = arg);
|
parser.RegisterOption("run").Do(arg => actionArgument = arg);
|
||||||
@@ -219,7 +219,7 @@ namespace UnitTests.Common.Cli
|
|||||||
public void ShouldThrowExceptionOnMultipleAutocomplete()
|
public void ShouldThrowExceptionOnMultipleAutocomplete()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
string[] args = new[] { "/Opt:on" };
|
string[] args = ["/Opt:on"];
|
||||||
var parser = new CommandLineParser
|
var parser = new CommandLineParser
|
||||||
{
|
{
|
||||||
IsCaseSensitive = true
|
IsCaseSensitive = true
|
||||||
@@ -239,7 +239,7 @@ namespace UnitTests.Common.Cli
|
|||||||
public void ShouldThrowExceptionOnMissingOption()
|
public void ShouldThrowExceptionOnMissingOption()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
string[] args = new[] { "/Option:on" };
|
string[] args = ["/Option:on"];
|
||||||
var parser = new CommandLineParser
|
var parser = new CommandLineParser
|
||||||
{
|
{
|
||||||
AutoCompleteOptions = false
|
AutoCompleteOptions = false
|
||||||
@@ -259,7 +259,7 @@ namespace UnitTests.Common.Cli
|
|||||||
public void ShouldTrhowExceptionOnDuplicateOption()
|
public void ShouldTrhowExceptionOnDuplicateOption()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
string[] args = new[] { "/Opt:on", "--opt=off" };
|
string[] args = ["/Opt:on", "--opt=off"];
|
||||||
var parser = new CommandLineParser();
|
var parser = new CommandLineParser();
|
||||||
parser.RegisterOption("opt", 1).Single();
|
parser.RegisterOption("opt", 1).Single();
|
||||||
|
|
||||||
@@ -275,7 +275,7 @@ namespace UnitTests.Common.Cli
|
|||||||
public void ShouldThrowExceptionOnMissingArgument()
|
public void ShouldThrowExceptionOnMissingArgument()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
string[] args = new[] { "/Option" };
|
string[] args = ["/Option"];
|
||||||
var parser = new CommandLineParser();
|
var parser = new CommandLineParser();
|
||||||
parser.RegisterOption("option", 1);
|
parser.RegisterOption("option", 1);
|
||||||
|
|
||||||
@@ -291,7 +291,7 @@ namespace UnitTests.Common.Cli
|
|||||||
public void ShouldThrowExceptionForMissingRequiredOption()
|
public void ShouldThrowExceptionForMissingRequiredOption()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
string[] args = new[] { "/opt" };
|
string[] args = ["/opt"];
|
||||||
var parser = new CommandLineParser();
|
var parser = new CommandLineParser();
|
||||||
parser.RegisterOption("opt").Required();
|
parser.RegisterOption("opt").Required();
|
||||||
parser.RegisterOption("foo").Required();
|
parser.RegisterOption("foo").Required();
|
||||||
|
|||||||
@@ -8,18 +8,12 @@ namespace UnitTests.Common.Cli
|
|||||||
[TestClass]
|
[TestClass]
|
||||||
public class EnumerableWalkerTests
|
public class EnumerableWalkerTests
|
||||||
{
|
{
|
||||||
private List<string> list;
|
private List<string> _list;
|
||||||
|
|
||||||
[TestInitialize]
|
[TestInitialize]
|
||||||
public void Initialize()
|
public void Initialize()
|
||||||
{
|
{
|
||||||
list = new List<string>
|
_list = ["one", "two", "three", "four"];
|
||||||
{
|
|
||||||
"one",
|
|
||||||
"two",
|
|
||||||
"three",
|
|
||||||
"four",
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
@@ -39,7 +33,7 @@ namespace UnitTests.Common.Cli
|
|||||||
public void ShouldReturnEnumerator()
|
public void ShouldReturnEnumerator()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
var walker = new EnumerableWalker<string>(list);
|
var walker = new EnumerableWalker<string>(_list);
|
||||||
|
|
||||||
// act
|
// act
|
||||||
var enumerator = walker.GetEnumerator();
|
var enumerator = walker.GetEnumerator();
|
||||||
@@ -52,7 +46,7 @@ namespace UnitTests.Common.Cli
|
|||||||
public void ShouldReturnGenericEnumerator()
|
public void ShouldReturnGenericEnumerator()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
var walker = new EnumerableWalker<string>(list);
|
var walker = new EnumerableWalker<string>(_list);
|
||||||
|
|
||||||
// act
|
// act
|
||||||
var enumerator = ((IEnumerable<string>)walker).GetEnumerator();
|
var enumerator = ((IEnumerable<string>)walker).GetEnumerator();
|
||||||
@@ -65,18 +59,18 @@ namespace UnitTests.Common.Cli
|
|||||||
public void ShouldReturnItems()
|
public void ShouldReturnItems()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
var walker = new EnumerableWalker<string>(list);
|
var walker = new EnumerableWalker<string>(_list);
|
||||||
_ = walker.GetEnumerator();
|
_ = walker.GetEnumerator();
|
||||||
|
|
||||||
string[] items = new string[list.Count];
|
string[] items = new string[_list.Count];
|
||||||
|
|
||||||
// act
|
// act
|
||||||
for (int i = 0; i < list.Count; i++)
|
for (int i = 0; i < _list.Count; i++)
|
||||||
items[i] = walker.GetNext();
|
items[i] = walker.GetNext();
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
for (int i = 0; i < list.Count; i++)
|
for (int i = 0; i < _list.Count; i++)
|
||||||
Assert.AreEqual(list[i], items[i], $"Position {i} failed");
|
Assert.AreEqual(_list[i], items[i], $"Position {i} failed");
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
@@ -90,7 +84,7 @@ namespace UnitTests.Common.Cli
|
|||||||
string item = walker.GetNext();
|
string item = walker.GetNext();
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
Assert.AreEqual(default(string), item);
|
Assert.AreEqual(default, item);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -12,7 +12,7 @@ namespace UnitTests.Common.Extensions
|
|||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
string str = "Hello World!";
|
string str = "Hello World!";
|
||||||
byte[] bytes = new byte[] { 0xaf, 0xfe };
|
byte[] bytes = [0xaf, 0xfe];
|
||||||
|
|
||||||
// act
|
// act
|
||||||
string strHash = str.Md5();
|
string strHash = str.Md5();
|
||||||
@@ -28,7 +28,7 @@ namespace UnitTests.Common.Extensions
|
|||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
string str = "Hello World!";
|
string str = "Hello World!";
|
||||||
byte[] bytes = new byte[] { 0xaf, 0xfe };
|
byte[] bytes = [0xaf, 0xfe];
|
||||||
|
|
||||||
// act
|
// act
|
||||||
string strHash = str.Sha1();
|
string strHash = str.Sha1();
|
||||||
@@ -44,7 +44,7 @@ namespace UnitTests.Common.Extensions
|
|||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
string str = "Hello World!";
|
string str = "Hello World!";
|
||||||
byte[] bytes = new byte[] { 0xaf, 0xfe };
|
byte[] bytes = [0xaf, 0xfe];
|
||||||
|
|
||||||
// act
|
// act
|
||||||
string strHash = str.Sha256();
|
string strHash = str.Sha256();
|
||||||
@@ -60,7 +60,7 @@ namespace UnitTests.Common.Extensions
|
|||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
string str = "Hello World!";
|
string str = "Hello World!";
|
||||||
byte[] bytes = new byte[] { 0xaf, 0xfe };
|
byte[] bytes = [0xaf, 0xfe];
|
||||||
|
|
||||||
// act
|
// act
|
||||||
string strHash = str.Sha512();
|
string strHash = str.Sha512();
|
||||||
|
|||||||
@@ -56,11 +56,11 @@ namespace UnitTests.Common.Extensions
|
|||||||
// arrange
|
// arrange
|
||||||
var innerExceptions = new List<Exception>
|
var innerExceptions = new List<Exception>
|
||||||
{
|
{
|
||||||
new Exception("Inner Exception 1."),
|
new("Inner Exception 1."),
|
||||||
new Exception("Inner Exception 2. See the inner exception for details.", new Exception("Inner Exception of Exception 2.")),
|
new("Inner Exception 2. See the inner exception for details.", new Exception("Inner Exception of Exception 2.")),
|
||||||
new Exception("Inner Exception 3."),
|
new("Inner Exception 3."),
|
||||||
new Exception("Inner Exception 4."),
|
new("Inner Exception 4."),
|
||||||
new Exception("Inner Exception 5.")
|
new("Inner Exception 5.")
|
||||||
};
|
};
|
||||||
var aggregateException = new AggregateException("Lots of exceptions.", innerExceptions);
|
var aggregateException = new AggregateException("Lots of exceptions.", innerExceptions);
|
||||||
string expectedMessage = "Inner Exception 1. Inner Exception 2. Inner Exception of Exception 2. Inner Exception 3.";
|
string expectedMessage = "Inner Exception 1. Inner Exception 2. Inner Exception of Exception 2. Inner Exception 3.";
|
||||||
|
|||||||
@@ -224,7 +224,7 @@ namespace UnitTests.Common.Extensions
|
|||||||
public void ShouldConvertToJArray()
|
public void ShouldConvertToJArray()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
string[] stringArray = new[] { "one", "two", "three" };
|
string[] stringArray = ["one", "two", "three"];
|
||||||
var objectArray = new[]
|
var objectArray = new[]
|
||||||
{
|
{
|
||||||
new JsonTestClass { StringValue = "One" },
|
new JsonTestClass { StringValue = "One" },
|
||||||
|
|||||||
@@ -154,7 +154,7 @@ namespace UnitTests.Common.Extensions
|
|||||||
catch (Exception)
|
catch (Exception)
|
||||||
{ /* keep it quiet */ }
|
{ /* keep it quiet */ }
|
||||||
});
|
});
|
||||||
Task.WaitAll(awaitableTask);
|
awaitableTask.Wait();
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
Assert.IsTrue(isTimeout);
|
Assert.IsTrue(isTimeout);
|
||||||
@@ -183,7 +183,7 @@ namespace UnitTests.Common.Extensions
|
|||||||
catch (Exception)
|
catch (Exception)
|
||||||
{ /* keep it quiet */ }
|
{ /* keep it quiet */ }
|
||||||
});
|
});
|
||||||
Task.WaitAll(awaitableTask);
|
awaitableTask.Wait();
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
Assert.IsTrue(isTimeout);
|
Assert.IsTrue(isTimeout);
|
||||||
@@ -212,7 +212,7 @@ namespace UnitTests.Common.Extensions
|
|||||||
catch (Exception)
|
catch (Exception)
|
||||||
{ /* keep it quiet */ }
|
{ /* keep it quiet */ }
|
||||||
});
|
});
|
||||||
Task.WaitAll(awaitableTask);
|
awaitableTask.Wait();
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
Assert.IsTrue(isTimeout);
|
Assert.IsTrue(isTimeout);
|
||||||
|
|||||||
@@ -87,7 +87,7 @@ namespace UnitTests.Common.Extensions
|
|||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
byte[] bytes1 = null;
|
byte[] bytes1 = null;
|
||||||
byte[] bytes2 = Array.Empty<byte>();
|
byte[] bytes2 = [];
|
||||||
|
|
||||||
// act
|
// act
|
||||||
string hex1 = bytes1.BytesToHex();
|
string hex1 = bytes1.BytesToHex();
|
||||||
@@ -102,7 +102,7 @@ namespace UnitTests.Common.Extensions
|
|||||||
public void ShouldReturnHexString()
|
public void ShouldReturnHexString()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
byte[] bytes = new byte[] { 0xaf, 0xfe };
|
byte[] bytes = [0xaf, 0xfe];
|
||||||
|
|
||||||
// act
|
// act
|
||||||
string hex = bytes.BytesToHex();
|
string hex = bytes.BytesToHex();
|
||||||
@@ -116,7 +116,7 @@ namespace UnitTests.Common.Extensions
|
|||||||
public void ShouldReturnHexStringWithDelimiter()
|
public void ShouldReturnHexStringWithDelimiter()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
byte[] bytes = new byte[] { 0xde, 0xad, 0xbe, 0xef };
|
byte[] bytes = [0xde, 0xad, 0xbe, 0xef];
|
||||||
|
|
||||||
// act
|
// act
|
||||||
string hex = bytes.BytesToHex("_");
|
string hex = bytes.BytesToHex("_");
|
||||||
|
|||||||
@@ -15,14 +15,14 @@ namespace UnitTests.Common.Logging
|
|||||||
[TestClass]
|
[TestClass]
|
||||||
public class FileLoggerTests
|
public class FileLoggerTests
|
||||||
{
|
{
|
||||||
private Mock<StreamWriter> streamWriterMock;
|
private Mock<StreamWriter> _streamWriterMock;
|
||||||
|
|
||||||
private List<string> lines;
|
private List<string> _lines;
|
||||||
|
|
||||||
[TestInitialize]
|
[TestInitialize]
|
||||||
public void Initialize()
|
public void Initialize()
|
||||||
{
|
{
|
||||||
lines = new List<string>();
|
_lines = [];
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
@@ -157,14 +157,14 @@ namespace UnitTests.Common.Logging
|
|||||||
|
|
||||||
// act
|
// act
|
||||||
logger.Log(LogLevel.Information, "Test Message");
|
logger.Log(LogLevel.Information, "Test Message");
|
||||||
SpinWait.SpinUntil(() => lines.Count == 1);
|
SpinWait.SpinUntil(() => _lines.Count == 1);
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
Assert.AreEqual("INFO | Test Message", lines.First());
|
Assert.AreEqual("INFO | Test Message", _lines.First());
|
||||||
|
|
||||||
streamWriterMock.Verify(sw => sw.WriteLineAsync(It.IsAny<string>()), Times.Once);
|
_streamWriterMock.Verify(sw => sw.WriteLineAsync(It.IsAny<string>()), Times.Once);
|
||||||
streamWriterMock.Verify(sw => sw.FlushAsync(), Times.Once);
|
_streamWriterMock.Verify(sw => sw.FlushAsync(), Times.Once);
|
||||||
streamWriterMock.VerifyNoOtherCalls();
|
_streamWriterMock.VerifyNoOtherCalls();
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
@@ -177,18 +177,18 @@ namespace UnitTests.Common.Logging
|
|||||||
foreach (LogLevel level in Enum.GetValues<LogLevel>())
|
foreach (LogLevel level in Enum.GetValues<LogLevel>())
|
||||||
logger.Log(level, "Test Message");
|
logger.Log(level, "Test Message");
|
||||||
|
|
||||||
SpinWait.SpinUntil(() => lines.Count == 7);
|
SpinWait.SpinUntil(() => _lines.Count == 7);
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
streamWriterMock.Verify(sw => sw.WriteLineAsync("TRCE | Test Message"), Times.Once);
|
_streamWriterMock.Verify(sw => sw.WriteLineAsync("TRCE | Test Message"), Times.Once);
|
||||||
streamWriterMock.Verify(sw => sw.WriteLineAsync("DBUG | Test Message"), Times.Once);
|
_streamWriterMock.Verify(sw => sw.WriteLineAsync("DBUG | Test Message"), Times.Once);
|
||||||
streamWriterMock.Verify(sw => sw.WriteLineAsync("INFO | Test Message"), Times.Once);
|
_streamWriterMock.Verify(sw => sw.WriteLineAsync("INFO | Test Message"), Times.Once);
|
||||||
streamWriterMock.Verify(sw => sw.WriteLineAsync("WARN | Test Message"), Times.Once);
|
_streamWriterMock.Verify(sw => sw.WriteLineAsync("WARN | Test Message"), Times.Once);
|
||||||
streamWriterMock.Verify(sw => sw.WriteLineAsync("FAIL | Test Message"), Times.Once);
|
_streamWriterMock.Verify(sw => sw.WriteLineAsync("FAIL | Test Message"), Times.Once);
|
||||||
streamWriterMock.Verify(sw => sw.WriteLineAsync("CRIT | Test Message"), Times.Once);
|
_streamWriterMock.Verify(sw => sw.WriteLineAsync("CRIT | Test Message"), Times.Once);
|
||||||
streamWriterMock.Verify(sw => sw.WriteLineAsync(" | Test Message"), Times.Once);
|
_streamWriterMock.Verify(sw => sw.WriteLineAsync(" | Test Message"), Times.Once);
|
||||||
streamWriterMock.Verify(sw => sw.FlushAsync(), Times.AtLeastOnce);
|
_streamWriterMock.Verify(sw => sw.FlushAsync(), Times.AtLeastOnce);
|
||||||
streamWriterMock.VerifyNoOtherCalls();
|
_streamWriterMock.VerifyNoOtherCalls();
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
@@ -202,14 +202,14 @@ namespace UnitTests.Common.Logging
|
|||||||
foreach (LogLevel level in Enum.GetValues<LogLevel>())
|
foreach (LogLevel level in Enum.GetValues<LogLevel>())
|
||||||
logger.Log(level, "Test Message");
|
logger.Log(level, "Test Message");
|
||||||
|
|
||||||
SpinWait.SpinUntil(() => lines.Count == 3);
|
SpinWait.SpinUntil(() => _lines.Count == 3);
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
streamWriterMock.Verify(sw => sw.WriteLineAsync("FAIL | Test Message"), Times.Once);
|
_streamWriterMock.Verify(sw => sw.WriteLineAsync("FAIL | Test Message"), Times.Once);
|
||||||
streamWriterMock.Verify(sw => sw.WriteLineAsync("CRIT | Test Message"), Times.Once);
|
_streamWriterMock.Verify(sw => sw.WriteLineAsync("CRIT | Test Message"), Times.Once);
|
||||||
streamWriterMock.Verify(sw => sw.WriteLineAsync(" | Test Message"), Times.Once);
|
_streamWriterMock.Verify(sw => sw.WriteLineAsync(" | Test Message"), Times.Once);
|
||||||
streamWriterMock.Verify(sw => sw.FlushAsync(), Times.AtLeastOnce);
|
_streamWriterMock.Verify(sw => sw.FlushAsync(), Times.AtLeastOnce);
|
||||||
streamWriterMock.VerifyNoOtherCalls();
|
_streamWriterMock.VerifyNoOtherCalls();
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
@@ -222,13 +222,13 @@ namespace UnitTests.Common.Logging
|
|||||||
|
|
||||||
// act
|
// act
|
||||||
logger.LogWarning("Some Warning");
|
logger.LogWarning("Some Warning");
|
||||||
SpinWait.SpinUntil(() => lines.Count == 1);
|
SpinWait.SpinUntil(() => _lines.Count == 1);
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
|
|
||||||
streamWriterMock.Verify(sw => sw.WriteLineAsync($"{DateTime.Now:yyyy-MM-dd HH:mm} | WARN | Some Warning"), Times.Once);
|
_streamWriterMock.Verify(sw => sw.WriteLineAsync($"{DateTime.Now:yyyy-MM-dd HH:mm} | WARN | Some Warning"), Times.Once);
|
||||||
streamWriterMock.Verify(sw => sw.FlushAsync(), Times.Once);
|
_streamWriterMock.Verify(sw => sw.FlushAsync(), Times.Once);
|
||||||
streamWriterMock.VerifyNoOtherCalls();
|
_streamWriterMock.VerifyNoOtherCalls();
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
@@ -241,12 +241,12 @@ namespace UnitTests.Common.Logging
|
|||||||
|
|
||||||
// act
|
// act
|
||||||
logger.LogWarning("Some Warning");
|
logger.LogWarning("Some Warning");
|
||||||
SpinWait.SpinUntil(() => lines.Count == 1);
|
SpinWait.SpinUntil(() => _lines.Count == 1);
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
streamWriterMock.Verify(sw => sw.WriteLineAsync($"{DateTime.UtcNow:yyyy-MM-dd HH:mm} | WARN | Some Warning"), Times.Once);
|
_streamWriterMock.Verify(sw => sw.WriteLineAsync($"{DateTime.UtcNow:yyyy-MM-dd HH:mm} | WARN | Some Warning"), Times.Once);
|
||||||
streamWriterMock.Verify(sw => sw.FlushAsync(), Times.Once);
|
_streamWriterMock.Verify(sw => sw.FlushAsync(), Times.Once);
|
||||||
streamWriterMock.VerifyNoOtherCalls();
|
_streamWriterMock.VerifyNoOtherCalls();
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
@@ -264,12 +264,12 @@ namespace UnitTests.Common.Logging
|
|||||||
|
|
||||||
// act
|
// act
|
||||||
logger.LogWarning("Some Warning");
|
logger.LogWarning("Some Warning");
|
||||||
SpinWait.SpinUntil(() => lines.Count == 1);
|
SpinWait.SpinUntil(() => _lines.Count == 1);
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
streamWriterMock.Verify(sw => sw.WriteLineAsync($"{DateTime.Now:yyyy-MM-dd HH:mm} | WARN | [NamedInstance] Some Warning"), Times.Once);
|
_streamWriterMock.Verify(sw => sw.WriteLineAsync($"{DateTime.Now:yyyy-MM-dd HH:mm} | WARN | [NamedInstance] Some Warning"), Times.Once);
|
||||||
streamWriterMock.Verify(sw => sw.FlushAsync(), Times.Once);
|
_streamWriterMock.Verify(sw => sw.FlushAsync(), Times.Once);
|
||||||
streamWriterMock.VerifyNoOtherCalls();
|
_streamWriterMock.VerifyNoOtherCalls();
|
||||||
|
|
||||||
Assert.AreEqual(0, new FileInfo(file).Length);
|
Assert.AreEqual(0, new FileInfo(file).Length);
|
||||||
}
|
}
|
||||||
@@ -290,13 +290,13 @@ namespace UnitTests.Common.Logging
|
|||||||
using (var scope = logger.BeginScope("scope"))
|
using (var scope = logger.BeginScope("scope"))
|
||||||
{
|
{
|
||||||
logger.LogError("Test");
|
logger.LogError("Test");
|
||||||
SpinWait.SpinUntil(() => lines.Count == 1);
|
SpinWait.SpinUntil(() => _lines.Count == 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
streamWriterMock.Verify(sw => sw.WriteLineAsync("FAIL | [NamedInstance] Test"), Times.Once);
|
_streamWriterMock.Verify(sw => sw.WriteLineAsync("FAIL | [NamedInstance] Test"), Times.Once);
|
||||||
streamWriterMock.Verify(sw => sw.FlushAsync(), Times.Once);
|
_streamWriterMock.Verify(sw => sw.FlushAsync(), Times.Once);
|
||||||
streamWriterMock.VerifyNoOtherCalls();
|
_streamWriterMock.VerifyNoOtherCalls();
|
||||||
|
|
||||||
scopeProvider.Verify(sp => sp.Push("scope"), Times.Once);
|
scopeProvider.Verify(sp => sp.Push("scope"), Times.Once);
|
||||||
scopeProvider.Verify(sp => sp.ForEachScope(It.IsAny<Action<object, It.IsAnyType>>(), It.IsAny<It.IsAnyType>()), Times.Once);
|
scopeProvider.Verify(sp => sp.ForEachScope(It.IsAny<Action<object, It.IsAnyType>>(), It.IsAny<It.IsAnyType>()), Times.Once);
|
||||||
@@ -311,12 +311,12 @@ namespace UnitTests.Common.Logging
|
|||||||
|
|
||||||
// act
|
// act
|
||||||
logger.LogCritical(new Exception("TestException"), "");
|
logger.LogCritical(new Exception("TestException"), "");
|
||||||
SpinWait.SpinUntil(() => lines.Count == 1);
|
SpinWait.SpinUntil(() => _lines.Count == 1);
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
streamWriterMock.Verify(sw => sw.WriteLineAsync("CRIT | System.Exception: TestException"), Times.Once);
|
_streamWriterMock.Verify(sw => sw.WriteLineAsync("CRIT | System.Exception: TestException"), Times.Once);
|
||||||
streamWriterMock.Verify(sw => sw.FlushAsync(), Times.Once);
|
_streamWriterMock.Verify(sw => sw.FlushAsync(), Times.Once);
|
||||||
streamWriterMock.VerifyNoOtherCalls();
|
_streamWriterMock.VerifyNoOtherCalls();
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
@@ -327,12 +327,12 @@ namespace UnitTests.Common.Logging
|
|||||||
|
|
||||||
// act
|
// act
|
||||||
logger.LogCritical(new Exception("TestException"), "Bad things happen...");
|
logger.LogCritical(new Exception("TestException"), "Bad things happen...");
|
||||||
SpinWait.SpinUntil(() => lines.Count == 1);
|
SpinWait.SpinUntil(() => _lines.Count == 1);
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
streamWriterMock.Verify(sw => sw.WriteLineAsync($"CRIT | Bad things happen...{Environment.NewLine} System.Exception: TestException"), Times.Once);
|
_streamWriterMock.Verify(sw => sw.WriteLineAsync($"CRIT | Bad things happen...{Environment.NewLine} System.Exception: TestException"), Times.Once);
|
||||||
streamWriterMock.Verify(sw => sw.FlushAsync(), Times.Once);
|
_streamWriterMock.Verify(sw => sw.FlushAsync(), Times.Once);
|
||||||
streamWriterMock.VerifyNoOtherCalls();
|
_streamWriterMock.VerifyNoOtherCalls();
|
||||||
}
|
}
|
||||||
|
|
||||||
private FileLogger GetFileLogger(string name = null, IExternalScopeProvider scopeProvider = null)
|
private FileLogger GetFileLogger(string name = null, IExternalScopeProvider scopeProvider = null)
|
||||||
@@ -340,10 +340,10 @@ namespace UnitTests.Common.Logging
|
|||||||
string tmpFilePath = Path.GetTempFileName();
|
string tmpFilePath = Path.GetTempFileName();
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
streamWriterMock = new Mock<StreamWriter>(Stream.Null);
|
_streamWriterMock = new Mock<StreamWriter>(Stream.Null);
|
||||||
streamWriterMock
|
_streamWriterMock
|
||||||
.Setup(sw => sw.WriteLineAsync(It.IsAny<string>()))
|
.Setup(sw => sw.WriteLineAsync(It.IsAny<string>()))
|
||||||
.Callback<string>(line => lines.Add(line))
|
.Callback<string>(line => _lines.Add(line))
|
||||||
.Returns(Task.CompletedTask);
|
.Returns(Task.CompletedTask);
|
||||||
|
|
||||||
FileLogger fileLogger;
|
FileLogger fileLogger;
|
||||||
@@ -356,9 +356,9 @@ namespace UnitTests.Common.Logging
|
|||||||
fileLogger = new FileLogger(tmpFilePath, name, scopeProvider);
|
fileLogger = new FileLogger(tmpFilePath, name, scopeProvider);
|
||||||
}
|
}
|
||||||
|
|
||||||
var fieldInfo = fileLogger.GetType().GetField("fileWriter", BindingFlags.NonPublic | BindingFlags.Instance);
|
var fieldInfo = fileLogger.GetType().GetField("_fileWriter", BindingFlags.NonPublic | BindingFlags.Instance);
|
||||||
(fieldInfo.GetValue(fileLogger) as StreamWriter).Dispose();
|
(fieldInfo.GetValue(fileLogger) as StreamWriter).Dispose();
|
||||||
fieldInfo.SetValue(fileLogger, streamWriterMock.Object);
|
fieldInfo.SetValue(fileLogger, _streamWriterMock.Object);
|
||||||
|
|
||||||
return fileLogger;
|
return fileLogger;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -10,35 +10,35 @@ namespace UnitTests.Common.Utilities
|
|||||||
[System.Diagnostics.CodeAnalysis.ExcludeFromCodeCoverage]
|
[System.Diagnostics.CodeAnalysis.ExcludeFromCodeCoverage]
|
||||||
public class AsyncQueueTests
|
public class AsyncQueueTests
|
||||||
{
|
{
|
||||||
private Queue<TestElement> internalQueue;
|
private Queue<TestElement> _internalQueue;
|
||||||
|
|
||||||
private TestElement queueElement1;
|
private TestElement _queueElement1;
|
||||||
private TestElement queueElement2;
|
private TestElement _queueElement2;
|
||||||
private TestElement queueElement3;
|
private TestElement _queueElement3;
|
||||||
|
|
||||||
[TestInitialize]
|
[TestInitialize]
|
||||||
public void InitializeTest()
|
public void InitializeTest()
|
||||||
{
|
{
|
||||||
queueElement1 = new TestElement
|
_queueElement1 = new TestElement
|
||||||
{
|
{
|
||||||
Number = 111,
|
Number = 111,
|
||||||
Text = "one"
|
Text = "one"
|
||||||
};
|
};
|
||||||
queueElement2 = new TestElement
|
_queueElement2 = new TestElement
|
||||||
{
|
{
|
||||||
Number = 222,
|
Number = 222,
|
||||||
Text = "two"
|
Text = "two"
|
||||||
};
|
};
|
||||||
queueElement3 = new TestElement
|
_queueElement3 = new TestElement
|
||||||
{
|
{
|
||||||
Number = 333,
|
Number = 333,
|
||||||
Text = "three"
|
Text = "three"
|
||||||
};
|
};
|
||||||
|
|
||||||
internalQueue = new Queue<TestElement>();
|
_internalQueue = new Queue<TestElement>();
|
||||||
internalQueue.Enqueue(queueElement1);
|
_internalQueue.Enqueue(_queueElement1);
|
||||||
internalQueue.Enqueue(queueElement2);
|
_internalQueue.Enqueue(_queueElement2);
|
||||||
internalQueue.Enqueue(queueElement3);
|
_internalQueue.Enqueue(_queueElement3);
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
@@ -47,15 +47,15 @@ namespace UnitTests.Common.Utilities
|
|||||||
// arrange
|
// arrange
|
||||||
var element = new TestElement { Number = 1, Text = "Hello" };
|
var element = new TestElement { Number = 1, Text = "Hello" };
|
||||||
|
|
||||||
internalQueue.Clear();
|
_internalQueue.Clear();
|
||||||
var queue = GetQueue();
|
var queue = GetQueue();
|
||||||
|
|
||||||
// act
|
// act
|
||||||
queue.Enqueue(element);
|
queue.Enqueue(element);
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
Assert.AreEqual(1, internalQueue.Count);
|
Assert.AreEqual(1, _internalQueue.Count);
|
||||||
Assert.AreEqual(internalQueue.Count, queue.Count);
|
Assert.AreEqual(_internalQueue.Count, queue.Count);
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
@@ -65,7 +65,7 @@ namespace UnitTests.Common.Utilities
|
|||||||
var element = new TestElement { Number = 1, Text = "Hello" };
|
var element = new TestElement { Number = 1, Text = "Hello" };
|
||||||
bool available = false;
|
bool available = false;
|
||||||
|
|
||||||
internalQueue.Clear();
|
_internalQueue.Clear();
|
||||||
var queue = GetQueue();
|
var queue = GetQueue();
|
||||||
|
|
||||||
// act
|
// act
|
||||||
@@ -88,7 +88,7 @@ namespace UnitTests.Common.Utilities
|
|||||||
var element = new TestElement { Number = 1, Text = "Hello" };
|
var element = new TestElement { Number = 1, Text = "Hello" };
|
||||||
TestElement callback = null;
|
TestElement callback = null;
|
||||||
|
|
||||||
internalQueue.Clear();
|
_internalQueue.Clear();
|
||||||
var queue = GetQueue();
|
var queue = GetQueue();
|
||||||
|
|
||||||
// act
|
// act
|
||||||
@@ -110,18 +110,18 @@ namespace UnitTests.Common.Utilities
|
|||||||
// arrange
|
// arrange
|
||||||
var elements = new TestElement[]
|
var elements = new TestElement[]
|
||||||
{
|
{
|
||||||
new TestElement { Number = 1, Text = "Hello" },
|
new() { Number = 1, Text = "Hello" },
|
||||||
new TestElement { Number = 2, Text = "World" },
|
new() { Number = 2, Text = "World" },
|
||||||
};
|
};
|
||||||
internalQueue.Clear();
|
_internalQueue.Clear();
|
||||||
var queue = GetQueue();
|
var queue = GetQueue();
|
||||||
|
|
||||||
// act
|
// act
|
||||||
queue.Enqueue(elements);
|
queue.Enqueue(elements);
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
Assert.AreEqual(2, internalQueue.Count);
|
Assert.AreEqual(2, _internalQueue.Count);
|
||||||
Assert.AreEqual(queue.Count, internalQueue.Count);
|
Assert.AreEqual(queue.Count, _internalQueue.Count);
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
@@ -136,7 +136,7 @@ namespace UnitTests.Common.Utilities
|
|||||||
// assert
|
// assert
|
||||||
Assert.IsTrue(isSuccess);
|
Assert.IsTrue(isSuccess);
|
||||||
Assert.IsNotNull(item);
|
Assert.IsNotNull(item);
|
||||||
Assert.AreEqual(queueElement1, item);
|
Assert.AreEqual(_queueElement1, item);
|
||||||
Assert.AreEqual(3, queue.Count);
|
Assert.AreEqual(3, queue.Count);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -144,7 +144,7 @@ namespace UnitTests.Common.Utilities
|
|||||||
public void ShouldNotPeekAValue()
|
public void ShouldNotPeekAValue()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
internalQueue.Clear();
|
_internalQueue.Clear();
|
||||||
var queue = GetQueue();
|
var queue = GetQueue();
|
||||||
|
|
||||||
// act
|
// act
|
||||||
@@ -167,7 +167,7 @@ namespace UnitTests.Common.Utilities
|
|||||||
// assert
|
// assert
|
||||||
Assert.IsTrue(isSuccess);
|
Assert.IsTrue(isSuccess);
|
||||||
Assert.IsNotNull(item);
|
Assert.IsNotNull(item);
|
||||||
Assert.AreEqual(queueElement1, item);
|
Assert.AreEqual(_queueElement1, item);
|
||||||
Assert.AreEqual(2, queue.Count);
|
Assert.AreEqual(2, queue.Count);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -175,7 +175,7 @@ namespace UnitTests.Common.Utilities
|
|||||||
public void ShouldNotDequeueAValue()
|
public void ShouldNotDequeueAValue()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
internalQueue.Clear();
|
_internalQueue.Clear();
|
||||||
var queue = GetQueue();
|
var queue = GetQueue();
|
||||||
|
|
||||||
// act
|
// act
|
||||||
@@ -193,14 +193,14 @@ namespace UnitTests.Common.Utilities
|
|||||||
var queue = GetQueue();
|
var queue = GetQueue();
|
||||||
|
|
||||||
// act
|
// act
|
||||||
queue.Remove(queueElement2);
|
queue.Remove(_queueElement2);
|
||||||
var item1 = queue.Dequeue();
|
var item1 = queue.Dequeue();
|
||||||
var item2 = queue.Dequeue();
|
var item2 = queue.Dequeue();
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
Assert.AreEqual(0, queue.Count);
|
Assert.AreEqual(0, queue.Count);
|
||||||
Assert.AreEqual(queueElement1, item1);
|
Assert.AreEqual(_queueElement1, item1);
|
||||||
Assert.AreEqual(queueElement3, item2);
|
Assert.AreEqual(_queueElement3, item2);
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
@@ -217,22 +217,22 @@ namespace UnitTests.Common.Utilities
|
|||||||
|
|
||||||
// assert
|
// assert
|
||||||
Assert.AreEqual(0, queue.Count);
|
Assert.AreEqual(0, queue.Count);
|
||||||
Assert.AreEqual(queueElement1, item1);
|
Assert.AreEqual(_queueElement1, item1);
|
||||||
Assert.AreEqual(queueElement2, item2);
|
Assert.AreEqual(_queueElement2, item2);
|
||||||
Assert.AreEqual(queueElement3, item3);
|
Assert.AreEqual(_queueElement3, item3);
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
public async Task ShouldAwaitOneDequeue()
|
public async Task ShouldAwaitOneDequeue()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
internalQueue.Clear();
|
_internalQueue.Clear();
|
||||||
var queue = GetQueue();
|
var queue = GetQueue();
|
||||||
|
|
||||||
var task = Task.Run(async () =>
|
var task = Task.Run(async () =>
|
||||||
{
|
{
|
||||||
await Task.Delay(1000);
|
await Task.Delay(1000);
|
||||||
queue.Enqueue(new[] { queueElement1, queueElement2, queueElement3 });
|
queue.Enqueue(new[] { _queueElement1, _queueElement2, _queueElement3 });
|
||||||
});
|
});
|
||||||
|
|
||||||
// act
|
// act
|
||||||
@@ -241,20 +241,20 @@ namespace UnitTests.Common.Utilities
|
|||||||
// assert
|
// assert
|
||||||
Assert.AreEqual(2, queue.Count);
|
Assert.AreEqual(2, queue.Count);
|
||||||
Assert.IsNotNull(item);
|
Assert.IsNotNull(item);
|
||||||
Assert.AreEqual(queueElement1, item);
|
Assert.AreEqual(_queueElement1, item);
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
public async Task ShouldAwaitManyDequeue()
|
public async Task ShouldAwaitManyDequeue()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
internalQueue.Clear();
|
_internalQueue.Clear();
|
||||||
var queue = GetQueue();
|
var queue = GetQueue();
|
||||||
|
|
||||||
var task = Task.Run(async () =>
|
var task = Task.Run(async () =>
|
||||||
{
|
{
|
||||||
await Task.Delay(1000);
|
await Task.Delay(1000);
|
||||||
queue.Enqueue(new[] { queueElement1, queueElement2, queueElement3 });
|
queue.Enqueue(new[] { _queueElement1, _queueElement2, _queueElement3 });
|
||||||
});
|
});
|
||||||
|
|
||||||
// act
|
// act
|
||||||
@@ -264,21 +264,21 @@ namespace UnitTests.Common.Utilities
|
|||||||
Assert.AreEqual(1, queue.Count);
|
Assert.AreEqual(1, queue.Count);
|
||||||
Assert.IsNotNull(items);
|
Assert.IsNotNull(items);
|
||||||
Assert.AreEqual(2, items.Length);
|
Assert.AreEqual(2, items.Length);
|
||||||
Assert.AreEqual(queueElement1, items[0]);
|
Assert.AreEqual(_queueElement1, items[0]);
|
||||||
Assert.AreEqual(queueElement2, items[1]);
|
Assert.AreEqual(_queueElement2, items[1]);
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
public async Task ShouldAwaitAllDequeue()
|
public async Task ShouldAwaitAllDequeue()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
internalQueue.Clear();
|
_internalQueue.Clear();
|
||||||
var queue = GetQueue();
|
var queue = GetQueue();
|
||||||
|
|
||||||
var task = Task.Run(async () =>
|
var task = Task.Run(async () =>
|
||||||
{
|
{
|
||||||
await Task.Delay(1000);
|
await Task.Delay(1000);
|
||||||
queue.Enqueue(new[] { queueElement1, queueElement2, queueElement3 });
|
queue.Enqueue(new[] { _queueElement1, _queueElement2, _queueElement3 });
|
||||||
});
|
});
|
||||||
|
|
||||||
// act
|
// act
|
||||||
@@ -288,22 +288,22 @@ namespace UnitTests.Common.Utilities
|
|||||||
Assert.AreEqual(0, queue.Count);
|
Assert.AreEqual(0, queue.Count);
|
||||||
Assert.IsNotNull(items);
|
Assert.IsNotNull(items);
|
||||||
Assert.AreEqual(3, items.Length);
|
Assert.AreEqual(3, items.Length);
|
||||||
Assert.AreEqual(queueElement1, items[0]);
|
Assert.AreEqual(_queueElement1, items[0]);
|
||||||
Assert.AreEqual(queueElement2, items[1]);
|
Assert.AreEqual(_queueElement2, items[1]);
|
||||||
Assert.AreEqual(queueElement3, items[2]);
|
Assert.AreEqual(_queueElement3, items[2]);
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
public async Task ShouldAwaitAvailableDequeue()
|
public async Task ShouldAwaitAvailableDequeue()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
internalQueue.Clear();
|
_internalQueue.Clear();
|
||||||
var queue = GetQueue();
|
var queue = GetQueue();
|
||||||
|
|
||||||
var task = Task.Run(async () =>
|
var task = Task.Run(async () =>
|
||||||
{
|
{
|
||||||
await Task.Delay(1000);
|
await Task.Delay(1000);
|
||||||
queue.Enqueue(new[] { queueElement1, queueElement2, queueElement3 });
|
queue.Enqueue(new[] { _queueElement1, _queueElement2, _queueElement3 });
|
||||||
});
|
});
|
||||||
|
|
||||||
// act
|
// act
|
||||||
@@ -313,8 +313,8 @@ namespace UnitTests.Common.Utilities
|
|||||||
Assert.AreEqual(1, queue.Count);
|
Assert.AreEqual(1, queue.Count);
|
||||||
Assert.IsNotNull(items);
|
Assert.IsNotNull(items);
|
||||||
Assert.AreEqual(2, items.Length);
|
Assert.AreEqual(2, items.Length);
|
||||||
Assert.AreEqual(queueElement1, items[0]);
|
Assert.AreEqual(_queueElement1, items[0]);
|
||||||
Assert.AreEqual(queueElement2, items[1]);
|
Assert.AreEqual(_queueElement2, items[1]);
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
@@ -322,7 +322,7 @@ namespace UnitTests.Common.Utilities
|
|||||||
public async Task ShouldThrowArumentOutOfRangeException()
|
public async Task ShouldThrowArumentOutOfRangeException()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
internalQueue.Clear();
|
_internalQueue.Clear();
|
||||||
var queue = GetQueue();
|
var queue = GetQueue();
|
||||||
|
|
||||||
// act
|
// act
|
||||||
@@ -336,8 +336,8 @@ namespace UnitTests.Common.Utilities
|
|||||||
{
|
{
|
||||||
var asyncQueue = new AsyncQueue<TestElement>();
|
var asyncQueue = new AsyncQueue<TestElement>();
|
||||||
|
|
||||||
var field = asyncQueue.GetType().GetField("queue", BindingFlags.Instance | BindingFlags.NonPublic);
|
var field = asyncQueue.GetType().GetField("_queue", BindingFlags.Instance | BindingFlags.NonPublic);
|
||||||
field.SetValue(asyncQueue, internalQueue);
|
field.SetValue(asyncQueue, _internalQueue);
|
||||||
|
|
||||||
return asyncQueue;
|
return asyncQueue;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -10,22 +10,22 @@ namespace UnitTests.Common.Utilities
|
|||||||
{
|
{
|
||||||
[TestClass]
|
[TestClass]
|
||||||
[System.Diagnostics.CodeAnalysis.ExcludeFromCodeCoverage]
|
[System.Diagnostics.CodeAnalysis.ExcludeFromCodeCoverage]
|
||||||
public class CryptographyHelperTests
|
public partial class CryptographyHelperTests
|
||||||
{
|
{
|
||||||
private string keyFile;
|
private string _keyFile;
|
||||||
private CryptographyHelper cryptoHelper;
|
private CryptographyHelper _cryptoHelper;
|
||||||
|
|
||||||
[TestInitialize]
|
[TestInitialize]
|
||||||
public void Initialize()
|
public void Initialize()
|
||||||
{
|
{
|
||||||
keyFile = Path.GetTempFileName();
|
_keyFile = Path.GetTempFileName();
|
||||||
cryptoHelper = new CryptographyHelper(keyFile);
|
_cryptoHelper = new CryptographyHelper(_keyFile);
|
||||||
}
|
}
|
||||||
|
|
||||||
[TestCleanup]
|
[TestCleanup]
|
||||||
public void Cleanup()
|
public void Cleanup()
|
||||||
{
|
{
|
||||||
File.Delete(keyFile);
|
File.Delete(_keyFile);
|
||||||
}
|
}
|
||||||
|
|
||||||
#region Static
|
#region Static
|
||||||
@@ -40,12 +40,12 @@ namespace UnitTests.Common.Utilities
|
|||||||
// arrange
|
// arrange
|
||||||
using var _ = CryptographyHelperSaltMock.Create(0);
|
using var _ = CryptographyHelperSaltMock.Create(0);
|
||||||
|
|
||||||
byte[] bytes = new byte[] { 0xaf, 0xfe };
|
byte[] bytes = [0xaf, 0xfe];
|
||||||
string str = "ABC";
|
string str = "ABC";
|
||||||
string password1 = "P@ssw0rd!";
|
string password1 = "P@ssw0rd!";
|
||||||
string password2 = "P@ssw0rd";
|
string password2 = "P@ssw0rd";
|
||||||
|
|
||||||
byte[] expectedBytes = new byte[] { 0x7c, 0x7b, 0x77, 0x56, 0x91, 0x1a, 0xd9, 0xc0, 0x72, 0x70, 0x36, 0x88, 0x9f, 0xb4, 0xb5, 0xbc };
|
byte[] expectedBytes = [0x7c, 0x7b, 0x77, 0x56, 0x91, 0x1a, 0xd9, 0xc0, 0x72, 0x70, 0x36, 0x88, 0x9f, 0xb4, 0xb5, 0xbc];
|
||||||
|
|
||||||
// act
|
// act
|
||||||
byte[] cipherBytes1 = CryptographyHelper.AesEncrypt(bytes, password1);
|
byte[] cipherBytes1 = CryptographyHelper.AesEncrypt(bytes, password1);
|
||||||
@@ -68,12 +68,12 @@ namespace UnitTests.Common.Utilities
|
|||||||
using var _ = CryptographyHelperSaltMock.Create(0);
|
using var _ = CryptographyHelperSaltMock.Create(0);
|
||||||
|
|
||||||
string cipherStr = "ueLuhFNpCuYmx8v3hczHtg==";
|
string cipherStr = "ueLuhFNpCuYmx8v3hczHtg==";
|
||||||
byte[] cipherBytes = new byte[] { 0x7c, 0x7b, 0x77, 0x56, 0x91, 0x1a, 0xd9, 0xc0, 0x72, 0x70, 0x36, 0x88, 0x9f, 0xb4, 0xb5, 0xbc };
|
byte[] cipherBytes = [0x7c, 0x7b, 0x77, 0x56, 0x91, 0x1a, 0xd9, 0xc0, 0x72, 0x70, 0x36, 0x88, 0x9f, 0xb4, 0xb5, 0xbc];
|
||||||
|
|
||||||
string password1 = "P@ssw0rd!";
|
string password1 = "P@ssw0rd!";
|
||||||
string password2 = "P@ssw0rd";
|
string password2 = "P@ssw0rd";
|
||||||
|
|
||||||
byte[] expectedBytes = new byte[] { 0xaf, 0xfe };
|
byte[] expectedBytes = [0xaf, 0xfe];
|
||||||
|
|
||||||
// act
|
// act
|
||||||
byte[] plainBytes1 = CryptographyHelper.AesDecrypt(cipherBytes, password1);
|
byte[] plainBytes1 = CryptographyHelper.AesDecrypt(cipherBytes, password1);
|
||||||
@@ -104,7 +104,7 @@ namespace UnitTests.Common.Utilities
|
|||||||
public void ShouldEncryptDecryptAesBytes()
|
public void ShouldEncryptDecryptAesBytes()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
byte[] plain = new byte[] { 0xaf, 0xfe };
|
byte[] plain = [0xaf, 0xfe];
|
||||||
string password = "P@ssw0rd!";
|
string password = "P@ssw0rd!";
|
||||||
|
|
||||||
// act
|
// act
|
||||||
@@ -154,12 +154,12 @@ namespace UnitTests.Common.Utilities
|
|||||||
// arrange
|
// arrange
|
||||||
using var _ = CryptographyHelperSaltMock.Create(0);
|
using var _ = CryptographyHelperSaltMock.Create(0);
|
||||||
|
|
||||||
byte[] bytes = new byte[] { 0xaf, 0xfe };
|
byte[] bytes = [0xaf, 0xfe];
|
||||||
string str = "ABC";
|
string str = "ABC";
|
||||||
string password1 = "P@ssw0rd!";
|
string password1 = "P@ssw0rd!";
|
||||||
string password2 = "P@ssw0rd";
|
string password2 = "P@ssw0rd";
|
||||||
|
|
||||||
byte[] expectedBytes = new byte[] { 0xbf, 0x59, 0x1f, 0x48, 0x69, 0xab, 0x18, 0xc7 };
|
byte[] expectedBytes = [0xbf, 0x59, 0x1f, 0x48, 0x69, 0xab, 0x18, 0xc7];
|
||||||
|
|
||||||
// act
|
// act
|
||||||
byte[] cipherBytes1 = CryptographyHelper.TripleDesEncrypt(bytes, password1);
|
byte[] cipherBytes1 = CryptographyHelper.TripleDesEncrypt(bytes, password1);
|
||||||
@@ -182,12 +182,12 @@ namespace UnitTests.Common.Utilities
|
|||||||
using var _ = CryptographyHelperSaltMock.Create(0);
|
using var _ = CryptographyHelperSaltMock.Create(0);
|
||||||
|
|
||||||
string cipherStr = "1l74soBuuEI=";
|
string cipherStr = "1l74soBuuEI=";
|
||||||
byte[] cipherBytes = new byte[] { 0xbf, 0x59, 0x1f, 0x48, 0x69, 0xab, 0x18, 0xc7 };
|
byte[] cipherBytes = [0xbf, 0x59, 0x1f, 0x48, 0x69, 0xab, 0x18, 0xc7];
|
||||||
|
|
||||||
string password1 = "P@ssw0rd!";
|
string password1 = "P@ssw0rd!";
|
||||||
string password2 = "P@ssw0rd";
|
string password2 = "P@ssw0rd";
|
||||||
|
|
||||||
byte[] expectedBytes = new byte[] { 0xaf, 0xfe };
|
byte[] expectedBytes = [0xaf, 0xfe];
|
||||||
|
|
||||||
// act
|
// act
|
||||||
byte[] plainBytes1 = CryptographyHelper.TripleDesDecrypt(cipherBytes, password1);
|
byte[] plainBytes1 = CryptographyHelper.TripleDesDecrypt(cipherBytes, password1);
|
||||||
@@ -218,7 +218,7 @@ namespace UnitTests.Common.Utilities
|
|||||||
public void ShouldEncryptDecryptTdesBytes()
|
public void ShouldEncryptDecryptTdesBytes()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
byte[] plain = new byte[] { 0xaf, 0xfe };
|
byte[] plain = [0xaf, 0xfe];
|
||||||
string password = "P@ssw0rd!";
|
string password = "P@ssw0rd!";
|
||||||
|
|
||||||
// act
|
// act
|
||||||
@@ -269,7 +269,7 @@ namespace UnitTests.Common.Utilities
|
|||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
string text = "Hello World!";
|
string text = "Hello World!";
|
||||||
byte[] bytes = new byte[] { 0xde, 0xad, 0xbe, 0xef };
|
byte[] bytes = [0xde, 0xad, 0xbe, 0xef];
|
||||||
string fileName = Path.GetTempFileName();
|
string fileName = Path.GetTempFileName();
|
||||||
|
|
||||||
// act
|
// act
|
||||||
@@ -291,7 +291,7 @@ namespace UnitTests.Common.Utilities
|
|||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
string text = "Hello World!";
|
string text = "Hello World!";
|
||||||
byte[] bytes = new byte[] { 0xde, 0xad, 0xbe, 0xef };
|
byte[] bytes = [0xde, 0xad, 0xbe, 0xef];
|
||||||
string fileName = Path.GetTempFileName();
|
string fileName = Path.GetTempFileName();
|
||||||
|
|
||||||
// act
|
// act
|
||||||
@@ -313,7 +313,7 @@ namespace UnitTests.Common.Utilities
|
|||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
string text = "Hello World!";
|
string text = "Hello World!";
|
||||||
byte[] bytes = new byte[] { 0xde, 0xad, 0xbe, 0xef };
|
byte[] bytes = [0xde, 0xad, 0xbe, 0xef];
|
||||||
string fileName = Path.GetTempFileName();
|
string fileName = Path.GetTempFileName();
|
||||||
|
|
||||||
// act
|
// act
|
||||||
@@ -335,7 +335,7 @@ namespace UnitTests.Common.Utilities
|
|||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
string text = "Hello World!";
|
string text = "Hello World!";
|
||||||
byte[] bytes = new byte[] { 0xde, 0xad, 0xbe, 0xef };
|
byte[] bytes = [0xde, 0xad, 0xbe, 0xef];
|
||||||
string fileName = Path.GetTempFileName();
|
string fileName = Path.GetTempFileName();
|
||||||
|
|
||||||
// act
|
// act
|
||||||
@@ -415,8 +415,8 @@ namespace UnitTests.Common.Utilities
|
|||||||
Assert.AreEqual(length, str1.Length);
|
Assert.AreEqual(length, str1.Length);
|
||||||
Assert.AreEqual(length, str2.Length);
|
Assert.AreEqual(length, str2.Length);
|
||||||
Assert.IsFalse(str1 == str2);
|
Assert.IsFalse(str1 == str2);
|
||||||
Assert.IsFalse(Regex.IsMatch(str1, "[^0-9a-f]"));
|
Assert.IsFalse(RandomStringWithPoolRegex().IsMatch(str1));
|
||||||
Assert.IsFalse(Regex.IsMatch(str2, "[^0-9a-f]"));
|
Assert.IsFalse(RandomStringWithPoolRegex().IsMatch(str2));
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion Random
|
#endregion Random
|
||||||
@@ -537,7 +537,6 @@ namespace UnitTests.Common.Utilities
|
|||||||
Assert.IsTrue(!string.IsNullOrWhiteSpace(content));
|
Assert.IsTrue(!string.IsNullOrWhiteSpace(content));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
public void ShouldEncryptAesUsingKeyFile()
|
public void ShouldEncryptAesUsingKeyFile()
|
||||||
{
|
{
|
||||||
@@ -545,11 +544,11 @@ namespace UnitTests.Common.Utilities
|
|||||||
string str = "Hello World!";
|
string str = "Hello World!";
|
||||||
byte[] bytes = CryptographyHelper.GetRandomBytes(32);
|
byte[] bytes = CryptographyHelper.GetRandomBytes(32);
|
||||||
|
|
||||||
string password = File.ReadAllText(keyFile);
|
string password = File.ReadAllText(_keyFile);
|
||||||
|
|
||||||
// act
|
// act
|
||||||
string cipherStr = cryptoHelper.EncryptAes(str);
|
string cipherStr = _cryptoHelper.EncryptAes(str);
|
||||||
byte[] cipherBytes = cryptoHelper.EncryptAes(bytes);
|
byte[] cipherBytes = _cryptoHelper.EncryptAes(bytes);
|
||||||
|
|
||||||
string plainStr = CryptographyHelper.AesDecrypt(cipherStr, password);
|
string plainStr = CryptographyHelper.AesDecrypt(cipherStr, password);
|
||||||
byte[] plainBytes = CryptographyHelper.AesDecrypt(cipherBytes, password);
|
byte[] plainBytes = CryptographyHelper.AesDecrypt(cipherBytes, password);
|
||||||
@@ -568,14 +567,14 @@ namespace UnitTests.Common.Utilities
|
|||||||
string str = "Hello World!";
|
string str = "Hello World!";
|
||||||
byte[] bytes = CryptographyHelper.GetRandomBytes(32);
|
byte[] bytes = CryptographyHelper.GetRandomBytes(32);
|
||||||
|
|
||||||
string password = File.ReadAllText(keyFile);
|
string password = File.ReadAllText(_keyFile);
|
||||||
|
|
||||||
// act
|
// act
|
||||||
string cipherStr = CryptographyHelper.AesEncrypt(str, password);
|
string cipherStr = CryptographyHelper.AesEncrypt(str, password);
|
||||||
byte[] cipherBytes = CryptographyHelper.AesEncrypt(bytes, password);
|
byte[] cipherBytes = CryptographyHelper.AesEncrypt(bytes, password);
|
||||||
|
|
||||||
string plainStr = cryptoHelper.DecryptAes(cipherStr);
|
string plainStr = _cryptoHelper.DecryptAes(cipherStr);
|
||||||
byte[] plainBytes = cryptoHelper.DecryptAes(cipherBytes);
|
byte[] plainBytes = _cryptoHelper.DecryptAes(cipherBytes);
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
Assert.AreNotEqual(str, cipherStr);
|
Assert.AreNotEqual(str, cipherStr);
|
||||||
@@ -591,11 +590,11 @@ namespace UnitTests.Common.Utilities
|
|||||||
string str = "Hello World!";
|
string str = "Hello World!";
|
||||||
byte[] bytes = CryptographyHelper.GetRandomBytes(32);
|
byte[] bytes = CryptographyHelper.GetRandomBytes(32);
|
||||||
|
|
||||||
string password = File.ReadAllText(keyFile);
|
string password = File.ReadAllText(_keyFile);
|
||||||
|
|
||||||
// act
|
// act
|
||||||
string cipherStr = cryptoHelper.EncryptTripleDes(str);
|
string cipherStr = _cryptoHelper.EncryptTripleDes(str);
|
||||||
byte[] cipherBytes = cryptoHelper.EncryptTripleDes(bytes);
|
byte[] cipherBytes = _cryptoHelper.EncryptTripleDes(bytes);
|
||||||
|
|
||||||
string plainStr = CryptographyHelper.TripleDesDecrypt(cipherStr, password);
|
string plainStr = CryptographyHelper.TripleDesDecrypt(cipherStr, password);
|
||||||
byte[] plainBytes = CryptographyHelper.TripleDesDecrypt(cipherBytes, password);
|
byte[] plainBytes = CryptographyHelper.TripleDesDecrypt(cipherBytes, password);
|
||||||
@@ -614,14 +613,14 @@ namespace UnitTests.Common.Utilities
|
|||||||
string str = "Hello World!";
|
string str = "Hello World!";
|
||||||
byte[] bytes = CryptographyHelper.GetRandomBytes(32);
|
byte[] bytes = CryptographyHelper.GetRandomBytes(32);
|
||||||
|
|
||||||
string password = File.ReadAllText(keyFile);
|
string password = File.ReadAllText(_keyFile);
|
||||||
|
|
||||||
// act
|
// act
|
||||||
string cipherStr = CryptographyHelper.TripleDesEncrypt(str, password);
|
string cipherStr = CryptographyHelper.TripleDesEncrypt(str, password);
|
||||||
byte[] cipherBytes = CryptographyHelper.TripleDesEncrypt(bytes, password);
|
byte[] cipherBytes = CryptographyHelper.TripleDesEncrypt(bytes, password);
|
||||||
|
|
||||||
string plainStr = cryptoHelper.DecryptTripleDes(cipherStr);
|
string plainStr = _cryptoHelper.DecryptTripleDes(cipherStr);
|
||||||
byte[] plainBytes = cryptoHelper.DecryptTripleDes(cipherBytes);
|
byte[] plainBytes = _cryptoHelper.DecryptTripleDes(cipherBytes);
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
Assert.AreNotEqual(str, cipherStr);
|
Assert.AreNotEqual(str, cipherStr);
|
||||||
@@ -630,6 +629,9 @@ namespace UnitTests.Common.Utilities
|
|||||||
CollectionAssert.AreEqual(bytes, plainBytes);
|
CollectionAssert.AreEqual(bytes, plainBytes);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[GeneratedRegex("[^0-9a-f]")]
|
||||||
|
private static partial Regex RandomStringWithPoolRegex();
|
||||||
|
|
||||||
#endregion Instance
|
#endregion Instance
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -17,11 +17,11 @@ namespace UnitTests.Common.Utilities
|
|||||||
// arrange
|
// arrange
|
||||||
int executionCount = 0;
|
int executionCount = 0;
|
||||||
var delay = TimeSpan.FromMilliseconds(100);
|
var delay = TimeSpan.FromMilliseconds(100);
|
||||||
var action = () => { executionCount++; };
|
void Action() { executionCount++; }
|
||||||
|
|
||||||
// act
|
// act
|
||||||
var cts = new CancellationTokenSource(delay.Add(TimeSpan.FromSeconds(1)));
|
var cts = new CancellationTokenSource(delay.Add(TimeSpan.FromSeconds(1)));
|
||||||
var delayedTask = DelayedTask.Create(action, delay);
|
var delayedTask = DelayedTask.Create(Action, delay);
|
||||||
SpinWait.SpinUntil(() => executionCount > 0 || cts.IsCancellationRequested);
|
SpinWait.SpinUntil(() => executionCount > 0 || cts.IsCancellationRequested);
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
@@ -39,11 +39,11 @@ namespace UnitTests.Common.Utilities
|
|||||||
// arrange
|
// arrange
|
||||||
int executionCount = 0;
|
int executionCount = 0;
|
||||||
var delay = TimeSpan.FromMilliseconds(100);
|
var delay = TimeSpan.FromMilliseconds(100);
|
||||||
var action = () => { executionCount++; };
|
void Action() { executionCount++; }
|
||||||
|
|
||||||
// act
|
// act
|
||||||
var cts = new CancellationTokenSource(delay.Add(TimeSpan.FromSeconds(1)));
|
var cts = new CancellationTokenSource(delay.Add(TimeSpan.FromSeconds(1)));
|
||||||
var delayedTask = DelayedTask.Run(action, delay);
|
var delayedTask = DelayedTask.Run(Action, delay);
|
||||||
SpinWait.SpinUntil(() => executionCount > 0 || cts.IsCancellationRequested);
|
SpinWait.SpinUntil(() => executionCount > 0 || cts.IsCancellationRequested);
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
@@ -61,11 +61,11 @@ namespace UnitTests.Common.Utilities
|
|||||||
// arrange
|
// arrange
|
||||||
int executionCount = 0;
|
int executionCount = 0;
|
||||||
var delay = TimeSpan.FromMilliseconds(100);
|
var delay = TimeSpan.FromMilliseconds(100);
|
||||||
var action = () => { executionCount++; };
|
void Action() { executionCount++; }
|
||||||
|
|
||||||
// act
|
// act
|
||||||
var cts = new CancellationTokenSource(delay.Add(TimeSpan.FromSeconds(1)));
|
var cts = new CancellationTokenSource(delay.Add(TimeSpan.FromSeconds(1)));
|
||||||
var delayedTask = DelayedTask.Create(action, delay);
|
var delayedTask = DelayedTask.Create(Action, delay);
|
||||||
delayedTask.Reset();
|
delayedTask.Reset();
|
||||||
SpinWait.SpinUntil(() => executionCount > 0 || cts.IsCancellationRequested);
|
SpinWait.SpinUntil(() => executionCount > 0 || cts.IsCancellationRequested);
|
||||||
|
|
||||||
@@ -84,11 +84,11 @@ namespace UnitTests.Common.Utilities
|
|||||||
// arrange
|
// arrange
|
||||||
int executionCount = 0;
|
int executionCount = 0;
|
||||||
var delay = TimeSpan.FromMilliseconds(100);
|
var delay = TimeSpan.FromMilliseconds(100);
|
||||||
var action = () => { executionCount++; };
|
void Action() { executionCount++; }
|
||||||
|
|
||||||
// act
|
// act
|
||||||
var cts = new CancellationTokenSource(delay.Add(TimeSpan.FromSeconds(1)));
|
var cts = new CancellationTokenSource(delay.Add(TimeSpan.FromSeconds(1)));
|
||||||
var delayedTask = DelayedTask.Run(action, delay);
|
var delayedTask = DelayedTask.Run(Action, delay);
|
||||||
delayedTask.Cancel();
|
delayedTask.Cancel();
|
||||||
SpinWait.SpinUntil(() => executionCount > 0 || cts.IsCancellationRequested);
|
SpinWait.SpinUntil(() => executionCount > 0 || cts.IsCancellationRequested);
|
||||||
|
|
||||||
@@ -109,12 +109,12 @@ namespace UnitTests.Common.Utilities
|
|||||||
var sw = new Stopwatch();
|
var sw = new Stopwatch();
|
||||||
|
|
||||||
var delay = TimeSpan.FromMilliseconds(200);
|
var delay = TimeSpan.FromMilliseconds(200);
|
||||||
var action = () => { sw.Stop(); executionCount++; };
|
void Action() { sw.Stop(); executionCount++; }
|
||||||
|
|
||||||
// act
|
// act
|
||||||
var cts = new CancellationTokenSource(delay.Add(TimeSpan.FromSeconds(1)));
|
var cts = new CancellationTokenSource(delay.Add(TimeSpan.FromSeconds(1)));
|
||||||
sw.Start();
|
sw.Start();
|
||||||
var delayedTask = DelayedTask.Run(action, delay);
|
var delayedTask = DelayedTask.Run(Action, delay);
|
||||||
await Task.Delay(50);
|
await Task.Delay(50);
|
||||||
delayedTask.Reset();
|
delayedTask.Reset();
|
||||||
SpinWait.SpinUntil(() => executionCount > 0 || cts.IsCancellationRequested);
|
SpinWait.SpinUntil(() => executionCount > 0 || cts.IsCancellationRequested);
|
||||||
@@ -138,12 +138,12 @@ namespace UnitTests.Common.Utilities
|
|||||||
var sw = new Stopwatch();
|
var sw = new Stopwatch();
|
||||||
|
|
||||||
var delay = TimeSpan.FromMilliseconds(200);
|
var delay = TimeSpan.FromMilliseconds(200);
|
||||||
var action = () => { sw.Stop(); executionCount++; };
|
void Action() { sw.Stop(); executionCount++; }
|
||||||
|
|
||||||
// act
|
// act
|
||||||
var cts = new CancellationTokenSource(delay.Add(TimeSpan.FromSeconds(1)));
|
var cts = new CancellationTokenSource(delay.Add(TimeSpan.FromSeconds(1)));
|
||||||
sw.Start();
|
sw.Start();
|
||||||
var delayedTask = DelayedTask.Create(action, delay);
|
var delayedTask = DelayedTask.Create(Action, delay);
|
||||||
await Task.Delay(50);
|
await Task.Delay(50);
|
||||||
bool isSuccess = delayedTask.ExecutePending();
|
bool isSuccess = delayedTask.ExecutePending();
|
||||||
SpinWait.SpinUntil(() => executionCount > 0 || cts.IsCancellationRequested);
|
SpinWait.SpinUntil(() => executionCount > 0 || cts.IsCancellationRequested);
|
||||||
@@ -169,12 +169,12 @@ namespace UnitTests.Common.Utilities
|
|||||||
var sw = new Stopwatch();
|
var sw = new Stopwatch();
|
||||||
|
|
||||||
var delay = TimeSpan.FromMilliseconds(200);
|
var delay = TimeSpan.FromMilliseconds(200);
|
||||||
var action = () => { sw.Stop(); executionCount++; };
|
void Action() { sw.Stop(); executionCount++; }
|
||||||
|
|
||||||
// act
|
// act
|
||||||
var cts = new CancellationTokenSource(delay.Add(TimeSpan.FromSeconds(1)));
|
var cts = new CancellationTokenSource(delay.Add(TimeSpan.FromSeconds(1)));
|
||||||
sw.Start();
|
sw.Start();
|
||||||
var delayedTask = DelayedTask.Run(action, delay);
|
var delayedTask = DelayedTask.Run(Action, delay);
|
||||||
await Task.Delay(50);
|
await Task.Delay(50);
|
||||||
bool isSuccess = delayedTask.ExecutePending();
|
bool isSuccess = delayedTask.ExecutePending();
|
||||||
SpinWait.SpinUntil(() => executionCount > 0 || cts.IsCancellationRequested);
|
SpinWait.SpinUntil(() => executionCount > 0 || cts.IsCancellationRequested);
|
||||||
@@ -197,8 +197,8 @@ namespace UnitTests.Common.Utilities
|
|||||||
// arrange
|
// arrange
|
||||||
int executionCount = 0;
|
int executionCount = 0;
|
||||||
var delay = TimeSpan.FromMilliseconds(100);
|
var delay = TimeSpan.FromMilliseconds(100);
|
||||||
var action = () => { executionCount++; };
|
void Action() { executionCount++; }
|
||||||
var delayedTask = DelayedTask.Create(action, delay);
|
var delayedTask = DelayedTask.Create(Action, delay);
|
||||||
|
|
||||||
// act
|
// act
|
||||||
delayedTask.Reset();
|
delayedTask.Reset();
|
||||||
@@ -219,10 +219,10 @@ namespace UnitTests.Common.Utilities
|
|||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
var delay = TimeSpan.FromMilliseconds(100);
|
var delay = TimeSpan.FromMilliseconds(100);
|
||||||
var action = () => { throw new Exception("TEST :D"); };
|
static void Action() { throw new Exception("TEST :D"); }
|
||||||
|
|
||||||
// act
|
// act
|
||||||
var delayedTask = DelayedTask.Run(action, delay);
|
var delayedTask = DelayedTask.Run(Action, delay);
|
||||||
|
|
||||||
var awaiter = delayedTask.GetAwaiter();
|
var awaiter = delayedTask.GetAwaiter();
|
||||||
SpinWait.SpinUntil(() => awaiter.IsCompleted);
|
SpinWait.SpinUntil(() => awaiter.IsCompleted);
|
||||||
@@ -240,15 +240,12 @@ namespace UnitTests.Common.Utilities
|
|||||||
// arrange
|
// arrange
|
||||||
string exceptionText = null;
|
string exceptionText = null;
|
||||||
var delay = TimeSpan.FromMilliseconds(100);
|
var delay = TimeSpan.FromMilliseconds(100);
|
||||||
var action = () => { throw new Exception("TEST :D"); };
|
void Action() { throw new Exception("TEST :D"); }
|
||||||
var exceptionHandler = (Exception ex) =>
|
void ExceptionHandler(Exception ex) { exceptionText = ex.Message; }
|
||||||
{
|
|
||||||
exceptionText = ex.Message;
|
|
||||||
};
|
|
||||||
|
|
||||||
// act
|
// act
|
||||||
var delayedTask = DelayedTask.Run(action, delay)
|
var delayedTask = DelayedTask.Run(Action, delay)
|
||||||
.WithExceptionHandler(exceptionHandler);
|
.WithExceptionHandler(ExceptionHandler);
|
||||||
|
|
||||||
var awaiter = delayedTask.GetAwaiter();
|
var awaiter = delayedTask.GetAwaiter();
|
||||||
SpinWait.SpinUntil(() => awaiter.IsCompleted);
|
SpinWait.SpinUntil(() => awaiter.IsCompleted);
|
||||||
@@ -267,8 +264,8 @@ namespace UnitTests.Common.Utilities
|
|||||||
// arrange
|
// arrange
|
||||||
int executionCount = 0;
|
int executionCount = 0;
|
||||||
var delay = TimeSpan.FromMilliseconds(100);
|
var delay = TimeSpan.FromMilliseconds(100);
|
||||||
var action = () => { executionCount++; };
|
void Action() { executionCount++; }
|
||||||
var delayedTask = DelayedTask.Create(action, delay);
|
var delayedTask = DelayedTask.Create(Action, delay);
|
||||||
|
|
||||||
// act
|
// act
|
||||||
delayedTask.Reset();
|
delayedTask.Reset();
|
||||||
|
|||||||
@@ -1,5 +1,4 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.Diagnostics;
|
|
||||||
using System.Threading;
|
using System.Threading;
|
||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
using AMWD.Common.Utilities;
|
using AMWD.Common.Utilities;
|
||||||
@@ -17,11 +16,11 @@ namespace UnitTests.Common.Utilities
|
|||||||
// arrange
|
// arrange
|
||||||
int executionCount = 0;
|
int executionCount = 0;
|
||||||
var delay = TimeSpan.FromMilliseconds(100);
|
var delay = TimeSpan.FromMilliseconds(100);
|
||||||
var function = () => { executionCount++; return new[] { 42, 21 }; };
|
int[] Function() { executionCount++; return [42, 21]; }
|
||||||
|
|
||||||
// act
|
// act
|
||||||
var cts = new CancellationTokenSource(delay.Add(TimeSpan.FromSeconds(1)));
|
var cts = new CancellationTokenSource(delay.Add(TimeSpan.FromSeconds(1)));
|
||||||
var delayedTaskWithResult = DelayedTask.Create(function, delay);
|
var delayedTaskWithResult = DelayedTask.Create(Function, delay);
|
||||||
SpinWait.SpinUntil(() => executionCount > 0 || cts.IsCancellationRequested);
|
SpinWait.SpinUntil(() => executionCount > 0 || cts.IsCancellationRequested);
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
@@ -34,15 +33,16 @@ namespace UnitTests.Common.Utilities
|
|||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
|
[System.Diagnostics.CodeAnalysis.SuppressMessage("Performance", "CA1861")]
|
||||||
public async Task ShouldCreateNewDelayedTaskStarting()
|
public async Task ShouldCreateNewDelayedTaskStarting()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
int executionCount = 0;
|
int executionCount = 0;
|
||||||
var delay = TimeSpan.FromMilliseconds(100);
|
var delay = TimeSpan.FromMilliseconds(100);
|
||||||
var function = () => { executionCount++; return new[] { 42, 21 }; };
|
int[] Function() { executionCount++; return [42, 21]; }
|
||||||
|
|
||||||
// act
|
// act
|
||||||
var delayedTaskWithResult = DelayedTask.Run(function, delay);
|
var delayedTaskWithResult = DelayedTask.Run(Function, delay);
|
||||||
int[] result = await delayedTaskWithResult;
|
int[] result = await delayedTaskWithResult;
|
||||||
|
|
||||||
// assert
|
// assert
|
||||||
@@ -61,11 +61,11 @@ namespace UnitTests.Common.Utilities
|
|||||||
// arrange
|
// arrange
|
||||||
var delay = TimeSpan.FromMilliseconds(100);
|
var delay = TimeSpan.FromMilliseconds(100);
|
||||||
#pragma warning disable CS0162 // Unreachable Code detected.
|
#pragma warning disable CS0162 // Unreachable Code detected.
|
||||||
var function = () => { throw new Exception("TEST :D"); return new[] { 42, 21 }; };
|
static int[] Function() { throw new Exception("TEST :D"); return [42, 21]; }
|
||||||
#pragma warning restore CS0162 // Unreachable Code detected
|
#pragma warning restore CS0162 // Unreachable Code detected
|
||||||
|
|
||||||
// act
|
// act
|
||||||
var delayedTaskWithResult = DelayedTask.Run(function, delay);
|
var delayedTaskWithResult = DelayedTask.Run(Function, delay);
|
||||||
|
|
||||||
var awaiter = delayedTaskWithResult.GetAwaiter();
|
var awaiter = delayedTaskWithResult.GetAwaiter();
|
||||||
SpinWait.SpinUntil(() => awaiter.IsCompleted);
|
SpinWait.SpinUntil(() => awaiter.IsCompleted);
|
||||||
@@ -84,16 +84,13 @@ namespace UnitTests.Common.Utilities
|
|||||||
string exceptionText = null;
|
string exceptionText = null;
|
||||||
var delay = TimeSpan.FromMilliseconds(100);
|
var delay = TimeSpan.FromMilliseconds(100);
|
||||||
#pragma warning disable CS0162 // Unreachable Code detected.
|
#pragma warning disable CS0162 // Unreachable Code detected.
|
||||||
var function = () => { throw new Exception("TEST :D"); return new[] { 42, 21 }; };
|
static int[] Function() { throw new Exception("TEST :D"); return [42, 21]; }
|
||||||
#pragma warning restore CS0162 // Unreachable Code detected
|
#pragma warning restore CS0162 // Unreachable Code detected
|
||||||
var exceptionHandler = (Exception ex) =>
|
void ExceptionHandler(Exception ex) { exceptionText = ex.Message; }
|
||||||
{
|
|
||||||
exceptionText = ex.Message;
|
|
||||||
};
|
|
||||||
|
|
||||||
// act
|
// act
|
||||||
var delayedTaskWithResult = DelayedTask.Run(function, delay)
|
var delayedTaskWithResult = DelayedTask.Run(Function, delay)
|
||||||
.WithExceptionHandler(exceptionHandler);
|
.WithExceptionHandler(ExceptionHandler);
|
||||||
|
|
||||||
var awaiter = delayedTaskWithResult.GetAwaiter();
|
var awaiter = delayedTaskWithResult.GetAwaiter();
|
||||||
SpinWait.SpinUntil(() => awaiter.IsCompleted);
|
SpinWait.SpinUntil(() => awaiter.IsCompleted);
|
||||||
@@ -107,13 +104,14 @@ namespace UnitTests.Common.Utilities
|
|||||||
}
|
}
|
||||||
|
|
||||||
[TestMethod]
|
[TestMethod]
|
||||||
|
[System.Diagnostics.CodeAnalysis.SuppressMessage("Performance", "CA1861")]
|
||||||
public async Task ShouldReturnNormalTask()
|
public async Task ShouldReturnNormalTask()
|
||||||
{
|
{
|
||||||
// arrange
|
// arrange
|
||||||
int executionCount = 0;
|
int executionCount = 0;
|
||||||
var delay = TimeSpan.FromMilliseconds(100);
|
var delay = TimeSpan.FromMilliseconds(100);
|
||||||
var function = () => { executionCount++; return new[] { 42, 21 }; };
|
int[] Function() { executionCount++; return [42, 21]; }
|
||||||
var delayedTaskWithResult = DelayedTask.Create(function, delay);
|
var delayedTaskWithResult = DelayedTask.Create(Function, delay);
|
||||||
|
|
||||||
// act
|
// act
|
||||||
delayedTaskWithResult.Reset();
|
delayedTaskWithResult.Reset();
|
||||||
|
|||||||
@@ -7,11 +7,11 @@ namespace UnitTests.Common.Utils
|
|||||||
[System.Diagnostics.CodeAnalysis.ExcludeFromCodeCoverage]
|
[System.Diagnostics.CodeAnalysis.ExcludeFromCodeCoverage]
|
||||||
internal class CryptographyHelperSaltMock : IDisposable
|
internal class CryptographyHelperSaltMock : IDisposable
|
||||||
{
|
{
|
||||||
private readonly int saltLength;
|
private readonly int _saltLength;
|
||||||
|
|
||||||
private CryptographyHelperSaltMock(int saltLength)
|
private CryptographyHelperSaltMock(int saltLength)
|
||||||
{
|
{
|
||||||
this.saltLength = typeof(CryptographyHelper).AsDynamicType().saltLength;
|
_saltLength = typeof(CryptographyHelper).AsDynamicType()._saltLength;
|
||||||
SetSaltLength(saltLength);
|
SetSaltLength(saltLength);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -19,9 +19,9 @@ namespace UnitTests.Common.Utils
|
|||||||
=> new CryptographyHelperSaltMock(saltLength);
|
=> new CryptographyHelperSaltMock(saltLength);
|
||||||
|
|
||||||
public void Dispose()
|
public void Dispose()
|
||||||
=> SetSaltLength(saltLength);
|
=> SetSaltLength(_saltLength);
|
||||||
|
|
||||||
private static void SetSaltLength(int length)
|
private static void SetSaltLength(int length)
|
||||||
=> typeof(CryptographyHelper).AsDynamicType().saltLength = length;
|
=> typeof(CryptographyHelper).AsDynamicType()._saltLength = length;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -4,13 +4,8 @@ namespace UnitTests.Common.Utils
|
|||||||
{
|
{
|
||||||
[System.Diagnostics.CodeAnalysis.ExcludeFromCodeCoverage]
|
[System.Diagnostics.CodeAnalysis.ExcludeFromCodeCoverage]
|
||||||
[AttributeUsage(AttributeTargets.All, AllowMultiple = true)]
|
[AttributeUsage(AttributeTargets.All, AllowMultiple = true)]
|
||||||
internal class CustomMultipleAttribute : Attribute
|
internal class CustomMultipleAttribute(string name) : Attribute
|
||||||
{
|
{
|
||||||
public CustomMultipleAttribute(string name)
|
public string Name { get; set; } = name;
|
||||||
{
|
|
||||||
Name = name;
|
|
||||||
}
|
|
||||||
|
|
||||||
public string Name { get; set; }
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -33,18 +33,21 @@ namespace UnitTests.Common.Utils
|
|||||||
[System.Diagnostics.CodeAnalysis.ExcludeFromCodeCoverage]
|
[System.Diagnostics.CodeAnalysis.ExcludeFromCodeCoverage]
|
||||||
internal class JsonErrorClass
|
internal class JsonErrorClass
|
||||||
{
|
{
|
||||||
private int? number;
|
private int? _number;
|
||||||
|
|
||||||
public int Number
|
public int Number
|
||||||
{
|
{
|
||||||
get
|
get
|
||||||
{
|
{
|
||||||
if (number.HasValue)
|
if (_number.HasValue)
|
||||||
return number.Value;
|
return _number.Value;
|
||||||
|
|
||||||
throw new Exception("Null value");
|
throw new Exception("Null value");
|
||||||
}
|
}
|
||||||
set { number = value; }
|
set
|
||||||
|
{
|
||||||
|
_number = value;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -6,11 +6,11 @@ namespace UnitTests.Common.Utils
|
|||||||
[System.Diagnostics.CodeAnalysis.ExcludeFromCodeCoverage]
|
[System.Diagnostics.CodeAnalysis.ExcludeFromCodeCoverage]
|
||||||
internal class TimeZoneInfoLocalMock : IDisposable
|
internal class TimeZoneInfoLocalMock : IDisposable
|
||||||
{
|
{
|
||||||
private readonly TimeZoneInfo localTimeZoneInfo;
|
private readonly TimeZoneInfo _localTimeZoneInfo;
|
||||||
|
|
||||||
private TimeZoneInfoLocalMock(TimeZoneInfo timeZoneInfo)
|
private TimeZoneInfoLocalMock(TimeZoneInfo timeZoneInfo)
|
||||||
{
|
{
|
||||||
localTimeZoneInfo = TimeZoneInfo.Local;
|
_localTimeZoneInfo = TimeZoneInfo.Local;
|
||||||
SetLocalTimeZone(timeZoneInfo);
|
SetLocalTimeZone(timeZoneInfo);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -18,7 +18,7 @@ namespace UnitTests.Common.Utils
|
|||||||
=> new TimeZoneInfoLocalMock(mockTimeZoneInfo);
|
=> new TimeZoneInfoLocalMock(mockTimeZoneInfo);
|
||||||
|
|
||||||
public void Dispose()
|
public void Dispose()
|
||||||
=> SetLocalTimeZone(localTimeZoneInfo);
|
=> SetLocalTimeZone(_localTimeZoneInfo);
|
||||||
|
|
||||||
private static void SetLocalTimeZone(TimeZoneInfo timeZoneInfo)
|
private static void SetLocalTimeZone(TimeZoneInfo timeZoneInfo)
|
||||||
=> typeof(TimeZoneInfo).AsDynamicType().s_cachedData._localTimeZone = timeZoneInfo;
|
=> typeof(TimeZoneInfo).AsDynamicType().s_cachedData._localTimeZone = timeZoneInfo;
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
<Project Sdk="Microsoft.NET.Sdk">
|
<Project Sdk="Microsoft.NET.Sdk">
|
||||||
|
|
||||||
<PropertyGroup>
|
<PropertyGroup>
|
||||||
<TargetFramework>net6.0</TargetFramework>
|
<TargetFramework>net8.0</TargetFramework>
|
||||||
<IsPackable>false</IsPackable>
|
<IsPackable>false</IsPackable>
|
||||||
<CollectCoverage>true</CollectCoverage>
|
<CollectCoverage>true</CollectCoverage>
|
||||||
<GenerateDocumentationFile>false</GenerateDocumentationFile>
|
<GenerateDocumentationFile>false</GenerateDocumentationFile>
|
||||||
|
|||||||
Reference in New Issue
Block a user