mirror of
https://github.com/claunia/SabreTools.git
synced 2025-12-16 19:14:27 +00:00
Add setters and getters for Machine
This commit is contained in:
@@ -15,29 +15,39 @@ namespace SabreTools.Test.DatFiles
|
||||
public void BucketByTest(ItemKey itemKey, int expected)
|
||||
{
|
||||
// Setup the items
|
||||
var rom1 = new Rom { Machine = new Machine { Name = "game-1" } };
|
||||
var machine1 = new Machine();
|
||||
machine1.SetFieldValue<string?>(Models.Metadata.Machine.NameKey, "game-1");
|
||||
|
||||
var machine2 = new Machine();
|
||||
machine2.SetFieldValue<string?>(Models.Metadata.Machine.NameKey, "game-2");
|
||||
|
||||
var rom1 = new Rom();
|
||||
rom1.SetName("rom-1");
|
||||
rom1.SetFieldValue<string?>(Models.Metadata.Rom.CRCKey, "DEADBEEF");
|
||||
rom1.SetFieldValue<string?>(Models.Metadata.Rom.SHA1Key, "0000000fbbb37f8488100b1b4697012de631a5e6");
|
||||
rom1.SetFieldValue<long?>(Models.Metadata.Rom.SizeKey, 1024);
|
||||
rom1.CopyMachineInformation(machine1);
|
||||
|
||||
var rom2 = new Rom { Machine = new Machine { Name = "game-1" } };
|
||||
var rom2 = new Rom();
|
||||
rom2.SetName("rom-2");
|
||||
rom2.SetFieldValue<string?>(Models.Metadata.Rom.CRCKey, "DEADBEEF");
|
||||
rom2.SetFieldValue<string?>(Models.Metadata.Rom.SHA1Key, "000000e948edcb4f7704b8af85a77a3339ecce44");
|
||||
rom2.SetFieldValue<long?>(Models.Metadata.Rom.SizeKey, 1024);
|
||||
rom1.CopyMachineInformation(machine1);
|
||||
|
||||
var rom3 = new Rom { Machine = new Machine { Name = "game-2" } };
|
||||
var rom3 = new Rom();
|
||||
rom3.SetName("rom-3");
|
||||
rom3.SetFieldValue<string?>(Models.Metadata.Rom.CRCKey, "DEADBEEF");
|
||||
rom3.SetFieldValue<string?>(Models.Metadata.Rom.SHA1Key, "00000ea4014ce66679e7e17d56ac510f67e39e26");
|
||||
rom3.SetFieldValue<long?>(Models.Metadata.Rom.SizeKey, 1024);
|
||||
rom1.CopyMachineInformation(machine2);
|
||||
|
||||
var rom4 = new Rom { Machine = new Machine { Name = "game-2" } };
|
||||
var rom4 = new Rom();
|
||||
rom4.SetName("rom-4");
|
||||
rom4.SetFieldValue<string?>(Models.Metadata.Rom.CRCKey, "DEADBEEF");
|
||||
rom4.SetFieldValue<string?>(Models.Metadata.Rom.SHA1Key, "00000151d437442e74e5134023fab8bf694a2487");
|
||||
rom4.SetFieldValue<long?>(Models.Metadata.Rom.SizeKey, 1024);
|
||||
rom1.CopyMachineInformation(machine2);
|
||||
|
||||
// Setup the dictionary
|
||||
var dict = new ItemDictionary
|
||||
@@ -49,7 +59,7 @@ namespace SabreTools.Test.DatFiles
|
||||
dict.BucketBy(itemKey, DedupeType.None);
|
||||
Assert.Equal(expected, dict.Keys.Count);
|
||||
}
|
||||
|
||||
|
||||
[Fact]
|
||||
public void ClearEmptyTest()
|
||||
{
|
||||
@@ -69,17 +79,22 @@ namespace SabreTools.Test.DatFiles
|
||||
public void ClearMarkedTest()
|
||||
{
|
||||
// Setup the items
|
||||
var rom1 = new Rom { Machine = new Machine { Name = "game-1" } };
|
||||
var machine1 = new Machine();
|
||||
machine1.SetFieldValue<string?>(Models.Metadata.Machine.NameKey, "game-1");
|
||||
|
||||
var rom1 = new Rom();
|
||||
rom1.SetName("rom-1");
|
||||
rom1.SetFieldValue<string?>(Models.Metadata.Rom.CRCKey, "DEADBEEF");
|
||||
rom1.SetFieldValue<string?>(Models.Metadata.Rom.SHA1Key, "0000000fbbb37f8488100b1b4697012de631a5e6");
|
||||
rom1.SetFieldValue<long?>(Models.Metadata.Rom.SizeKey, 1024);
|
||||
rom1.CopyMachineInformation(machine1);
|
||||
|
||||
var rom2 = new Rom { Machine = new Machine { Name = "game-1" }, Remove = true };
|
||||
var rom2 = new Rom { Remove = true };
|
||||
rom2.SetName("rom-2");
|
||||
rom2.SetFieldValue<string?>(Models.Metadata.Rom.CRCKey, "DEADBEEF");
|
||||
rom2.SetFieldValue<string?>(Models.Metadata.Rom.SHA1Key, "000000e948edcb4f7704b8af85a77a3339ecce44");
|
||||
rom2.SetFieldValue<long?>(Models.Metadata.Rom.SizeKey, 1024);
|
||||
rom1.CopyMachineInformation(machine1);
|
||||
|
||||
// Setup the dictionary
|
||||
var dict = new ItemDictionary
|
||||
@@ -93,22 +108,27 @@ namespace SabreTools.Test.DatFiles
|
||||
Assert.NotNull(dict[key]);
|
||||
Assert.Single(dict[key]!);
|
||||
}
|
||||
|
||||
|
||||
[Theory]
|
||||
[InlineData(true, 1)]
|
||||
[InlineData(false, 0)]
|
||||
public void GetDuplicatesTest(bool hasDuplicate, int expected)
|
||||
{
|
||||
// Setup the items
|
||||
var rom1 = new Rom { Machine = new Machine { Name = "game-1" } };
|
||||
var machine1 = new Machine();
|
||||
machine1.SetFieldValue<string?>(Models.Metadata.Machine.NameKey, "game-1");
|
||||
|
||||
var rom1 = new Rom();
|
||||
rom1.SetName("rom-1");
|
||||
rom1.SetFieldValue<string?>(Models.Metadata.Rom.SHA1Key, "0000000fbbb37f8488100b1b4697012de631a5e6");
|
||||
rom1.SetFieldValue<long?>(Models.Metadata.Rom.SizeKey, 1024);
|
||||
rom1.CopyMachineInformation(machine1);
|
||||
|
||||
var rom2 = new Rom { Machine = new Machine { Name = "game-1" } };
|
||||
var rom2 = new Rom();
|
||||
rom2.SetName("rom-2");
|
||||
rom2.SetFieldValue<string?>(Models.Metadata.Rom.SHA1Key, "000000e948edcb4f7704b8af85a77a3339ecce44");
|
||||
rom2.SetFieldValue<long?>(Models.Metadata.Rom.SizeKey, 1024);
|
||||
rom1.CopyMachineInformation(machine1);
|
||||
|
||||
// Setup the dictionary
|
||||
var dict = new ItemDictionary
|
||||
@@ -117,30 +137,36 @@ namespace SabreTools.Test.DatFiles
|
||||
};
|
||||
|
||||
// Setup the test item
|
||||
var rom = new Rom { Machine = new Machine { Name = "game-1" } };
|
||||
var rom = new Rom();
|
||||
rom.SetName("rom-1");
|
||||
rom.SetFieldValue<string?>(Models.Metadata.Rom.SHA1Key, "0000000fbbb37f8488100b1b4697012de631a5e6");
|
||||
rom.SetFieldValue<long?>(Models.Metadata.Rom.SizeKey, hasDuplicate ? 1024 : 2048);
|
||||
rom1.CopyMachineInformation(machine1);
|
||||
|
||||
var actual = dict.GetDuplicates(rom);
|
||||
Assert.Equal(expected, actual.Count);
|
||||
}
|
||||
|
||||
|
||||
[Theory]
|
||||
[InlineData(true)]
|
||||
[InlineData(false)]
|
||||
public void HasDuplicatesTest(bool expected)
|
||||
{
|
||||
// Setup the items
|
||||
var rom1 = new Rom { Machine = new Machine { Name = "game-1" } };
|
||||
var machine1 = new Machine();
|
||||
machine1.SetFieldValue<string?>(Models.Metadata.Machine.NameKey, "game-1");
|
||||
|
||||
var rom1 = new Rom();
|
||||
rom1.SetName("rom-1");
|
||||
rom1.SetFieldValue<string?>(Models.Metadata.Rom.SHA1Key, "0000000fbbb37f8488100b1b4697012de631a5e6");
|
||||
rom1.SetFieldValue<long?>(Models.Metadata.Rom.SizeKey, 1024);
|
||||
rom1.CopyMachineInformation(machine1);
|
||||
|
||||
var rom2 = new Rom { Machine = new Machine { Name = "game-1" } };
|
||||
var rom2 = new Rom();
|
||||
rom2.SetName("rom-2");
|
||||
rom2.SetFieldValue<string?>(Models.Metadata.Rom.SHA1Key, "000000e948edcb4f7704b8af85a77a3339ecce44");
|
||||
rom2.SetFieldValue<long?>(Models.Metadata.Rom.SizeKey, 1024);
|
||||
rom1.CopyMachineInformation(machine1);
|
||||
|
||||
// Setup the dictionary
|
||||
var dict = new ItemDictionary
|
||||
@@ -149,15 +175,16 @@ namespace SabreTools.Test.DatFiles
|
||||
};
|
||||
|
||||
// Setup the test item
|
||||
var rom = new Rom { Machine = new Machine { Name = "game-1" } };
|
||||
var rom = new Rom();
|
||||
rom.SetName("rom-1");
|
||||
rom.SetFieldValue<string?>(Models.Metadata.Rom.SHA1Key, "0000000fbbb37f8488100b1b4697012de631a5e6");
|
||||
rom.SetFieldValue<long?>(Models.Metadata.Rom.SizeKey, expected ? 1024 : 2048);
|
||||
rom1.CopyMachineInformation(machine1);
|
||||
|
||||
bool actual = dict.HasDuplicates(rom);
|
||||
Assert.Equal(expected, actual);
|
||||
}
|
||||
|
||||
|
||||
[Fact]
|
||||
public void ResetStatisticsTest()
|
||||
{
|
||||
|
||||
Reference in New Issue
Block a user