Add GetMissingRequiredFields tests

This commit is contained in:
Matt Nadareski
2025-02-14 14:27:43 -05:00
parent f4d7d5ea11
commit e4b6bb86fd
7 changed files with 1489 additions and 228 deletions

File diff suppressed because it is too large Load Diff

View File

@@ -13,14 +13,6 @@ namespace SabreTools.DatFiles.Formats
{ {
#region Fields #region Fields
/// <inheritdoc/>
public override ItemType[] SupportedTypes
=> [
ItemType.Disk,
ItemType.Media,
ItemType.Rom,
];
// Private instance variables specific to Hashfile DATs // Private instance variables specific to Hashfile DATs
protected HashType _hash; protected HashType _hash;
@@ -53,167 +45,6 @@ namespace SabreTools.DatFiles.Formats
} }
} }
/// <inheritdoc/>
protected internal override List<string>? GetMissingRequiredFields(DatItem datItem)
{
List<string> missingFields = [];
// Check item name
if (string.IsNullOrEmpty(datItem.GetName()))
missingFields.Add(Models.Metadata.Rom.NameKey);
// Check hash linked to specific Hashfile type
switch (_hash)
{
case HashType.CRC32:
case HashType.CRC32_AIXM:
case HashType.CRC32_AUTOSAR:
case HashType.CRC32_BASE91D:
case HashType.CRC32_BZIP2:
case HashType.CRC32_CDROMEDC:
case HashType.CRC32_CKSUM:
case HashType.CRC32_ISCSI:
case HashType.CRC32_ISOHDLC:
case HashType.CRC32_JAMCRC:
case HashType.CRC32_MEF:
case HashType.CRC32_MPEG2:
case HashType.CRC32_XFER:
switch (datItem)
{
case Rom rom:
if (string.IsNullOrEmpty(rom.GetStringFieldValue(Models.Metadata.Rom.CRCKey)))
missingFields.Add(Models.Metadata.Rom.CRCKey);
break;
default:
missingFields.Add(Models.Metadata.Rom.CRCKey);
break;
}
break;
case HashType.MD2:
switch (datItem)
{
case Rom rom:
if (string.IsNullOrEmpty(rom.GetStringFieldValue(Models.Metadata.Rom.MD2Key)))
missingFields.Add(Models.Metadata.Rom.MD2Key);
break;
default:
missingFields.Add(Models.Metadata.Rom.MD2Key);
break;
}
break;
case HashType.MD4:
switch (datItem)
{
case Rom rom:
if (string.IsNullOrEmpty(rom.GetStringFieldValue(Models.Metadata.Rom.MD4Key)))
missingFields.Add(Models.Metadata.Rom.MD4Key);
break;
default:
missingFields.Add(Models.Metadata.Rom.MD4Key);
break;
}
break;
case HashType.MD5:
switch (datItem)
{
case Disk disk:
if (string.IsNullOrEmpty(disk.GetStringFieldValue(Models.Metadata.Disk.MD5Key)))
missingFields.Add(Models.Metadata.Disk.MD5Key);
break;
case Media medium:
if (string.IsNullOrEmpty(medium.GetStringFieldValue(Models.Metadata.Media.MD5Key)))
missingFields.Add(Models.Metadata.Media.MD5Key);
break;
case Rom rom:
if (string.IsNullOrEmpty(rom.GetStringFieldValue(Models.Metadata.Rom.MD5Key)))
missingFields.Add(Models.Metadata.Rom.MD5Key);
break;
default:
missingFields.Add(Models.Metadata.Rom.MD5Key);
break;
}
break;
case HashType.SHA1:
switch (datItem)
{
case Disk disk:
if (string.IsNullOrEmpty(disk.GetStringFieldValue(Models.Metadata.Disk.SHA1Key)))
missingFields.Add(Models.Metadata.Disk.SHA1Key);
break;
case Media medium:
if (string.IsNullOrEmpty(medium.GetStringFieldValue(Models.Metadata.Media.SHA1Key)))
missingFields.Add(Models.Metadata.Media.SHA1Key);
break;
case Rom rom:
if (string.IsNullOrEmpty(rom.GetStringFieldValue(Models.Metadata.Rom.SHA1Key)))
missingFields.Add(Models.Metadata.Rom.SHA1Key);
break;
default:
missingFields.Add(Models.Metadata.Rom.SHA1Key);
break;
}
break;
case HashType.SHA256:
switch (datItem)
{
case Media medium:
if (string.IsNullOrEmpty(medium.GetStringFieldValue(Models.Metadata.Media.SHA256Key)))
missingFields.Add(Models.Metadata.Media.SHA256Key);
break;
case Rom rom:
if (string.IsNullOrEmpty(rom.GetStringFieldValue(Models.Metadata.Rom.SHA256Key)))
missingFields.Add(Models.Metadata.Rom.SHA256Key);
break;
default:
missingFields.Add(Models.Metadata.Rom.SHA256Key);
break;
}
break;
case HashType.SHA384:
switch (datItem)
{
case Rom rom:
if (string.IsNullOrEmpty(rom.GetStringFieldValue(Models.Metadata.Rom.SHA384Key)))
missingFields.Add(Models.Metadata.Rom.SHA384Key);
break;
default:
missingFields.Add(Models.Metadata.Rom.SHA384Key);
break;
}
break;
case HashType.SHA512:
switch (datItem)
{
case Rom rom:
if (string.IsNullOrEmpty(rom.GetStringFieldValue(Models.Metadata.Rom.SHA512Key)))
missingFields.Add(Models.Metadata.Rom.SHA512Key);
break;
default:
missingFields.Add(Models.Metadata.Rom.SHA512Key);
break;
}
break;
case HashType.SpamSum:
switch (datItem)
{
case Media medium:
if (string.IsNullOrEmpty(medium.GetStringFieldValue(Models.Metadata.Media.SpamSumKey)))
missingFields.Add(Models.Metadata.Media.SpamSumKey);
break;
case Rom rom:
if (string.IsNullOrEmpty(rom.GetStringFieldValue(Models.Metadata.Rom.SpamSumKey)))
missingFields.Add(Models.Metadata.Rom.SpamSumKey);
break;
default:
missingFields.Add(Models.Metadata.Rom.SpamSumKey);
break;
}
break;
}
return missingFields;
}
/// <inheritdoc/> /// <inheritdoc/>
public override bool WriteToFile(string outfile, bool ignoreblanks = false, bool throwOnError = false) public override bool WriteToFile(string outfile, bool ignoreblanks = false, bool throwOnError = false)
{ {
@@ -224,7 +55,7 @@ namespace SabreTools.DatFiles.Formats
// Serialize the input file // Serialize the input file
var metadata = ConvertToMetadata(ignoreblanks); var metadata = ConvertToMetadata(ignoreblanks);
var hashfile = new Serialization.CrossModel.Hashfile().Deserialize(metadata, _hash); var hashfile = new Serialization.CrossModel.Hashfile().Deserialize(metadata, _hash);
if (!(Serialization.Serializers.Hashfile.SerializeFile(hashfile, outfile, _hash))) if (!Serialization.Serializers.Hashfile.SerializeFile(hashfile, outfile, _hash))
{ {
_logger.Warning($"File '{outfile}' could not be written! See the log for more details."); _logger.Warning($"File '{outfile}' could not be written! See the log for more details.");
return false; return false;
@@ -246,6 +77,12 @@ namespace SabreTools.DatFiles.Formats
/// </summary> /// </summary>
public sealed class SfvFile : Hashfile public sealed class SfvFile : Hashfile
{ {
/// <inheritdoc/>
public override ItemType[] SupportedTypes
=> [
ItemType.Rom,
];
/// <summary> /// <summary>
/// Constructor designed for casting a base DatFile /// Constructor designed for casting a base DatFile
/// </summary> /// </summary>
@@ -254,6 +91,26 @@ namespace SabreTools.DatFiles.Formats
{ {
_hash = HashType.CRC32; _hash = HashType.CRC32;
} }
/// <inheritdoc/>
protected internal override List<string>? GetMissingRequiredFields(DatItem datItem)
{
List<string> missingFields = [];
// Check item name
if (string.IsNullOrEmpty(datItem.GetName()))
missingFields.Add(Models.Metadata.Rom.NameKey);
switch (datItem)
{
case Rom rom:
if (string.IsNullOrEmpty(rom.GetStringFieldValue(Models.Metadata.Rom.CRCKey)))
missingFields.Add(Models.Metadata.Rom.CRCKey);
break;
}
return missingFields;
}
} }
/// <summary> /// <summary>
@@ -261,6 +118,12 @@ namespace SabreTools.DatFiles.Formats
/// </summary> /// </summary>
public sealed class Md2File : Hashfile public sealed class Md2File : Hashfile
{ {
/// <inheritdoc/>
public override ItemType[] SupportedTypes
=> [
ItemType.Rom,
];
/// <summary> /// <summary>
/// Constructor designed for casting a base DatFile /// Constructor designed for casting a base DatFile
/// </summary> /// </summary>
@@ -269,6 +132,26 @@ namespace SabreTools.DatFiles.Formats
{ {
_hash = HashType.MD2; _hash = HashType.MD2;
} }
/// <inheritdoc/>
protected internal override List<string>? GetMissingRequiredFields(DatItem datItem)
{
List<string> missingFields = [];
// Check item name
if (string.IsNullOrEmpty(datItem.GetName()))
missingFields.Add(Models.Metadata.Rom.NameKey);
switch (datItem)
{
case Rom rom:
if (string.IsNullOrEmpty(rom.GetStringFieldValue(Models.Metadata.Rom.MD2Key)))
missingFields.Add(Models.Metadata.Rom.MD2Key);
break;
}
return missingFields;
}
} }
/// <summary> /// <summary>
@@ -276,6 +159,12 @@ namespace SabreTools.DatFiles.Formats
/// </summary> /// </summary>
public sealed class Md4File : Hashfile public sealed class Md4File : Hashfile
{ {
/// <inheritdoc/>
public override ItemType[] SupportedTypes
=> [
ItemType.Rom,
];
/// <summary> /// <summary>
/// Constructor designed for casting a base DatFile /// Constructor designed for casting a base DatFile
/// </summary> /// </summary>
@@ -284,6 +173,26 @@ namespace SabreTools.DatFiles.Formats
{ {
_hash = HashType.MD4; _hash = HashType.MD4;
} }
/// <inheritdoc/>
protected internal override List<string>? GetMissingRequiredFields(DatItem datItem)
{
List<string> missingFields = [];
// Check item name
if (string.IsNullOrEmpty(datItem.GetName()))
missingFields.Add(Models.Metadata.Rom.NameKey);
switch (datItem)
{
case Rom rom:
if (string.IsNullOrEmpty(rom.GetStringFieldValue(Models.Metadata.Rom.MD4Key)))
missingFields.Add(Models.Metadata.Rom.MD4Key);
break;
}
return missingFields;
}
} }
/// <summary> /// <summary>
@@ -291,6 +200,14 @@ namespace SabreTools.DatFiles.Formats
/// </summary> /// </summary>
public sealed class Md5File : Hashfile public sealed class Md5File : Hashfile
{ {
/// <inheritdoc/>
public override ItemType[] SupportedTypes
=> [
ItemType.Disk,
ItemType.Media,
ItemType.Rom,
];
/// <summary> /// <summary>
/// Constructor designed for casting a base DatFile /// Constructor designed for casting a base DatFile
/// </summary> /// </summary>
@@ -299,6 +216,36 @@ namespace SabreTools.DatFiles.Formats
{ {
_hash = HashType.MD5; _hash = HashType.MD5;
} }
/// <inheritdoc/>
protected internal override List<string>? GetMissingRequiredFields(DatItem datItem)
{
List<string> missingFields = [];
// Check item name
if (string.IsNullOrEmpty(datItem.GetName()))
missingFields.Add(Models.Metadata.Rom.NameKey);
switch (datItem)
{
case Disk disk:
if (string.IsNullOrEmpty(disk.GetStringFieldValue(Models.Metadata.Disk.MD5Key)))
missingFields.Add(Models.Metadata.Disk.MD5Key);
break;
case Media medium:
if (string.IsNullOrEmpty(medium.GetStringFieldValue(Models.Metadata.Media.MD5Key)))
missingFields.Add(Models.Metadata.Media.MD5Key);
break;
case Rom rom:
if (string.IsNullOrEmpty(rom.GetStringFieldValue(Models.Metadata.Rom.MD5Key)))
missingFields.Add(Models.Metadata.Rom.MD5Key);
break;
}
return missingFields;
}
} }
/// <summary> /// <summary>
@@ -306,6 +253,14 @@ namespace SabreTools.DatFiles.Formats
/// </summary> /// </summary>
public sealed class Sha1File : Hashfile public sealed class Sha1File : Hashfile
{ {
/// <inheritdoc/>
public override ItemType[] SupportedTypes
=> [
ItemType.Disk,
ItemType.Media,
ItemType.Rom,
];
/// <summary> /// <summary>
/// Constructor designed for casting a base DatFile /// Constructor designed for casting a base DatFile
/// </summary> /// </summary>
@@ -314,6 +269,36 @@ namespace SabreTools.DatFiles.Formats
{ {
_hash = HashType.SHA1; _hash = HashType.SHA1;
} }
/// <inheritdoc/>
protected internal override List<string>? GetMissingRequiredFields(DatItem datItem)
{
List<string> missingFields = [];
// Check item name
if (string.IsNullOrEmpty(datItem.GetName()))
missingFields.Add(Models.Metadata.Rom.NameKey);
switch (datItem)
{
case Disk disk:
if (string.IsNullOrEmpty(disk.GetStringFieldValue(Models.Metadata.Disk.SHA1Key)))
missingFields.Add(Models.Metadata.Disk.SHA1Key);
break;
case Media medium:
if (string.IsNullOrEmpty(medium.GetStringFieldValue(Models.Metadata.Media.SHA1Key)))
missingFields.Add(Models.Metadata.Media.SHA1Key);
break;
case Rom rom:
if (string.IsNullOrEmpty(rom.GetStringFieldValue(Models.Metadata.Rom.SHA1Key)))
missingFields.Add(Models.Metadata.Rom.SHA1Key);
break;
}
return missingFields;
}
} }
/// <summary> /// <summary>
@@ -321,6 +306,13 @@ namespace SabreTools.DatFiles.Formats
/// </summary> /// </summary>
public sealed class Sha256File : Hashfile public sealed class Sha256File : Hashfile
{ {
/// <inheritdoc/>
public override ItemType[] SupportedTypes
=> [
ItemType.Media,
ItemType.Rom,
];
/// <summary> /// <summary>
/// Constructor designed for casting a base DatFile /// Constructor designed for casting a base DatFile
/// </summary> /// </summary>
@@ -329,6 +321,31 @@ namespace SabreTools.DatFiles.Formats
{ {
_hash = HashType.SHA256; _hash = HashType.SHA256;
} }
/// <inheritdoc/>
protected internal override List<string>? GetMissingRequiredFields(DatItem datItem)
{
List<string> missingFields = [];
// Check item name
if (string.IsNullOrEmpty(datItem.GetName()))
missingFields.Add(Models.Metadata.Rom.NameKey);
switch (datItem)
{
case Media medium:
if (string.IsNullOrEmpty(medium.GetStringFieldValue(Models.Metadata.Media.SHA256Key)))
missingFields.Add(Models.Metadata.Media.SHA256Key);
break;
case Rom rom:
if (string.IsNullOrEmpty(rom.GetStringFieldValue(Models.Metadata.Rom.SHA256Key)))
missingFields.Add(Models.Metadata.Rom.SHA256Key);
break;
}
return missingFields;
}
} }
/// <summary> /// <summary>
@@ -336,6 +353,12 @@ namespace SabreTools.DatFiles.Formats
/// </summary> /// </summary>
public sealed class Sha384File : Hashfile public sealed class Sha384File : Hashfile
{ {
/// <inheritdoc/>
public override ItemType[] SupportedTypes
=> [
ItemType.Rom,
];
/// <summary> /// <summary>
/// Constructor designed for casting a base DatFile /// Constructor designed for casting a base DatFile
/// </summary> /// </summary>
@@ -344,6 +367,26 @@ namespace SabreTools.DatFiles.Formats
{ {
_hash = HashType.SHA384; _hash = HashType.SHA384;
} }
/// <inheritdoc/>
protected internal override List<string>? GetMissingRequiredFields(DatItem datItem)
{
List<string> missingFields = [];
// Check item name
if (string.IsNullOrEmpty(datItem.GetName()))
missingFields.Add(Models.Metadata.Rom.NameKey);
switch (datItem)
{
case Rom rom:
if (string.IsNullOrEmpty(rom.GetStringFieldValue(Models.Metadata.Rom.SHA384Key)))
missingFields.Add(Models.Metadata.Rom.SHA384Key);
break;
}
return missingFields;
}
} }
/// <summary> /// <summary>
@@ -351,6 +394,12 @@ namespace SabreTools.DatFiles.Formats
/// </summary> /// </summary>
public sealed class Sha512File : Hashfile public sealed class Sha512File : Hashfile
{ {
/// <inheritdoc/>
public override ItemType[] SupportedTypes
=> [
ItemType.Rom,
];
/// <summary> /// <summary>
/// Constructor designed for casting a base DatFile /// Constructor designed for casting a base DatFile
/// </summary> /// </summary>
@@ -359,6 +408,26 @@ namespace SabreTools.DatFiles.Formats
{ {
_hash = HashType.SHA512; _hash = HashType.SHA512;
} }
/// <inheritdoc/>
protected internal override List<string>? GetMissingRequiredFields(DatItem datItem)
{
List<string> missingFields = [];
// Check item name
if (string.IsNullOrEmpty(datItem.GetName()))
missingFields.Add(Models.Metadata.Rom.NameKey);
switch (datItem)
{
case Rom rom:
if (string.IsNullOrEmpty(rom.GetStringFieldValue(Models.Metadata.Rom.SHA512Key)))
missingFields.Add(Models.Metadata.Rom.SHA512Key);
break;
}
return missingFields;
}
} }
/// <summary> /// <summary>
@@ -366,6 +435,13 @@ namespace SabreTools.DatFiles.Formats
/// </summary> /// </summary>
public sealed class SpamSumFile : Hashfile public sealed class SpamSumFile : Hashfile
{ {
/// <inheritdoc/>
public override ItemType[] SupportedTypes
=> [
ItemType.Media,
ItemType.Rom,
];
/// <summary> /// <summary>
/// Constructor designed for casting a base DatFile /// Constructor designed for casting a base DatFile
/// </summary> /// </summary>
@@ -374,5 +450,30 @@ namespace SabreTools.DatFiles.Formats
{ {
_hash = HashType.SpamSum; _hash = HashType.SpamSum;
} }
/// <inheritdoc/>
protected internal override List<string>? GetMissingRequiredFields(DatItem datItem)
{
List<string> missingFields = [];
// Check item name
if (string.IsNullOrEmpty(datItem.GetName()))
missingFields.Add(Models.Metadata.Rom.NameKey);
switch (datItem)
{
case Media medium:
if (string.IsNullOrEmpty(medium.GetStringFieldValue(Models.Metadata.Media.SpamSumKey)))
missingFields.Add(Models.Metadata.Media.SpamSumKey);
break;
case Rom rom:
if (string.IsNullOrEmpty(rom.GetStringFieldValue(Models.Metadata.Rom.SpamSumKey)))
missingFields.Add(Models.Metadata.Rom.SpamSumKey);
break;
}
return missingFields;
}
} }
} }

View File

@@ -53,7 +53,7 @@ namespace SabreTools.DatFiles.Formats
break; break;
} }
return null; return missingFields;
} }
} }
} }

