Skip to content

Commit f6f6b51

Browse files
Better checksum tests
1 parent 179dc94 commit f6f6b51

File tree

4 files changed

+83
-51
lines changed

4 files changed

+83
-51
lines changed
Lines changed: 41 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,41 @@
1+
// Copyright (c) Six Labors and contributors.
2+
// Licensed under the GNU Affero General Public License, Version 3.
3+
4+
using System;
5+
using SixLabors.ImageSharp.Formats.Png.Zlib;
6+
using Xunit;
7+
using SharpAdler32 = ICSharpCode.SharpZipLib.Checksum.Adler32;
8+
9+
namespace SixLabors.ImageSharp.Tests.Formats.Png
10+
{
11+
public class Adler32Tests
12+
{
13+
[Theory]
14+
[InlineData(0)]
15+
[InlineData(8)]
16+
[InlineData(215)]
17+
[InlineData(1024)]
18+
[InlineData(1024 + 15)]
19+
[InlineData(2034)]
20+
[InlineData(4096)]
21+
public void MatchesReference(int length)
22+
{
23+
var data = GetBuffer(length);
24+
var adler = new SharpAdler32();
25+
adler.Update(data);
26+
27+
long expected = adler.Value;
28+
long actual = Adler32.Calculate(data);
29+
30+
Assert.Equal(expected, actual);
31+
}
32+
33+
private static byte[] GetBuffer(int length)
34+
{
35+
var data = new byte[length];
36+
new Random(1).NextBytes(data);
37+
38+
return data;
39+
}
40+
}
41+
}
Lines changed: 41 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,41 @@
1+
// Copyright (c) Six Labors and contributors.
2+
// Licensed under the GNU Affero General Public License, Version 3.
3+
4+
using System;
5+
using SixLabors.ImageSharp.Formats.Png.Zlib;
6+
using Xunit;
7+
using SharpCrc32 = ICSharpCode.SharpZipLib.Checksum.Crc32;
8+
9+
namespace SixLabors.ImageSharp.Tests.Formats.Png
10+
{
11+
public class Crc32Tests
12+
{
13+
[Theory]
14+
[InlineData(0)]
15+
[InlineData(8)]
16+
[InlineData(215)]
17+
[InlineData(1024)]
18+
[InlineData(1024 + 15)]
19+
[InlineData(2034)]
20+
[InlineData(4096)]
21+
public void MatchesReference(int length)
22+
{
23+
var data = GetBuffer(length);
24+
var crc = new SharpCrc32();
25+
crc.Update(data);
26+
27+
long expected = crc.Value;
28+
long actual = Crc32.Calculate(data);
29+
30+
Assert.Equal(expected, actual);
31+
}
32+
33+
private static byte[] GetBuffer(int length)
34+
{
35+
var data = new byte[length];
36+
new Random(1).NextBytes(data);
37+
38+
return data;
39+
}
40+
}
41+
}

tests/ImageSharp.Tests/Formats/Png/PngDecoderTests.Chunks.cs

Lines changed: 0 additions & 51 deletions
Original file line numberDiff line numberDiff line change
@@ -83,57 +83,6 @@ public void Decode_IncorrectCRCForCriticalChunk_ExceptionIsThrown(uint chunkType
8383
}
8484
}
8585

86-
[Fact]
87-
public void CalculateCrc_Works_LongerRun()
88-
{
89-
// Longer run, enough to require moving the point in SIMD implementation with
90-
// offset for dropping back to scalar.
91-
var data = new byte[]
92-
{
93-
0, 1, 2, 3, 4, 5, 6, 7, 8,
94-
9, 10, 11, 12, 13, 14, 15, 16,
95-
17, 18, 19, 20, 21, 22, 23, 24,
96-
25, 26, 27, 28, 29, 30, 31, 32,
97-
33, 34, 35, 36, 37, 38, 39, 40,
98-
41, 42, 43, 44, 45, 46, 47, 48,
99-
49, 50, 51, 52, 53, 54, 55, 56,
100-
57, 58, 59, 60, 61, 62, 63, 64,
101-
65, 66, 67, 68, 69, 70, 71, 72,
102-
73, 74, 75, 76, 77, 78, 79, 80,
103-
81, 82, 83, 84, 85, 86, 87, 88,
104-
89, 90, 91, 92, 93, 94, 95, 96,
105-
97, 98, 99, 100, 101, 102, 103, 104,
106-
105, 106, 107, 108, 109, 110, 111, 112,
107-
113, 114, 115, 116, 117, 118, 119, 120,
108-
121, 122, 123, 124, 125, 126, 127, 128,
109-
129, 130, 131, 132, 133, 134, 135, 136,
110-
137, 138, 139, 140, 141, 142, 143, 144,
111-
145, 146, 147, 148, 149, 150, 151, 152,
112-
153, 154, 155, 156, 157, 158, 159, 160,
113-
161, 162, 163, 164, 165, 166, 167, 168,
114-
169, 170, 171, 172, 173, 174, 175, 176,
115-
177, 178, 179, 180, 181, 182, 183, 184,
116-
185, 186, 187, 188, 189, 190, 191, 192,
117-
193, 194, 195, 196, 197, 198, 199, 200,
118-
201, 202, 203, 204, 205, 206, 207, 208,
119-
209, 210, 211, 212, 213, 214, 215
120-
};
121-
122-
// assert
123-
uint crc = Crc32.Calculate(data);
124-
Assert.Equal(0xC1125402, crc);
125-
}
126-
127-
[Fact]
128-
public void CalculateCrc_Works()
129-
{
130-
// Short run, less than 64.
131-
var data = new byte[] { 0, 1, 2, 3, 4, 5, 6, 7 };
132-
uint crc = Crc32.Calculate(data);
133-
134-
Assert.Equal(0x88AA689F, crc);
135-
}
136-
13786
private static string GetChunkTypeName(uint value)
13887
{
13988
var data = new byte[4];

tests/ImageSharp.Tests/ImageSharp.Tests.csproj

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -21,6 +21,7 @@
2121
<PackageReference Include="Magick.NET-Q16-AnyCPU" />
2222
<PackageReference Include="Microsoft.DotNet.RemoteExecutor" />
2323
<PackageReference Include="Moq" />
24+
<PackageReference Include="SharpZipLib" />
2425
<PackageReference Include="System.Drawing.Common" />
2526
</ItemGroup>
2627

0 commit comments

Comments
 (0)