Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Finish migrating to C# 10.0 and cleanup #43

Merged
merged 2 commits into from
Sep 2, 2022
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
42 changes: 20 additions & 22 deletions IntelliTect.Multitool.Tests/ClaimsPrincipalGetRolesTests.cs
Original file line number Diff line number Diff line change
@@ -1,35 +1,33 @@
using System;
using IntelliTect.Multitool.Security;
using System.Security.Claims;
using System.Security.Principal;
using IntelliTect.Multitool.Security;
using Xunit;

namespace IntelliTect.Multitool.Tests
namespace IntelliTect.Multitool.Tests;

public class ClaimsPrincipalGetRolesTests
{
public class ClaimsPrincipalGetRolesTests
[Fact]
public void WhenClaimsPrincipalNull_Should_Throw()
{
[Fact]
public void WhenClaimsPrincipalNull_Should_Throw()
{
ClaimsPrincipal? sut = null;
ClaimsPrincipal? sut = null;

Assert.Throws<ArgumentNullException>(() => sut!.GetRoles());
}
Assert.Throws<ArgumentNullException>(() => sut!.GetRoles());
}

[Fact]
public void WhenClaimsPrincipalHasNoRoles_Should_ReturnEmpty()
{
ClaimsPrincipal sut = new ClaimsPrincipal();
[Fact]
public void WhenClaimsPrincipalHasNoRoles_Should_ReturnEmpty()
{
ClaimsPrincipal sut = new();

Assert.Empty(sut.GetRoles());
}
Assert.Empty(sut.GetRoles());
}

[Fact]
public void WhenClaimsPrincipalHasRoles_Should_ReturnNotEmpty()
{
ClaimsPrincipal sut = new GenericPrincipal(new GenericIdentity("Uncle Festus"), new[] {"Foo", "Bar"});
[Fact]
public void WhenClaimsPrincipalHasRoles_Should_ReturnNotEmpty()
{
ClaimsPrincipal sut = new GenericPrincipal(new GenericIdentity("Uncle Festus"), new[] { "Foo", "Bar" });

Assert.Collection(sut.GetRoles(), s => Assert.Equal("Foo", s), t => Assert.Equal("Bar", t) );
}
Assert.Collection(sut.GetRoles(), s => Assert.Equal("Foo", s), t => Assert.Equal("Bar", t));
}
}
7 changes: 3 additions & 4 deletions IntelliTect.Multitool.Tests/ClaimsPrincipalGetUserIdTests.cs
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
using System;
using IntelliTect.Multitool.Security;
using System.Security.Claims;
using System.Security.Principal;
using IntelliTect.Multitool.Security;
using Xunit;

namespace IntelliTect.Multitool.Tests;
Expand All @@ -19,15 +18,15 @@ public void WhenClaimsPrincipalNull_Should_Throw()
[Fact]
public void WhenClaimsPrincipalHasNoProperty_Should_ReturnNull()
{
ClaimsPrincipal sut = new ClaimsPrincipal();
ClaimsPrincipal sut = new();

Assert.Null(sut.GetUserId());
}

[Fact]
public void WhenClaimsPrincipalHasId_Should_ReturnString()
{
ClaimsPrincipal sut = new GenericPrincipal(new GenericIdentity("Taki The Frog"), new []{ "Bar" } );
ClaimsPrincipal sut = new GenericPrincipal(new GenericIdentity("Taki The Frog"), new[] { "Bar" });

Assert.Equal("Taki The Frog", sut.GetUserId());
}
Expand Down
5 changes: 1 addition & 4 deletions IntelliTect.Multitool.Tests/RepositoryPaths.Tests.cs
Original file line number Diff line number Diff line change
@@ -1,7 +1,4 @@
using System;
using System.Security.Claims;
using System.Security.Principal;
using Xunit;
using Xunit;

namespace IntelliTect.Multitool.Tests;

Expand Down
73 changes: 35 additions & 38 deletions IntelliTect.Multitool/AssemblyInfo.cs
Original file line number Diff line number Diff line change
@@ -1,55 +1,52 @@
using System;
using System.IO;
using System.Reflection;
using System.Reflection;

namespace IntelliTect.Multitool
namespace IntelliTect.Multitool;

/// <summary>
/// Information about the executing assembly.
/// </summary>
public static class AssemblyInfo
{
private static DateTime? _Date;

/// <summary>
/// Information about the executing assembly.
/// Gets the linker date from the assembly header.
/// </summary>
public static class AssemblyInfo
public static DateTime Date
{
private static DateTime? _Date;

/// <summary>
/// Gets the linker date from the assembly header.
/// </summary>
public static DateTime Date
get
{
get
if (_Date == null)
{
if (_Date == null)
{
_Date = GetLinkerTime(Assembly.GetExecutingAssembly());
}
return _Date.Value;
_Date = GetLinkerTime(Assembly.GetExecutingAssembly());
}
return _Date.Value;
}
}

/// <summary>
/// Gets the linker date of the assembly.
/// </summary>
/// <param name="assembly"></param>
/// <returns></returns>
/// <remarks>https://blog.codinghorror.com/determining-build-date-the-hard-way/</remarks>
private static DateTime GetLinkerTime(Assembly assembly)
{
var filePath = assembly.Location;
const int cPeHeaderOffset = 60;
const int cLinkerTimestampOffset = 8;
/// <summary>
/// Gets the linker date of the assembly.
/// </summary>
/// <param name="assembly"></param>
/// <returns></returns>
/// <remarks>https://blog.codinghorror.com/determining-build-date-the-hard-way/</remarks>
private static DateTime GetLinkerTime(Assembly assembly)
{
var filePath = assembly.Location;
const int cPeHeaderOffset = 60;
const int cLinkerTimestampOffset = 8;

var buffer = new byte[2048];
var buffer = new byte[2048];

using (var stream = new FileStream(filePath, FileMode.Open, FileAccess.Read))
stream.Read(buffer, 0, 2048);
using (var stream = new FileStream(filePath, FileMode.Open, FileAccess.Read))
stream.Read(buffer, 0, 2048);

var offset = BitConverter.ToInt32(buffer, cPeHeaderOffset);
var secondsSince1970 = BitConverter.ToInt32(buffer, offset + cLinkerTimestampOffset);
var epoch = new DateTime(1970, 1, 1, 0, 0, 0, DateTimeKind.Utc);
var offset = BitConverter.ToInt32(buffer, cPeHeaderOffset);
var secondsSince1970 = BitConverter.ToInt32(buffer, offset + cLinkerTimestampOffset);
var epoch = new DateTime(1970, 1, 1, 0, 0, 0, DateTimeKind.Utc);

var linkTimeUtc = epoch.AddSeconds(secondsSince1970);
var linkTimeUtc = epoch.AddSeconds(secondsSince1970);

return linkTimeUtc;
}
return linkTimeUtc;
}
}
3 changes: 1 addition & 2 deletions IntelliTect.Multitool/Properties/AssemblyInfo.cs
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
using System;
using System.Runtime.InteropServices;
using System.Runtime.InteropServices;


[assembly: CLSCompliant(true)]
Expand Down
5 changes: 1 addition & 4 deletions IntelliTect.Multitool/Security/ClaimsPrincipalExtensions.cs
Original file line number Diff line number Diff line change
@@ -1,7 +1,4 @@
using System;
using System.Collections.Generic;
using System.Linq;
using System.Security.Claims;
using System.Security.Claims;

namespace IntelliTect.Multitool.Security;

Expand Down