diff --git a/devices/test_device.py b/devices/test_device.py index 553c6e6f871cbe80f0b740e88c585c602f0002b4..6a62907112ea1cf081436285aa0d21532ba24d0a 100644 --- a/devices/test_device.py +++ b/devices/test_device.py @@ -13,83 +13,63 @@ # PyTango imports from tango.server import run from tango.server import device_property +from tango import DevState # Additional import -<<<<<<< HEAD -from clients.SNMP_client import SNMP_client -from src.attribute_wrapper import * -from src.hardware_device import * -======= from clients.test_client import test_client from util.attribute_wrapper import * from util.hardware_device import * ->>>>>>> master -__all__ = ["example_device", "main"] - - -class example_device(hardware_device): +__all__ = ["test_device", "main"] +class test_device(hardware_device): # ----------------- # Device Properties # ----------------- - SNMP_community = b"public" - SNMP_host = "127.0.0.1" - SNMP_timeout = 5.0 + OPC_Server_Name = device_property( + dtype='DevString', + ) + + OPC_Server_Port = device_property( + dtype='DevULong', + ) + + OPC_Time_Out = device_property( + dtype='DevDouble', + ) # ---------- # Attributes # ---------- + bool_scalar_R = attribute_wrapper(comms_annotation="numpy.bool_ type read scalar", datatype=numpy.bool_) + bool_scalar_RW = attribute_wrapper(comms_annotation="numpy.bool_ type read/write scalar", datatype=numpy.bool_, access=AttrWriteType.READ_WRITE) - # simple scalar - attr1 = attribute_wrapper(comms_annotation={"oids": "1.3.6.1.2.1.1.6.0"}, datatype=numpy.bool_, access=AttrWriteType.READ_WRITE) - # simple scalar with host - attr2 = attribute_wrapper(comms_annotation={"oids": "1.3.6.1.2.1.1.5.0"}, datatype=numpy.bool_, access=AttrWriteType.READ_WRITE) - - #spectrum with all elements - attr3 = attribute_wrapper(comms_annotation={"oids": ["1.3.6.1.2.1.1.5.1", "1.3.6.1.2.1.1.5.2", "1.3.6.1.2.1.1.5.3"]}, dims=(3,), datatype=numpy.bool_) - #inferred spectrum - attr4 = attribute_wrapper(comms_annotation={"oids": ["1.3.6.1.2.1.1.5.0"]}, dims=(3,), datatype=numpy.bool_) - + int32_spectrum_R = attribute_wrapper(comms_annotation="numpy.int32 type read spectrum (len = 8)", datatype=numpy.int32, dims=(8,)) + int32_spectrum_RW = attribute_wrapper(comms_annotation="numpy.int32 type read spectrum (len = 8)", datatype=numpy.int32, dims=(8,), + access=AttrWriteType.READ_WRITE) - def always_executed_hook(self): - """Method always executed before any TANGO command is executed.""" - pass + double_image_R = attribute_wrapper(comms_annotation="numpy.double type read image (dims = 2x8)", datatype=numpy.double, dims=(2, 8)) + double_image_RW = attribute_wrapper(comms_annotation="numpy.double type read/write image (dims = 8x2)", datatype=numpy.double, dims=(8, 2), + access=AttrWriteType.READ_WRITE) - def delete_device(self): - """Hook to delete resources allocated in init_device. - - This method allows for any memory or other resources allocated in the - init_device method to be released. This method is called by the device - destructor and by the device Init command (a Tango built-in). - """ - self.debug_stream("Shutting down...") - - self.Off() - self.debug_stream("Shut down. Good bye.") + int32_scalar_R = attribute_wrapper(comms_annotation="numpy.int32 type read scalar", datatype=numpy.int32) + uint16_spectrum_RW = attribute_wrapper(comms_annotation="numpy.uint16 type read/write spectrum (len = 8)", datatype=numpy.uint16, dims=(8,), + access=AttrWriteType.READ_WRITE) + float32_image_R = attribute_wrapper(comms_annotation="numpy.float32 type read image (dims = 8x2)", datatype=numpy.float32, dims=(8, 2)) + uint8_image_RW = attribute_wrapper(comms_annotation="numpy.uint8 type read/write image (dims = 2x8)", datatype=numpy.uint8, dims=(2, 8), + access=AttrWriteType.READ_WRITE) # -------- # overloaded functions # -------- - def initialise(self): - """ user code here. is called when the state is set to STANDBY """ - - # set up the SNMP ua client - self.snmp_manager = SNMP_client(self.SNMP_community, self.SNMP_host, self.SNMP_timeout, self.Fault, self) - -<<<<<<< HEAD - # map the attributes to the OPC ua comm client - for i in self.attr_list(): - i.set_comm_client(self.snmp_manager) + def configure_for_initialise(self): + """ user code here. is called when the sate is set to INIT """ + """Initialises the attributes and properties of the PCC.""" - self.snmp_manager.start() + self.set_state(DevState.INIT) -# -------- -# Commands -# -------- -======= # set up the test client self.test_client = test_client(self.Fault, self) @@ -98,15 +78,14 @@ class example_device(hardware_device): i.set_comm_client(self.test_client) self.test_client.start() ->>>>>>> master # ---------- # Run server # ---------- def main(args=None, **kwargs): - """Main function of the PCC module.""" - return run((example_device,), args=args, **kwargs) + """Main function of the example module.""" + return run((test_device,), args=args, **kwargs) if __name__ == '__main__':