Skip to content

Commit 6b2c0e9

Browse files
googyiabergs
authored andcommitted
Improve trustanchor test coverage
Improve trustanchor test coverage based on codecov report
1 parent 9e96e9f commit 6b2c0e9

7 files changed

+416
-1
lines changed

Test/Fido2Tests.cs

Lines changed: 62 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -16,7 +16,7 @@
1616
using Moq;
1717

1818
using NSec.Cryptography;
19-
19+
using Test;
2020
using static Fido2NetLib.AuthenticatorAttestationResponse;
2121

2222
namespace fido2_net_lib.Test;
@@ -76,6 +76,17 @@ static Fido2Tests()
7676
];
7777
}
7878

79+
private TestMetadataService CreateMetadataService(string cacheDir)
80+
{
81+
var repos = new List<IMetadataRepository>
82+
{
83+
new FileSystemMetadataRepository(cacheDir)
84+
};
85+
var simpleService = new TestMetadataService(repos);
86+
simpleService.InitializeAsync().Wait();
87+
return simpleService;
88+
}
89+
7990
private async Task<T> GetAsync<T>(string filename)
8091
{
8192
return JsonSerializer.Deserialize<T>(await File.ReadAllTextAsync(filename));
@@ -536,6 +547,56 @@ public async Task TestU2FAttestationAsync()
536547
await o.VerifyAsync(options, _config, (x, cancellationToken) => Task.FromResult(true), _metadataService, null, CancellationToken.None);
537548
}
538549

