Files
Aaru/DiscImageChef.Tests/Filesystems/HPFS.cs

117 lines
4.7 KiB
C#
Raw Normal View History

// /***************************************************************************
2017-07-02 05:07:07 +01:00
// The Disc Image Chef
// ----------------------------------------------------------------------------
//
// Filename : HPFS.cs
// Author(s) : Natalia Portillo <claunia@claunia.com>
2017-07-02 05:07:07 +01:00
//
// Component : DiscImageChef unit testing.
2017-07-02 05:07:07 +01:00
//
// --[ License ] --------------------------------------------------------------
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as
// published by the Free Software Foundation, either version 3 of the
// License, or (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program. If not, see <http://www.gnu.org/licenses/>.
//
// ----------------------------------------------------------------------------
// Copyright © 2011-2018 Natalia Portillo
2017-07-02 05:07:07 +01:00
// ****************************************************************************/
2017-07-02 05:07:16 +01:00
using System.Collections.Generic;
using System.IO;
using DiscImageChef.CommonTypes;
using DiscImageChef.DiscImages;
using DiscImageChef.Filesystems;
using DiscImageChef.Filters;
using DiscImageChef.ImagePlugins;
using NUnit.Framework;
2017-07-02 05:07:07 +01:00
namespace DiscImageChef.Tests.Filesystems
{
2017-07-02 05:07:16 +01:00
[TestFixture]
2017-07-02 05:07:07 +01:00
public class HPFS
{
2017-07-02 05:07:16 +01:00
readonly string[] testfiles = {
"ecs.vdi.lz", "msos2_1.21.vdi.lz", "msos2_1.30.1.vdi.lz", "os2_1.20.vdi.lz",
"os2_1.30.vdi.lz", "os2_6.307.vdi.lz", "os2_6.514.vdi.lz", "os2_6.617.vdi.lz",
2017-07-05 01:47:45 +01:00
"os2_8.162.vdi.lz", "os2_9.023.vdi.lz", "winnt_3.10.vdi.lz", "winnt_3.50.vdi.lz",
2017-07-02 05:07:16 +01:00
};
readonly ulong[] sectors = {
262144, 1024000, 1024000, 1024000,
1024000, 1024000, 262144, 262144,
2017-07-05 01:47:45 +01:00
262144, 262144, 262144, 262144
2017-07-02 05:07:16 +01:00
};
readonly uint[] sectorsize = {
512, 512, 512, 512,
512, 512, 512, 512,
2017-07-05 01:47:45 +01:00
512, 512, 512, 512
2017-07-02 05:07:16 +01:00
};
readonly long[] clusters = {
2017-07-10 22:45:58 +01:00
261072, 1023056, 1023056, 1023056,
1023056, 1023056, 262016, 262016,
262016, 262016, 262016, 262112,
2017-07-02 05:07:16 +01:00
};
readonly int[] clustersize = {
2017-07-10 22:45:58 +01:00
512, 512, 512, 512,
512, 512, 512, 512,
512, 512, 512, 512,
2017-07-02 05:07:16 +01:00
};
readonly string[] volumename = {
"VOLUMELABEL","VOLUMELABEL","VOLUMELABEL","VOLUMELABEL",
"VOLUMELABEL","VOLUMELABEL","VOLUMELABEL","VOLUMELABEL",
2017-07-05 01:47:45 +01:00
"VOLUMELABEL","VOLUMELABEL","VOLUMELABEL","VOLUMELABEL",
2017-07-02 05:07:16 +01:00
};
readonly string[] volumeserial = {
"2BBBD814","AC0DDC15","ABEB2C15","6C4EE015",
"6C406015","6C49B015","2BCEB414","2C157414",
2017-07-10 22:45:58 +01:00
"2BF55414","2BE31414","E851CB14","A4EDC29C",
2017-07-02 05:07:16 +01:00
};
readonly string[] oemid = {
"IBM 4.50", "OS2 10.1", "OS2 10.0", "OS2 10.0",
"OS2 10.0", "OS2 20.0", "OS2 20.0", "OS2 20.1",
2017-07-05 01:47:45 +01:00
"OS2 20.0", "OS2 20.0", "MSDOS5.0", "MSDOS5.0",
2017-07-02 05:07:16 +01:00
};
[Test]
public void Test()
2017-07-02 05:07:07 +01:00
{
2017-07-02 05:07:16 +01:00
for(int i = 0; i < testfiles.Length; i++)
{
string location = Path.Combine(Consts.TestFilesRoot, "filesystems", "hpfs", testfiles[i]);
Filter filter = new LZip();
filter.Open(location);
ImagePlugin image = new VDI();
Assert.AreEqual(true, image.OpenImage(filter), testfiles[i]);
Assert.AreEqual(sectors[i], image.ImageInfo.sectors, testfiles[i]);
Assert.AreEqual(sectorsize[i], image.ImageInfo.sectorSize, testfiles[i]);
List<Partition> partitions = Core.Partitions.GetAll(image);
2017-07-02 05:07:16 +01:00
Filesystem fs = new DiscImageChef.Filesystems.HPFS();
Assert.AreEqual(true, fs.Identify(image, partitions[0]), testfiles[i]);
fs.GetInformation(image, partitions[0], out string information);
2017-07-02 05:07:16 +01:00
Assert.AreEqual(clusters[i], fs.XmlFSType.Clusters, testfiles[i]);
Assert.AreEqual(clustersize[i], fs.XmlFSType.ClusterSize, testfiles[i]);
Assert.AreEqual("HPFS", fs.XmlFSType.Type, testfiles[i]);
Assert.AreEqual(volumename[i], fs.XmlFSType.VolumeName, testfiles[i]);
Assert.AreEqual(volumeserial[i], fs.XmlFSType.VolumeSerial, testfiles[i]);
Assert.AreEqual(oemid[i], fs.XmlFSType.SystemIdentifier, testfiles[i]);
}
2017-07-02 05:07:07 +01:00
}
}
}