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]);
+ }
}
}
}