Files
Aaru/Aaru.Tests/Issues/OpticalImageReadIssueTest.cs

80 lines
2.5 KiB
C#
Raw Normal View History

2022-03-07 07:36:44 +00:00
namespace Aaru.Tests.Issues;
2021-03-07 17:23:23 +00:00
using System;
using System.Collections.Generic;
using System.IO;
using Aaru.Checksums;
using Aaru.CommonTypes;
using Aaru.CommonTypes.Enums;
2021-03-07 17:23:23 +00:00
using Aaru.CommonTypes.Interfaces;
using Aaru.CommonTypes.Structs;
using Aaru.Core;
using NUnit.Framework;
2022-03-06 13:29:38 +00:00
/// <summary>This class will test an issue that happens when reading an image completely, from start to end, crashes.</summary>
public abstract class OpticalImageReadIssueTest
2021-03-07 17:23:23 +00:00
{
2022-03-06 13:29:38 +00:00
const uint SECTORS_TO_READ = 256;
public abstract string DataFolder { get; }
public abstract string TestFile { get; }
[Test]
public void Test()
2021-03-07 17:23:23 +00:00
{
2022-03-06 13:29:38 +00:00
Environment.CurrentDirectory = DataFolder;
2021-03-07 17:23:23 +00:00
2022-03-06 13:29:38 +00:00
bool exists = File.Exists(TestFile);
Assert.True(exists, "Test file not found");
2021-03-07 17:23:23 +00:00
2022-03-06 13:29:38 +00:00
var filtersList = new FiltersList();
IFilter inputFilter = filtersList.GetFilter(TestFile);
2021-03-07 17:23:23 +00:00
2022-03-06 13:29:38 +00:00
Assert.IsNotNull(inputFilter, "Filter for test file is not detected");
2021-03-07 17:23:23 +00:00
2022-03-07 07:36:44 +00:00
var image = ImageFormat.Detect(inputFilter) as IMediaImage;
2021-03-07 17:23:23 +00:00
2022-03-06 13:29:38 +00:00
Assert.IsNotNull(image, "Image format for test file is not detected");
2021-03-07 17:23:23 +00:00
2022-03-06 13:29:38 +00:00
Assert.AreEqual(ErrorNumber.NoError, image.Open(inputFilter), "Cannot open image for test file");
2021-03-07 17:23:23 +00:00
2022-03-06 13:29:38 +00:00
var opticalInput = image as IOpticalMediaImage;
2021-03-07 17:23:23 +00:00
2022-03-06 13:29:38 +00:00
Assert.IsNotNull(opticalInput, "Image format for test file is not for an optical disc");
2021-03-07 17:23:23 +00:00
2022-03-06 13:29:38 +00:00
var ctx = new Crc32Context();
2021-03-07 17:23:23 +00:00
2022-03-06 13:29:38 +00:00
ulong previousTrackEnd = 0;
2021-03-07 17:23:23 +00:00
2022-03-06 13:29:38 +00:00
List<Track> inputTracks = opticalInput.Tracks;
ErrorNumber errno;
2021-03-07 17:23:23 +00:00
2022-03-06 13:29:38 +00:00
foreach(Track currentTrack in inputTracks)
{
ulong sectors = currentTrack.EndSector - currentTrack.StartSector + 1;
ulong doneSectors = 0;
2021-03-07 17:23:23 +00:00
2022-03-06 13:29:38 +00:00
while(doneSectors < sectors)
2021-03-07 17:23:23 +00:00
{
2022-03-06 13:29:38 +00:00
byte[] sector;
2021-03-07 17:23:23 +00:00
2022-03-06 13:29:38 +00:00
if(sectors - doneSectors >= SECTORS_TO_READ)
2021-03-07 17:23:23 +00:00
{
2022-03-07 07:36:44 +00:00
errno = opticalInput.ReadSectors(doneSectors, SECTORS_TO_READ, currentTrack.Sequence, out sector);
2021-03-07 17:23:23 +00:00
2022-03-06 13:29:38 +00:00
doneSectors += SECTORS_TO_READ;
}
else
{
2022-03-07 07:36:44 +00:00
errno = opticalInput.ReadSectors(doneSectors, (uint)(sectors - doneSectors), currentTrack.Sequence,
out sector);
2021-03-07 17:23:23 +00:00
2022-03-06 13:29:38 +00:00
doneSectors += sectors - doneSectors;
}
2021-03-07 17:23:23 +00:00
2022-03-06 13:29:38 +00:00
Assert.AreEqual(ErrorNumber.NoError, errno);
2022-03-06 13:29:38 +00:00
ctx.Update(sector);
2021-03-07 17:23:23 +00:00
}
}
}
}