artiq/artiq/test/hardware_testbench.py

59 lines
1.7 KiB
Python
Raw Normal View History

2015-06-26 12:19:11 +08:00
import os
import sys
import unittest
import logging
2015-06-29 10:08:39 +08:00
from artiq.language import *
2015-06-26 12:19:11 +08:00
from artiq.protocols.file_db import FlatFileDB
from artiq.master.worker_db import DBHub, ResultDB
from artiq.frontend.artiq_run import (
DummyScheduler, DummyWatchdog, SimpleParamLogger)
artiq_root = os.getenv("ARTIQ_ROOT")
logger = logging.getLogger(__name__)
def get_from_ddb(*path, default="skip"):
if not artiq_root:
raise unittest.SkipTest("no ARTIQ_ROOT")
v = FlatFileDB(os.path.join(artiq_root, "ddb.pyon")).data
try:
for p in path:
2015-07-05 12:36:23 +08:00
v = v[p]
return v.read
except KeyError:
if default == "skip":
raise unittest.SkipTest("ddb path {} not found".format(path))
else:
return default
2015-06-26 12:19:11 +08:00
@unittest.skipUnless(artiq_root, "no ARTIQ_ROOT")
class ExperimentCase(unittest.TestCase):
def setUp(self):
self.ddb = FlatFileDB(os.path.join(artiq_root, "ddb.pyon"))
self.pdb = FlatFileDB(os.path.join(artiq_root, "pdb.pyon"))
self.rdb = ResultDB(lambda description: None, lambda mod: None)
self.dbh = DBHub(self.ddb, self.pdb, self.rdb)
def execute(self, cls, **kwargs):
expid = {
"file": sys.modules[cls.__module__].__file__,
"experiment": cls.__name__,
"arguments": kwargs
}
sched = DummyScheduler(expid)
try:
try:
exp = cls(self.dbh, scheduler=sched, **kwargs)
except KeyError as e:
2015-06-29 10:08:39 +08:00
# skip if ddb does not match requirements
2015-06-26 12:19:11 +08:00
raise unittest.SkipTest(*e.args)
self.rdb.build()
exp.run()
exp.analyze()
2015-07-05 10:05:11 +08:00
return exp
2015-06-26 12:19:11 +08:00
finally:
self.dbh.close_devices()