File: SHA1CryptoServiceProviderTest.cs

package info (click to toggle)
mono 2.6.7-5.1
  • links: PTS, VCS
  • area: main
  • in suites: squeeze
  • size: 327,344 kB
  • ctags: 413,649
  • sloc: cs: 2,471,883; xml: 1,768,594; ansic: 350,665; sh: 13,644; makefile: 8,640; perl: 1,784; asm: 717; cpp: 209; python: 146; sql: 81; sed: 16
file content (87 lines) | stat: -rw-r--r-- 2,904 bytes parent folder | download | duplicates (4)
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
//
// SHA1CryptoServiceProviderTest.cs - NUnit Test Cases for SHA1CryptoServiceProvider
//
// Author:
//	Sebastien Pouliot  <sebastien@ximian.com>
//
// (C) 2002 Motus Technologies Inc. (http://www.motus.com)
// Copyright (C) 2004, 2007 Novell, Inc (http://www.novell.com)
//

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

namespace MonoTests.System.Security.Cryptography {

// References:
// a.	FIPS PUB 180-1: Secure Hash Standard
//	http://csrc.nist.gov/publications/fips/fips180-1/fip180-1.txt

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

[TestFixture]
public class SHA1CryptoServiceProviderTest : SHA1Test {

	[SetUp]
	protected override void SetUp () 
	{
		hash = new SHA1CryptoServiceProvider ();
	}

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

	// none of those values changes for a particuliar implementation of SHA1
	[Test]
	public override void StaticInfo ()
	{
		// test all values static for SHA1
		base.StaticInfo();
		string className = hash.ToString ();
		Assert.IsTrue (hash.CanReuseTransform, className + ".CanReuseTransform");
		Assert.IsTrue (hash.CanTransformMultipleBlocks, className + ".CanTransformMultipleBlocks");
		Assert.AreEqual ("System.Security.Cryptography.SHA1CryptoServiceProvider", className, className + ".ToString()");
	}

	public void TestSHA1CSPforFIPSCompliance () 
	{
		SHA1 sha = (SHA1)hash;
		// First test, we hash the string "abc"
		FIPS186_Test1 (sha);
                // Second test, we hash the string "abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq"
		FIPS186_Test2 (sha);
		// Third test, we hash 1,000,000 times the character "a"
		FIPS186_Test3 (sha);
	}

	// LAMESPEC / MSBUG: Under Windows an Initialize is required after 
	// TransformFinalBlock/Hash or SHA1CryptoServiceProvider will still return 
	// the previous Hash. SHA1Managed behavior's is different as it will return
	// a bad Hash if Initialize isn't called.
	// FIXME: Do we want to duplicate this bad behaviour ?
/*	public void TestInitialize () 
	{
		byte[] expectedDEF = { 0x58, 0x9c, 0x22, 0x33, 0x5a, 0x38, 0x1f, 0x12, 0x2d, 0x12, 0x92, 0x25, 0xf5, 0xc0, 0xba, 0x30, 0x56, 0xed, 0x58, 0x11 };
		string className = hash.ToString ();
		// hash abc
		byte[] inputABC = Encoding.Default.GetBytes ("abc");
		hash.TransformFinalBlock (inputABC, 0, inputABC.Length);
		byte[] resultABC = hash.Hash;
		// hash def
		byte[] inputDEF = Encoding.Default.GetBytes ("def");
		byte[] resultDEF = hash.ComputeHash (inputDEF); 
		// result(abc) == result(def) -> forgot to initialize
		AssertEquals (className + ".Initialize ABC=DEF", resultABC, resultDEF);
		hash.Initialize ();
		resultDEF = hash.ComputeHash (inputDEF);
		AssertEquals (className + ".Initialize DEF ok", expectedDEF, resultDEF);
	}*/
}

}