blob: 643ab68e7b0838b06f738890f89a786229906ec3 (
plain)
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
|
import matplotlib.pyplot as plt
from unittest import TestCase
from pyecsca.sca import Trace
from os.path import join, exists, split
from os import mkdir, getenv, getcwd
force_plot = True
def slow(func):
func.slow = 1
return func
cases = {}
def plot(case: TestCase, *traces: Trace, **kwtraces: Trace):
if not force_plot and getenv("PYECSCA_TEST_PLOTS") is None:
return
fig = plt.figure()
ax = fig.add_subplot(111)
for i, trace in enumerate(traces):
ax.plot(trace.samples, label=str(i))
for name, trace in kwtraces.items():
ax.plot(trace.samples, label=name)
ax.legend(loc="best")
if split(getcwd())[1] == "test":
directory = "plots"
else:
directory = join("test", "plots")
if not exists(directory):
mkdir(directory)
case_id = cases.setdefault(case.id(), 0) + 1
cases[case.id()] = case_id
plt.savefig(join(directory, case.id() + str(case_id) + ".png"))
|