mirror of
https://github.com/claunia/cuetools.net.git
synced 2025-12-16 18:14:25 +00:00
122 lines
3.6 KiB
C#
122 lines
3.6 KiB
C#
using System;
|
|
using Microsoft.VisualStudio.TestTools.UnitTesting;
|
|
using CUETools.AccurateRip;
|
|
using CUETools.CDImage;
|
|
using CUETools.Codecs;
|
|
|
|
namespace CUETools.TestParity
|
|
{
|
|
|
|
|
|
/// <summary>
|
|
///This is a test class for CDRepairEncodeTest and is intended
|
|
///to contain all CDRepairEncodeTest Unit Tests
|
|
///</summary>
|
|
[TestClass()]
|
|
public class CDRepairEncodeTest
|
|
{
|
|
|
|
const int finalSampleCount = 44100 * 60 * 10; // 10 minutes long
|
|
//const int stride = finalSampleCount * 2 / 32768;
|
|
const int stride = 10 * 588 * 2;
|
|
// CD has maximum of 360.000 sectors;
|
|
// If stride equals 10 sectors (10 sectors * 588 samples * 2 words),
|
|
// then maximum sequence length is 36.000 sectors.
|
|
// 36.000 is less than (65535 - npar), so we're ok here.
|
|
// npar == 8 provides error correction for 4 samples out of every 36k,
|
|
// i.e. at best one sample per 9k can be repaired.
|
|
// Parity data per one CD requires 10 * 588 * 4 * npar bytes,
|
|
// which equals 188.160b == 184kb
|
|
// We might consider shorter strides to reduce parity data size,
|
|
// but it probably should still be a multiple of 588 * 2;
|
|
// (or the size of CD CIRC buffer?)
|
|
|
|
const int npar = 8;
|
|
|
|
private TestContext testContextInstance;
|
|
|
|
/// <summary>
|
|
///Gets or sets the test context which provides
|
|
///information about and functionality for the current test run.
|
|
///</summary>
|
|
public TestContext TestContext
|
|
{
|
|
get
|
|
{
|
|
return testContextInstance;
|
|
}
|
|
set
|
|
{
|
|
testContextInstance = value;
|
|
}
|
|
}
|
|
|
|
public static CDRepairEncode VerifyNoise(CDImageLayout toc, int seed, int offset, int start, int end, int errors, bool do_verify, bool do_encode)
|
|
{
|
|
if (start < 0 || start > end || end > toc.AudioLength * 588)
|
|
throw new ArgumentOutOfRangeException();
|
|
var src = new NoiseAndErrorsGenerator(AudioPCMConfig.RedBook, end - start, seed, offset + start, errors);
|
|
var buff = new AudioBuffer(src, 588 * 100);
|
|
var ar = new AccurateRipVerify(toc, null);
|
|
var encode = new CDRepairEncode(ar, stride, npar, do_verify, do_encode);
|
|
var rnd = new Random(seed);
|
|
ar.Position = start;
|
|
while (src.Remaining > 0)
|
|
{
|
|
src.Read(buff, rnd.Next(1, buff.Size));
|
|
ar.Write(buff);
|
|
}
|
|
ar.Close();
|
|
return encode;
|
|
}
|
|
|
|
public static CDRepairEncode VerifyNoise(string trackoffsets, int seed, int offset, int errors, bool do_verify, bool do_encode)
|
|
{
|
|
var toc = new CDImageLayout(trackoffsets);
|
|
return VerifyNoise(toc, seed, offset, 0, (int)toc.AudioLength * 588, errors, do_verify, do_encode);
|
|
}
|
|
|
|
#region Additional test attributes
|
|
//
|
|
//You can use the following additional attributes as you write your tests:
|
|
//
|
|
//Use ClassInitialize to run code before running the first test in the class
|
|
[ClassInitialize()]
|
|
public static void MyClassInitialize(TestContext testContext)
|
|
{
|
|
}
|
|
|
|
//Use ClassCleanup to run code after all tests in a class have run
|
|
//[ClassCleanup()]
|
|
//public static void MyClassCleanup()
|
|
//{
|
|
//}
|
|
//
|
|
//Use TestInitialize to run code before running each test
|
|
//[TestInitialize()]
|
|
//public void MyTestInitialize()
|
|
//{
|
|
//}
|
|
//
|
|
//Use TestCleanup to run code after each test has run
|
|
//[TestCleanup()]
|
|
//public void MyTestCleanup()
|
|
//{
|
|
//}
|
|
//
|
|
#endregion
|
|
|
|
|
|
/// <summary>
|
|
///A test for Write
|
|
///</summary>
|
|
[TestMethod()]
|
|
public void CDRepairEncodeWriteTest()
|
|
{
|
|
var encode = VerifyNoise("0 45000", 2423, 0, 0, false, true);
|
|
Assert.AreEqual<string>("CAz3OBAHPAw=", Convert.ToBase64String(encode.Parity, 0, 8));
|
|
Assert.AreEqual<uint>(2278257733, encode.CRC);
|
|
}
|
|
}
|
|
}
|