213 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			213 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
	
	
| #!/usr/bin/env python3
 | |
| 
 | |
| import pyvisa
 | |
| import time
 | |
| import sys
 | |
| 
 | |
| 
 | |
| def test_idn():
 | |
| 	idn = inst.query("*idn?");
 | |
| 	assert (idn == "TinyUSB,ModelNumber,SerialNumber,FirmwareVer123456\r\n")
 | |
| 	assert (inst.is_4882_compliant)
 | |
| 
 | |
| def test_echo(m,n):
 | |
| 	longstr = "0123456789abcdefghijklmnopqrstuvwxyz" * 50
 | |
| 	t0 = time.monotonic()
 | |
| 
 | |
| 	#Next try echo from 1 to 175 characters (200 is max buffer size on DUT)
 | |
| 	for i in range(m,n):
 | |
| 		#print(i)
 | |
| 		x = longstr[0:i]
 | |
| 		xt = x + inst.write_termination
 | |
| 		y = inst.query(x)
 | |
| 		#print(x)
 | |
| 		#print (":".join("{:02x}".format(ord(c)) for c in xt))
 | |
| 		#print (":".join("{:02x}".format(ord(c)) for c in y))
 | |
| 		assert(xt == y), f"failed i={i}"
 | |
| 		#inst.read_stb();# Just to make USB logging easier by sending a control query (bad thing is that this made things slow)
 | |
| 	t = time.monotonic() - t0
 | |
| 	print(f"  elapsed: {t:0.3} sec")
 | |
| 
 | |
| def test_trig():
 | |
| 	# clear SRQ
 | |
| 	inst.read_stb()
 | |
| 	assert (inst.read_stb() == 0)
 | |
| 	inst.assert_trigger()
 | |
| 	time.sleep(0.3) # SRQ may have some delay
 | |
| 	assert (inst.read_stb() & 0x40), "SRQ not set after 0.3 seconds"
 | |
| 	assert (inst.read_stb() == 0)
 | |
| 
 | |
| 
 | |
| def test_mav():
 | |
| 	inst.write("delay 50")
 | |
| 	inst.read_stb() # clear STB
 | |
| 	assert (inst.read_stb() == 0)
 | |
| 	inst.write("123")
 | |
| 	time.sleep(0.3)
 | |
| 	assert (inst.read_stb() & 0x10), "MAV not set after 0.5 seconds"
 | |
| 
 | |
| 	rsp = inst.read()
 | |
| 	assert(rsp == "123\r\n")
 | |
| 
 | |
| 
 | |
| def test_srq():
 | |
| 	assert (inst.read_stb() == 0)
 | |
| 	inst.write("123")
 | |
| 
 | |
| 	#inst.enable_event(pyvisa.constants.VI_EVENT_SERVICE_REQ, pyvisa.constants.VI_QUEUE)
 | |
| 	#waitrsp = inst.wait_on_event(pyvisa.constants.VI_EVENT_SERVICE_REQ, 5000)
 | |
| 	#inst.discard_events(pyvisa.constants.VI_EVENT_SERVICE_REQ, pyvisa.constants.VI_QUEUE)
 | |
| 	#inst.wait_for_srq()
 | |
| 	time.sleep(0.3)
 | |
| 	stb = inst.read_stb()
 | |
| 	msg =  "SRQ not set after 0.5 seconds, was {:02x}".format(stb)
 | |
| 	assert (stb == 0x50),msg
 | |
| 
 | |
| 	assert (inst.read_stb() == 0x10), "SRQ set at second read!"
 | |
| 
 | |
| 	rsp = inst.read()
 | |
| 	assert(rsp == "123\r\n")
 | |
| 
 | |
| def test_read_timeout():
 | |
| 	inst.timeout = 500
 | |
| 	# First read with no MAV
 | |
| 	inst.read_stb()
 | |
| 	assert (inst.read_stb() == 0)
 | |
| 	inst.write("delay 500")
 | |
| 	t0 = time.monotonic()
 | |
| 	try:
 | |
| 		rsp = inst.read()
 | |
| 		assert(False), "Read should have resulted in timeout"
 | |
| 	except pyvisa.VisaIOError:
 | |
| 		print("  Got expected exception")
 | |
| 	t = time.monotonic() - t0
 | |
| 	assert ((t*1000.0) > (inst.timeout - 300))
 | |
| 	assert ((t*1000.0) < (inst.timeout + 300))
 | |
| 	print(f"Delay was {t:0.3}")
 | |
| 	# Response is still in queue, so send a clear (to be more helpful to the next test)
 | |
| 	inst.clear()
 | |
| 	time.sleep(0.3)
 | |
| 	assert(0 ==  (inst.read_stb() & 0x10)), "MAV not reset after clear"
 | |
| 
 | |
| def test_abort_in():
 | |
| 	inst.timeout = 200
 | |
| 	# First read with no MAV
 | |
| 	inst.read_stb()
 | |
| 	assert (inst.read_stb() == 0)
 | |
| 	inst.write("delay 500")
 | |
