diff --git a/DiscImageChef.Tests/DiscImageChef.Tests.csproj b/DiscImageChef.Tests/DiscImageChef.Tests.csproj index 54aa2b4e..6637b30b 100644 --- a/DiscImageChef.Tests/DiscImageChef.Tests.csproj +++ b/DiscImageChef.Tests/DiscImageChef.Tests.csproj @@ -62,6 +62,7 @@ + @@ -69,6 +70,7 @@ + @@ -79,6 +81,22 @@ {D571B8EF-903D-4353-BDD5-B834F9F029EF} DiscImageChef.Filters + + {74032CBC-339B-42F3-AF6F-E96C261F3E6A} + DiscImageChef.DiscImages + + + {D7016DF2-5A5E-4524-B40D-BA2D59576688} + DiscImageChef.Filesystems + + + {F2B84194-26EB-4227-B1C5-6602517E85AE} + DiscImageChef.CommonTypes + + + {9F213318-5CB8-4066-A757-074489C9F818} + DiscImageChef.Metadata + @@ -89,7 +107,7 @@ - + diff --git a/DiscImageChef.Tests/Filesystems/ADFS.cs b/DiscImageChef.Tests/Filesystems/ADFS.cs index f427b660..3c2c2a4f 100644 --- a/DiscImageChef.Tests/Filesystems/ADFS.cs +++ b/DiscImageChef.Tests/Filesystems/ADFS.cs @@ -36,12 +36,77 @@ // ****************************************************************************/ // //$Id$ using System; +using NUnit.Framework; +using System.IO; +using DiscImageChef.Filters; +using DiscImageChef.ImagePlugins; +using DiscImageChef.CommonTypes; +using DiscImageChef.Filesystems; + namespace DiscImageChef.Tests.Filesystems { + [TestFixture] public class ADFS { - public ADFS() + readonly string[] testfiles = { + "adfs_d.adf.lz", + "adfs_e.adf.lz", + "adfs_f.adf.lz", + "adfs_e+.adf.lz", + "adfs_f+.adf.lz", + "adfs_s.adf.lz", + "adfs_m.adf.lz", + "adfs_l.adf.lz" + }; + + readonly MediaType[] mediatypes = { + MediaType.ACORN_35_DS_DD, + MediaType.ACORN_35_DS_DD, + MediaType.ACORN_35_DS_HD, + MediaType.ACORN_35_DS_DD, + MediaType.ACORN_35_DS_HD, + MediaType.ACORN_525_SS_DD_40, + MediaType.ACORN_525_SS_DD_80, + MediaType.ACORN_525_DS_DD + }; + + readonly ulong[] sectors = { 1600, 1600, 1600, 1600, 1600, 640, 1280, 2560 }; + + readonly uint[] sectorsize = { 512, 512, 1024, 512, 1024, 256, 256, 256 }; + + readonly bool[] bootable = { false, false, false, false, false, false, false, false }; + + readonly long[] clusters = { 1600, 1600, 1600, 1600, 1600, 640, 1280, 2560 }; + + readonly int[] clustersize = { 512, 512, 1024, 512, 1024, 256, 256, 256 }; + + readonly string[] volumename = { "ADFSD", "ADFSE", "", "ADFSE+", "", "", "", "" }; + + readonly string[] volumeserial = { "0", "0", "0", "0", "0", "0", "0", "0" }; + + [Test] + public void Test() { + for(int i = 0; i < testfiles.Length; i++) + { + string location = Path.Combine(Consts.TestFilesRoot, "filesystems", "adfs", testfiles[i]); + Filter filter = new LZip(); + filter.Open(location); + ImagePlugin image = new ZZZRawImage(); + Assert.AreEqual(true, image.OpenImage(filter), testfiles[i]); + Assert.AreEqual(mediatypes[i], image.ImageInfo.mediaType, testfiles[i]); + Assert.AreEqual(sectors[i], image.ImageInfo.sectors, testfiles[i]); + Assert.AreEqual(sectorsize[i], image.ImageInfo.sectorSize, testfiles[i]); + Filesystem fs = new AcornADFS(); + Assert.AreEqual(true, fs.Identify(image, 0, image.ImageInfo.sectors - 1), testfiles[i]); + fs.GetInformation(image, 0, image.ImageInfo.sectors - 1, out string information); + Assert.AreEqual(bootable[i], fs.XmlFSType.Bootable, testfiles[i]); + Assert.AreEqual(clusters[i], fs.XmlFSType.Clusters, testfiles[i]); + Assert.AreEqual(clustersize[i], fs.XmlFSType.ClusterSize, testfiles[i]); + Assert.AreEqual("Acorn Advanced Disc Filing System", fs.XmlFSType.Type, testfiles[i]); + Assert.AreEqual(volumename[i], fs.XmlFSType.VolumeName, testfiles[i]); + Assert.AreEqual(volumeserial[i], fs.XmlFSType.VolumeSerial, testfiles[i]); + } } } }