-
Notifications
You must be signed in to change notification settings - Fork 20
/
Copy pathRoundTripTests.cs
69 lines (57 loc) · 2.3 KB
/
RoundTripTests.cs
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
using Cantarus.Libraries.Encryption;
using Microsoft.VisualStudio.TestTools.UnitTesting;
using System.IO;
using System.Text;
namespace EncryptionTests
{
[TestClass]
public class RoundTripTests
{
private const int Iterations = 100;
[TestMethod]
public void RoundTrip_RandomString_MatchesAfterEncryptDecrypt()
{
for (int i = 0; i < Iterations; i++)
{
string passPhrase = TestUtilities.GeneratePassPhrase();
string beforeString = Encoding.UTF8.GetString(TestUtilities.GeneratePayload());
string encryptedString = Crypto.Encrypt(beforeString, passPhrase);
string afterString = Crypto.Decrypt(encryptedString, passPhrase);
Assert.AreEqual(beforeString, afterString);
}
}
[TestMethod]
public void RoundTrip_RandomBytes_MatchesAfterEncryptDecrypt()
{
for (int i = 0; i < Iterations; i++)
{
string passPhrase = TestUtilities.GeneratePassPhrase();
byte[] beforeBytes = TestUtilities.GeneratePayload();
byte[] encryptedBytes = Crypto.Encrypt(beforeBytes, passPhrase);
byte[] afterBytes = Crypto.Decrypt(encryptedBytes, passPhrase);
CollectionAssert.AreEqual(beforeBytes, afterBytes);
}
}
[TestMethod]
public void RoundTrip_RandomStreamOfBytes_MatchesAfterEncryptDecrypt()
{
for (int i = 0; i < Iterations; i++)
{
string passPhrase = TestUtilities.GeneratePassPhrase();
byte[] beforeBytes = TestUtilities.GeneratePayload();
byte[] afterBytes;
using (MemoryStream plainStream = new MemoryStream(beforeBytes))
{
using (Stream encryptedSteam = Crypto.Encrypt(plainStream, passPhrase))
{
using (MemoryStream decryptedStream = (MemoryStream)Crypto.Decrypt(encryptedSteam, passPhrase))
{
afterBytes = decryptedStream.ToArray();
}
}
}
CollectionAssert.AreEqual(beforeBytes, afterBytes);
}
}
}
}