LibHac/tests/LibHac.Tests/CryptoTests/AesXtsTests.cs

127 lines
4.6 KiB
C#
Raw Permalink Normal View History

2019-11-16 01:38:55 +01:00
using System;
using System.Collections.Generic;
using System.Linq;
2019-11-19 02:31:06 +01:00
using LibHac.Crypto;
2019-11-16 01:38:55 +01:00
using Xunit;
2021-11-14 20:08:57 +01:00
namespace LibHac.Tests.CryptoTests;
2021-11-14 20:08:57 +01:00
public class AesXtsTests
{
public static EncryptionTestVector[] EncryptTestVectors =
RemovePartialByteTests(RspReader.ReadEncryptionTestVectorsArray(true, "XTSGenAES128.rsp", "XTSAES128Long.rsp"));
2021-11-14 20:08:57 +01:00
public static EncryptionTestVector[] DecryptTestVectors =
RemovePartialByteTests(RspReader.ReadEncryptionTestVectorsArray(false, "XTSGenAES128.rsp", "XTSAES128Long.rsp"));
2021-11-14 20:08:57 +01:00
// The XTS implementation only supports multiples of whole bytes
private static EncryptionTestVector[] RemovePartialByteTests(EncryptionTestVector[] input)
{
IEnumerable<EncryptionTestVector> filteredTestVectors = input
.Where(x => x.DataUnitLength % 8 == 0);
2021-11-14 20:08:57 +01:00
var output = new List<EncryptionTestVector>();
2021-11-14 20:08:57 +01:00
foreach (EncryptionTestVector item in filteredTestVectors)
{
2021-11-14 20:08:57 +01:00
output.Add(item);
}
2021-11-14 20:08:57 +01:00
return output.ToArray();
}
2021-11-14 20:08:57 +01:00
[Fact]
public static void Encrypt()
{
Common.EncryptCipherTest(EncryptTestVectors,
(key, iv) => Aes.CreateXtsEncryptor(key.AsSpan(0, 0x10), key.AsSpan(0x10, 0x10), iv, true));
}
2021-11-14 20:08:57 +01:00
[Fact]
public static void Decrypt()
{
Common.DecryptCipherTest(DecryptTestVectors,
(key, iv) => Aes.CreateXtsDecryptor(key.AsSpan(0, 0x10), key.AsSpan(0x10, 0x10), iv, true));
}
2021-11-14 20:08:57 +01:00
[AesIntrinsicsRequiredFact]
public static void EncryptIntrinsics()
{
Common.EncryptCipherTest(EncryptTestVectors,
(key, iv) => Aes.CreateXtsEncryptor(key.AsSpan(0, 0x10), key.AsSpan(0x10, 0x10), iv));
}
2021-11-14 20:08:57 +01:00
[AesIntrinsicsRequiredFact]
public static void DecryptIntrinsics()
{
Common.DecryptCipherTest(DecryptTestVectors,
(key, iv) => Aes.CreateXtsDecryptor(key.AsSpan(0, 0x10), key.AsSpan(0x10, 0x10), iv));
}
2021-11-14 20:08:57 +01:00
// The above tests run all the test vectors in a single test to avoid having thousands of tests.
// Use the below tests if running each test vector as an individual test is needed.
2021-11-14 20:08:57 +01:00
// ReSharper disable InconsistentNaming
2019-11-16 01:38:55 +01:00
2021-11-14 20:08:57 +01:00
#pragma warning disable xUnit1013 // Public method should be marked as test
2019-11-16 01:38:55 +01:00
2021-11-14 20:08:57 +01:00
public static TheoryData<EncryptionTestVector> EncryptTestVectors_Individual =
RemovePartialByteTests(RspReader.ReadEncryptionTestVectors(true, "XTSGenAES128.rsp", "XTSAES128Long.rsp"));
2019-11-16 01:38:55 +01:00
2021-11-14 20:08:57 +01:00
public static TheoryData<EncryptionTestVector> DecryptTestVectors_Individual =
RemovePartialByteTests(RspReader.ReadEncryptionTestVectors(false, "XTSGenAES128.rsp", "XTSAES128Long.rsp"));
2019-11-16 01:38:55 +01:00
2021-11-14 20:08:57 +01:00
private static TheoryData<EncryptionTestVector> RemovePartialByteTests(TheoryData<EncryptionTestVector> input)
{
IEnumerable<EncryptionTestVector> filteredTestVectors = input
.Select(x => x[0])
.Cast<EncryptionTestVector>()
.Where(x => x.DataUnitLength % 8 == 0);
2019-11-16 01:38:55 +01:00
2021-11-14 20:08:57 +01:00
var output = new TheoryData<EncryptionTestVector>();
2019-11-16 01:38:55 +01:00
2021-11-14 20:08:57 +01:00
foreach (EncryptionTestVector item in filteredTestVectors)
2019-11-16 01:38:55 +01:00
{
2021-11-14 20:08:57 +01:00
output.Add(item);
2019-11-16 01:38:55 +01:00
}
2021-11-14 20:08:57 +01:00
return output;
}
2019-11-16 01:38:55 +01:00
2021-11-14 20:08:57 +01:00
//[Theory, MemberData(nameof(EncryptTestVectors_Individual))]
public static void Encrypt_Individual(EncryptionTestVector tv)
{
Span<byte> key1 = tv.Key.AsSpan(0, 0x10);
Span<byte> key2 = tv.Key.AsSpan(0x10, 0x10);
2019-11-16 01:38:55 +01:00
2021-11-14 20:08:57 +01:00
Common.CipherTestCore(tv.PlainText, tv.CipherText, Aes.CreateXtsEncryptor(key1, key2, tv.Iv, true));
}
2019-11-16 01:38:55 +01:00
2021-11-14 20:08:57 +01:00
//[Theory, MemberData(nameof(DecryptTestVectors_Individual))]
public static void Decrypt_Individual(EncryptionTestVector tv)
{
Span<byte> key1 = tv.Key.AsSpan(0, 0x10);
Span<byte> key2 = tv.Key.AsSpan(0x10, 0x10);
2019-11-16 01:38:55 +01:00
2021-11-14 20:08:57 +01:00
Common.CipherTestCore(tv.CipherText, tv.PlainText, Aes.CreateXtsDecryptor(key1, key2, tv.Iv, true));
}
2019-11-16 01:38:55 +01:00
2021-11-14 20:08:57 +01:00
//[AesIntrinsicsRequiredTheory, MemberData(nameof(EncryptTestVectors_Individual))]
public static void EncryptIntrinsics_Individual(EncryptionTestVector tv)
{
Span<byte> key1 = tv.Key.AsSpan(0, 0x10);
Span<byte> key2 = tv.Key.AsSpan(0x10, 0x10);
Common.CipherTestCore(tv.PlainText, tv.CipherText, Aes.CreateXtsEncryptor(key1, key2, tv.Iv));
}
//[AesIntrinsicsRequiredTheory, MemberData(nameof(DecryptTestVectors_Individual))]
public static void DecryptIntrinsics_Individual(EncryptionTestVector tv)
{
Span<byte> key1 = tv.Key.AsSpan(0, 0x10);
Span<byte> key2 = tv.Key.AsSpan(0x10, 0x10);
Common.CipherTestCore(tv.CipherText, tv.PlainText, Aes.CreateXtsDecryptor(key1, key2, tv.Iv));
2019-11-16 01:38:55 +01:00
}
}