test-rs232.nut 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324
  1. local __WIN32__ = os.getenv("WINDIR") != null
  2. //local port_name = __WIN32__ ? "COM1" : "/dev/ttyUSB0";
  3. local port_name = __WIN32__ ? "COM1" : "/dev/ttyS0";
  4. local platform = __WIN32__ ? "win32" : "linux";
  5. function time_stamp(){
  6. local t = os.date("*t");
  7. return format("[%02d.%02d.%d %02d:%02d:%02d] ",
  8. t.day, t.month, t.year,
  9. t.hour, t.min, t.sec);
  10. }
  11. local oldprint = print;
  12. function myprint(text){
  13. text = time_stamp() + text;
  14. oldprint(text);
  15. local fd = file("test_sqrs232_log.txt", "a+");
  16. fd.write(text + "\n");
  17. fd.close();
  18. }
  19. print = myprint;
  20. /*
  21. local string_delegate = port_name.getdelegate();
  22. string_delegate.lines <- function(str){
  23. return str.find_lua("([^\n]*)\n");
  24. }
  25. */
  26. function format_test(text, err){
  27. local ret = "\n";
  28. local line_number = 1;
  29. local si = get_last_stackinfo();
  30. local line_err = si.line;
  31. foreach( line in text.split("\n")) {
  32. if (line_number == line_err.tointeger())
  33. ret += format("--> %d. %s (%s)\n", line_number, line, err);
  34. else
  35. ret += format("% 8d. %s\n", line_number, line);
  36. ++line_number;
  37. }
  38. return ret;
  39. }
  40. function test(text){
  41. local chunk = compilestring(text);
  42. if (chunk == null){
  43. print(format([==[
  44. ---------------------------------------------------------------
  45. %s
  46. loadstring error: '%s'
  47. ---------------------------------------------------------------
  48. ]==], format_test(text, err), err))
  49. return false;
  50. }
  51. try {
  52. chunk();
  53. }
  54. catch(e){
  55. print(format([==[
  56. ---------------------------------------------------------------
  57. %s
  58. call error: '%s'
  59. ---------------------------------------------------------------
  60. ]==], format_test(text, e), e));
  61. //return false;
  62. }
  63. return true;
  64. }
  65. local baud_rates = [
  66. "SqRs232.RS232_BAUD_9600",
  67. "SqRs232.RS232_BAUD_19200",
  68. "SqRs232.RS232_BAUD_38400",
  69. "SqRs232.RS232_BAUD_57600",
  70. "SqRs232.RS232_BAUD_115200",
  71. ];
  72. // It's such a crap, Windows seems to not like 5 data
  73. // bits. If you make this test to work with 5 data bits on
  74. // Windows, I'll buy you a beer or two...
  75. local data_bits;
  76. if (platform == "win32"){
  77. data_bits = [
  78. "SqRs232.RS232_DATA_6",
  79. "SqRs232.RS232_DATA_7",
  80. "SqRs232.RS232_DATA_8",
  81. ];
  82. }
  83. else
  84. {
  85. data_bits = [
  86. "SqRs232.RS232_DATA_5",
  87. "SqRs232.RS232_DATA_6",
  88. "SqRs232.RS232_DATA_7",
  89. "SqRs232.RS232_DATA_8",
  90. ];
  91. }
  92. local stop_bits = [
  93. "SqRs232.RS232_STOP_1",
  94. "SqRs232.RS232_STOP_2",
  95. ];
  96. local parity_bits = [
  97. "SqRs232.RS232_PARITY_NONE",
  98. "SqRs232.RS232_PARITY_ODD",
  99. "SqRs232.RS232_PARITY_EVEN",
  100. ];
  101. local flow_bits = [
  102. "SqRs232.RS232_FLOW_OFF",
  103. "SqRs232.RS232_FLOW_HW",
  104. "SqRs232.RS232_FLOW_XON_XOFF",
  105. ];
  106. local dtr_bits = [
  107. "SqRs232.RS232_DTR_ON",
  108. "SqRs232.RS232_DTR_OFF",
  109. ];
  110. local rts_bits = [
  111. "SqRs232.RS232_RTS_ON",
  112. "SqRs232.RS232_RTS_OFF",
  113. ];
  114. local errors = [
  115. "SqRs232.RS232_ERR_NOERROR",
  116. "SqRs232.RS232_ERR_UNKNOWN",
  117. "SqRs232.RS232_ERR_OPEN",
  118. "SqRs232.RS232_ERR_CLOSE",
  119. "SqRs232.RS232_ERR_FLUSH",
  120. "SqRs232.RS232_ERR_CONFIG",
  121. "SqRs232.RS232_ERR_READ",
  122. "SqRs232.RS232_ERR_WRITE",
  123. "SqRs232.RS232_ERR_SELECT",
  124. "SqRs232.RS232_ERR_TIMEOUT",
  125. "SqRs232.RS232_ERR_IOCTL",
  126. "SqRs232.RS232_ERR_PORT_CLOSED",
  127. ];
  128. assert(
  129. test(format([==[
  130. local p = SqRs232();
  131. p.open("%s");
  132. assert(p.close() == SqRs232.RS232_ERR_NOERROR);
  133. ]==], port_name))
  134. );
  135. assert(
  136. test([==[
  137. local p = SqRs232();
  138. p.open("/dev/hell");
  139. ]==])
  140. );
  141. foreach(baud in baud_rates) {
  142. foreach(data in data_bits) {
  143. foreach(parity in parity_bits) {
  144. foreach(stop in stop_bits) {
  145. foreach(flow in flow_bits) {
  146. foreach(dtr in dtr_bits) {
  147. foreach(rts in rts_bits) {
  148. assert(
  149. test(
  150. format([==[
  151. local p = SqRs232();
  152. p.open("%s");
  153. local bret = p.strerror(p.baud_rate(%s));
  154. local dret = p.strerror(p.data_bits(%s));
  155. local pret = p.strerror(p.parity(%s));
  156. local sret = p.strerror(p.stop_bits(%s));
  157. local fret = p.strerror(p.flow_control(%s));
  158. local dtr_ret = p.strerror(p.dtr(%s));
  159. local rts_ret = p.strerror(p.rts(%s));
  160. local text = p.tostring();
  161. assert(text != null);
  162. local errors = "";
  163. if (bret != "no error") errors = "set baud rate,";
  164. if (dret != "no error") errors += "set data bits,";
  165. if (pret != "no error") errors += "set parity,";
  166. if (sret != "no error") errors += "set stop bits,";
  167. if (fret != "no error") errors += "set flow control";
  168. if (dtr_ret != "no error") errors += "set dtr";
  169. if (rts_ret != "no error") errors += "set rts";
  170. if (errors.len() > 0) print(format(" [!] ERROR: %%s (failed: %%s)", text, errors));
  171. else print(format(" [!] OK: %%s", text));
  172. assert(p.close() == SqRs232.RS232_ERR_NOERROR);
  173. ]==], port_name, baud, data, parity, stop, flow, dtr, rts)
  174. )
  175. );
  176. }
  177. }
  178. }
  179. }
  180. }
  181. }
  182. }
  183. foreach(baud in baud_rates) {
  184. foreach(data in data_bits) {
  185. foreach(parity in parity_bits) {
  186. foreach(stop in stop_bits) {
  187. foreach(flow in flow_bits) {
  188. foreach(dtr in dtr_bits) {
  189. foreach(rts in rts_bits) {
  190. assert(
  191. test(
  192. format([==[
  193. local timeout = 10;
  194. local p = SqRs232();
  195. p.open("%s");
  196. assert(p.baud_rate(%s) == SqRs232.RS232_ERR_NOERROR);
  197. assert(p.data_bits(%s) == SqRs232.RS232_ERR_NOERROR);
  198. assert(p.parity(%s) == SqRs232.RS232_ERR_NOERROR);
  199. assert(p.stop_bits(%s) == SqRs232.RS232_ERR_NOERROR);
  200. assert(p.flow_control(%s) == SqRs232.RS232_ERR_NOERROR);
  201. assert(p.dtr(%s) == SqRs232.RS232_ERR_NOERROR);
  202. assert(p.rts(%s) == SqRs232.RS232_ERR_NOERROR);
  203. local baud = p.baud_rate();
  204. local str_baud1 = p.baud_rate_tostring();
  205. local str_baud2 = p.baud_rate_tostring(baud);
  206. assert(str_baud1 == str_baud2);
  207. local bits = p.data_bits();
  208. local str_bits1 = p.data_bits_tostring();
  209. local str_bits2 = p.data_bits_tostring(bits);
  210. assert(str_bits1 == str_bits2);
  211. local parity = p.parity();
  212. local str_parity1 = p.parity_tostring();
  213. local str_parity2 = p.parity_tostring(parity);
  214. assert(str_parity1 == str_parity2);
  215. local stop = p.stop_bits();
  216. local str_stop1 = p.stop_bits_tostring();
  217. local str_stop2 = p.stop_bits_tostring(stop);
  218. assert(str_stop1 == str_stop2);
  219. local flow = p.flow_control();
  220. local str_flow1 = p.flow_control_tostring();
  221. local str_flow2 = p.flow_control_tostring(flow);
  222. assert(str_flow1 == str_flow2);
  223. local dtr = p.dtr();
  224. local str_dtr1 = p.dtr_tostring();
  225. local str_dtr2 = p.dtr_tostring(dtr);
  226. assert(str_dtr1 == str_dtr2);
  227. local rts = p.rts();
  228. local str_rts1 = p.rts_tostring();
  229. local str_rts2 = p.rts_tostring(rts);
  230. assert(str_rts1 == str_rts2);
  231. local e = p.flush();
  232. assert(e == SqRs232.RS232_ERR_NOERROR);
  233. e, d, l = p.read(1, timeout);
  234. assert(e == SqRs232.RS232_ERR_TIMEOUT);
  235. assert(d == nil);
  236. assert(l == 0);
  237. // not implemented yet...
  238. if (platform != "win32"){
  239. local forced = 1;
  240. e, d, l = p.read(1, timeout, forced)
  241. assert(e == SqRs232.RS232_ERR_TIMEOUT)
  242. assert(d == nil)
  243. assert(l == 0)
  244. }
  245. local forced = 0;
  246. e, d, l = p.read(1, timeout, forced);
  247. assert(e == SqRs232.RS232_ERR_TIMEOUT)
  248. assert(d == nil)
  249. assert(l == 0)
  250. e, l = p.write("ynezz")
  251. assert(e == SqRs232.RS232_ERR_NOERROR)
  252. // althought the write is successful it returns 0 bytes written
  253. // in some baud/data/stop/flow combinations...
  254. if (platform != "win32") assert(l == 5);
  255. e, l = p.write("ynezz", timeout)
  256. assert(e == SqRs232.RS232_ERR_NOERROR);
  257. // althought the write is successful it returns 0 bytes written
  258. // in some baud/data/stop/flow combinations...
  259. if (platform != "win32") assert(l == 5);
  260. local text = p.tostring();
  261. assert(text != niull)
  262. print("tostring(p): " + text);
  263. assert(p.close() == SqRs232.RS232_ERR_NOERROR);
  264. ]==], port_name, baud, data, parity, stop, flow, dtr, rts)
  265. )
  266. );
  267. }
  268. }
  269. }
  270. }
  271. }
  272. }
  273. }
  274. print("[*] All tests passed succesfuly!");