using Microsoft.VisualStudio.TestTools.UnitTesting; using System; using System.Linq; using ZeroLevel.DocumentObjectModel; using ZeroLevel.Network; using ZeroLevel.Services.Encryption; using ZeroLevel.Services.Serialization; using ZeroLevel.UnitTests.Models; namespace ZeroLevel.EncryptionUnitTests { [TestClass] public class EncryptionTests { private static double CalculateDeviation(byte[] data) { double average = data.Average(b => (double)b); double sumOfSquaresOfDifferences = (double)data.Select(val => (val - average) * (val - average)).Sum(); return Math.Sqrt(sumOfSquaresOfDifferences / data.Length); } [TestMethod] public void FastObfuscatorTest() { // Arrange var comparator = new Func((left, right) => { var l_bin = MessageSerializer.Serialize(left); var r_bin = MessageSerializer.Serialize(right); return ArrayExtensions.UnsafeEquals(l_bin, r_bin); }); var instance = CompositeInstanceFactory.MakeDocument(); var data = MessageSerializer.Serialize(instance); // Act var obfscator = new FastObfuscator("mypassword"); var deviation = CalculateDeviation(data); obfscator.HashData(data); var obf_deviation = CalculateDeviation(data); new FastObfuscator("mypassword").DeHashData(data); var deobf_deviation = CalculateDeviation(data); var clone = MessageSerializer.Deserialize(data); // Assert Assert.AreEqual(deviation, deobf_deviation); Assert.AreNotEqual(deviation, obf_deviation); Assert.IsTrue(obf_deviation >= deviation); Assert.IsTrue(comparator(instance, clone)); } [TestMethod] public void NetworkStreamDataObfuscatorTest() { // Arrange var comparator = new Func((left, right) => { var l_bin = MessageSerializer.Serialize(left); var r_bin = MessageSerializer.Serialize(right); return ArrayExtensions.UnsafeEquals(l_bin, r_bin); }); var instance = CompositeInstanceFactory.MakeDocument(); var data = MessageSerializer.Serialize(instance); byte initial = 66; // Act var deviation = CalculateDeviation(data); NetworkStreamFastObfuscator.HashData(data, initial); var obf_deviation = CalculateDeviation(data); NetworkStreamFastObfuscator.DeHashData(data, initial); var deobf_deviation = CalculateDeviation(data); var clone = MessageSerializer.Deserialize(data); // Assert Assert.AreEqual(deviation, deobf_deviation); Assert.AreNotEqual(deviation, obf_deviation); Assert.IsTrue(obf_deviation >= deviation); Assert.IsTrue(comparator(instance, clone)); } } }