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