View File

@@ -356,7 +356,7 @@ namespace SabreTools.DatFiles.Formats
break; break;
case Device device: case Device device:
if (device.GetStringFieldValue(Models.Metadata.Device.DeviceTypeKey).AsEnumValue<DeviceType>() != DeviceType.NULL) if (device.GetStringFieldValue(Models.Metadata.Device.DeviceTypeKey).AsEnumValue<DeviceType>() == DeviceType.NULL)
missingFields.Add(Models.Metadata.Device.DeviceTypeKey); missingFields.Add(Models.Metadata.Device.DeviceTypeKey);
break; break;

View File

@@ -228,11 +228,14 @@ namespace SabreTools.DatFiles.Formats
=> [ => [
ItemType.Archive, ItemType.Archive,
ItemType.BiosSet, ItemType.BiosSet,
ItemType.DeviceRef,
ItemType.Disk, ItemType.Disk,
ItemType.Driver,
ItemType.Media, ItemType.Media,
ItemType.Release, ItemType.Release,
ItemType.Rom, ItemType.Rom,
ItemType.Sample, ItemType.Sample,
ItemType.SoftwareList,
]; ];
/// <summary> /// <summary>

View File

@@ -73,6 +73,16 @@ namespace SabreTools.DatFiles.Formats
} }
break; break;
case Media media:
if (string.IsNullOrEmpty(media.GetStringFieldValue(Models.Metadata.Media.MD5Key))
&& string.IsNullOrEmpty(media.GetStringFieldValue(Models.Metadata.Media.SHA1Key))
&& string.IsNullOrEmpty(media.GetStringFieldValue(Models.Metadata.Media.SHA256Key))
&& string.IsNullOrEmpty(media.GetStringFieldValue(Models.Metadata.Media.SpamSumKey)))
{
missingFields.Add(Models.Metadata.Media.SHA1Key);
}
break;
case Rom rom: case Rom rom:
if (rom.GetInt64FieldValue(Models.Metadata.Rom.SizeKey) == null || rom.GetInt64FieldValue(Models.Metadata.Rom.SizeKey) < 0) if (rom.GetInt64FieldValue(Models.Metadata.Rom.SizeKey) == null || rom.GetInt64FieldValue(Models.Metadata.Rom.SizeKey) < 0)
missingFields.Add(Models.Metadata.Rom.SizeKey); missingFields.Add(Models.Metadata.Rom.SizeKey);
@@ -102,7 +112,7 @@ namespace SabreTools.DatFiles.Formats
// Serialize the input file // Serialize the input file
var metadata = ConvertToMetadata(ignoreblanks); var metadata = ConvertToMetadata(ignoreblanks);
var metadataFile = new Serialization.CrossModel.SeparatedValue().Deserialize(metadata); var metadataFile = new Serialization.CrossModel.SeparatedValue().Deserialize(metadata);
if (!(Serialization.Serializers.SeparatedValue.SerializeFile(metadataFile, outfile, _delim))) if (!Serialization.Serializers.SeparatedValue.SerializeFile(metadataFile, outfile, _delim))
{ {
_logger.Warning($"File '{outfile}' could not be written! See the log for more details."); _logger.Warning($"File '{outfile}' could not be written! See the log for more details.");
return false; return false;

View File

@@ -197,9 +197,6 @@ namespace SabreTools.DatFiles.Formats
if (string.IsNullOrEmpty(sharedFeat.GetName())) if (string.IsNullOrEmpty(sharedFeat.GetName()))
missingFields.Add(Models.Metadata.SharedFeat.NameKey); missingFields.Add(Models.Metadata.SharedFeat.NameKey);
break; break;
default:
// Unsupported ItemTypes should be caught already
return null;
} }
return missingFields; return missingFields;