aboutsummaryrefslogtreecommitdiff
path: root/test/test_combine.py
diff options
context:
space:
mode:
authorJ08nY2018-11-20 00:36:46 +0100
committerJ08nY2019-03-14 18:03:54 +0100
commite0a6e7c452cd55365096bc3e4b8f36f5f9660ae7 (patch)
treebf1c80e015cdfd47d864665946f44a072f7b38db /test/test_combine.py
downloadpyecsca-e0a6e7c452cd55365096bc3e4b8f36f5f9660ae7.tar.gz
pyecsca-e0a6e7c452cd55365096bc3e4b8f36f5f9660ae7.tar.zst
pyecsca-e0a6e7c452cd55365096bc3e4b8f36f5f9660ae7.zip
Diffstat (limited to 'test/test_combine.py')
-rw-r--r--test/test_combine.py35
1 files changed, 35 insertions, 0 deletions
diff --git a/test/test_combine.py b/test/test_combine.py
new file mode 100644
index 0000000..ca23197
--- /dev/null
+++ b/test/test_combine.py
@@ -0,0 +1,35 @@
+from unittest import TestCase
+
+import numpy as np
+from pyecsca import Trace, CombinedTrace, average, conditional_average, standard_deviation
+
+
+class CombineTests(TestCase):
+
+ def setUp(self):
+ self.a = Trace(None, b"\xff", np.array([20, 80], dtype=np.dtype("i1")))
+ self.b = Trace(None, b"\xff", np.array([30, 42], dtype=np.dtype("i1")))
+ self.c = Trace(None, b"\x00", np.array([78, 56], dtype=np.dtype("i1")))
+
+ def test_average(self):
+ self.assertIsNone(average())
+ result = average(self.a, self.b)
+ self.assertIsNotNone(result)
+ self.assertIsInstance(result, CombinedTrace)
+ self.assertEqual(len(result.samples), 2)
+ self.assertEqual(result.samples[0], 25)
+ self.assertEqual(result.samples[1], 61)
+
+ def test_conditional_average(self):
+ result = conditional_average(self.a, self.b, self.c,
+ condition=lambda trace: trace.data[0] == 0xff)
+ self.assertIsInstance(result, CombinedTrace)
+ self.assertEqual(len(result.samples), 2)
+ self.assertEqual(result.samples[0], 25)
+ self.assertEqual(result.samples[1], 61)
+
+ def test_standard_deviation(self):
+ self.assertIsNone(standard_deviation())
+ result = standard_deviation(self.a, self.b)
+ self.assertIsInstance(result, CombinedTrace)
+ self.assertEqual(len(result.samples), 2)