forked from M-Labs/artiq
test/coredevice: add tests for exception sync
This commit is contained in:
parent
bd9648d960
commit
99f76a7595
@ -3,8 +3,9 @@ import artiq.coredevice.exceptions as exceptions
|
|||||||
|
|
||||||
from artiq.experiment import *
|
from artiq.experiment import *
|
||||||
from artiq.test.hardware_testbench import ExperimentCase
|
from artiq.test.hardware_testbench import ExperimentCase
|
||||||
from artiq.compiler.embedding import EmbeddingMap
|
from artiq.language.embedding_map import EmbeddingMap
|
||||||
from artiq.coredevice.core import test_exception_id_sync
|
from artiq.coredevice.core import test_exception_id_sync
|
||||||
|
from numpy import int32
|
||||||
|
|
||||||
"""
|
"""
|
||||||
Test sync in exceptions raised between host and kernel
|
Test sync in exceptions raised between host and kernel
|
||||||
@ -16,33 +17,34 @@ Considers the following two cases:
|
|||||||
Ensures same exception is raised on both kernel and host in either case
|
Ensures same exception is raised on both kernel and host in either case
|
||||||
"""
|
"""
|
||||||
|
|
||||||
exception_names = EmbeddingMap().str_reverse_map
|
exception_names = EmbeddingMap().string_map
|
||||||
|
|
||||||
|
|
||||||
|
@nac3
|
||||||
class _TestExceptionSync(EnvExperiment):
|
class _TestExceptionSync(EnvExperiment):
|
||||||
def build(self):
|
def build(self):
|
||||||
self.setattr_device("core")
|
self.setattr_device("core")
|
||||||
|
|
||||||
@rpc
|
@rpc
|
||||||
def _raise_exception_host(self, id):
|
def _raise_exception_host(self, id: int32):
|
||||||
exn = exception_names[id].split('.')[-1].split(':')[-1]
|
exn = exception_names[id].split('.')[-1].split(':')[-1]
|
||||||
exn = getattr(exceptions, exn)
|
exn = getattr(exceptions, exn)
|
||||||
raise exn
|
raise exn
|
||||||
|
|
||||||
@kernel
|
@kernel
|
||||||
def raise_exception_host(self, id):
|
def raise_exception_host(self, id: int32):
|
||||||
self._raise_exception_host(id)
|
self._raise_exception_host(id)
|
||||||
|
|
||||||
@kernel
|
@kernel
|
||||||
def raise_exception_kernel(self, id):
|
def raise_exception_kernel(self, id: int32):
|
||||||
test_exception_id_sync(id)
|
test_exception_id_sync(id)
|
||||||
|
|
||||||
|
|
||||||
class ExceptionTest(ExperimentCase):
|
class ExceptionTest(ExperimentCase):
|
||||||
def test_raise_exceptions_kernel(self):
|
def test_raise_exceptions_kernel(self):
|
||||||
exp = self.create(_TestExceptionSync)
|
exp = self.create(_TestExceptionSync)
|
||||||
|
|
||||||
for id, name in list(exception_names.items())[::-1]:
|
for id, name in exception_names.items():
|
||||||
name = name.split('.')[-1].split(':')[-1]
|
name = name.split('.')[-1].split(':')[-1]
|
||||||
with self.assertRaises(getattr(exceptions, name)) as ctx:
|
with self.assertRaises(getattr(exceptions, name)) as ctx:
|
||||||
exp.raise_exception_kernel(id)
|
exp.raise_exception_kernel(id)
|
||||||
@ -56,4 +58,3 @@ class ExceptionTest(ExperimentCase):
|
|||||||
name = name.split('.')[-1].split(':')[-1]
|
name = name.split('.')[-1].split(':')[-1]
|
||||||
with self.assertRaises(getattr(exceptions, name)) as ctx:
|
with self.assertRaises(getattr(exceptions, name)) as ctx:
|
||||||
exp.raise_exception_host(id)
|
exp.raise_exception_host(id)
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user