object-test.cpp 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273
  1. #include "test_common.h"
  2. TEST_START
  3. void testFloat(PikaObj* obj, Args* args) {
  4. float val1 = args_getFloat(args, "val1");
  5. float val2 = args_getFloat(args, "val2");
  6. int32_t isShow = args_getInt(args, "isShow");
  7. if (isShow) {
  8. printf("the float val1 is: %f\r\n", val1);
  9. printf("the float val2 is: %f\r\n", val2);
  10. }
  11. method_returnFloat(args, val1 + val2);
  12. }
  13. void hello2(PikaObj* obj, Args* args) {
  14. char* name1 = args_getStr(args, "name1");
  15. char* name2 = args_getStr(args, "name2");
  16. char* name3 = args_getStr(args, "name3");
  17. int32_t isShow = args_getInt(args, "isShow");
  18. if (isShow) {
  19. printf("hello, %s, %s and %s!\r\n", name1, name2, name3);
  20. }
  21. }
  22. void hello(PikaObj* obj, Args* args) {
  23. char* name = args_getStr(args, "name");
  24. int32_t isShow = args_getInt(args, "isShow");
  25. if (isShow) {
  26. printf("hello, %s!\r\n", name);
  27. }
  28. }
  29. void add(PikaObj* obj, Args* args) {
  30. int32_t val1 = args_getInt(args, "val1");
  31. int32_t val2 = args_getInt(args, "val2");
  32. method_returnInt(args, val1 + val2);
  33. }
  34. PikaObj* New_PikaObj_test(Args* args) {
  35. PikaObj* self = New_PikaStdLib_SysObj(args);
  36. class_defineMethod(self, "hello", "name,isShow", hello);
  37. class_defineMethod(self, "hello2", "name1,name2,name3,isShow", hello2);
  38. class_defineMethod(self, "testFloat", "val1,val2,isShow", testFloat);
  39. class_defineMethod(self, "add", "val1,val2", add);
  40. return self;
  41. }
  42. void sendMethod(PikaObj* self, Args* args) {
  43. char* data = args_getStr(args, "data");
  44. /* send to com1 */
  45. printf("[com1]: %s\r\n", data);
  46. }
  47. PikaObj* New_USART(Args* args) {
  48. /* Derive from the tiny object class.
  49. Tiny object can not import sub object.
  50. Tiny object is the smallest object. */
  51. PikaObj* self = New_TinyObj(args);
  52. /* bind the method */
  53. class_defineMethod(self, "send", "data:str", sendMethod);
  54. /* return the object */
  55. return self;
  56. }
  57. PikaObj* New_MYROOT1(Args* args) {
  58. /* Derive from the base object class .
  59. BaseObj is the smallest object that can
  60. import sub object. */
  61. PikaObj* self = New_BaseObj(args);
  62. /* new led object bellow root object */
  63. obj_newObj(self, "usart", "USART", (NewFun)New_USART);
  64. /* return the object */
  65. return self;
  66. }
  67. TEST(object_test, test10) {
  68. PikaObj* root = newRootObj("root", New_MYROOT1);
  69. obj_run(root, "usart.send('hello world')");
  70. obj_deinit(root);
  71. EXPECT_EQ(pikaMemNow(), 0);
  72. }
  73. // TEST(object_test, test1) {
  74. // PikaObj* process = newRootObj("sys", New_PikaStdLib_SysObj);
  75. // float floatTest = 12.231;
  76. // obj_bindFloat(process, "testFloatBind", &floatTest);
  77. // EXPECT_TRUE(
  78. // strEqu("12.231000", obj_print(process, "testFloatBind")));
  79. // obj_deinit(process);
  80. // EXPECT_EQ(pikaMemNow(), 0);
  81. // }
  82. TEST(object_test, test2) {
  83. int isShow = 1;
  84. PikaObj* obj = newRootObj("test", New_PikaObj_test);
  85. obj_setInt(obj, "isShow", isShow);
  86. obj_run(obj, "hello(name = 'world', isShow = isShow)");
  87. obj_deinit(obj);
  88. EXPECT_EQ(pikaMemNow(), 0);
  89. }
  90. TEST(object_test, test3) {
  91. int isShow = 1;
  92. PikaObj* obj = newRootObj("test", New_PikaObj_test);
  93. obj_setInt(obj, "isShow", isShow);
  94. obj_run(obj,
  95. "hello2(name2='tom', name1='john', name3='cat', isShow=isShow) ");
  96. obj_deinit(obj);
  97. EXPECT_EQ(pikaMemNow(), 0);
  98. }
  99. TEST(object_test, test6) {
  100. PikaObj* obj = newRootObj("test", New_PikaObj_test);
  101. VMParameters* globals = obj_run(obj, "res = add(1, 2)");
  102. int32_t res = obj_getInt(globals, "res");
  103. EXPECT_EQ(3, res);
  104. obj_deinit(obj);
  105. // obj_deinit(globals);
  106. EXPECT_EQ(pikaMemNow(), 0);
  107. }
  108. TEST(object_test, test8) {
  109. PikaObj* sys = newRootObj("sys", New_PikaStdLib_SysObj);
  110. obj_run(sys, "a=1");
  111. obj_run(sys, "remove('a')");
  112. obj_deinit(sys);
  113. EXPECT_EQ(pikaMemNow(), 0);
  114. }
  115. TEST(object_test, test9) {
  116. PikaObj* sys = newRootObj("sys", New_PikaStdLib_SysObj);
  117. obj_run(sys, "ls()");
  118. obj_setPtr(sys, "baseClass", (void*)New_TinyObj);
  119. obj_run(sys, "ls()");
  120. obj_deinit(sys);
  121. EXPECT_EQ(pikaMemNow(), 0);
  122. }
  123. TEST(object_test, noMethod) {
  124. PikaObj* root = newRootObj("root", New_MYROOT1);
  125. obj_run(root, "noDefindMethod()");
  126. obj_deinit(root);
  127. EXPECT_EQ(pikaMemNow(), 0);
  128. }
  129. TEST(object_test, a_b) {
  130. PikaObj* root = newRootObj("root", New_MYROOT1);
  131. obj_run(root, "b=1");
  132. obj_run(root, "a=b");
  133. obj_deinit(root);
  134. EXPECT_EQ(pikaMemNow(), 0);
  135. }
  136. TEST(object_test, voidRun) {
  137. PikaObj* root = newRootObj("root", New_MYROOT1);
  138. obj_run(root, "");
  139. obj_deinit(root);
  140. EXPECT_EQ(pikaMemNow(), 0);
  141. }
  142. /* the log_buff of printf */
  143. extern char log_buff[LOG_BUFF_MAX][LOG_SIZE];
  144. TEST(object_test, printa) {
  145. PikaObj* root = newRootObj("root", New_PikaStdLib_SysObj);
  146. obj_run(root,
  147. "a = 2\n"
  148. "print(a)\n");
  149. // char* sysOut = obj_getSysOut(globals);
  150. EXPECT_STREQ(log_buff[0], "2\r\n");
  151. // ASSERT_STREQ(sysOut, "2");
  152. // obj_deinit(globals);
  153. obj_deinit(root);
  154. EXPECT_EQ(pikaMemNow(), 0);
  155. }
  156. TEST(object_test, copyArg) {
  157. PikaObj* root = newRootObj("root", New_BaseObj);
  158. Arg* arg = New_arg(NULL);
  159. arg = arg_setInt(arg, "a", 1);
  160. obj_setArg(root, "a", arg);
  161. arg_deinit(arg);
  162. Arg* argOut = obj_getArg(root, "a");
  163. int argOutInt = arg_getInt(argOut);
  164. ASSERT_EQ(argOutInt, 1);
  165. obj_deinit(root);
  166. EXPECT_EQ(pikaMemNow(), 0);
  167. }
  168. TEST(object_test, obj_run_while) {
  169. PikaObj* root = newRootObj("root", New_BaseObj);
  170. char lines[] =
  171. "a = 1\n"
  172. "b = 0\n"
  173. "while a:\n"
  174. " b = 1\n"
  175. " a = 0\n"
  176. "\n";
  177. VMParameters* globals = obj_run(root, lines);
  178. EXPECT_EQ(obj_getInt(globals, "a"), 0);
  179. EXPECT_EQ(obj_getInt(globals, "b"), 1);
  180. obj_deinit(root);
  181. // obj_deinit(globals);
  182. EXPECT_EQ(pikaMemNow(), 0);
  183. }
  184. TEST(object_test, obj_mem) {
  185. uint8_t mem_test[] = {0x33, 0x55, 0x00, 0x15};
  186. uint8_t mem_out_buff[32] = {0};
  187. PikaObj* self = New_TinyObj(NULL);
  188. obj_setBytes(self, "mem", mem_test, sizeof(mem_test));
  189. size_t mem_size = obj_getBytesSize(self, "mem");
  190. char* mem_test_out = (char*)obj_getBytes(self, "mem");
  191. ArgType arg_type = arg_getType(obj_getArg(self, "mem"));
  192. obj_loadBytes(self, "mem", mem_out_buff);
  193. /* assert */
  194. EXPECT_EQ(mem_size, sizeof(mem_test));
  195. EXPECT_EQ(mem_test_out[0], 0x33);
  196. EXPECT_EQ(mem_test_out[1], 0x55);
  197. EXPECT_EQ(mem_test_out[2], 0x00);
  198. EXPECT_EQ(mem_test_out[3], 0x15);
  199. EXPECT_EQ(arg_type, ARG_TYPE_BYTES);
  200. /* deinit */
  201. obj_deinit(self);
  202. EXPECT_EQ(mem_out_buff[0], 0x33);
  203. EXPECT_EQ(mem_out_buff[1], 0x55);
  204. EXPECT_EQ(mem_out_buff[2], 0x00);
  205. EXPECT_EQ(mem_out_buff[3], 0x15);
  206. EXPECT_EQ(pikaMemNow(), 0);
  207. EXPECT_EQ(pikaMemNow(), 0);
  208. }
  209. TEST(object_test, mem) {
  210. EXPECT_EQ(pikaMemNow(), 0);
  211. EXPECT_EQ(pikaMemNow(), 0);
  212. }
  213. TEST(object_test, bytes) {
  214. PikaObj* root = newRootObj("root", New_BaseObj);
  215. uint8_t test_arg[] = {0x00, 0x02, 0x03, 0x05, 0x07};
  216. obj_setBytes(root, "test", test_arg, sizeof(test_arg));
  217. uint16_t mem_now_before = pikaMemNow();
  218. obj_setBytes(root, "test", test_arg, sizeof(test_arg));
  219. EXPECT_EQ(pikaMemNow(), mem_now_before);
  220. obj_deinit(root);
  221. EXPECT_EQ(pikaMemNow(), 0);
  222. }
  223. TEST(object_test, bytes_0_size) {
  224. PikaObj* root = newRootObj("root", New_BaseObj);
  225. uint8_t test[] = {0, 1, 2, 3, 4, 5};
  226. obj_setBytes(root, "test", test, 0);
  227. obj_deinit(root);
  228. EXPECT_EQ(pikaMemNow(), 0);
  229. }
  230. TEST(object, str_set_int) {
  231. PikaObj* root = newRootObj("root", New_BaseObj);
  232. obj_setStr(root, "test", "teststr");
  233. EXPECT_STREQ(obj_getStr(root, "test"), "teststr");
  234. obj_setInt(root, "test", 123);
  235. EXPECT_EQ(obj_getInt(root, "test"), 123);
  236. obj_deinit(root);
  237. EXPECT_EQ(pikaMemNow(), 0);
  238. }
  239. TEST_END