visaQuery.py 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. import visa
  2. import time
  3. import sys
  4. def test_idn():
  5. idn = inst.query("*idn?");
  6. assert idn == "TinyUSB,ModelNumber,SerialNumber,FirmwareVer123456\r\n"
  7. def test_echo(m,n):
  8. longstr = "0123456789abcdefghijklmnopqrstuvwxyz" * 50
  9. #Next try echo from 1 to 175 characters (200 is max buffer size on DUT)
  10. for i in range(m,n):
  11. #print(i)
  12. x = longstr[0:i]
  13. xt = x + inst.write_termination
  14. y = inst.query(x)
  15. #print(x)
  16. #print (":".join("{:02x}".format(ord(c)) for c in xt))
  17. #print (":".join("{:02x}".format(ord(c)) for c in y))
  18. assert(xt == y), f"failed i={i}"
  19. inst.read_stb();# Just to make USB logging easier by sending a control query
  20. def test_mav():
  21. assert (inst.read_stb() == 0)
  22. inst.write("123")
  23. time.sleep(0.3)
  24. assert (inst.read_stb() & 0x10), "MAV not set after 0.5 seconds"
  25. rsp = inst.read()
  26. assert(rsp == "123\r\n")
  27. def test_srq():
  28. assert (inst.read_stb() == 0)
  29. inst.write("123")
  30. #inst.enable_event(visa.constants.VI_EVENT_SERVICE_REQ, visa.constants.VI_QUEUE)
  31. #waitrsp = inst.wait_on_event(visa.constants.VI_EVENT_SERVICE_REQ, 5000)
  32. #inst.discard_events(visa.constants.VI_EVENT_SERVICE_REQ, visa.constants.VI_QUEUE)
  33. #inst.wait_for_srq()
  34. time.sleep(0.3)
  35. stb = inst.read_stb()
  36. msg = "SRQ not set after 0.5 seconds, was {:02x}".format(stb)
  37. assert (stb == 0x50),msg
  38. assert (inst.read_stb() == 0x10), "SRQ set at second read!"
  39. rsp = inst.read()
  40. assert(rsp == "123\r\n")
  41. rm = visa.ResourceManager("/c/Windows/system32/visa64.dll")
  42. reslist = rm.list_resources("USB?::?*::INSTR")
  43. print(reslist)
  44. if (len(reslist) == 0):
  45. sys.exit()
  46. inst = rm.open_resource(reslist[0]);
  47. inst.timeout = 3000
  48. inst.clear()
  49. #print("+ IDN")
  50. #test_idn()
  51. print("+ random trigger")
  52. #inst.assert_trigger();
  53. print("+ echo delay=0")
  54. inst.write("delay 0")
  55. test_echo(1,175)
  56. print("+ echo delay=2")
  57. inst.write("delay 2")
  58. test_echo(1,175)
  59. print("+ echo delay=200")
  60. inst.write("delay 200")
  61. test_echo(50,90)
  62. test_echo(165,170)
  63. print("+ MAV")
  64. test_mav()
  65. print("+ SRQ")
  66. test_srq()
  67. inst.close()
  68. print("Test complete")