Chris@43: // Chris@43: // © Copyright Henrik Ravn 2004 Chris@43: // Chris@43: // Use, modification and distribution are subject to the Boost Software License, Version 1.0. Chris@43: // (See accompanying file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) Chris@43: // Chris@43: Chris@43: using System; Chris@43: using System.Collections; Chris@43: using System.IO; Chris@43: Chris@43: // uncomment the define below to include unit tests Chris@43: //#define nunit Chris@43: #if nunit Chris@43: using NUnit.Framework; Chris@43: Chris@43: // Unit tests for the DotZLib class library Chris@43: // ---------------------------------------- Chris@43: // Chris@43: // Use this with NUnit 2 from http://www.nunit.org Chris@43: // Chris@43: Chris@43: namespace DotZLibTests Chris@43: { Chris@43: using DotZLib; Chris@43: Chris@43: // helper methods Chris@43: internal class Utils Chris@43: { Chris@43: public static bool byteArrEqual( byte[] lhs, byte[] rhs ) Chris@43: { Chris@43: if (lhs.Length != rhs.Length) Chris@43: return false; Chris@43: for (int i = lhs.Length-1; i >= 0; --i) Chris@43: if (lhs[i] != rhs[i]) Chris@43: return false; Chris@43: return true; Chris@43: } Chris@43: Chris@43: } Chris@43: Chris@43: Chris@43: [TestFixture] Chris@43: public class CircBufferTests Chris@43: { Chris@43: #region Circular buffer tests Chris@43: [Test] Chris@43: public void SinglePutGet() Chris@43: { Chris@43: CircularBuffer buf = new CircularBuffer(10); Chris@43: Assert.AreEqual( 0, buf.Size ); Chris@43: Assert.AreEqual( -1, buf.Get() ); Chris@43: Chris@43: Assert.IsTrue(buf.Put( 1 )); Chris@43: Assert.AreEqual( 1, buf.Size ); Chris@43: Assert.AreEqual( 1, buf.Get() ); Chris@43: Assert.AreEqual( 0, buf.Size ); Chris@43: Assert.AreEqual( -1, buf.Get() ); Chris@43: } Chris@43: Chris@43: [Test] Chris@43: public void BlockPutGet() Chris@43: { Chris@43: CircularBuffer buf = new CircularBuffer(10); Chris@43: byte[] arr = {1,2,3,4,5,6,7,8,9,10}; Chris@43: Assert.AreEqual( 10, buf.Put(arr,0,10) ); Chris@43: Assert.AreEqual( 10, buf.Size ); Chris@43: Assert.IsFalse( buf.Put(11) ); Chris@43: Assert.AreEqual( 1, buf.Get() ); Chris@43: Assert.IsTrue( buf.Put(11) ); Chris@43: Chris@43: byte[] arr2 = (byte[])arr.Clone(); Chris@43: Assert.AreEqual( 9, buf.Get(arr2,1,9) ); Chris@43: Assert.IsTrue( Utils.byteArrEqual(arr,arr2) ); Chris@43: } Chris@43: Chris@43: #endregion Chris@43: } Chris@43: Chris@43: [TestFixture] Chris@43: public class ChecksumTests Chris@43: { Chris@43: #region CRC32 Tests Chris@43: [Test] Chris@43: public void CRC32_Null() Chris@43: { Chris@43: CRC32Checksum crc32 = new CRC32Checksum(); Chris@43: Assert.AreEqual( 0, crc32.Value ); Chris@43: Chris@43: crc32 = new CRC32Checksum(1); Chris@43: Assert.AreEqual( 1, crc32.Value ); Chris@43: Chris@43: crc32 = new CRC32Checksum(556); Chris@43: Assert.AreEqual( 556, crc32.Value ); Chris@43: } Chris@43: Chris@43: [Test] Chris@43: public void CRC32_Data() Chris@43: { Chris@43: CRC32Checksum crc32 = new CRC32Checksum(); Chris@43: byte[] data = { 1,2,3,4,5,6,7 }; Chris@43: crc32.Update(data); Chris@43: Assert.AreEqual( 0x70e46888, crc32.Value ); Chris@43: Chris@43: crc32 = new CRC32Checksum(); Chris@43: crc32.Update("penguin"); Chris@43: Assert.AreEqual( 0x0e5c1a120, crc32.Value ); Chris@43: Chris@43: crc32 = new CRC32Checksum(1); Chris@43: crc32.Update("penguin"); Chris@43: Assert.AreEqual(0x43b6aa94, crc32.Value); Chris@43: Chris@43: } Chris@43: #endregion Chris@43: Chris@43: #region Adler tests Chris@43: Chris@43: [Test] Chris@43: public void Adler_Null() Chris@43: { Chris@43: AdlerChecksum adler = new AdlerChecksum(); Chris@43: Assert.AreEqual(0, adler.Value); Chris@43: Chris@43: adler = new AdlerChecksum(1); Chris@43: Assert.AreEqual( 1, adler.Value ); Chris@43: Chris@43: adler = new AdlerChecksum(556); Chris@43: Assert.AreEqual( 556, adler.Value ); Chris@43: } Chris@43: Chris@43: [Test] Chris@43: public void Adler_Data() Chris@43: { Chris@43: AdlerChecksum adler = new AdlerChecksum(1); Chris@43: byte[] data = { 1,2,3,4,5,6,7 }; Chris@43: adler.Update(data); Chris@43: Assert.AreEqual( 0x5b001d, adler.Value ); Chris@43: Chris@43: adler = new AdlerChecksum(); Chris@43: adler.Update("penguin"); Chris@43: Assert.AreEqual(0x0bcf02f6, adler.Value ); Chris@43: Chris@43: adler = new AdlerChecksum(1); Chris@43: adler.Update("penguin"); Chris@43: Assert.AreEqual(0x0bd602f7, adler.Value); Chris@43: Chris@43: } Chris@43: #endregion Chris@43: } Chris@43: Chris@43: [TestFixture] Chris@43: public class InfoTests Chris@43: { Chris@43: #region Info tests Chris@43: [Test] Chris@43: public void Info_Version() Chris@43: { Chris@43: Info info = new Info(); Chris@43: Assert.AreEqual("1.2.8", Info.Version); Chris@43: Assert.AreEqual(32, info.SizeOfUInt); Chris@43: Assert.AreEqual(32, info.SizeOfULong); Chris@43: Assert.AreEqual(32, info.SizeOfPointer); Chris@43: Assert.AreEqual(32, info.SizeOfOffset); Chris@43: } Chris@43: #endregion Chris@43: } Chris@43: Chris@43: [TestFixture] Chris@43: public class DeflateInflateTests Chris@43: { Chris@43: #region Deflate tests Chris@43: [Test] Chris@43: public void Deflate_Init() Chris@43: { Chris@43: using (Deflater def = new Deflater(CompressLevel.Default)) Chris@43: { Chris@43: } Chris@43: } Chris@43: Chris@43: private ArrayList compressedData = new ArrayList(); Chris@43: private uint adler1; Chris@43: Chris@43: private ArrayList uncompressedData = new ArrayList(); Chris@43: private uint adler2; Chris@43: Chris@43: public void CDataAvail(byte[] data, int startIndex, int count) Chris@43: { Chris@43: for (int i = 0; i < count; ++i) Chris@43: compressedData.Add(data[i+startIndex]); Chris@43: } Chris@43: Chris@43: [Test] Chris@43: public void Deflate_Compress() Chris@43: { Chris@43: compressedData.Clear(); Chris@43: Chris@43: byte[] testData = new byte[35000]; Chris@43: for (int i = 0; i < testData.Length; ++i) Chris@43: testData[i] = 5; Chris@43: Chris@43: using (Deflater def = new Deflater((CompressLevel)5)) Chris@43: { Chris@43: def.DataAvailable += new DataAvailableHandler(CDataAvail); Chris@43: def.Add(testData); Chris@43: def.Finish(); Chris@43: adler1 = def.Checksum; Chris@43: } Chris@43: } Chris@43: #endregion Chris@43: Chris@43: #region Inflate tests Chris@43: [Test] Chris@43: public void Inflate_Init() Chris@43: { Chris@43: using (Inflater inf = new Inflater()) Chris@43: { Chris@43: } Chris@43: } Chris@43: Chris@43: private void DDataAvail(byte[] data, int startIndex, int count) Chris@43: { Chris@43: for (int i = 0; i < count; ++i) Chris@43: uncompressedData.Add(data[i+startIndex]); Chris@43: } Chris@43: Chris@43: [Test] Chris@43: public void Inflate_Expand() Chris@43: { Chris@43: uncompressedData.Clear(); Chris@43: Chris@43: using (Inflater inf = new Inflater()) Chris@43: { Chris@43: inf.DataAvailable += new DataAvailableHandler(DDataAvail); Chris@43: inf.Add((byte[])compressedData.ToArray(typeof(byte))); Chris@43: inf.Finish(); Chris@43: adler2 = inf.Checksum; Chris@43: } Chris@43: Assert.AreEqual( adler1, adler2 ); Chris@43: } Chris@43: #endregion Chris@43: } Chris@43: Chris@43: [TestFixture] Chris@43: public class GZipStreamTests Chris@43: { Chris@43: #region GZipStream test Chris@43: [Test] Chris@43: public void GZipStream_WriteRead() Chris@43: { Chris@43: using (GZipStream gzOut = new GZipStream("gzstream.gz", CompressLevel.Best)) Chris@43: { Chris@43: BinaryWriter writer = new BinaryWriter(gzOut); Chris@43: writer.Write("hi there"); Chris@43: writer.Write(Math.PI); Chris@43: writer.Write(42); Chris@43: } Chris@43: Chris@43: using (GZipStream gzIn = new GZipStream("gzstream.gz")) Chris@43: { Chris@43: BinaryReader reader = new BinaryReader(gzIn); Chris@43: string s = reader.ReadString(); Chris@43: Assert.AreEqual("hi there",s); Chris@43: double d = reader.ReadDouble(); Chris@43: Assert.AreEqual(Math.PI, d); Chris@43: int i = reader.ReadInt32(); Chris@43: Assert.AreEqual(42,i); Chris@43: } Chris@43: Chris@43: } Chris@43: #endregion Chris@43: } Chris@43: } Chris@43: Chris@43: #endif