127 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			127 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| import visa
 | |
| import time
 | |
| import sys
 | |
| 
 | |
| 
 | |
| 
 | |
| def test_idn():
 | |
| 	idn = inst.query("*idn?");
 | |
| 	assert idn == "TinyUSB,ModelNumber,SerialNumber,FirmwareVer123456\r\n"
 | |
| 
 | |
| def test_echo(m,n):
 | |
| 	longstr = "0123456789abcdefghijklmnopqrstuvwxyz" * 50
 | |
| 
 | |
| 	#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
 | |
| 
 | |
| 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():
 | |
| 	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(visa.constants.VI_EVENT_SERVICE_REQ, visa.constants.VI_QUEUE)
 | |
| 	#waitrsp = inst.wait_on_event(visa.constants.VI_EVENT_SERVICE_REQ, 5000)
 | |
| 	#inst.discard_events(visa.constants.VI_EVENT_SERVICE_REQ, visa.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.time()
 | |
| 	try:
 | |
| 		rsp = inst.read()
 | |
| 		assert(false), "Read should have resulted in timeout"
 | |
| 	except visa.VisaIOError:
 | |
| 		print("Got expected exception")
 | |
| 	t = time.time() - t0
 | |
| 	assert ((t*1000.0) > (inst.timeout - 300))
 | |
| 	assert ((t*1000.0) < (inst.timeout + 300))
 | |
| 	print(f"Delay was {t}")
 | |
| 
 | |
| rm = visa.ResourceManager("/c/Windows/system32/visa64.dll")
 | |
| 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()
 | |
| 
 | |
| inst.timeout = 3000
 | |
| 
 | |
| 
 | |
| 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("+ MAV")
 | |
| test_mav()
 | |
| 
 | |
| print("+ SRQ")
 | |
| test_srq()
 | |
| 
 | |
| print("+ TRIG")
 | |
| test_trig()
 | |
| 
 | |
| inst.close()
 | |
| print("Test complete")
 | 
