forked from M-Labs/artiq
novatech409b: add unit test
This commit is contained in:
parent
f850336537
commit
83fd5fdf16
34
artiq/test/novatech409b.py
Normal file
34
artiq/test/novatech409b.py
Normal file
@ -0,0 +1,34 @@
|
||||
import unittest
|
||||
import os
|
||||
|
||||
from artiq.devices.novatech409b.driver import Novatech409B
|
||||
|
||||
|
||||
novatech409b_device = os.getenv("NOVATECH409B_DEVICE")
|
||||
|
||||
|
||||
class GenericNovatech409BTest:
|
||||
def test_parameters_readback(self):
|
||||
# write sample data and read it back
|
||||
for i in range(4):
|
||||
self.driver.set_freq(i, 1e6)
|
||||
self.driver.set_phase(i, 0.5)
|
||||
self.driver.set_gain(i, 0.25)
|
||||
result = self.driver.get_status()
|
||||
|
||||
# check for expected status message; ignore all but first 23 bytes
|
||||
# compare with previous result extracted from Novatech
|
||||
for i in range(4):
|
||||
r = result[i]
|
||||
self.assertEqual(r[0:23], "00989680 2000 01F5 0000")
|
||||
|
||||
|
||||
@unittest.skipUnless(novatech409b_device, "no hardware")
|
||||
class TestNovatech409B(GenericNovatech409BTest, unittest.TestCase):
|
||||
def setUp(self):
|
||||
self.driver = Novatech409B(novatech409b_device)
|
||||
|
||||
|
||||
class TestNovatech409BSim(GenericNovatech409BTest, unittest.TestCase):
|
||||
def setUp(self):
|
||||
self.driver = Novatech409B(None)
|
Loading…
Reference in New Issue
Block a user