mirror of
https://github.com/aaru-dps/Aaru.git
synced 2025-12-16 19:24:25 +00:00
268 lines
8.8 KiB
C#
268 lines
8.8 KiB
C#
// /***************************************************************************
|
|
// Aaru Data Preservation Suite
|
|
// ----------------------------------------------------------------------------
|
|
//
|
|
// Filename : SFS_MBR.cs
|
|
// Author(s) : Natalia Portillo <claunia@claunia.com>
|
|
//
|
|
// Component : Aaru unit testing.
|
|
//
|
|
// --[ 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-2021 Natalia Portillo
|
|
// ****************************************************************************/
|
|
|
|
using System.Collections.Generic;
|
|
using System.IO;
|
|
using Aaru.CommonTypes;
|
|
using Aaru.CommonTypes.Interfaces;
|
|
using Aaru.DiscImages;
|
|
using Aaru.Filesystems;
|
|
using Aaru.Filters;
|
|
using NUnit.Framework;
|
|
|
|
namespace Aaru.Tests.Filesystems
|
|
{
|
|
[TestFixture]
|
|
public class SfsMbr
|
|
{
|
|
readonly string[] _testFiles =
|
|
{
|
|
"aros.aif"
|
|
};
|
|
|
|
readonly ulong[] _sectors =
|
|
{
|
|
409600
|
|
};
|
|
|
|
readonly uint[] _sectorSize =
|
|
{
|
|
512
|
|
};
|
|
|
|
readonly long[] _clusters =
|
|
{
|
|
408240
|
|
};
|
|
|
|
readonly int[] _clusterSize =
|
|
{
|
|
512
|
|
};
|
|
|
|
readonly string[] _volumeName =
|
|
{
|
|
null
|
|
};
|
|
|
|
readonly string[] _volumeSerial =
|
|
{
|
|
null
|
|
};
|
|
|
|
[Test]
|
|
public void Test()
|
|
{
|
|
for(int i = 0; i < _testFiles.Length; i++)
|
|
{
|
|
string location = Path.Combine(Consts.TEST_FILES_ROOT, "Filesystems", "Smart File System (MBR)",
|
|
_testFiles[i]);
|
|
|
|
IFilter filter = new ZZZNoFilter();
|
|
filter.Open(location);
|
|
IMediaImage image = new AaruFormat();
|
|
Assert.AreEqual(true, image.Open(filter), _testFiles[i]);
|
|
Assert.AreEqual(_sectors[i], image.Info.Sectors, _testFiles[i]);
|
|
Assert.AreEqual(_sectorSize[i], image.Info.SectorSize, _testFiles[i]);
|
|
List<Partition> partitions = Core.Partitions.GetAll(image);
|
|
IFilesystem fs = new SFS();
|
|
int part = -1;
|
|
|
|
for(int j = 0; j < partitions.Count; j++)
|
|
if(partitions[j].Type == "0x2F")
|
|
{
|
|
part = j;
|
|
|
|
break;
|
|
}
|
|
|
|
Assert.AreNotEqual(-1, part, $"Partition not found on {_testFiles[i]}");
|
|
Assert.AreEqual(true, fs.Identify(image, partitions[part]), _testFiles[i]);
|
|
fs.GetInformation(image, partitions[part], out _, null);
|
|
Assert.AreEqual(_clusters[i], fs.XmlFsType.Clusters, _testFiles[i]);
|
|
Assert.AreEqual(_clusterSize[i], fs.XmlFsType.ClusterSize, _testFiles[i]);
|
|
Assert.AreEqual("SmartFileSystem", fs.XmlFsType.Type, _testFiles[i]);
|
|
Assert.AreEqual(_volumeName[i], fs.XmlFsType.VolumeName, _testFiles[i]);
|
|
Assert.AreEqual(_volumeSerial[i], fs.XmlFsType.VolumeSerial, _testFiles[i]);
|
|
}
|
|
}
|
|
}
|
|
|
|
[TestFixture]
|
|
public class SfsMbrRdb
|
|
{
|
|
readonly string[] _testFiles =
|
|
{
|
|
"aros.aif"
|
|
};
|
|
|
|
readonly ulong[] _sectors =
|
|
{
|
|
409600
|
|
};
|
|
|
|
readonly uint[] _sectorSize =
|
|
{
|
|
512
|
|
};
|
|
|
|
readonly long[] _clusters =
|
|
{
|
|
406224
|
|
};
|
|
|
|
readonly int[] _clusterSize =
|
|
{
|
|
512
|
|
};
|
|
|
|
readonly string[] _volumeName =
|
|
{
|
|
null
|
|
};
|
|
|
|
readonly string[] _volumeSerial =
|
|
{
|
|
null
|
|
};
|
|
|
|
[Test]
|
|
public void Test()
|
|
{
|
|
for(int i = 0; i < _testFiles.Length; i++)
|
|
{
|
|
string location = Path.Combine(Consts.TEST_FILES_ROOT, "Filesystems", "Smart File System (MBR+RDB)",
|
|
_testFiles[i]);
|
|
|
|
IFilter filter = new ZZZNoFilter();
|
|
filter.Open(location);
|
|
IMediaImage image = new AaruFormat();
|
|
Assert.AreEqual(true, image.Open(filter), _testFiles[i]);
|
|
Assert.AreEqual(_sectors[i], image.Info.Sectors, _testFiles[i]);
|
|
Assert.AreEqual(_sectorSize[i], image.Info.SectorSize, _testFiles[i]);
|
|
List<Partition> partitions = Core.Partitions.GetAll(image);
|
|
IFilesystem fs = new SFS();
|
|
int part = -1;
|
|
|
|
for(int j = 0; j < partitions.Count; j++)
|
|
if(partitions[j].Type == "\"SFS\\0\"")
|
|
{
|
|
part = j;
|
|
|
|
break;
|
|
}
|
|
|
|
Assert.AreNotEqual(-1, part, $"Partition not found on {_testFiles[i]}");
|
|
Assert.AreEqual(true, fs.Identify(image, partitions[part]), _testFiles[i]);
|
|
fs.GetInformation(image, partitions[part], out _, null);
|
|
Assert.AreEqual(_clusters[i], fs.XmlFsType.Clusters, _testFiles[i]);
|
|
Assert.AreEqual(_clusterSize[i], fs.XmlFsType.ClusterSize, _testFiles[i]);
|
|
Assert.AreEqual("SmartFileSystem", fs.XmlFsType.Type, _testFiles[i]);
|
|
Assert.AreEqual(_volumeName[i], fs.XmlFsType.VolumeName, _testFiles[i]);
|
|
Assert.AreEqual(_volumeSerial[i], fs.XmlFsType.VolumeSerial, _testFiles[i]);
|
|
}
|
|
}
|
|
}
|
|
|
|
[TestFixture]
|
|
public class SfsRdb
|
|
{
|
|
readonly string[] _testFiles =
|
|
{
|
|
"uae.aif", "aros.aif", "amigaos_4.0.aif", "amigaos_4.0_sfs2.aif"
|
|
};
|
|
|
|
readonly ulong[] _sectors =
|
|
{
|
|
1024128, 409600, 1024128, 1024128
|
|
};
|
|
|
|
readonly uint[] _sectorSize =
|
|
{
|
|
512, 512, 512, 512
|
|
};
|
|
|
|
readonly long[] _clusters =
|
|
{
|
|
127000, 407232, 511040, 511040
|
|
};
|
|
|
|
readonly int[] _clusterSize =
|
|
{
|
|
2048, 512, 1024, 1024
|
|
};
|
|
|
|
readonly string[] _volumeName =
|
|
{
|
|
null, null, null, null
|
|
};
|
|
|
|
readonly string[] _volumeSerial =
|
|
{
|
|
null, null, null, null
|
|
};
|
|
|
|
[Test]
|
|
public void Test()
|
|
{
|
|
for(int i = 0; i < _testFiles.Length; i++)
|
|
{
|
|
string location = Path.Combine(Consts.TEST_FILES_ROOT, "Filesystems", "Smart File System (RDB)",
|
|
_testFiles[i]);
|
|
|
|
IFilter filter = new ZZZNoFilter();
|
|
filter.Open(location);
|
|
IMediaImage image = new AaruFormat();
|
|
Assert.AreEqual(true, image.Open(filter), _testFiles[i]);
|
|
Assert.AreEqual(_sectors[i], image.Info.Sectors, _testFiles[i]);
|
|
Assert.AreEqual(_sectorSize[i], image.Info.SectorSize, _testFiles[i]);
|
|
List<Partition> partitions = Core.Partitions.GetAll(image);
|
|
IFilesystem fs = new SFS();
|
|
int part = -1;
|
|
|
|
for(int j = 0; j < partitions.Count; j++)
|
|
if(partitions[j].Type == "\"SFS\\0\"" ||
|
|
partitions[j].Type == "\"SFS\\2\"")
|
|
{
|
|
part = j;
|
|
|
|
break;
|
|
}
|
|
|
|
Assert.AreNotEqual(-1, part, $"Partition not found on {_testFiles[i]}");
|
|
Assert.AreEqual(true, fs.Identify(image, partitions[part]), _testFiles[i]);
|
|
fs.GetInformation(image, partitions[part], out _, null);
|
|
Assert.AreEqual(_clusters[i], fs.XmlFsType.Clusters, _testFiles[i]);
|
|
Assert.AreEqual(_clusterSize[i], fs.XmlFsType.ClusterSize, _testFiles[i]);
|
|
Assert.AreEqual("SmartFileSystem", fs.XmlFsType.Type, _testFiles[i]);
|
|
Assert.AreEqual(_volumeName[i], fs.XmlFsType.VolumeName, _testFiles[i]);
|
|
Assert.AreEqual(_volumeSerial[i], fs.XmlFsType.VolumeSerial, _testFiles[i]);
|
|
}
|
|
}
|
|
}
|
|
} |