550+
[Fact]
551+
public async Task TestPackedttestationAsyncFailTrustAnchorOnRootCertInTrustPath()
552+
{
553+
var targetGuid = new Guid("42383245-4437-3343-3846-423445354132");
554+
var metadataService = CreateMetadataService("./metadata");
555+
metadataService.ChangeEntryGuid(new Guid("00000000-0000-0000-0000-000000000004"), targetGuid);
556+
var jsonPost = JsonSerializer.Deserialize<AuthenticatorAttestationRawResponse>(await File.ReadAllTextAsync("./attestationResultsPacked.json"));
557+
var options = JsonSerializer.Deserialize<CredentialCreateOptions>(await File.ReadAllTextAsync("./attestationOptionsPacked.json"));
558+
var o = AuthenticatorAttestationResponse.Parse(jsonPost);
559+
CborArray X5c = o.AttestationObject.AttStmt["x5c"] as CborArray;
560+
var entry = await metadataService.GetEntryAsync(targetGuid);
561+
foreach (var attRootCert in entry.MetadataStatement.AttestationRootCertificates)
562+
X5c.Add(Encoding.UTF8.GetBytes(attRootCert));
563+
564+
await Assert.ThrowsAsync<Fido2VerificationException>(() => o.VerifyAsync(options, _config, (x, cancellationToken) => Task.FromResult(true), metadataService, null, CancellationToken.None));
565+
}
566+
567+
[Fact]
568+
public async Task TestU2FAttestationAsyncFailTrustAnchorBasicFull()
569+
{
570+
var metadataService = CreateMetadataService("./metadata");
571+
metadataService.ChangeEntryGuid(new Guid("00000000-0000-0000-0000-000000000001"), new Guid("00000000-0000-0000-0000-000000000000"));
572+
var jsonPost = JsonSerializer.Deserialize<AuthenticatorAttestationRawResponse>(await File.ReadAllTextAsync("./attestationResultsU2F.json"));
573+
var options = JsonSerializer.Deserialize<CredentialCreateOptions>(await File.ReadAllTextAsync("./attestationOptionsU2F.json"));
574+
var o = AuthenticatorAttestationResponse.Parse(jsonPost);
575+
await Assert.ThrowsAsync<Fido2VerificationException>(() => o.VerifyAsync(options, _config, (x, cancellationToken) => Task.FromResult(true), metadataService, null, CancellationToken.None));
576+
}
577+
578+
[Fact]
579+
public async Task TestU2FAttestationAsyncCantFailTrustAnchorAnonca()
580+
{
581+
var metadataService = CreateMetadataService("./metadata");
582+
metadataService.ChangeEntryGuid(new Guid("00000000-0000-0000-0000-000000000002"), new Guid("00000000-0000-0000-0000-000000000000"));
583+
var jsonPost = JsonSerializer.Deserialize<AuthenticatorAttestationRawResponse>(await File.ReadAllTextAsync("./attestationResultsU2F.json"));
584+
var options = JsonSerializer.Deserialize<CredentialCreateOptions>(await File.ReadAllTextAsync("./attestationOptionsU2F.json"));
585+
var o = AuthenticatorAttestationResponse.Parse(jsonPost);
586+
await o.VerifyAsync(options, _config, (x, cancellationToken) => Task.FromResult(true), metadataService, null, CancellationToken.None);
587+
}
588+
589+
[Fact]
590+
public async Task TestU2FAttestationAsyncFailTrustAnchorBasicSurrogate()
591+
{
592+
var metadataService = CreateMetadataService("./metadata");
593+
metadataService.ChangeEntryGuid(new Guid("00000000-0000-0000-0000-000000000003"), new Guid("00000000-0000-0000-0000-000000000000"));
594+
var jsonPost = JsonSerializer.Deserialize<AuthenticatorAttestationRawResponse>(await File.ReadAllTextAsync("./attestationResultsU2F.json"));
595+
var options = JsonSerializer.Deserialize<CredentialCreateOptions>(await File.ReadAllTextAsync("./attestationOptionsU2F.json"));
596+
var o = AuthenticatorAttestationResponse.Parse(jsonPost);
597+
await Assert.ThrowsAsync<Fido2VerificationException>(() => o.VerifyAsync(options, _config, (x, cancellationToken) => Task.FromResult(true), metadataService, null, CancellationToken.None));
598+
}
599+
539600
[Fact]
540601
public async Task TestPackedAttestationAsync()
541602
{

Test/Test.csproj

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -17,6 +17,7 @@
1717

1818
<ItemGroup>
1919
<ProjectReference Include="..\Src\Fido2.AspNet\Fido2.AspNet.csproj" />
20+
<ProjectReference Include="..\Src\Fido2.Development\Fido2.Development.csproj" />
2021
<ProjectReference Include="..\Src\Fido2.Models\Fido2.Models.csproj" />
2122
<ProjectReference Include="..\Src\Fido2\Fido2.csproj" />
2223
</ItemGroup>
Lines changed: 68 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,68 @@
1+
{
2+
"legalHeader": "https://fidoalliance.org/metadata/metadata-statement-legal-header/",
3+
"description": "Virtual Secp256K1 U2F authenticator",
4+
"aaguid": "00000000-0000-0000-0000-000000000002",
5+
"alternativeDescriptions": {
6+
"en-GB": "Virtual Secp256K1 U2F authenticator"
7+
},
8+
"attestationCertificateKeyIdentifiers": [
9+
"564df7c0f8c655b6a11f6c4d19f3bf41e2fd0179"
10+
],
11+
"protocolFamily": "u2f",
12+
"schema": 3,
13+
"authenticatorVersion": 2,
14+
"upv": [
15+
{
16+
"major": 1,
17+
"minor": 0
18+
},
19+
{
20+
"major": 1,
21+
"minor": 1
22+
},
23+
{
24+
"major": 1,
25+
"minor": 2
26+
}
27+
],
28+
"authenticationAlgorithms": [
29+
"secp256r1_ecdsa_sha256_raw"
30+
],
31+
"publicKeyAlgAndEncodings": [
32+
"ecc_x962_raw"
33+
],
34+
"attestationTypes": [
35+
"anonca"
36+
],
37+
"userVerificationDetails": [
38+
[
39+
{
40+
"userVerificationMethod": "none"
41+
}
42+
],
43+
[
44+
{
45+
"userVerificationMethod": "presence_internal"
46+
}
47+
]
48+
],
49+
"keyProtection": [
50+
"hardware",
51+
"secure_element"
52+
],
53+
"matcherProtection": [
54+
"on_chip"
55+
],
56+
"cryptoStrength": 128,
57+
"attachmentHint": [
58+
"external",
59+
"wired",
60+
"nfc",
61+
"wireless"
62+
],
63+
"tcDisplay": [],
64+
"attestationRootCertificates": [
65+
"MIIFwDCCA6gCCQCNm1u56oRwXTANBgkqhkiG9w0BAQsFADCBoTEYMBYGA1UEAwwPRklETzIgVEVTVCBST09UMTEwLwYJKoZIhvcNAQkBFiJjb25mb3JtYW5jZS10b29sc0BmaWRvYWxsaWFuY2Uub3JnMRYwFAYDVQQKDA1GSURPIEFsbGlhbmNlMQwwCgYDVQQLDANDV0cxCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJNWTESMBAGA1UEBwwJV2FrZWZpZWxkMB4XDTE4MDMxNjE0MzUyN1oXDTQ1MDgwMTE0MzUyN1owgaExGDAWBgNVBAMMD0ZJRE8yIFRFU1QgUk9PVDExMC8GCSqGSIb3DQEJARYiY29uZm9ybWFuY2UtdG9vbHNAZmlkb2FsbGlhbmNlLm9yZzEWMBQGA1UECgwNRklETyBBbGxpYW5jZTEMMAoGA1UECwwDQ1dHMQswCQYDVQQGEwJVUzELMAkGA1UECAwCTVkxEjAQBgNVBAcMCVdha2VmaWVsZDCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAL11U5yAIVLMrL3xS8u8ysMSdOkDeoTO+RcAy+uXXp6k4SC+jOy37gICEtYI+MKQV1EMeMMf3rM1ueZAO3iPFa0NEdi/oQ7npnGjBNI8wMzD8FfNe6rWtzkDaHpsZW///MwWDpGyJR+Xyjcq6U4vS9bS6zZ7jslw0Oczx4UsYgOsIUXSSBaGOrRbxJ/JC5gnDYEYvtNM+PDPczLNKAyhdvBZWNWHr7MZ0P5TeJQcXsAoShRX2Y8U8fRNJm7SeiFKDP0Nn/QKxOSt7zGP4xt9nMasE1q2ZTdar2+W13CRz37RI0ZWpq/+YquoEbZ7Uj7NmBTcqhb260nmDER2FpwwYwPSark92IZbamozB8d7OEI1jJgsrjJhKan0EmRaWVBpHT4xYKdEu7r09S0JhKyU+52WDmmVQTMpYLrm4Xl7hRxyPyBYkalrozsGmPs8vlhNq3VsVbyBSMSpEmUaeAa7LLE9/Vh0agJLVFHh1ehYKJpzHnmmBXUqx0Fz3afmDm1NX0sr3O/6xIx1VSTViT3KNxBYpVH1qjHATLzuxcWmm+75fcJMiPYPSMXVmRb3Q1l91AM4BBeWhlP3Fbc7gDy0r+s7m0sGS6PT2J2rGog2rUxnJ+zCM11M7DeO0XM2nny4uRYPPk9w2EXzfvtdvieYU/5RB4RDm5TGxHhGXVZUgac5AgMBAAEwDQYJKoZIhvcNAQELBQADggIBAFt2XGd3k5GpbO1EUm3u60zT1fE6u6pOscp156k5VnsHgaHRHdIAPNLeLNmR7y5OnrXbh13CrGwU1q84jjJXpv+v14xUCc5i01yopFTQFLr4A7NHp2nNYfNhhIVSFAgW43EflJflbLEelCJzxLlWb5BoDsZeeNmEQsXIM1mJ26R3r0dzsHBb0uy+8LNR1gdVqdjhC8BLy3gh4+BWuidyZNt07LveDsSFW5rcj5wRrSx9hXPIyVpjQSljNvY7MVTouqJzNAAQMsTKkXPkTXldCop9Qo9UPkHRRm0l7LLtdaOoXrct0Ymocf8zxf9bFNiw9f4WRYQM6sMhzt8+s/oDilo4QhcUgeJEiEPESi6ynYTV62SHA4eMunUJ5dlCaRnFiR9DTImFa5IRzie326/nW/SPCaKc/yrFIihMMjJoSAPhpTb/K6yHOUG8r+KiQut7NzqGV301pQ9u62dGL5Oi1VXmCFlE2ramZs15BNOUyAo2CBbRJg3jKcdu/8QC6ojjDvQ863+7LPtn74wJC5RpUJsS0GhQWgq5pAXO3wA61Uobxi6MkOpCC0zBWx/d4CqpS4j4hFgxWBTXX48ihPu+hIxIF/AxbqtPvqLMExW/xZITn6ArpWyQ9e4SUVr3n3F33ap1XdDyZ0vwFcm18JQAtsvXT6qCLrWOXnHUgfn/+Viu"
66+
],
67+
"icon": ""
68+
}

0 commit comments

Comments
 (0)