File: SHA224ManagedTest.cs

package info (click to toggle)
mono 6.14.1%2Bds2-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 1,282,732 kB
  • sloc: cs: 11,182,461; xml: 2,850,281; ansic: 699,123; cpp: 122,919; perl: 58,604; javascript: 30,841; asm: 21,845; makefile: 19,602; sh: 10,973; python: 4,772; pascal: 925; sql: 859; sed: 16; php: 1
file content (98 lines) | stat: -rw-r--r-- 3,263 bytes parent folder | download | duplicates (15)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
//
// SHA224ManagedTest.cs - NUnit Test Cases for SHA224Managed
//
// Author:
//	Sebastien Pouliot  <sebastien@ximian.com>
//
// Copyright (C) 2004 Novell, Inc (http://www.novell.com)
//
// Permission is hereby granted, free of charge, to any person obtaining
// a copy of this software and associated documentation files (the
// "Software"), to deal in the Software without restriction, including
// without limitation the rights to use, copy, modify, merge, publish,
// distribute, sublicense, and/or sell copies of the Software, and to
// permit persons to whom the Software is furnished to do so, subject to
// the following conditions:
// 
// The above copyright notice and this permission notice shall be
// included in all copies or substantial portions of the Software.
// 
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
//

using NUnit.Framework;
using System;
using System.Security.Cryptography;
using System.Text;
using Mono.Security.Cryptography;

namespace MonoTests.System.Security.Cryptography {

	// References:
	// a.	RFC 3874 - A 224-bit One-way Hash Function: SHA-224, September 2004
	//	http://www.faqs.org/rfc/rfc3874.txt
	// b.	FIPS PUB 180-2: Secure Hash Standard
	//	http://csrc.nist.gov/publications/fips/fips180-2/fips180-2.pdf

	// we inherit from SHA224Test because all SHA224 implementation must return the 
	// same results (hence should run a common set of unit tests).

	[TestFixture]
	public class SHA224ManagedTest : SHA224Test {

		[SetUp]
		public override void SetUp () 
		{
			hash = new SHA224Managed ();
		}

		[Test]
		public override void Create () 
		{
			// no need to repeat this test
		}

		// none of those values changes for a particuliar implementation of SHA224
		[Test]
		public override void StaticInfo () 
		{
			// test all values static for SHA224
			base.StaticInfo ();
			string className = hash.ToString ();
			Assert.AreEqual (true, hash.CanReuseTransform, className + ".CanReuseTransform");
			Assert.AreEqual (true, hash.CanTransformMultipleBlocks, className + ".CanTransformMultipleBlocks");
// FIXME: Change namespace when (or if) classes are moved into corlib
			Assert.AreEqual ("Mono.Security.Cryptography.SHA224Managed", className, className + ".ToString()");
		}

		[Test]
		public void FIPSCompliance_Test1 () 
		{
			SHA224 sha = (SHA224) hash;
			// First test, we hash the string "abc"
			FIPS186_Test1 (sha);
		}

		[Test]
		public void FIPSCompliance_Test2 () 
		{
			SHA224 sha = (SHA224) hash;
			// Second test, we hash the string "abcdefghbcdefghicdefghijdefghijkefghijklfghijklmghijklmnhijklmnoijklmnopjklmnopqklmnopqrlmnopqrsmnopqrstnopqrstu"
			FIPS186_Test2 (sha);
		}

		[Test]
		public void FIPSCompliance_Test3 () 
		{
			SHA224 sha = (SHA224) hash;
			// Third test, we hash 1,000,000 times the character "a"
			FIPS186_Test3 (sha);
		}
	}
}