pikapython/port/linux/test/pikaMain-test.cpp

1722 lines
45 KiB
C
Raw Normal View History

#include "gtest/gtest.h"
extern "C" {
#include "PikaMain.h"
2022-02-25 18:21:27 +08:00
#include "PikaParser.h"
#include "PikaStdLib_MemChecker.h"
2022-02-25 18:21:27 +08:00
#include "PikaVM.h"
#include "dataArgs.h"
#include "dataMemory.h"
2022-02-25 18:21:27 +08:00
#include "dataStrs.h"
2022-01-04 11:24:34 +08:00
#include "pikaScript.h"
2022-01-24 19:34:43 +08:00
#include "pika_config_gtest.h"
}
2022-01-24 19:08:33 +08:00
extern PikaMemInfo pikaMemInfo;
TEST(pikaMain, init) {
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = pikaScriptInit();
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
}
TEST(pikaMain, new_mem) {
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
2022-02-22 00:41:45 +08:00
VMParameters* globals =
obj_runDirect(pikaMain, (char*)
"mem = PikaStdLib.MemChecker()\n"
"mem.max()\n"
);
PikaObj* mem = (PikaObj*)args_getPtr(globals->list, (char*)"mem");
PikaObj* memClassPtr = (PikaObj*)obj_getPtr(mem, (char*)"_clsptr");
EXPECT_EQ((void*)memClassPtr, (void*)New_PikaStdLib_MemChecker);
obj_deinit(pikaMain);
2021-11-23 12:15:12 +08:00
// obj_deinit(globals);
EXPECT_EQ(pikaMemNow(), 0);
2021-11-17 10:59:13 +08:00
}
TEST(pikaMain, list_new) {
/* init */
2021-11-17 11:03:56 +08:00
pikaMemInfo.heapUsedMax = 0;
2021-11-17 10:59:13 +08:00
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
2022-02-22 00:41:45 +08:00
VMParameters* globals =
2021-11-17 10:59:13 +08:00
obj_runDirect(pikaMain, (char*)
2021-12-13 21:24:48 +08:00
"list = PikaStdData.List()\n"
2021-11-17 10:59:13 +08:00
"list.append(7)\n"
"list.append('eee')\n"
"len = list.len()\n"
"a1 = list.get(0)\n"
"a2 = list.get(1)\n"
);
/* collect */
int len = obj_getInt(globals, (char*)"len");
int a1 = obj_getInt(globals, (char*)"a1");
char* a2 = obj_getStr(globals, (char*)"a2");
/* assert */
EXPECT_EQ(len, 2);
EXPECT_EQ(a1, 7);
EXPECT_STREQ(a2, "eee");
2021-11-20 09:28:21 +08:00
/* deinit */
2021-11-23 12:15:12 +08:00
// obj_deinit(globals);
2021-11-20 09:28:21 +08:00
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
}
TEST(pikaMain, int_float_convert) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
2022-02-22 00:41:45 +08:00
VMParameters* globals =
2021-11-20 09:28:21 +08:00
obj_runDirect(pikaMain, (char*)
"a = 1\n"
"a_f = float(a)\n"
"b = 1.3\n"
"b_i = int(b)\n"
);
/* collect */
int a = obj_getInt(globals, (char*)"a");
float a_f = obj_getFloat(globals, (char*)"a_f");
float b = obj_getFloat(globals, (char*)"b");
int b_i = obj_getInt(globals, (char*)"b_i");
/* assert */
EXPECT_EQ(a, 1);
EXPECT_FLOAT_EQ(a_f, 1);
EXPECT_FLOAT_EQ(b, 1.3);
EXPECT_FLOAT_EQ(b_i, 1);
2021-11-20 09:33:38 +08:00
/* deinit */
2021-11-23 12:15:12 +08:00
// obj_deinit(globals);
2021-11-20 09:33:38 +08:00
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
}
TEST(pikaMain, type_) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
obj_runDirect(pikaMain, (char*)
2021-11-20 09:33:38 +08:00
"type(1)\n"
"b = 1.4\n"
"type(b)\n"
);
/* collect */
/* assert */
/* deinit */
// obj_deinit(globals);
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
}
TEST(pikaMain, a_signed) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
obj_runDirect(pikaMain, (char*)"a = -1\n");
/* collect */
int a = obj_getInt(pikaMain, (char*)"a");
/* assert */
EXPECT_EQ(-1, a);
2021-11-28 01:29:47 +08:00
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
}
TEST(pikaMain, a_mm) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
obj_runDirect(pikaMain, (char*)"a = -1.1 ** 3\n");
/* collect */
float a = obj_getFloat(pikaMain, (char*)"a");
/* assert */
EXPECT_FLOAT_EQ(-1.331, a);
2021-11-28 01:42:14 +08:00
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
}
TEST(pikaMain, a_n1) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
2022-03-29 18:02:55 +08:00
obj_runDirect(pikaMain, (char*)"a = -2\n");
2021-11-28 01:42:14 +08:00
/* collect */
int a = obj_getInt(pikaMain, (char*)"a");
/* assert */
EXPECT_EQ(-2, a);
2021-11-28 01:44:17 +08:00
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
}
TEST(pikaMain, a_l4) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
obj_runDirect(pikaMain, (char*)"a = 1<<4\n");
/* collect */
int a = obj_getInt(pikaMain, (char*)"a");
/* assert */
EXPECT_EQ(16, a);
2021-11-28 11:51:41 +08:00
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
}
TEST(pikaMain, less_equ) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
obj_runDirect(pikaMain, (char*)
"a = 0\n"
"while a <= 10:\n"
2022-03-31 15:36:35 +08:00
" a += 1\n"
2021-11-28 11:51:41 +08:00
"\n"
);
/* collect */
int a = obj_getInt(pikaMain, (char*)"a");
/* assert */
EXPECT_EQ(11, a);
2021-11-28 17:26:17 +08:00
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
}
TEST(pikaMain, and_or_not) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
obj_runDirect(pikaMain, (char*)
"a = 0\n"
"b = 0\n"
"c = 0\n"
"if (1>2) or (2>1):\n"
" a = 1\n"
"\n"
"if (1>2) and (2>1):\n"
" b = 1\n"
"\n"
"if not (1>2):\n"
" c = 1\n"
"\n"
);
/* collect */
int a = obj_getInt(pikaMain, (char*)"a");
int b = obj_getInt(pikaMain, (char*)"b");
int c = obj_getInt(pikaMain, (char*)"c");
/* assert */
EXPECT_EQ(1, a);
EXPECT_EQ(0, b);
EXPECT_EQ(1, c);
2021-12-10 11:41:33 +08:00
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
}
TEST(pikaMain, err_scop) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
2021-12-24 23:34:34 +08:00
obj_run(pikaMain, (char*)"print('test'");
2021-12-10 11:41:33 +08:00
/* collect */
/* assert */
2021-12-10 22:53:06 +08:00
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
}
2021-12-24 23:34:34 +08:00
TEST(pikaMain, PikaStdData) {
2021-12-13 22:01:42 +08:00
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
obj_run(pikaMain, (char*)
"dict = PikaStdData.Dict()\n"
"dict.set('a', 1)\n"
2021-12-13 22:03:59 +08:00
"dict.set('b', 2)\n"
"dict.remove('b')\n"
2021-12-13 22:01:42 +08:00
"a = dict.get('a')\n"
2021-12-13 22:03:59 +08:00
"b = dict.get('b')\n"
2021-12-13 22:01:42 +08:00
);
/* collect */
2021-12-24 23:34:34 +08:00
int a = obj_getInt(pikaMain, (char*)"a");
int b = obj_getInt(pikaMain, (char*)"b");
2021-12-13 22:01:42 +08:00
/* assert */
EXPECT_EQ(a, 1);
2022-01-11 22:22:53 +08:00
EXPECT_EQ(b, -999999999);
2021-12-13 22:01:42 +08:00
2021-11-17 10:59:13 +08:00
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
2021-12-24 23:10:50 +08:00
}
2022-04-26 10:06:15 +08:00
TEST(pikaMain, list_method) {
2021-12-24 23:34:34 +08:00
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
2021-12-24 23:39:32 +08:00
obj_runDirect(pikaMain, (char*)
2021-12-24 23:34:34 +08:00
"list = PikaStdData.List()\n"
"list.append(7)\n"
"list.append('eee')\n"
"len = list.len()\n"
"a1 = list.get(0)\n"
"a2 = list.get(1)\n"
2022-04-26 10:06:15 +08:00
"\n"
);
/* collect */
/* assert */
/* deinit */
// obj_deinit(globals);
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
}
TEST(pikaMain, list_iter) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
obj_runDirect(pikaMain, (char*)
"list = PikaStdData.List()\n"
2021-12-24 23:34:34 +08:00
"res = iter(list)\n"
"\n"
);
/* collect */
2021-12-24 23:39:32 +08:00
PikaObj* res = (PikaObj*)obj_getPtr(pikaMain, (char*)"res");
PikaObj* list = (PikaObj*)obj_getPtr(pikaMain, (char*)"list");
2021-12-24 23:34:34 +08:00
/* assert */
2021-12-24 23:39:32 +08:00
EXPECT_EQ(res, list);
2021-12-24 23:34:34 +08:00
/* deinit */
// obj_deinit(globals);
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
}
TEST(pikaMain, list_for_loop) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
2021-12-25 00:33:55 +08:00
obj_runDirect(pikaMain, (char*)
"list = PikaStdData.List()\n"
"list.append(7)\n"
"list.append('eee')\n"
"len = list.len()\n"
"for item in list:\n"
" print(item)\n"
2021-12-25 00:33:55 +08:00
" a = item\n"
"\n"
);
/* collect */
2021-12-25 00:33:55 +08:00
char* a = obj_getStr(pikaMain, (char*)"a");
/* assert */
2021-12-25 00:33:55 +08:00
EXPECT_STREQ(a, (char*)"eee");
/* deinit */
// obj_deinit(globals);
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
2021-12-27 21:57:08 +08:00
}
TEST(pikaMain, range) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
obj_runDirect(pikaMain, (char*)
"r = range(10, 0)\n"
2021-12-27 23:17:21 +08:00
"ir = iter(r)\n"
2021-12-27 21:57:08 +08:00
"\n"
);
/* collect */
/* assert */
obj_deinit(pikaMain);
/* mem check */
EXPECT_EQ(pikaMemNow(), 0);
2021-12-28 01:04:10 +08:00
}
TEST(pikaMain, for_in_range) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
obj_runDirect(pikaMain, (char*)
"a = 0\n"
"for i in range(0, 10):\n"
" print(i)\n"
" a = a + i\n"
"\n"
);
/* collect */
int a = obj_getInt(pikaMain, (char*)"a");
/* assert */
EXPECT_EQ(a, 45);
/* deinit */
obj_deinit(pikaMain);
/* mem check */
EXPECT_EQ(pikaMemNow(), 0);
}
2021-12-29 10:06:48 +08:00
TEST(pikaMain, for_for_in_range) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
obj_runDirect(pikaMain, (char*)
"a = 0\n"
"for i in range(0, 10):\n"
" for k in range(0, 3):\n"
" print(k)\n"
" a = a + k\n"
"\n"
);
/* collect */
int a = obj_getInt(pikaMain, (char*)"a");
/* assert */
EXPECT_EQ(a, 30);
/* deinit */
obj_deinit(pikaMain);
/* mem check */
EXPECT_EQ(pikaMemNow(), 0);
}
2021-12-29 22:28:40 +08:00
TEST(pikaMain, for_if_break) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
obj_runDirect(pikaMain, (char*)
"a = 0\n"
"for i in range(0, 10):\n"
2021-12-29 22:51:26 +08:00
" if i == 5:\n"
2021-12-29 22:28:40 +08:00
" break\n"
2021-12-29 22:51:26 +08:00
" a = a + i\n"
"\n"
);
/* collect */
int a = obj_getInt(pikaMain, (char*)"a");
/* assert */
EXPECT_EQ(a, 10);
/* deinit */
obj_deinit(pikaMain);
/* mem check */
EXPECT_EQ(pikaMemNow(), 0);
}
TEST(pikaMain, for_if_continue) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
2022-01-04 00:29:11 +08:00
obj_run(pikaMain, (char*)
2021-12-29 22:51:26 +08:00
"a = 0\n"
"for i in range(0, 10):\n"
" if i == 5:\n"
" continue\n"
" a = a + i\n"
2021-12-29 22:28:40 +08:00
"\n"
);
/* collect */
int a = obj_getInt(pikaMain, (char*)"a");
/* assert */
2021-12-29 22:51:26 +08:00
EXPECT_EQ(a, 40);
2021-12-29 22:28:40 +08:00
/* deinit */
obj_deinit(pikaMain);
/* mem check */
EXPECT_EQ(pikaMemNow(), 0);
}
2022-01-03 21:12:05 +08:00
/* the log_buff of printf */
extern char log_buff[LOG_BUFF_MAX][LOG_SIZE];
TEST(pikaMain, print_in_def) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
/* the test is used to fix too many print in def */
/* clear the log_buff */
memset(log_buff, 0, LOG_BUFF_MAX * LOG_SIZE);
obj_runDirect(pikaMain, (char*)
"def test_print():\n"
" print('test')\n"
"test_print()\n"
);
/* collect */
/* assert */
/* should only print once, so the second log (log_buff[1]) shuold be '\0' */
EXPECT_STREQ(log_buff[0], "test\r\n");
EXPECT_STREQ(log_buff[1], "");
2022-01-03 21:12:05 +08:00
/* deinit */
obj_deinit(pikaMain);
/* mem check */
EXPECT_EQ(pikaMemNow(), 0);
}
2022-01-04 11:24:34 +08:00
2022-01-04 11:25:28 +08:00
TEST(pikaMain, prime_100) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
obj_run(pikaMain, (char*)
"num = 0\n"
"i = 2\n"
"for i in range(2 , 100):\n"
" j=2\n"
" is_prime = 1\n"
" for j in range(2 , i):\n"
" if i%j==0 :\n"
" is_prime = 0\n"
" break\n"
" if is_prime:\n"
" num = num + i\n"
"\n");
/* collect */
int num = obj_getInt(pikaMain, (char*)"num");
/* assert */
EXPECT_EQ(num, 1060);
/* deinit */
obj_deinit(pikaMain);
/* mem check */
EXPECT_EQ(pikaMemNow(), 0);
2022-01-06 11:13:43 +08:00
}
/* the log_buff of printf */
extern char log_buff[LOG_BUFF_MAX][LOG_SIZE];
TEST(pikaMain, for_in_dict) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
obj_run(pikaMain, (char*)
"print('__start__')\n"
"dict = PikaStdData.Dict()\n"
"dict.set('a', 1)\n"
"dict.set('b', 2)\n"
"dict.remove('b')\n"
"for item in dict:\n"
" print(item)\n"
"\n"
);
/* collect */
/* assert */
EXPECT_STREQ(log_buff[0], "1\r\n");
EXPECT_STREQ(log_buff[1], "__start__\r\n");
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
2022-01-08 23:40:10 +08:00
}
2022-01-26 08:38:02 +08:00
TEST(pikaMain, str_add) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
obj_run(pikaMain, (char*)
"a = 'a'\n"
"b = 'b'\n"
"c = a + b\n"
"d = 1\n"
"e = 1.2\n"
"g = c + str(d)\n"
"h = c + str(d) + str(e)\n"
"\n"
);
/* collect */
char* c = obj_getStr(pikaMain, (char*)"c");
char* g = obj_getStr(pikaMain, (char*)"g");
char* h = obj_getStr(pikaMain, (char*)"h");
/* assert */
EXPECT_STREQ(c, (char*)"ab");
EXPECT_STREQ(g, (char*)"ab1");
EXPECT_STREQ(h, (char*)"ab11.200000");
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
}
2022-01-08 23:40:10 +08:00
TEST(pikaMain, str_add_print) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
obj_run(pikaMain, (char*)
2022-01-09 00:16:01 +08:00
"print('test: ' + str(2233))\n"
2022-01-08 23:40:10 +08:00
"\n"
);
/* collect */
/* assert */
EXPECT_STREQ(log_buff[0], "test: 2233\r\n");
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
2022-01-09 00:12:38 +08:00
}
TEST(pikaMain, int_float_to_str) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
obj_run(pikaMain, (char*)
"a = str(1)\n"
"b = str(1.2)\n"
"\n"
);
/* collect */
char* a = obj_getStr(pikaMain, (char*)"a");
char* b = obj_getStr(pikaMain, (char*)"b");
/* assert */
EXPECT_STREQ(a, "1");
EXPECT_STREQ(b, "1.200000");
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
2022-01-09 22:17:17 +08:00
}
TEST(pikaMain, str_eq) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
obj_run(pikaMain, (char*)
"a = '1ee'\n"
"b = '1ee'\n"
"c = '1e'\n"
"if a==b:\n"
" res1 = 1\n"
"else:\n"
" res1 = 0\n"
"if a==c:\n"
" res2 = 1\n"
"else:\n"
" res2 = 0\n"
"\n"
);
/* collect */
int res1 = obj_getInt(pikaMain, (char*)"res1");
int res2 = obj_getInt(pikaMain, (char*)"res2");
/* assert */
EXPECT_EQ(res1, 1);
EXPECT_EQ(res2, 0);
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
2022-01-10 21:49:52 +08:00
}
TEST(pikaMain, print_with_enter) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
__platform_printf((char*)"BEGIN\n");
obj_run(pikaMain, (char*)"print('test\\n')\n");
/* collect */
/* assert */
EXPECT_STREQ(log_buff[0], (char*)"test\n\r\n");
EXPECT_STREQ(log_buff[1], (char*)"BEGIN\n");
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
2022-01-11 12:21:53 +08:00
}
TEST(pikaMain, print_with_2enter) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
__platform_printf((char*)"BEGIN\n");
obj_run(pikaMain, (char*)"print('test\\r\\n\\n')\n");
/* collect */
/* assert */
EXPECT_STREQ(log_buff[0], (char*)"test\r\n\n\r\n");
EXPECT_STREQ(log_buff[1], (char*)"BEGIN\n");
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
2022-01-12 22:38:35 +08:00
}
TEST(pikaMain, print_ddd) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
__platform_printf((char*)"BEGIN\n");
2022-01-12 22:41:55 +08:00
obj_run(pikaMain, (char*)"print(\"[Info]: in Python config ...\")\n");
2022-01-12 22:38:35 +08:00
/* collect */
/* assert */
2022-01-12 22:41:55 +08:00
EXPECT_STREQ(log_buff[0], (char*)"[Info]: in Python config ...\r\n");
2022-01-12 22:38:35 +08:00
EXPECT_STREQ(log_buff[1], (char*)"BEGIN\n");
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
}
2022-01-13 17:07:07 +08:00
TEST(pikaMain, for_in_string) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
__platform_printf((char*)"BEGIN\n");
obj_run(pikaMain, (char*)
2022-04-04 13:52:00 +08:00
"s = PikaStdData.String('test')\n"
2022-01-13 17:07:07 +08:00
"for c in s:\n"
" print(c)\n"
"\n"
);
/* collect */
/* assert */
EXPECT_STREQ(log_buff[4], (char*)"BEGIN\n");
EXPECT_STREQ(log_buff[3], (char*)"t\r\n");
EXPECT_STREQ(log_buff[2], (char*)"e\r\n");
EXPECT_STREQ(log_buff[1], (char*)"s\r\n");
EXPECT_STREQ(log_buff[0], (char*)"t\r\n");
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
2022-01-13 19:39:05 +08:00
}
2022-04-04 23:59:33 +08:00
TEST(pikaMain, string_no_init_arg) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
__platform_printf((char*)"BEGIN\r\n");
obj_run(pikaMain, (char*)"s = PikaStdData.String()\n");
/* collect */
/* assert */
EXPECT_STREQ(log_buff[3], (char*)"BEGIN\r\n");
EXPECT_STREQ(log_buff[2], (char*)"TypeError: __init__() takes 1 positional argument but 0 were given\r\n");
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
}
2022-02-13 09:27:02 +08:00
// TEST(pikaMain, obj_no_free) {
// /* init */
// pikaMemInfo.heapUsedMax = 0;
// PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
// /* run */
// __platform_printf((char*)"BEGIN\n");
// obj_run(pikaMain, (char*)
// "s = PikaStdData.String()\n"
// "s.set('test')\n"
// "s = PikaStdData.String()\n"
// "s.set('test')\n"
// "\n"
// );
// /* collect */
// /* assert */
// /* deinit */
// obj_deinit(pikaMain);
// EXPECT_EQ(pikaMemNow(), 0);
// }
TEST(pikaMain, list__set__) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
__platform_printf((char*)"BEGIN\n");
obj_run(pikaMain, (char*)
"list = PikaStdData.List()\n"
2022-03-29 18:02:55 +08:00
"__set__(list, 0, 2, 'list')\n"
"res = __get__(list, 0)\n"
"\n"
);
/* collect */
int res = obj_getInt(pikaMain, (char*)"res");
/* assert */
EXPECT_EQ(res, 2);
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
}
TEST(pikaMain, string__get__) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
__platform_printf((char*)"BEGIN\n");
obj_run(pikaMain, (char*)
2022-04-04 13:52:00 +08:00
"s = PikaStdData.String('test')\n"
"res = __get__(s, 2)\n"
"\n"
);
/* collect */
char* res = obj_getStr(pikaMain, (char*)"res");
/* assert */
EXPECT_STREQ(res, "s");
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
}
TEST(pikaMain, dict__set__get) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
__platform_printf((char*)"BEGIN\n");
obj_run(pikaMain, (char*)
"list = PikaStdData.Dict()\n"
2022-03-29 18:02:55 +08:00
"__set__(list, 'a', 2, 'list')\n"
"res = __get__(list, 'a')\n"
"\n"
);
/* collect */
int res = obj_getInt(pikaMain, (char*)"res");
/* assert */
EXPECT_EQ(res, 2);
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
2022-01-18 21:55:08 +08:00
}
2022-01-18 23:37:48 +08:00
TEST(pikaMain, str___get____set__) {
2022-01-18 21:55:08 +08:00
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
__platform_printf((char*)"BEGIN\n");
obj_run(pikaMain, (char*)
"s = 'test'\n"
"res = __get__(s, 2)\n"
2022-01-18 23:37:48 +08:00
"__set__(s, 2, 'q', 's')\n"
2022-01-18 21:55:08 +08:00
"\n"
);
/* collect */
char* res = obj_getStr(pikaMain, (char*)"res");
char* s = obj_getStr(pikaMain, (char*)"s");
2022-01-18 21:55:08 +08:00
/* assert */
EXPECT_STREQ(res, (char*)"s");
2022-01-18 23:37:48 +08:00
EXPECT_STREQ(s, (char*)"teqt");
2022-01-18 21:55:08 +08:00
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
2022-01-18 22:05:34 +08:00
}
TEST(pikaMain, str__index__) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
__platform_printf((char*)"BEGIN\n");
obj_run(pikaMain, (char*)
"s = 'test'\n"
"res = s[2]\n"
2022-01-18 23:37:48 +08:00
"res2 = 'eqrt'[2]\n"
"s[2] = 'q'\n"
2022-01-18 22:05:34 +08:00
"\n"
);
/* collect */
char* res = obj_getStr(pikaMain, (char*)"res");
2022-01-18 23:37:48 +08:00
char* res2 = obj_getStr(pikaMain, (char*)"res2");
char* s = obj_getStr(pikaMain, (char*)"s");
2022-01-18 22:05:34 +08:00
/* assert */
EXPECT_STREQ(res, (char*)"s");
2022-01-18 23:37:48 +08:00
EXPECT_STREQ(res2, (char*)"r");
EXPECT_STREQ(s, (char*)"teqt");
2022-01-18 22:05:34 +08:00
// EXPECT_STREQ(s, (char*)"teqt");
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
2022-01-18 23:51:02 +08:00
}
TEST(pikaMain, list_index) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
__platform_printf((char*)"BEGIN\n");
obj_run(pikaMain, (char*)
"list = PikaStdData.List()\n"
"list[0] = 2\n"
"res = list[0]\n"
"\n"
);
/* collect */
int res = obj_getInt(pikaMain, (char*)"res");
/* assert */
EXPECT_EQ(res, 2);
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
}
TEST(pikaMain, dict_index) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
__platform_printf((char*)"BEGIN\n");
obj_run(pikaMain, (char*)
"dict = PikaStdData.Dict()\n"
"dict['a'] = 2\n"
"res = dict['a']\n"
"\n"
);
/* collect */
int res = obj_getInt(pikaMain, (char*)"res");
/* assert */
EXPECT_EQ(res, 2);
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
}
2022-03-15 18:26:33 +08:00
TEST(pikaMain, task_run_once) {
/* init */
pikaMemInfo.heapUsedMax = 0;
/* run */
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
obj_run(pikaMain,(char*)
"def todo1():\n"
" print('task 1 running...')\n"
"def todo2():\n"
" print('task 2 running...')\n"
"task = GTestTask.Task()\n"
"task.call_always(todo1)\n"
"task.call_always(todo2)\n"
"task.run_once()\n"
"\n");
/* collect */
/* assert */
EXPECT_STREQ(log_buff[0], (char*)"task 2 running...\r\n");
EXPECT_STREQ(log_buff[1], (char*)"task 1 running...\r\n");
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
}
2022-01-22 23:49:53 +08:00
2022-03-15 18:26:33 +08:00
TEST(pikaMain, task_run_when) {
/* init */
pikaMemInfo.heapUsedMax = 0;
/* run */
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
obj_run(pikaMain,(char*)
"def todo1():\n"
" print('task 1 running...')\n"
"def todo2():\n"
" print('task 2 running...')\n"
"def todo3():\n"
" print('task 3 running...')\n"
"def when3():\n"
" return True\n"
"task = GTestTask.Task()\n"
"task.call_always(todo1)\n"
"task.call_always(todo2)\n"
"task.call_when(todo3, when3)\n"
"task.run_once()\n"
"\n");
/* collect */
/* assert */
EXPECT_STREQ(log_buff[0], (char*)"task 3 running...\r\n");
EXPECT_STREQ(log_buff[1], (char*)"task 2 running...\r\n");
EXPECT_STREQ(log_buff[2], (char*)"task 1 running...\r\n");
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
}
2022-01-24 19:34:43 +08:00
2022-03-15 18:26:33 +08:00
TEST(pikaMain, task_run_period_until) {
/* init */
pikaMemInfo.heapUsedMax = 0;
/* run */
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
__platform_printf((char*)"BEGIN\r\n");
obj_run(pikaMain,(char*)
"def todo1():\n"
" print('task 1 running...')\n"
"def todo2():\n"
" print('task 2 running...')\n"
"def todo3():\n"
" print('task 3 running...')\n"
"def when3():\n"
" return True\n"
"task = GTestTask.Task()\n"
"task.call_period_ms(todo1, 200)\n"
"task.call_period_ms(todo2, 500)\n"
"# task.call_when(todo3, when3)\n"
"task.run_until_ms(1000)\n"
"\n");
/* collect */
/* assert */
EXPECT_STREQ(log_buff[0], (char*)"task 1 running...\r\n");
EXPECT_STREQ(log_buff[1], (char*)"task 1 running...\r\n");
EXPECT_STREQ(log_buff[2], (char*)"task 2 running...\r\n");
EXPECT_STREQ(log_buff[3], (char*)"task 1 running...\r\n");
EXPECT_STREQ(log_buff[4], (char*)"task 1 running...\r\n");
EXPECT_STREQ(log_buff[5], (char*)"task 2 running...\r\n");
EXPECT_STREQ(log_buff[6], (char*)"task 1 running...\r\n");
EXPECT_STREQ(log_buff[7], (char*)"BEGIN\r\n");
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
}
2022-01-25 23:31:21 +08:00
TEST(pikaMain, fun_call) {
/* init */
pikaMemInfo.heapUsedMax = 0;
/* run */
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
__platform_printf((char*)"BEGIN\r\n");
obj_run(pikaMain,(char*)
"def fun(a,b,c,d,e):\n"
" print(a)\n"
" print(b)\n"
" print(c)\n"
" print(d)\n"
" print(e)\n"
"fun(10,20,30,40, 'xxx')\n"
"\n");
2022-01-26 23:23:08 +08:00
/* assert */
2022-01-25 23:31:21 +08:00
EXPECT_STREQ(log_buff[0], (char*)"xxx\r\n");
EXPECT_STREQ(log_buff[1], (char*)"40\r\n");
EXPECT_STREQ(log_buff[2], (char*)"30\r\n");
EXPECT_STREQ(log_buff[3], (char*)"20\r\n");
EXPECT_STREQ(log_buff[4], (char*)"10\r\n");
EXPECT_STREQ(log_buff[5], (char*)"BEGIN\r\n");
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
}
2022-01-26 23:23:08 +08:00
TEST(pikaMain, global) {
/* init */
pikaMemInfo.heapUsedMax = 0;
/* run */
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
__platform_printf((char*)"BEGIN\r\n");
obj_run(pikaMain,(char*)
"x = 0\n"
"a = 0\n"
"z = 0\n"
"def test_global():\n"
" global x\n"
" global y, z\n"
" x = 1\n"
" a = 1\n"
" z = 1\n"
" print('test global')\n"
"test_global()\n"
"\n"
);
/* assert */
int x = obj_getInt(pikaMain, (char*)"x");
int a = obj_getInt(pikaMain, (char*)"a");
int z = obj_getInt(pikaMain, (char*)"z");
EXPECT_EQ(x, 1);
EXPECT_EQ(a, 0);
EXPECT_EQ(z, 1);
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
2022-02-21 15:13:47 +08:00
}
TEST(pikaMain, complex_str) {
/* init */
pikaMemInfo.heapUsedMax = 0;
/* run */
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
__platform_printf((char*)"BEGIN\r\n");
obj_run(pikaMain, (char*)"print('test,test')\n");
/* assert */
2022-02-21 17:49:54 +08:00
EXPECT_STREQ(log_buff[0], (char*)"test,test\r\n");
EXPECT_STREQ(log_buff[1], (char*)"BEGIN\r\n");
2022-02-21 15:13:47 +08:00
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
}
TEST(pikaMain, synac_err_1) {
/* init */
pikaMemInfo.heapUsedMax = 0;
/* run */
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
__platform_printf((char*)"BEGIN\r\n");
obj_run(pikaMain, (char*)"print('testtest)\n");
/* assert */
EXPECT_STREQ(log_buff[0], (char*)"[error]: Syntax error.\r\n");
EXPECT_STREQ(log_buff[1], (char*)"BEGIN\r\n");
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
}
2022-02-25 18:21:27 +08:00
2022-03-01 20:57:04 +08:00
TEST(pikaMain, class_arg) {
/* init */
pikaMemInfo.heapUsedMax = 0;
/* run */
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
__platform_printf((char*)"BEGIN\r\n");
Args* buffs = New_strBuff();
char * pikaAsm = Parser_multiLineToAsm(buffs, (char*)
"class Test(PikaStdLib.PikaObj):\n"
" x = 1\n"
"\n"
"test = Test()\n"
"print(test.x)\n"
);
printf("%s", pikaAsm);
pikaVM_runAsm(pikaMain, pikaAsm);
/* assert */
EXPECT_STREQ(log_buff[0], (char*)"1\r\n");
EXPECT_STREQ(log_buff[1], (char*)"BEGIN\r\n");
/* deinit */
obj_deinit(pikaMain);
args_deinit(buffs);
EXPECT_EQ(pikaMemNow(), 0);
}
2022-03-29 20:34:48 +08:00
TEST(pikaMain, class_def) {
/* init */
pikaMemInfo.heapUsedMax = 0;
/* run */
PikaObj* self = newRootObj((char*)"pikaMain", New_PikaMain);
__platform_printf((char*)"BEGIN\r\n");
obj_run(self, (char*)
"class Test():\n"
" x = 1\n"
" def hello(self, x):\n"
" return x + 2\n"
"test = Test()\n"
"x = test.hello(test.x)\n"
"print(x)\n"
);
/* assert */
EXPECT_STREQ(log_buff[0], (char*)"3\r\n");
EXPECT_STREQ(log_buff[1], (char*)"BEGIN\r\n");
/* deinit */
obj_deinit(self);
EXPECT_EQ(pikaMemNow(), 0);
}
2022-03-09 14:01:35 +08:00
TEST(pikaMain, class_def_print) {
/* init */
pikaMemInfo.heapUsedMax = 0;
/* run */
PikaObj* self = newRootObj((char*)"pikaMain", New_PikaMain);
__platform_printf((char*)"BEGIN\r\n");
obj_run(self, (char*)
"class Test():\n"
" x = 1\n"
" def hi(self):\n"
" print('hi' + str(self.x))\n"
"test = Test()\n"
"test.hi()\n"
);
/* assert */
EXPECT_STREQ(log_buff[0], (char*)"hi1\r\n");
EXPECT_STREQ(log_buff[1], (char*)"BEGIN\r\n");
/* deinit */
obj_deinit(self);
EXPECT_EQ(pikaMemNow(), 0);
}
2022-03-02 15:37:17 +08:00
TEST(pikaMain, class_demo_1) {
/* init */
pikaMemInfo.heapUsedMax = 0;
/* run */
PikaObj* self = newRootObj((char*)"pikaMain", New_PikaMain);
__platform_printf((char*)"BEGIN\r\n");
obj_run(self, (char*)
"class MyClass:\n"
" i = 12345\n"
" def f(self):\n"
" return 'hello world'\n"
" \n"
"x = MyClass()\n"
" \n"
"print(x.i)\n"
"print(x.f())\n"
);
/* assert */
EXPECT_STREQ(log_buff[0], (char*)"hello world\r\n");
EXPECT_STREQ(log_buff[1], (char*)"12345\r\n");
EXPECT_STREQ(log_buff[2], (char*)"BEGIN\r\n");
/* deinit */
obj_deinit(self);
EXPECT_EQ(pikaMemNow(), 0);
}
2022-03-02 15:43:27 +08:00
2022-04-04 15:16:27 +08:00
TEST(pikaMain, class_demo_2) {
/* init */
pikaMemInfo.heapUsedMax = 0;
/* run */
PikaObj* self = newRootObj((char*)"pikaMain", New_PikaMain);
__platform_printf((char*)"BEGIN\r\n");
obj_run(self, (char*)
"class Complex:\n"
" def __init__(self):\n"
" self.r = 3.0\n"
" self.i = -4.5\n"
"x = Complex()\n"
"print(x.r)\n"
"print(x.i)\n"
);
/* assert */
EXPECT_STREQ(log_buff[0], (char*)"-4.500000\r\n");
EXPECT_STREQ(log_buff[1], (char*)"3.000000\r\n");
EXPECT_STREQ(log_buff[2], (char*)"BEGIN\r\n");
/* deinit */
obj_deinit(self);
EXPECT_EQ(pikaMemNow(), 0);
}
2022-03-02 15:48:27 +08:00
TEST(pikaMain, class_demo_3) {
/* init */
pikaMemInfo.heapUsedMax = 0;
/* run */
PikaObj* self = newRootObj((char*)"pikaMain", New_PikaMain);
__platform_printf((char*)"BEGIN\r\n");
obj_run(self, (char*)
"class people:\n"
" def speak(self):\n"
" print('i am a people')\n"
" \n"
"class student(people):\n"
" def speak(self):\n"
" print('i am a student')\n"
" \n"
"p = people()\n"
"s = student()\n"
"p.speak()\n"
"s.speak()\n"
);
/* assert */
EXPECT_STREQ(log_buff[2], (char*)"BEGIN\r\n");
EXPECT_STREQ(log_buff[1], (char*)"i am a people\r\n");
EXPECT_STREQ(log_buff[0], (char*)"i am a student\r\n");
/* deinit */
obj_deinit(self);
EXPECT_EQ(pikaMemNow(), 0);
}
TEST(pikaMain, class_demo_save_asm) {
/* init */
pikaMemInfo.heapUsedMax = 0;
/* run */
PikaObj* self = newRootObj((char*)"pikaMain", New_PikaMain);
__platform_printf((char*)"BEGIN\r\n");
obj_run(self, (char*)
"class people:\n"
" def speak(self):\n"
" print('i am a people')\n"
" \n"
"class student(people):\n"
" def speak(self):\n"
" print('i am a student')\n"
" \n"
);
obj_run(self, (char*)
"p = people()\n"
"s = student()\n"
"p.speak()\n"
"s.speak()\n"
);
/* assert */
EXPECT_STREQ(log_buff[2], (char*)"BEGIN\r\n");
EXPECT_STREQ(log_buff[1], (char*)"i am a people\r\n");
EXPECT_STREQ(log_buff[0], (char*)"i am a student\r\n");
/* deinit */
obj_deinit(self);
EXPECT_EQ(pikaMemNow(), 0);
}
2022-03-14 12:12:04 +08:00
TEST(pikaMain, for_if_continue_byte_code) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
2022-03-14 21:24:35 +08:00
pikaVM_run(pikaMain, (char*)
2022-03-14 12:12:04 +08:00
"a = 0\n"
"for i in range(0, 10):\n"
" if i == 5:\n"
" continue\n"
" a = a + i\n"
2022-03-14 21:24:35 +08:00
"\n");
2022-03-14 12:12:04 +08:00
/* collect */
int a = obj_getInt(pikaMain, (char*)"a");
/* assert */
EXPECT_EQ(a, 40);
/* deinit */
obj_deinit(pikaMain);
/* mem check */
EXPECT_EQ(pikaMemNow(), 0);
}
2022-03-14 13:43:07 +08:00
2022-03-14 15:56:08 +08:00
TEST(pikaMain, print_in_def_byte_code) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
__platform_printf((char*)"BEGIN\r\n");
2022-03-14 21:24:35 +08:00
pikaVM_run(pikaMain, (char*)
2022-03-14 15:56:08 +08:00
"def test_print():\n"
" print('test')\n"
"test_print()\n"
);
/* collect */
/* assert */
/* should only print once, so the second log (log_buff[1]) shuold be '\0' */
EXPECT_STREQ(log_buff[0], "test\r\n");
EXPECT_STREQ(log_buff[1], "BEGIN\r\n");
/* deinit */
obj_deinit(pikaMain);
/* mem check */
EXPECT_EQ(pikaMemNow(), 0);
}
2022-03-18 15:46:13 +08:00
TEST(pikaMain, class_demo_1_file) {
/* init */
pikaMemInfo.heapUsedMax = 0;
/* run */
PikaObj* self = newRootObj((char*)"pikaMain", New_PikaMain);
__platform_printf((char*)"BEGIN\r\n");
char lines[] =
"class MyClass:\n"
" i = 12345\n"
" def f(self):\n"
" return 'hello world'\n"
" \n"
"x = MyClass()\n"
" \n"
"print(x.i)\n"
"print(x.f())\n";
2022-03-18 18:25:44 +08:00
pikaCompile((char*)"pika_bytecode.bin", (char*)lines);
2022-03-18 16:01:52 +08:00
char bytecodebuff[4096] = {0};
FILE* f = __platform_fopen("pika_bytecode.bin", "r");
2022-03-18 16:17:43 +08:00
printf("size: %ld\n", fread(bytecodebuff, 1, 4096, f));
__platform_printf((char*)"BEGIN\r\n");
2022-03-18 16:01:52 +08:00
pikaVM_runByteCode(self, (uint8_t*)bytecodebuff);
2022-03-18 15:46:13 +08:00
/* assert */
2022-03-18 16:01:52 +08:00
EXPECT_STREQ(log_buff[0], (char*)"hello world\r\n");
EXPECT_STREQ(log_buff[1], (char*)"12345\r\n");
EXPECT_STREQ(log_buff[2], (char*)"BEGIN\r\n");
2022-03-18 15:46:13 +08:00
/* deinit */
obj_deinit(self);
EXPECT_EQ(pikaMemNow(), 0);
}
2022-03-19 09:29:32 +08:00
TEST(pikaMain, get_native_method) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
__platform_printf((char*)"BEGIN\r\n");
/* do some thing */
Args args = {0};
args_setStr(&args, (char*)"val", (char*)"test");
2022-03-19 09:33:40 +08:00
obj_runNativeMethod(pikaMain, (char*)"print", &args);
2022-03-19 09:29:32 +08:00
args_deinit_stack(&args);
/* assert */
EXPECT_STREQ(log_buff[0], (char*)"test\r\n");
EXPECT_STREQ(log_buff[1], (char*)"BEGIN\r\n");
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
}
2022-03-25 19:47:48 +08:00
TEST(pikaMain, hex_list) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
__platform_printf((char*)"BEGIN\r\n");
pikaVM_run(pikaMain, (char*)
"bytes = PikaStdData.List()\n"
"bytes.append(0x0F)\n"
"bytes.append(0xFF)\n"
"sum = 0\n"
"for byte in bytes:\n"
" sum = sum + byte\n"
"\n"
"print(sum)\n"
);
/* collect */
/* assert */
EXPECT_STREQ(log_buff[0], "270\r\n");
EXPECT_STREQ(log_buff[1], "BEGIN\r\n");
/* deinit */
obj_deinit(pikaMain);
/* mem check */
EXPECT_EQ(pikaMemNow(), 0);
}
2022-03-25 21:18:54 +08:00
TEST(pikaMain, bytearray) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
__platform_printf((char*)"BEGIN\r\n");
pikaVM_run(pikaMain, (char*)
"bytes = PikaStdData.ByteArray()\n"
"bytes.fromString('test')\n"
"sum = 0\n"
"for byte in bytes:\n"
" sum = sum + byte\n"
"\n"
"print(sum)\n"
);
/* collect */
/* assert */
EXPECT_STREQ(log_buff[0], "448\r\n");
EXPECT_STREQ(log_buff[1], "BEGIN\r\n");
/* deinit */
obj_deinit(pikaMain);
/* mem check */
EXPECT_EQ(pikaMemNow(), 0);
}
2022-03-28 22:45:29 +08:00
TEST(pikaMain, not_4_space) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
__platform_printf((char*)"BEGIN\r\n");
2022-03-31 15:29:23 +08:00
pikaVM_run(pikaMain, (char*)" print('test')\n");
2022-03-28 22:45:29 +08:00
/* collect */
/* assert */
EXPECT_STREQ(log_buff[0], "[error]: Syntax error.\r\n");
2022-04-11 17:53:17 +08:00
EXPECT_STREQ(
log_buff[1],
"IndentationError: unexpected indent, only support 4 spaces\r\n");
2022-04-09 09:04:38 +08:00
EXPECT_STREQ(log_buff[2], "BEGIN\r\n");
2022-03-28 22:45:29 +08:00
/* deinit */
obj_deinit(pikaMain);
/* mem check */
EXPECT_EQ(pikaMemNow(), 0);
}
2022-03-31 15:29:23 +08:00
TEST(pikaMain, self_operator) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
__platform_printf((char*)"BEGIN\r\n");
pikaVM_run(pikaMain, (char*)
"a = 1\n"
"b = 2\n"
"c = 3\n"
"d = 4\n"
"a += 2\n"
2022-03-31 15:33:43 +08:00
"b -= 1+1-3\n"
2022-03-31 15:29:23 +08:00
"c *= 4\n"
"d /= 2\n"
);
/* collect */
int a = obj_getInt(pikaMain, (char*)"a");
int b = obj_getInt(pikaMain, (char*)"b");
int c = obj_getInt(pikaMain, (char*)"c");
int d = obj_getInt(pikaMain, (char*)"d");
/* assert */
EXPECT_EQ(a, 3);
2022-03-31 15:33:43 +08:00
EXPECT_EQ(b, 3);
2022-03-31 15:29:23 +08:00
EXPECT_EQ(c, 12);
EXPECT_EQ(d, 2);
/* deinit */
obj_deinit(pikaMain);
/* mem check */
EXPECT_EQ(pikaMemNow(), 0);
}
2022-04-04 15:16:27 +08:00
TEST(pikaMain, class_demo_2_initwitharg) {
/* init */
pikaMemInfo.heapUsedMax = 0;
/* run */
PikaObj* self = newRootObj((char*)"pikaMain", New_PikaMain);
__platform_printf((char*)"BEGIN\r\n");
obj_run(self, (char*)
"class Complex:\n"
" def __init__(self, r, i):\n"
" self.r = r\n"
" self.i = i\n"
"x = Complex(3.0, -4.5)\n"
"print(x.r)\n"
"print(x.i)\n"
);
/* assert */
EXPECT_STREQ(log_buff[0], (char*)"-4.500000\r\n");
EXPECT_STREQ(log_buff[1], (char*)"3.000000\r\n");
EXPECT_STREQ(log_buff[2], (char*)"BEGIN\r\n");
/* deinit */
obj_deinit(self);
EXPECT_EQ(pikaMemNow(), 0);
}
2022-04-04 23:59:33 +08:00
TEST(pikaMain, def_args_err) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
obj_run(pikaMain, (char*)"print()\n");
/* collect */
/* assert */
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
}
2022-04-05 13:12:04 +08:00
TEST(pikaMain, class_args_err) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
obj_run(pikaMain, (char*)"mem = PikaStdLib.MemChecker(0)\n");
/* collect */
/* assert */
EXPECT_STREQ(
log_buff[4],
(char*)"TypeError: PikaStdLib.MemChecker() takes no arguments\r\n");
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
}
TEST(pikaMain, int_) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
obj_run(pikaMain, (char*)"a = int('3')\n");
/* collect */
int a = obj_getInt(pikaMain, (char*)"a");
/* assert */
EXPECT_EQ(a, 3);
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
}
TEST(pikaMain, len_) {
/* init */
pikaMemInfo.heapUsedMax = 0;
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* run */
obj_run(pikaMain, (char*)"a = len('331dd')\n");
/* collect */
int a = obj_getInt(pikaMain, (char*)"a");
/* assert */
EXPECT_EQ(a, 5);
2022-04-05 13:12:04 +08:00
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
}
2022-04-11 17:53:17 +08:00
2022-04-11 21:52:39 +08:00
TEST(pikaMain, def_in_shell) {
2022-04-11 17:53:17 +08:00
/* init */
pikaMemInfo.heapUsedMax = 0;
/* run */
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
2022-04-11 21:52:39 +08:00
/* skip the first obj_run */
obj_run(pikaMain, (char*)"'BEGIN'");
/* as run in shell */
2022-04-11 17:53:17 +08:00
obj_run(pikaMain,(char*)
"def test():\n"
2022-04-11 21:52:39 +08:00
" print('test')\n"
"\n"
);
obj_run(pikaMain,(char*)
"def test2():\n"
" print('test2')\n"
"\n"
2022-04-11 17:53:17 +08:00
);
2022-04-11 21:52:39 +08:00
obj_run(pikaMain, (char*)"test()\n");
obj_run(pikaMain, (char*)"test2()\n");
2022-04-11 17:53:17 +08:00
/* collect */
/* assert */
2022-04-11 21:52:39 +08:00
EXPECT_STREQ((char*)"test2\r\n", log_buff[0]);
EXPECT_STREQ((char*)"test\r\n", log_buff[1]);
EXPECT_STREQ((char*)"BEGIN\r\n", log_buff[2]);
2022-04-11 17:53:17 +08:00
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
}
2022-04-11 22:27:18 +08:00
TEST(pikaMain, def_in_shell_override) {
/* init */
pikaMemInfo.heapUsedMax = 0;
/* run */
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* skip the first obj_run */
obj_run(pikaMain, (char*)"'BEGIN'");
/* as run in shell */
obj_run(pikaMain,(char*)
"def test():\n"
" print('test')\n"
"\n"
);
obj_run(pikaMain, (char*)"test()\n");
obj_run(pikaMain,(char*)
"def test():\n"
" print('test2')\n"
"\n"
);
obj_run(pikaMain, (char*)"test()\n");
/* collect */
/* assert */
EXPECT_STREQ((char*)"test2\r\n", log_buff[0]);
EXPECT_STREQ((char*)"test\r\n", log_buff[1]);
EXPECT_STREQ((char*)"BEGIN\r\n", log_buff[2]);
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
}
2022-04-11 22:31:36 +08:00
TEST(pikaMain, class_in_shell) {
/* init */
pikaMemInfo.heapUsedMax = 0;
/* run */
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* skip the first obj_run */
obj_run(pikaMain, (char*)"'BEGIN'");
/* as run in shell */
obj_run(pikaMain,(char*)
"class Test():\n"
" def hi(self):\n"
" print('hi')\n"
"\n"
);
obj_run(pikaMain, (char*)
"t = Test()\n"
"t.hi()\n"
);
/* collect */
/* assert */
EXPECT_STREQ((char*)"hi\r\n", log_buff[0]);
EXPECT_STREQ((char*)"BEGIN\r\n", log_buff[1]);
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
}
TEST(pikaMain, class_TinyObj) {
/* init */
pikaMemInfo.heapUsedMax = 0;
/* run */
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* skip the first obj_run */
obj_run(pikaMain, (char*)"'BEGIN'");
/* as run in shell */
obj_run(pikaMain,(char*)
"class MyClass( TinyObj ):\n"
" def __init__(self):\n"
" self.val = 123\n"
"\n"
);
obj_run(pikaMain, (char*)
"x = MyClass()\n"
"x.val\n"
);
/* collect */
/* assert */
EXPECT_STREQ((char*)"123\r\n", log_buff[0]);
EXPECT_STREQ((char*)"BEGIN\r\n", log_buff[1]);
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
}
2022-04-13 12:03:10 +08:00
TEST(pikaMain, list_sysobj) {
/* init */
pikaMemInfo.heapUsedMax = 0;
/* run */
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
/* skip the first obj_run */
obj_run(pikaMain, (char*)
"a = list()\n"
"a.len()\n"
);
/* as run in shell */
/* collect */
/* assert */
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
}
2022-04-13 20:19:52 +08:00
#if PIKA_BUILTIN_LIST_ENABLE
2022-04-13 20:19:52 +08:00
TEST(pikaMain, list_init) {
/* init */
pikaMemInfo.heapUsedMax = 0;
/* run */
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
2022-04-14 13:10:34 +08:00
__platform_printf((char*)"BEGIN\r\n");
2022-04-13 20:19:52 +08:00
obj_run(pikaMain, (char*)
"a = [1, 2, 3]\n"
"a.len()\n"
);
/* as run in shell */
/* collect */
/* assert */
2022-04-14 13:10:34 +08:00
EXPECT_STREQ((char*)"3\r\n", log_buff[0]);
EXPECT_STREQ((char*)"BEGIN\r\n", log_buff[1]);
2022-04-13 20:19:52 +08:00
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
}
2022-04-14 15:58:24 +08:00
#endif
2022-04-20 14:51:38 +08:00
TEST(pikaMain, ctypes) {
/* init */
pikaMemInfo.heapUsedMax = 0;
/* run */
PikaObj* pikaMain = newRootObj((char*)"pikaMain", New_PikaMain);
2022-04-20 14:55:26 +08:00
char* lines = (char*)
2022-04-20 14:51:38 +08:00
"t = ctypes.Test()\n"
"sendbuf = b'\\x03\\x04\\x33\\x00\\x05'\n"
"rlen = ctypes.c_uint(0)\n"
"rcvbuf = ctypes.c_char_p('')\n"
"res = t.dc_cpuapdu_hex(5, sendbuf, rlen, rcvbuf)\n"
2022-04-20 14:55:26 +08:00
"t.print_rcv(rcvbuf)\n";
__platform_printf((char*)"%s\n", lines);
__platform_printf((char*)"BEGIN\r\n");
obj_run(pikaMain, lines);
2022-04-20 14:51:38 +08:00
/* as run in shell */
/* collect */
Arg* sendbuf = obj_getArg(pikaMain, (char*)"sendbuf");
Arg* rcvbuf = obj_getArg(pikaMain, (char*)"rcvbuf.value");
/* assert */
EXPECT_EQ(arg_getBytesSize(sendbuf), 5);
EXPECT_EQ(arg_getBytesSize(rcvbuf), 6);
/* deinit */
obj_deinit(pikaMain);
EXPECT_EQ(pikaMemNow(), 0);
}