| 	inst.write("xxx")
 | |
| 	t0 = time.monotonic()
 | |
| 	try:
 | |
| 		rsp = inst.read()
 | |
| 		assert(False), "Read should have resulted in timeout"
 | |
| 	except pyvisa.VisaIOError:
 | |
| 		print("  Got expected exception")
 | |
| 	t = time.monotonic() - t0
 | |
| 	assert ((t*1000.0) > (inst.timeout - 300))
 | |
| 	assert ((t*1000.0) < (inst.timeout + 300))
 | |
| 	print(f"  Delay was {t:0.3}")
 | |
| 	# Response is still in queue, so read it out (to be more helpful to the next test)
 | |
| 	inst.timeout = 800
 | |
| 	y = inst.read()
 | |
| 	assert(y == "xxx\r\n")
 | |
| 
 | |
| def test_indicate():
 | |
| 	# perform indicator pulse
 | |
| 	usb_iface = inst.get_visa_attribute(pyvisa.constants.VI_ATTR_USB_INTFC_NUM)
 | |
| 	retv = inst.control_in(request_type_bitmap_field=0xA1, request_id=64, request_value=0x0000, index=usb_iface, length=0x0001)
 | |
| 	# pyvisa used to return (statuscode,bytes), but now only returns bytes, so we need to handle both cases
 | |
| 	if(isinstance(retv,bytes)):
 | |
| 		assert(retv == b'\x01')
 | |
| 	else:
 | |
| 		assert((retv[1] == pyvisa.constants.StatusCode(0)) and (retv[0] == b'\x01')), f"indicator pulse failed: retv={retv}"
 | |
| 
 | |
| 
 | |
| def test_multi_read():
 | |
| 	old_chunk_size = inst.chunk_size
 | |
| 	longstr = "0123456789abcdefghijklmnopqrstuvwxyz" * 10
 | |
| 	timeout = 10
 | |
| 	x = longstr[0:174]
 | |
| 	inst.chunk_size = 50 # Seems chunk size only applies to read but not write
 | |
| 	inst.write(x)
 | |
| 	# I'm not sure how to request just the remaining bit using a max count... so just read it all.
 | |
| 	y = inst.read()
 | |
| 	assert (x + "\r\n" == y)
 | |
| 	#inst.chunk_size = old_chunk_size
 | |
| 
 | |
| def test_stall_ep0():
 | |
| 	usb_iface = inst.get_visa_attribute(pyvisa.constants.VI_ATTR_USB_INTFC_NUM)
 | |
| 	inst.read_stb()
 | |
| 	# This is an invalid request, should create stall.
 | |
| 	try:
 | |
| 		retv = inst.control_in(request_type_bitmap_field=0xA1, request_id=60, request_value=0x0000, index=usb_iface, length=0x0001)
 | |
| 		assert(False)
 | |
| 	except pyvisa.VisaIOError:
 | |
| 		pass
 | |
| 
 | |
| 	assert (inst.read_stb() == 0)
 | |
| 
 | |
| 
 | |
| rm = pyvisa.ResourceManager()
 | |
| reslist = rm.list_resources("USB?::?*::INSTR")
 | |
| print(reslist)
 | |
| 
 | |
| if (len(reslist) == 0):
 | |
|     sys.exit()
 | |
| 
 | |
| inst = rm.open_resource(reslist[0]);
 | |
| inst.timeout = 3000
 | |
| 
 | |
| inst.clear()
 | |
| 
 | |
| print("+ IDN")
 | |
| test_idn()
 | |
| 
 | |
| print("+test abort in")
 | |
| test_abort_in()
 | |
| 
 | |
| 
 | |
| inst.timeout = 2000
 | |
| 
 | |
| print("+ multi read")
 | |
| test_multi_read()
 | |
| 
 | |
| print("+ echo delay=0")
 | |
| inst.write("delay 0")
 | |
| test_echo(1,175)
 | |
| 
 | |
| print("+ echo delay=2")
 | |
| inst.write("delay 2")
 | |
| test_echo(1,175)
 | |
| 
 | |
| print("+ echo delay=150")
 | |
| inst.write("delay 150")
 | |
| test_echo(53,76)
 | |
| test_echo(165,170)
 | |
| 
 | |
| print("+ Read timeout (no MAV)")
 | |
| test_read_timeout()
 | |
| 
 | |
| print("+ Test EP0 stall recovery")
 | |
| test_stall_ep0()
 | |
| 
 | |
| print("+ MAV")
 | |
| test_mav()
 | |
| 
 | |
| print("+ SRQ")
 | |
| test_srq()
 | |
| 
 | |
| print("+ indicate")
 | |
| test_indicate()
 | |
| 
 | |
| print("+ TRIG")
 | |
| test_trig()
 | |
| 
 | |
| # Untested:
 | |
| #  abort bulk out
 | |
| #  LLO, GTL, etc
 | |
| #  Throughput rate?
 | |
| #  Transmitting a message using multiple transfers
 | |
| 
 | |
| inst.close()
 | |
| print("Test complete")
 | 
