mirror of
https://github.com/SabreTools/SabreTools.IO.git
synced 2026-02-04 05:36:05 +00:00
179 lines
5.7 KiB
C#
179 lines
5.7 KiB
C#
using System;
|
|
using SabreTools.Numerics;
|
|
using Xunit;
|
|
|
|
namespace SabreTools.IO.Test.Numerics
|
|
{
|
|
public class BothUInt32Tests
|
|
{
|
|
[Theory]
|
|
[InlineData(0, 0, true)]
|
|
[InlineData(0, 1, false)]
|
|
public void IsValidTest(uint le, uint be, bool expected)
|
|
{
|
|
var val = new BothUInt32(le, be);
|
|
|
|
Assert.Equal(le, val.LittleEndian);
|
|
Assert.Equal(be, val.BigEndian);
|
|
Assert.Equal(expected, val.IsValid);
|
|
}
|
|
|
|
[Fact]
|
|
public void ImplicitConversionTest()
|
|
{
|
|
uint expected = 1;
|
|
var val = new BothUInt32(expected, expected);
|
|
|
|
uint to = (uint)val;
|
|
Assert.Equal(expected, to);
|
|
|
|
BothUInt32 back = (BothUInt32)to;
|
|
Assert.Equal(expected, back.LittleEndian);
|
|
Assert.Equal(expected, back.BigEndian);
|
|
}
|
|
|
|
[Theory]
|
|
[InlineData(0, -1)]
|
|
[InlineData(1, 0)]
|
|
[InlineData(2, 1)]
|
|
public void CompareToTest(uint le, int expected)
|
|
{
|
|
uint compare = 1;
|
|
var val = new BothUInt32(le, le);
|
|
|
|
int actual = val.CompareTo(compare);
|
|
Assert.Equal(expected, actual);
|
|
}
|
|
|
|
[Fact]
|
|
public void GetTypeCodeTest()
|
|
{
|
|
TypeCode expected = ((uint)1).GetTypeCode();
|
|
|
|
var val = new BothUInt32(1, 1);
|
|
Assert.Equal(expected, val.GetTypeCode());
|
|
}
|
|
|
|
[Fact]
|
|
public void ToTypesTest()
|
|
{
|
|
var val = new BothUInt32(1, 1);
|
|
|
|
bool expectedBool = Convert.ToBoolean((uint)1);
|
|
Assert.Equal(expectedBool, val.ToBoolean(null));
|
|
|
|
char expectedChar = Convert.ToChar((uint)1);
|
|
Assert.Equal(expectedChar, val.ToChar(null));
|
|
|
|
sbyte expectedSByte = Convert.ToSByte((uint)1);
|
|
Assert.Equal(expectedSByte, val.ToSByte(null));
|
|
|
|
byte expectedByte = Convert.ToByte((uint)1);
|
|
Assert.Equal(expectedByte, val.ToByte(null));
|
|
|
|
short expectedInt16 = Convert.ToInt16((uint)1);
|
|
Assert.Equal(expectedInt16, val.ToInt16(null));
|
|
|
|
ushort expectedUInt16 = Convert.ToUInt16((uint)1);
|
|
Assert.Equal(expectedUInt16, val.ToUInt16(null));
|
|
|
|
int expectedInt32 = Convert.ToInt32((uint)1);
|
|
Assert.Equal(expectedInt32, val.ToInt32(null));
|
|
|
|
uint expectedUInt32 = Convert.ToUInt32((uint)1);
|
|
Assert.Equal(expectedUInt32, val.ToUInt32(null));
|
|
|
|
long expectedInt64 = Convert.ToInt64((uint)1);
|
|
Assert.Equal(expectedInt64, val.ToInt64(null));
|
|
|
|
ulong expectedUInt64 = Convert.ToUInt64((uint)1);
|
|
Assert.Equal(expectedUInt64, val.ToUInt64(null));
|
|
|
|
float expectedSingle = Convert.ToSingle((uint)1);
|
|
Assert.Equal(expectedSingle, val.ToSingle(null));
|
|
|
|
double expectedDouble = Convert.ToDouble((uint)1);
|
|
Assert.Equal(expectedDouble, val.ToDouble(null));
|
|
|
|
decimal expectedDecimal = Convert.ToDecimal((uint)1);
|
|
Assert.Equal(expectedDecimal, val.ToDecimal(null));
|
|
|
|
Assert.Throws<InvalidCastException>(() => val.ToDateTime(null));
|
|
|
|
string expectedString = Convert.ToString((uint)1);
|
|
Assert.Equal(expectedString, val.ToString(null));
|
|
|
|
ulong expectedObject = Convert.ToUInt64((uint)1);
|
|
Assert.Equal(expectedObject, val.ToType(typeof(ulong), null));
|
|
}
|
|
|
|
[Theory]
|
|
[InlineData(0, 0, false)]
|
|
[InlineData(0, 1, false)]
|
|
[InlineData(1, 0, false)]
|
|
[InlineData(1, 1, true)]
|
|
public void Equals_BothEndian(uint le, uint be, bool expected)
|
|
{
|
|
var val = new BothUInt32(le, be);
|
|
var equalTo = new BothUInt32(1, 1);
|
|
|
|
bool actual = val.Equals(equalTo);
|
|
Assert.Equal(expected, actual);
|
|
}
|
|
|
|
[Theory]
|
|
[InlineData(0, 0, false)]
|
|
[InlineData(1, 1, true)]
|
|
public void Equals_BaseType(uint le, uint be, bool expected)
|
|
{
|
|
var val = new BothUInt32(le, be);
|
|
uint equalTo = 1;
|
|
|
|
bool actual = val.Equals(equalTo);
|
|
Assert.Equal(expected, actual);
|
|
}
|
|
|
|
[Fact]
|
|
public void OperatorsTest()
|
|
{
|
|
var valA = new BothUInt32(2, 2);
|
|
var valB = new BothUInt32(1, 1);
|
|
|
|
uint expected = (uint)2 + (uint)1;
|
|
BothUInt32 actual = valA + valB;
|
|
Assert.Equal(expected, actual.LittleEndian);
|
|
Assert.Equal(expected, actual.BigEndian);
|
|
|
|
expected = (uint)2 - (uint)1;
|
|
actual = valA - valB;
|
|
Assert.Equal(expected, actual.LittleEndian);
|
|
Assert.Equal(expected, actual.BigEndian);
|
|
|
|
expected = (uint)2 * (uint)1;
|
|
actual = valA * valB;
|
|
Assert.Equal(expected, actual.LittleEndian);
|
|
Assert.Equal(expected, actual.BigEndian);
|
|
|
|
expected = (uint)2 / (uint)1;
|
|
actual = valA / valB;
|
|
Assert.Equal(expected, actual.LittleEndian);
|
|
Assert.Equal(expected, actual.BigEndian);
|
|
|
|
expected = (uint)2 ^ (uint)1;
|
|
actual = valA ^ valB;
|
|
Assert.Equal(expected, actual.LittleEndian);
|
|
Assert.Equal(expected, actual.BigEndian);
|
|
|
|
expected = (uint)2 & (uint)1;
|
|
actual = valA & valB;
|
|
Assert.Equal(expected, actual.LittleEndian);
|
|
Assert.Equal(expected, actual.BigEndian);
|
|
|
|
expected = (uint)2 | (uint)1;
|
|
actual = valA | valB;
|
|
Assert.Equal(expected, actual.LittleEndian);
|
|
Assert.Equal(expected, actual.BigEndian);
|
|
}
|
|
}
|
|
}
|