forked from M-Labs/artiq
pyon: Correctly deserialize bare NaNs
This also fixes (non-numpy) lists containing NaNs. Previously, accidentally storing a NaN in a dataset would bring down large parts of the system.
This commit is contained in:
parent
17665c7271
commit
a6b61f0c1d
@ -188,6 +188,7 @@ _eval_dict = {
|
||||
"false": False,
|
||||
"true": True,
|
||||
"slice": slice,
|
||||
"nan": numpy.nan,
|
||||
|
||||
"Fraction": Fraction,
|
||||
"OrderedDict": OrderedDict,
|
||||
|
@ -26,6 +26,8 @@ class PYON(unittest.TestCase):
|
||||
with self.subTest(enc=enc):
|
||||
self.assertEqual(pyon.decode(enc(_pyon_test_object)),
|
||||
_pyon_test_object)
|
||||
# NaNs don't compare equal, so test separately.
|
||||
assert np.isnan(pyon.decode(enc(np.nan)))
|
||||
|
||||
def test_encdec_array(self):
|
||||
orig = {k: (np.array(v), np.array([v]))
|
||||
|
Loading…
Reference in New Issue
Block a user