From d9c637ed31db351129748b6a8fdefb8e69e16c53 Mon Sep 17 00:00:00 2001 From: TSR Berry <20988865+TSRBerry@users.noreply.github.com> Date: Sat, 8 Jul 2023 20:24:12 +0200 Subject: [PATCH] Convert Ryujinx.Tests.Cpu test fixtures to xUnit --- src/Ryujinx.Tests/Cpu/CpuTest.cs | 220 ++++++++++++++--------------- src/Ryujinx.Tests/Cpu/CpuTest32.cs | 162 ++++++++++----------- 2 files changed, 177 insertions(+), 205 deletions(-) diff --git a/src/Ryujinx.Tests/Cpu/CpuTest.cs b/src/Ryujinx.Tests/Cpu/CpuTest.cs index da0f03e6b..55a3de770 100644 --- a/src/Ryujinx.Tests/Cpu/CpuTest.cs +++ b/src/Ryujinx.Tests/Cpu/CpuTest.cs @@ -1,17 +1,16 @@ using ARMeilleure; using ARMeilleure.State; using ARMeilleure.Translation; -using NUnit.Framework; using Ryujinx.Cpu.Jit; using Ryujinx.Memory; using Ryujinx.Tests.Unicorn; using System; +using Xunit; using MemoryPermission = Ryujinx.Tests.Unicorn.MemoryPermission; namespace Ryujinx.Tests.Cpu { - [TestFixture] - public class CpuTest + public class CpuTest : IDisposable { protected static readonly ulong Size = MemoryBlock.GetPageSize(); #pragma warning disable CA2211 // Non-constant fields should not be visible @@ -38,8 +37,12 @@ namespace Ryujinx.Tests.Cpu private bool _usingMemory; - [SetUp] - public void Setup() + protected CpuTest() + { + Setup(); + } + + private void Setup() { int pageBits = (int)ulong.Log2(Size); @@ -75,8 +78,7 @@ namespace Ryujinx.Tests.Cpu _unicornEmu.PC = CodeBaseAddress; } - [TearDown] - public void Teardown() + public void Dispose() { _unicornEmu.Dispose(); _unicornEmu = null; @@ -95,7 +97,7 @@ namespace Ryujinx.Tests.Cpu protected void Reset() { - Teardown(); + Dispose(); Setup(); } @@ -330,43 +332,43 @@ namespace Ryujinx.Tests.Cpu } #pragma warning disable IDE0055 // Disable formatting - Assert.That(_context.GetX(0), Is.EqualTo(_unicornEmu.X[0]), "X0"); - Assert.That(_context.GetX(1), Is.EqualTo(_unicornEmu.X[1]), "X1"); - Assert.That(_context.GetX(2), Is.EqualTo(_unicornEmu.X[2]), "X2"); - Assert.That(_context.GetX(3), Is.EqualTo(_unicornEmu.X[3]), "X3"); - Assert.That(_context.GetX(4), Is.EqualTo(_unicornEmu.X[4])); - Assert.That(_context.GetX(5), Is.EqualTo(_unicornEmu.X[5])); - Assert.That(_context.GetX(6), Is.EqualTo(_unicornEmu.X[6])); - Assert.That(_context.GetX(7), Is.EqualTo(_unicornEmu.X[7])); - Assert.That(_context.GetX(8), Is.EqualTo(_unicornEmu.X[8])); - Assert.That(_context.GetX(9), Is.EqualTo(_unicornEmu.X[9])); - Assert.That(_context.GetX(10), Is.EqualTo(_unicornEmu.X[10])); - Assert.That(_context.GetX(11), Is.EqualTo(_unicornEmu.X[11])); - Assert.That(_context.GetX(12), Is.EqualTo(_unicornEmu.X[12])); - Assert.That(_context.GetX(13), Is.EqualTo(_unicornEmu.X[13])); - Assert.That(_context.GetX(14), Is.EqualTo(_unicornEmu.X[14])); - Assert.That(_context.GetX(15), Is.EqualTo(_unicornEmu.X[15])); - Assert.That(_context.GetX(16), Is.EqualTo(_unicornEmu.X[16])); - Assert.That(_context.GetX(17), Is.EqualTo(_unicornEmu.X[17])); - Assert.That(_context.GetX(18), Is.EqualTo(_unicornEmu.X[18])); - Assert.That(_context.GetX(19), Is.EqualTo(_unicornEmu.X[19])); - Assert.That(_context.GetX(20), Is.EqualTo(_unicornEmu.X[20])); - Assert.That(_context.GetX(21), Is.EqualTo(_unicornEmu.X[21])); - Assert.That(_context.GetX(22), Is.EqualTo(_unicornEmu.X[22])); - Assert.That(_context.GetX(23), Is.EqualTo(_unicornEmu.X[23])); - Assert.That(_context.GetX(24), Is.EqualTo(_unicornEmu.X[24])); - Assert.That(_context.GetX(25), Is.EqualTo(_unicornEmu.X[25])); - Assert.That(_context.GetX(26), Is.EqualTo(_unicornEmu.X[26])); - Assert.That(_context.GetX(27), Is.EqualTo(_unicornEmu.X[27])); - Assert.That(_context.GetX(28), Is.EqualTo(_unicornEmu.X[28])); - Assert.That(_context.GetX(29), Is.EqualTo(_unicornEmu.X[29])); - Assert.That(_context.GetX(30), Is.EqualTo(_unicornEmu.X[30])); - Assert.That(_context.GetX(31), Is.EqualTo(_unicornEmu.SP), "X31"); + Assert.Equal(_unicornEmu.X[0], _context.GetX(0)); + Assert.Equal(_unicornEmu.X[1], _context.GetX(1)); + Assert.Equal(_unicornEmu.X[2], _context.GetX(2)); + Assert.Equal(_unicornEmu.X[3], _context.GetX(3)); + Assert.Equal(_unicornEmu.X[4], _context.GetX(4)); + Assert.Equal(_unicornEmu.X[5], _context.GetX(5)); + Assert.Equal(_unicornEmu.X[6], _context.GetX(6)); + Assert.Equal(_unicornEmu.X[7], _context.GetX(7)); + Assert.Equal(_unicornEmu.X[8], _context.GetX(8)); + Assert.Equal(_unicornEmu.X[9], _context.GetX(9)); + Assert.Equal(_unicornEmu.X[10], _context.GetX(10)); + Assert.Equal(_unicornEmu.X[11], _context.GetX(11)); + Assert.Equal(_unicornEmu.X[12], _context.GetX(12)); + Assert.Equal(_unicornEmu.X[13], _context.GetX(13)); + Assert.Equal(_unicornEmu.X[14], _context.GetX(14)); + Assert.Equal(_unicornEmu.X[15], _context.GetX(15)); + Assert.Equal(_unicornEmu.X[16], _context.GetX(16)); + Assert.Equal(_unicornEmu.X[17], _context.GetX(17)); + Assert.Equal(_unicornEmu.X[18], _context.GetX(18)); + Assert.Equal(_unicornEmu.X[19], _context.GetX(19)); + Assert.Equal(_unicornEmu.X[20], _context.GetX(20)); + Assert.Equal(_unicornEmu.X[21], _context.GetX(21)); + Assert.Equal(_unicornEmu.X[22], _context.GetX(22)); + Assert.Equal(_unicornEmu.X[23], _context.GetX(23)); + Assert.Equal(_unicornEmu.X[24], _context.GetX(24)); + Assert.Equal(_unicornEmu.X[25], _context.GetX(25)); + Assert.Equal(_unicornEmu.X[26], _context.GetX(26)); + Assert.Equal(_unicornEmu.X[27], _context.GetX(27)); + Assert.Equal(_unicornEmu.X[28], _context.GetX(28)); + Assert.Equal(_unicornEmu.X[29], _context.GetX(29)); + Assert.Equal(_unicornEmu.X[30], _context.GetX(30)); + Assert.Equal(_unicornEmu.SP, _context.GetX(31)); #pragma warning restore IDE0055 if (fpTolerances == FpTolerances.None) { - Assert.That(V128ToSimdValue(_context.GetV(0)), Is.EqualTo(_unicornEmu.Q[0]), "V0"); + Assert.Equal(_unicornEmu.Q[0], V128ToSimdValue(_context.GetV(0))); } else { @@ -374,48 +376,48 @@ namespace Ryujinx.Tests.Cpu } #pragma warning disable IDE0055 // Disable formatting - Assert.That(V128ToSimdValue(_context.GetV(1)), Is.EqualTo(_unicornEmu.Q[1]), "V1"); - Assert.That(V128ToSimdValue(_context.GetV(2)), Is.EqualTo(_unicornEmu.Q[2]), "V2"); - Assert.That(V128ToSimdValue(_context.GetV(3)), Is.EqualTo(_unicornEmu.Q[3]), "V3"); - Assert.That(V128ToSimdValue(_context.GetV(4)), Is.EqualTo(_unicornEmu.Q[4]), "V4"); - Assert.That(V128ToSimdValue(_context.GetV(5)), Is.EqualTo(_unicornEmu.Q[5]), "V5"); - Assert.That(V128ToSimdValue(_context.GetV(6)), Is.EqualTo(_unicornEmu.Q[6])); - Assert.That(V128ToSimdValue(_context.GetV(7)), Is.EqualTo(_unicornEmu.Q[7])); - Assert.That(V128ToSimdValue(_context.GetV(8)), Is.EqualTo(_unicornEmu.Q[8])); - Assert.That(V128ToSimdValue(_context.GetV(9)), Is.EqualTo(_unicornEmu.Q[9])); - Assert.That(V128ToSimdValue(_context.GetV(10)), Is.EqualTo(_unicornEmu.Q[10])); - Assert.That(V128ToSimdValue(_context.GetV(11)), Is.EqualTo(_unicornEmu.Q[11])); - Assert.That(V128ToSimdValue(_context.GetV(12)), Is.EqualTo(_unicornEmu.Q[12])); - Assert.That(V128ToSimdValue(_context.GetV(13)), Is.EqualTo(_unicornEmu.Q[13])); - Assert.That(V128ToSimdValue(_context.GetV(14)), Is.EqualTo(_unicornEmu.Q[14])); - Assert.That(V128ToSimdValue(_context.GetV(15)), Is.EqualTo(_unicornEmu.Q[15])); - Assert.That(V128ToSimdValue(_context.GetV(16)), Is.EqualTo(_unicornEmu.Q[16])); - Assert.That(V128ToSimdValue(_context.GetV(17)), Is.EqualTo(_unicornEmu.Q[17])); - Assert.That(V128ToSimdValue(_context.GetV(18)), Is.EqualTo(_unicornEmu.Q[18])); - Assert.That(V128ToSimdValue(_context.GetV(19)), Is.EqualTo(_unicornEmu.Q[19])); - Assert.That(V128ToSimdValue(_context.GetV(20)), Is.EqualTo(_unicornEmu.Q[20])); - Assert.That(V128ToSimdValue(_context.GetV(21)), Is.EqualTo(_unicornEmu.Q[21])); - Assert.That(V128ToSimdValue(_context.GetV(22)), Is.EqualTo(_unicornEmu.Q[22])); - Assert.That(V128ToSimdValue(_context.GetV(23)), Is.EqualTo(_unicornEmu.Q[23])); - Assert.That(V128ToSimdValue(_context.GetV(24)), Is.EqualTo(_unicornEmu.Q[24])); - Assert.That(V128ToSimdValue(_context.GetV(25)), Is.EqualTo(_unicornEmu.Q[25])); - Assert.That(V128ToSimdValue(_context.GetV(26)), Is.EqualTo(_unicornEmu.Q[26])); - Assert.That(V128ToSimdValue(_context.GetV(27)), Is.EqualTo(_unicornEmu.Q[27])); - Assert.That(V128ToSimdValue(_context.GetV(28)), Is.EqualTo(_unicornEmu.Q[28])); - Assert.That(V128ToSimdValue(_context.GetV(29)), Is.EqualTo(_unicornEmu.Q[29])); - Assert.That(V128ToSimdValue(_context.GetV(30)), Is.EqualTo(_unicornEmu.Q[30]), "V30"); - Assert.That(V128ToSimdValue(_context.GetV(31)), Is.EqualTo(_unicornEmu.Q[31]), "V31"); + Assert.Equal(_unicornEmu.Q[1], V128ToSimdValue(_context.GetV(1))); + Assert.Equal(_unicornEmu.Q[2], V128ToSimdValue(_context.GetV(2))); + Assert.Equal(_unicornEmu.Q[3], V128ToSimdValue(_context.GetV(3))); + Assert.Equal(_unicornEmu.Q[4], V128ToSimdValue(_context.GetV(4))); + Assert.Equal(_unicornEmu.Q[5], V128ToSimdValue(_context.GetV(5))); + Assert.Equal(_unicornEmu.Q[6], V128ToSimdValue(_context.GetV(6))); + Assert.Equal(_unicornEmu.Q[7], V128ToSimdValue(_context.GetV(7))); + Assert.Equal(_unicornEmu.Q[8], V128ToSimdValue(_context.GetV(8))); + Assert.Equal(_unicornEmu.Q[9], V128ToSimdValue(_context.GetV(9))); + Assert.Equal(_unicornEmu.Q[10], V128ToSimdValue(_context.GetV(10))); + Assert.Equal(_unicornEmu.Q[11], V128ToSimdValue(_context.GetV(11))); + Assert.Equal(_unicornEmu.Q[12], V128ToSimdValue(_context.GetV(12))); + Assert.Equal(_unicornEmu.Q[13], V128ToSimdValue(_context.GetV(13))); + Assert.Equal(_unicornEmu.Q[14], V128ToSimdValue(_context.GetV(14))); + Assert.Equal(_unicornEmu.Q[15], V128ToSimdValue(_context.GetV(15))); + Assert.Equal(_unicornEmu.Q[16], V128ToSimdValue(_context.GetV(16))); + Assert.Equal(_unicornEmu.Q[17], V128ToSimdValue(_context.GetV(17))); + Assert.Equal(_unicornEmu.Q[18], V128ToSimdValue(_context.GetV(18))); + Assert.Equal(_unicornEmu.Q[19], V128ToSimdValue(_context.GetV(19))); + Assert.Equal(_unicornEmu.Q[20], V128ToSimdValue(_context.GetV(20))); + Assert.Equal(_unicornEmu.Q[21], V128ToSimdValue(_context.GetV(21))); + Assert.Equal(_unicornEmu.Q[22], V128ToSimdValue(_context.GetV(22))); + Assert.Equal(_unicornEmu.Q[23], V128ToSimdValue(_context.GetV(23))); + Assert.Equal(_unicornEmu.Q[24], V128ToSimdValue(_context.GetV(24))); + Assert.Equal(_unicornEmu.Q[25], V128ToSimdValue(_context.GetV(25))); + Assert.Equal(_unicornEmu.Q[26], V128ToSimdValue(_context.GetV(26))); + Assert.Equal(_unicornEmu.Q[27], V128ToSimdValue(_context.GetV(27))); + Assert.Equal(_unicornEmu.Q[28], V128ToSimdValue(_context.GetV(28))); + Assert.Equal(_unicornEmu.Q[29], V128ToSimdValue(_context.GetV(29))); + Assert.Equal(_unicornEmu.Q[30], V128ToSimdValue(_context.GetV(30))); + Assert.Equal(_unicornEmu.Q[31], V128ToSimdValue(_context.GetV(31))); Assert.Multiple(() => { - Assert.That(_context.GetPstateFlag(PState.VFlag), Is.EqualTo(_unicornEmu.OverflowFlag), "VFlag"); - Assert.That(_context.GetPstateFlag(PState.CFlag), Is.EqualTo(_unicornEmu.CarryFlag), "CFlag"); - Assert.That(_context.GetPstateFlag(PState.ZFlag), Is.EqualTo(_unicornEmu.ZeroFlag), "ZFlag"); - Assert.That(_context.GetPstateFlag(PState.NFlag), Is.EqualTo(_unicornEmu.NegativeFlag), "NFlag"); + Assert.Equal(_unicornEmu.OverflowFlag, _context.GetPstateFlag(PState.VFlag)); + Assert.Equal(_unicornEmu.CarryFlag, _context.GetPstateFlag(PState.CFlag)); + Assert.Equal(_unicornEmu.ZeroFlag, _context.GetPstateFlag(PState.ZFlag)); + Assert.Equal(_unicornEmu.NegativeFlag, _context.GetPstateFlag(PState.NFlag)); }); - Assert.That((int)_context.Fpcr, Is.EqualTo(_unicornEmu.Fpcr), "Fpcr"); - Assert.That((int)_context.Fpsr & (int)fpsrMask, Is.EqualTo(_unicornEmu.Fpsr & (int)fpsrMask), "Fpsr"); + Assert.Equal(_unicornEmu.Fpcr, (int)_context.Fpcr); + Assert.Equal(_unicornEmu.Fpsr & (int)fpsrMask, (int)_context.Fpsr & (int)fpsrMask); #pragma warning restore IDE0055 if (_usingMemory) @@ -423,7 +425,7 @@ namespace Ryujinx.Tests.Cpu byte[] mem = _memory.GetSpan(DataBaseAddress, (int)Size).ToArray(); byte[] unicornMem = _unicornEmu.MemoryRead(DataBaseAddress, Size); - Assert.That(mem, Is.EqualTo(unicornMem), "Data"); + Assert.Equal(unicornMem, mem); } } @@ -431,33 +433,21 @@ namespace Ryujinx.Tests.Cpu { if (fpSkips.HasFlag(FpSkips.IfNaNS)) { - if (float.IsNaN(_unicornEmu.Q[0].AsFloat())) - { - Assert.Ignore("NaN test."); - } + Skip.If(float.IsNaN(_unicornEmu.Q[0].AsFloat()), "NaN test."); } else if (fpSkips.HasFlag(FpSkips.IfNaND)) { - if (double.IsNaN(_unicornEmu.Q[0].AsDouble())) - { - Assert.Ignore("NaN test."); - } + Skip.If(double.IsNaN(_unicornEmu.Q[0].AsDouble()), "NaN test."); } if (fpSkips.HasFlag(FpSkips.IfUnderflow)) { - if ((_unicornEmu.Fpsr & (int)Fpsr.Ufc) != 0) - { - Assert.Ignore("Underflow test."); - } + Skip.If((_unicornEmu.Fpsr & (int)Fpsr.Ufc) != 0, "Underflow test."); } if (fpSkips.HasFlag(FpSkips.IfOverflow)) { - if ((_unicornEmu.Fpsr & (int)Fpsr.Ofc) != 0) - { - Assert.Ignore("Overflow test."); - } + Skip.If((_unicornEmu.Fpsr & (int)Fpsr.Ofc) != 0, "Overflow test."); } } @@ -466,8 +456,10 @@ namespace Ryujinx.Tests.Cpu bool IsNormalOrSubnormalS(float f) => float.IsNormal(f) || float.IsSubnormal(f); bool IsNormalOrSubnormalD(double d) => double.IsNormal(d) || double.IsSubnormal(d); - if (!Is.EqualTo(_unicornEmu.Q[0]).ApplyTo(V128ToSimdValue(_context.GetV(0))).IsSuccess) + if (V128ToSimdValue(_context.GetV(0)) != _unicornEmu.Q[0]) { + // https://docs.nunit.org/articles/nunit/writing-tests/constraints/EqualConstraint.html#comparing-floating-point-values + // NOTE: XUnit only allows us to specify a tolerance and a MidpointRounding value if (fpTolerances == FpTolerances.UpToOneUlpsS) { if (IsNormalOrSubnormalS(_unicornEmu.Q[0].AsFloat()) && @@ -475,21 +467,17 @@ namespace Ryujinx.Tests.Cpu { Assert.Multiple(() => { - Assert.That(_context.GetV(0).Extract(0), - Is.EqualTo(_unicornEmu.Q[0].GetFloat(0)).Within(1).Ulps, "V0[0]"); - Assert.That(_context.GetV(0).Extract(1), - Is.EqualTo(_unicornEmu.Q[0].GetFloat(1)).Within(1).Ulps, "V0[1]"); - Assert.That(_context.GetV(0).Extract(2), - Is.EqualTo(_unicornEmu.Q[0].GetFloat(2)).Within(1).Ulps, "V0[2]"); - Assert.That(_context.GetV(0).Extract(3), - Is.EqualTo(_unicornEmu.Q[0].GetFloat(3)).Within(1).Ulps, "V0[3]"); + Assert.Equal(_unicornEmu.Q[0].GetFloat(0), _context.GetV(0).Extract(0), 1f); + Assert.Equal(_unicornEmu.Q[0].GetFloat(1), _context.GetV(0).Extract(1), 1f); + Assert.Equal(_unicornEmu.Q[0].GetFloat(2), _context.GetV(0).Extract(2), 1f); + Assert.Equal(_unicornEmu.Q[0].GetFloat(3), _context.GetV(0).Extract(3), 1f); }); Console.WriteLine(fpTolerances); } else { - Assert.That(V128ToSimdValue(_context.GetV(0)), Is.EqualTo(_unicornEmu.Q[0])); + Assert.Equal(_unicornEmu.Q[0], V128ToSimdValue(_context.GetV(0))); } } @@ -500,17 +488,17 @@ namespace Ryujinx.Tests.Cpu { Assert.Multiple(() => { - Assert.That(_context.GetV(0).Extract(0), - Is.EqualTo(_unicornEmu.Q[0].GetDouble(0)).Within(1).Ulps, "V0[0]"); - Assert.That(_context.GetV(0).Extract(1), - Is.EqualTo(_unicornEmu.Q[0].GetDouble(1)).Within(1).Ulps, "V0[1]"); + Assert.Equal(_context.GetV(0).Extract(0), + _unicornEmu.Q[0].GetDouble(0), 1d); + Assert.Equal(_context.GetV(0).Extract(1), + _unicornEmu.Q[0].GetDouble(1), 1d); }); Console.WriteLine(fpTolerances); } else { - Assert.That(V128ToSimdValue(_context.GetV(0)), Is.EqualTo(_unicornEmu.Q[0])); + Assert.Equal(_unicornEmu.Q[0], V128ToSimdValue(_context.GetV(0))); } } } @@ -537,7 +525,7 @@ namespace Ryujinx.Tests.Cpu uint rnd; do - rnd = TestContext.CurrentContext.Random.NextUShort(); + rnd = Random.Shared.NextUShort(); while ((rnd & 0x7C00u) == 0u || (~rnd & 0x7C00u) == 0u); @@ -549,7 +537,7 @@ namespace Ryujinx.Tests.Cpu uint rnd; do - rnd = TestContext.CurrentContext.Random.NextUShort(); + rnd = Random.Shared.NextUShort(); while ((rnd & 0x03FFu) == 0u); return (ushort)(rnd & 0x83FFu); @@ -560,7 +548,7 @@ namespace Ryujinx.Tests.Cpu uint rnd; do - rnd = TestContext.CurrentContext.Random.NextUInt(); + rnd = Random.Shared.NextUInt(); while ((rnd & 0x7F800000u) == 0u || (~rnd & 0x7F800000u) == 0u); @@ -572,7 +560,7 @@ namespace Ryujinx.Tests.Cpu uint rnd; do - rnd = TestContext.CurrentContext.Random.NextUInt(); + rnd = Random.Shared.NextUInt(); while ((rnd & 0x007FFFFFu) == 0u); return rnd & 0x807FFFFFu; @@ -583,7 +571,7 @@ namespace Ryujinx.Tests.Cpu ulong rnd; do - rnd = TestContext.CurrentContext.Random.NextULong(); + rnd = Random.Shared.NextULong(); while ((rnd & 0x7FF0000000000000ul) == 0ul || (~rnd & 0x7FF0000000000000ul) == 0ul); @@ -595,7 +583,7 @@ namespace Ryujinx.Tests.Cpu ulong rnd; do - rnd = TestContext.CurrentContext.Random.NextULong(); + rnd = Random.Shared.NextULong(); while ((rnd & 0x000FFFFFFFFFFFFFul) == 0ul); return rnd & 0x800FFFFFFFFFFFFFul; diff --git a/src/Ryujinx.Tests/Cpu/CpuTest32.cs b/src/Ryujinx.Tests/Cpu/CpuTest32.cs index 6a690834f..84fab8bd2 100644 --- a/src/Ryujinx.Tests/Cpu/CpuTest32.cs +++ b/src/Ryujinx.Tests/Cpu/CpuTest32.cs @@ -1,17 +1,16 @@ using ARMeilleure; using ARMeilleure.State; using ARMeilleure.Translation; -using NUnit.Framework; using Ryujinx.Cpu.Jit; using Ryujinx.Memory; using Ryujinx.Tests.Unicorn; using System; +using Xunit; using MemoryPermission = Ryujinx.Tests.Unicorn.MemoryPermission; namespace Ryujinx.Tests.Cpu { - [TestFixture] - public class CpuTest32 + public class CpuTest32 : IDisposable { protected static readonly uint Size = (uint)MemoryBlock.GetPageSize(); #pragma warning disable CA2211 // Non-constant fields should not be visible @@ -32,7 +31,11 @@ namespace Ryujinx.Tests.Cpu private bool _usingMemory; - [SetUp] + public CpuTest32() + { + Setup(); + } + public void Setup() { int pageBits = (int)ulong.Log2(Size); @@ -70,8 +73,7 @@ namespace Ryujinx.Tests.Cpu _unicornEmu.PC = CodeBaseAddress; } - [TearDown] - public void Teardown() + public void Dispose() { _unicornEmu.Dispose(); _unicornEmu = null; @@ -90,7 +92,7 @@ namespace Ryujinx.Tests.Cpu protected void Reset() { - Teardown(); + Dispose(); Setup(); } @@ -270,11 +272,11 @@ namespace Ryujinx.Tests.Cpu for (int i = 0; i < 15; i++) { - Assert.That(GetContext().GetX(i), Is.EqualTo(test.FinalRegs[i])); + Assert.Equal(test.FinalRegs[i], GetContext().GetX(i)); } uint finalCpsr = test.FinalRegs[15]; - Assert.That(GetContext().Pstate, Is.EqualTo(finalCpsr)); + Assert.Equal(finalCpsr, GetContext().Pstate); } public void RunPrecomputedTestCase(PrecomputedMemoryThumbTestCase test) @@ -304,7 +306,7 @@ namespace Ryujinx.Tests.Cpu byte[] mem = _memory.GetSpan(DataBaseAddress, (int)Size).ToArray(); - Assert.That(mem, Is.EqualTo(testMem), "testmem"); + Assert.Equal(testMem, mem); } protected void SetWorkingMemory(uint offset, byte[] data) @@ -398,67 +400,67 @@ namespace Ryujinx.Tests.Cpu ManageFpSkips(fpSkips); } - Assert.That(_context.GetX(0), Is.EqualTo(_unicornEmu.R[0]), "R0"); - Assert.That(_context.GetX(1), Is.EqualTo(_unicornEmu.R[1]), "R1"); - Assert.That(_context.GetX(2), Is.EqualTo(_unicornEmu.R[2]), "R2"); - Assert.That(_context.GetX(3), Is.EqualTo(_unicornEmu.R[3]), "R3"); - Assert.That(_context.GetX(4), Is.EqualTo(_unicornEmu.R[4])); - Assert.That(_context.GetX(5), Is.EqualTo(_unicornEmu.R[5])); - Assert.That(_context.GetX(6), Is.EqualTo(_unicornEmu.R[6])); - Assert.That(_context.GetX(7), Is.EqualTo(_unicornEmu.R[7])); - Assert.That(_context.GetX(8), Is.EqualTo(_unicornEmu.R[8])); - Assert.That(_context.GetX(9), Is.EqualTo(_unicornEmu.R[9])); - Assert.That(_context.GetX(10), Is.EqualTo(_unicornEmu.R[10])); - Assert.That(_context.GetX(11), Is.EqualTo(_unicornEmu.R[11])); - Assert.That(_context.GetX(12), Is.EqualTo(_unicornEmu.R[12])); - Assert.That(_context.GetX(13), Is.EqualTo(_unicornEmu.SP), "SP"); - Assert.That(_context.GetX(14), Is.EqualTo(_unicornEmu.R[14])); + Assert.Equal(_unicornEmu.R[0], _context.GetX(0)); + Assert.Equal(_unicornEmu.R[1], _context.GetX(1)); + Assert.Equal(_unicornEmu.R[2], _context.GetX(2)); + Assert.Equal(_unicornEmu.R[3], _context.GetX(3)); + Assert.Equal(_unicornEmu.R[4], _context.GetX(4)); + Assert.Equal(_unicornEmu.R[5], _context.GetX(5)); + Assert.Equal(_unicornEmu.R[6], _context.GetX(6)); + Assert.Equal(_unicornEmu.R[7], _context.GetX(7)); + Assert.Equal(_unicornEmu.R[8], _context.GetX(8)); + Assert.Equal(_unicornEmu.R[9], _context.GetX(9)); + Assert.Equal(_unicornEmu.R[10], _context.GetX(10)); + Assert.Equal(_unicornEmu.R[11], _context.GetX(11)); + Assert.Equal(_unicornEmu.R[12], _context.GetX(12)); + Assert.Equal(_unicornEmu.SP, _context.GetX(13)); + Assert.Equal(_unicornEmu.R[14], _context.GetX(14)); if (fpTolerances == FpTolerances.None) { - Assert.That(V128ToSimdValue(_context.GetV(0)), Is.EqualTo(_unicornEmu.Q[0]), "V0"); + Assert.Equal(_unicornEmu.Q[0], V128ToSimdValue(_context.GetV(0))); } else { ManageFpTolerances(fpTolerances); } - Assert.That(V128ToSimdValue(_context.GetV(1)), Is.EqualTo(_unicornEmu.Q[1]), "V1"); - Assert.That(V128ToSimdValue(_context.GetV(2)), Is.EqualTo(_unicornEmu.Q[2]), "V2"); - Assert.That(V128ToSimdValue(_context.GetV(3)), Is.EqualTo(_unicornEmu.Q[3]), "V3"); - Assert.That(V128ToSimdValue(_context.GetV(4)), Is.EqualTo(_unicornEmu.Q[4]), "V4"); - Assert.That(V128ToSimdValue(_context.GetV(5)), Is.EqualTo(_unicornEmu.Q[5]), "V5"); - Assert.That(V128ToSimdValue(_context.GetV(6)), Is.EqualTo(_unicornEmu.Q[6])); - Assert.That(V128ToSimdValue(_context.GetV(7)), Is.EqualTo(_unicornEmu.Q[7])); - Assert.That(V128ToSimdValue(_context.GetV(8)), Is.EqualTo(_unicornEmu.Q[8])); - Assert.That(V128ToSimdValue(_context.GetV(9)), Is.EqualTo(_unicornEmu.Q[9])); - Assert.That(V128ToSimdValue(_context.GetV(10)), Is.EqualTo(_unicornEmu.Q[10])); - Assert.That(V128ToSimdValue(_context.GetV(11)), Is.EqualTo(_unicornEmu.Q[11])); - Assert.That(V128ToSimdValue(_context.GetV(12)), Is.EqualTo(_unicornEmu.Q[12])); - Assert.That(V128ToSimdValue(_context.GetV(13)), Is.EqualTo(_unicornEmu.Q[13])); - Assert.That(V128ToSimdValue(_context.GetV(14)), Is.EqualTo(_unicornEmu.Q[14]), "V14"); - Assert.That(V128ToSimdValue(_context.GetV(15)), Is.EqualTo(_unicornEmu.Q[15]), "V15"); + Assert.Equal(_unicornEmu.Q[1], V128ToSimdValue(_context.GetV(1))); + Assert.Equal(_unicornEmu.Q[2], V128ToSimdValue(_context.GetV(2))); + Assert.Equal(_unicornEmu.Q[3], V128ToSimdValue(_context.GetV(3))); + Assert.Equal(_unicornEmu.Q[4], V128ToSimdValue(_context.GetV(4))); + Assert.Equal(_unicornEmu.Q[5], V128ToSimdValue(_context.GetV(5))); + Assert.Equal(_unicornEmu.Q[6], V128ToSimdValue(_context.GetV(6))); + Assert.Equal(_unicornEmu.Q[7], V128ToSimdValue(_context.GetV(7))); + Assert.Equal(_unicornEmu.Q[8], V128ToSimdValue(_context.GetV(8))); + Assert.Equal(_unicornEmu.Q[9], V128ToSimdValue(_context.GetV(9))); + Assert.Equal(_unicornEmu.Q[10], V128ToSimdValue(_context.GetV(10))); + Assert.Equal(_unicornEmu.Q[11], V128ToSimdValue(_context.GetV(11))); + Assert.Equal(_unicornEmu.Q[12], V128ToSimdValue(_context.GetV(12))); + Assert.Equal(_unicornEmu.Q[13], V128ToSimdValue(_context.GetV(13))); + Assert.Equal(_unicornEmu.Q[14], V128ToSimdValue(_context.GetV(14))); + Assert.Equal(_unicornEmu.Q[15], V128ToSimdValue(_context.GetV(15))); Assert.Multiple(() => { - Assert.That(_context.GetPstateFlag(PState.GE0Flag), Is.EqualTo((_unicornEmu.CPSR & (1u << 16)) != 0), "GE0Flag"); - Assert.That(_context.GetPstateFlag(PState.GE1Flag), Is.EqualTo((_unicornEmu.CPSR & (1u << 17)) != 0), "GE1Flag"); - Assert.That(_context.GetPstateFlag(PState.GE2Flag), Is.EqualTo((_unicornEmu.CPSR & (1u << 18)) != 0), "GE2Flag"); - Assert.That(_context.GetPstateFlag(PState.GE3Flag), Is.EqualTo((_unicornEmu.CPSR & (1u << 19)) != 0), "GE3Flag"); - Assert.That(_context.GetPstateFlag(PState.QFlag), Is.EqualTo(_unicornEmu.QFlag), "QFlag"); - Assert.That(_context.GetPstateFlag(PState.VFlag), Is.EqualTo(_unicornEmu.OverflowFlag), "VFlag"); - Assert.That(_context.GetPstateFlag(PState.CFlag), Is.EqualTo(_unicornEmu.CarryFlag), "CFlag"); - Assert.That(_context.GetPstateFlag(PState.ZFlag), Is.EqualTo(_unicornEmu.ZeroFlag), "ZFlag"); - Assert.That(_context.GetPstateFlag(PState.NFlag), Is.EqualTo(_unicornEmu.NegativeFlag), "NFlag"); + Assert.Equal((_unicornEmu.CPSR & (1u << 16)) != 0, _context.GetPstateFlag(PState.GE0Flag)); + Assert.Equal((_unicornEmu.CPSR & (1u << 17)) != 0, _context.GetPstateFlag(PState.GE1Flag)); + Assert.Equal((_unicornEmu.CPSR & (1u << 18)) != 0, _context.GetPstateFlag(PState.GE2Flag)); + Assert.Equal((_unicornEmu.CPSR & (1u << 19)) != 0, _context.GetPstateFlag(PState.GE3Flag)); + Assert.Equal(_unicornEmu.QFlag, _context.GetPstateFlag(PState.QFlag)); + Assert.Equal(_unicornEmu.OverflowFlag, _context.GetPstateFlag(PState.VFlag)); + Assert.Equal(_unicornEmu.CarryFlag, _context.GetPstateFlag(PState.CFlag)); + Assert.Equal(_unicornEmu.ZeroFlag, _context.GetPstateFlag(PState.ZFlag)); + Assert.Equal(_unicornEmu.NegativeFlag, _context.GetPstateFlag(PState.NFlag)); }); - Assert.That((int)_context.Fpscr & (int)fpsrMask, Is.EqualTo(_unicornEmu.Fpscr & (int)fpsrMask), "Fpscr"); + Assert.Equal(_unicornEmu.Fpscr & (int)fpsrMask, (int)_context.Fpscr & (int)fpsrMask); if (_usingMemory) { byte[] mem = _memory.GetSpan(DataBaseAddress, (int)Size).ToArray(); byte[] unicornMem = _unicornEmu.MemoryRead(DataBaseAddress, Size); - Assert.That(mem, Is.EqualTo(unicornMem), "Data"); + Assert.Equal(unicornMem, mem); } } @@ -466,33 +468,21 @@ namespace Ryujinx.Tests.Cpu { if (fpSkips.HasFlag(FpSkips.IfNaNS)) { - if (float.IsNaN(_unicornEmu.Q[0].AsFloat())) - { - Assert.Ignore("NaN test."); - } + Skip.If(float.IsNaN(_unicornEmu.Q[0].AsFloat()), "NaN test."); } else if (fpSkips.HasFlag(FpSkips.IfNaND)) { - if (double.IsNaN(_unicornEmu.Q[0].AsDouble())) - { - Assert.Ignore("NaN test."); - } + Skip.If(double.IsNaN(_unicornEmu.Q[0].AsDouble()), "NaN test."); } if (fpSkips.HasFlag(FpSkips.IfUnderflow)) { - if ((_unicornEmu.Fpscr & (int)Fpsr.Ufc) != 0) - { - Assert.Ignore("Underflow test."); - } + Skip.If((_unicornEmu.Fpscr & (int)Fpsr.Ufc) != 0, "Underflow test."); } if (fpSkips.HasFlag(FpSkips.IfOverflow)) { - if ((_unicornEmu.Fpscr & (int)Fpsr.Ofc) != 0) - { - Assert.Ignore("Overflow test."); - } + Skip.If((_unicornEmu.Fpscr & (int)Fpsr.Ofc) != 0, "Overflow test."); } } @@ -501,7 +491,7 @@ namespace Ryujinx.Tests.Cpu bool IsNormalOrSubnormalS(float f) => float.IsNormal(f) || float.IsSubnormal(f); bool IsNormalOrSubnormalD(double d) => double.IsNormal(d) || double.IsSubnormal(d); - if (!Is.EqualTo(_unicornEmu.Q[0]).ApplyTo(V128ToSimdValue(_context.GetV(0))).IsSuccess) + if (_unicornEmu.Q[0] != V128ToSimdValue(_context.GetV(0))) { if (fpTolerances == FpTolerances.UpToOneUlpsS) { @@ -510,21 +500,17 @@ namespace Ryujinx.Tests.Cpu { Assert.Multiple(() => { - Assert.That(_context.GetV(0).Extract(0), - Is.EqualTo(_unicornEmu.Q[0].GetFloat(0)).Within(1).Ulps, "V0[0]"); - Assert.That(_context.GetV(0).Extract(1), - Is.EqualTo(_unicornEmu.Q[0].GetFloat(1)).Within(1).Ulps, "V0[1]"); - Assert.That(_context.GetV(0).Extract(2), - Is.EqualTo(_unicornEmu.Q[0].GetFloat(2)).Within(1).Ulps, "V0[2]"); - Assert.That(_context.GetV(0).Extract(3), - Is.EqualTo(_unicornEmu.Q[0].GetFloat(3)).Within(1).Ulps, "V0[3]"); + Assert.Equal(_unicornEmu.Q[0].GetFloat(0), _context.GetV(0).Extract(0), 1f); + Assert.Equal(_unicornEmu.Q[0].GetFloat(1), _context.GetV(0).Extract(1), 1f); + Assert.Equal(_unicornEmu.Q[0].GetFloat(2), _context.GetV(0).Extract(2), 1f); + Assert.Equal(_unicornEmu.Q[0].GetFloat(3), _context.GetV(0).Extract(3), 1f); }); Console.WriteLine(fpTolerances); } else { - Assert.That(V128ToSimdValue(_context.GetV(0)), Is.EqualTo(_unicornEmu.Q[0])); + Assert.Equal(_unicornEmu.Q[0], V128ToSimdValue(_context.GetV(0))); } } @@ -535,17 +521,15 @@ namespace Ryujinx.Tests.Cpu { Assert.Multiple(() => { - Assert.That(_context.GetV(0).Extract(0), - Is.EqualTo(_unicornEmu.Q[0].GetDouble(0)).Within(1).Ulps, "V0[0]"); - Assert.That(_context.GetV(0).Extract(1), - Is.EqualTo(_unicornEmu.Q[0].GetDouble(1)).Within(1).Ulps, "V0[1]"); + Assert.Equal(_unicornEmu.Q[0].GetDouble(0), _context.GetV(0).Extract(0), 1d); + Assert.Equal(_unicornEmu.Q[0].GetDouble(1), _context.GetV(0).Extract(1), 1d); }); Console.WriteLine(fpTolerances); } else { - Assert.That(V128ToSimdValue(_context.GetV(0)), Is.EqualTo(_unicornEmu.Q[0])); + Assert.Equal(_unicornEmu.Q[0], V128ToSimdValue(_context.GetV(0))); } } } @@ -577,7 +561,7 @@ namespace Ryujinx.Tests.Cpu uint rnd; do - rnd = TestContext.CurrentContext.Random.NextUShort(); + rnd = Random.Shared.NextUShort(); while ((rnd & 0x7C00u) == 0u || (~rnd & 0x7C00u) == 0u); @@ -589,7 +573,7 @@ namespace Ryujinx.Tests.Cpu uint rnd; do - rnd = TestContext.CurrentContext.Random.NextUShort(); + rnd = Random.Shared.NextUShort(); while ((rnd & 0x03FFu) == 0u); return (ushort)(rnd & 0x83FFu); @@ -600,7 +584,7 @@ namespace Ryujinx.Tests.Cpu uint rnd; do - rnd = TestContext.CurrentContext.Random.NextUInt(); + rnd = Random.Shared.NextUInt(); while ((rnd & 0x7F800000u) == 0u || (~rnd & 0x7F800000u) == 0u); @@ -612,7 +596,7 @@ namespace Ryujinx.Tests.Cpu uint rnd; do - rnd = TestContext.CurrentContext.Random.NextUInt(); + rnd = Random.Shared.NextUInt(); while ((rnd & 0x007FFFFFu) == 0u); return rnd & 0x807FFFFFu; @@ -623,7 +607,7 @@ namespace Ryujinx.Tests.Cpu ulong rnd; do - rnd = TestContext.CurrentContext.Random.NextULong(); + rnd = Random.Shared.NextULong(); while ((rnd & 0x7FF0000000000000ul) == 0ul || (~rnd & 0x7FF0000000000000ul) == 0ul); @@ -635,7 +619,7 @@ namespace Ryujinx.Tests.Cpu ulong rnd; do - rnd = TestContext.CurrentContext.Random.NextULong(); + rnd = Random.Shared.NextULong(); while ((rnd & 0x000FFFFFFFFFFFFFul) == 0ul); return rnd & 0x800FFFFFFFFFFFFFul;