mirror of
https://gitee.com/Lyon1998/pikapython.git
synced 2025-01-22 17:12:55 +08:00
7f5edaf090
ready to check where enable the mark_sweep auto gc with threshold failed, add some assert more assert about obj alive, dict mark not correct add pikaGC_try, but cannot run at any time markSweep crashed on keyword save gcRoot for obj to debug add debug point add kernal_debug config to keep more debug info use @res_<opt> to mark operation found self reference on __iter__() can not fix gc err around iter remove lock, only keep the self lock more obj info for debug only pikaui not pass only pikaui not pass
160 lines
4.3 KiB
C
160 lines
4.3 KiB
C
#include "test_common.h"
|
||
TEST_START
|
||
|
||
#if PIKA_SYNTAX_SLICE_ENABLE
|
||
TEST(builtin, bytes) {
|
||
/* init */
|
||
g_PikaMemInfo.heapUsedMax = 0;
|
||
PikaObj* pikaMain = newRootObj("pikaMain", New_PikaMain);
|
||
/* run */
|
||
__platform_printf("BEGIN\r\n");
|
||
pikaVM_runSingleFile(pikaMain, "../../examples/BuiltIn/bytes.py");
|
||
/* collect */
|
||
uint8_t* res = obj_getBytes(pikaMain, "res");
|
||
/* assert */
|
||
EXPECT_EQ(res[1], 1);
|
||
/* deinit */
|
||
obj_deinit(pikaMain);
|
||
EXPECT_EQ(pikaMemNow(), 0);
|
||
}
|
||
#endif
|
||
|
||
#if PIKA_BUILTIN_STRUCT_ENABLE
|
||
TEST(builtin, type1) {
|
||
/* init */
|
||
g_PikaMemInfo.heapUsedMax = 0;
|
||
PikaObj* pikaMain = newRootObj("pikaMain", New_PikaMain);
|
||
/* run */
|
||
__platform_printf("BEGIN\r\n");
|
||
pikaVM_runSingleFile(pikaMain, "../../examples/BuiltIn/type.py");
|
||
/* collect */
|
||
/* assert */
|
||
EXPECT_STREQ(log_buff[1], "BEGIN\r\n");
|
||
EXPECT_STREQ(log_buff[0], "OK\r\n");
|
||
/* deinit */
|
||
obj_deinit(pikaMain);
|
||
EXPECT_EQ(pikaMemNow(), 0);
|
||
}
|
||
#endif
|
||
|
||
#if PIKA_SYNTAX_LEVEL == PIKA_SYNTAX_LEVEL_MAXIMAL
|
||
TEST(builtin, seek) {
|
||
/* init */
|
||
g_PikaMemInfo.heapUsedMax = 0;
|
||
PikaObj* pikaMain = newRootObj("pikaMain", New_PikaMain);
|
||
/* run */
|
||
__platform_printf("BEGIN\r\n");
|
||
pikaVM_runSingleFile(pikaMain, "../../examples/BuiltIn/seek.py");
|
||
/* collect */
|
||
int len = obj_getInt(pikaMain, "len");
|
||
/* assert */
|
||
EXPECT_EQ(len, 3576);
|
||
/* deinit */
|
||
obj_deinit(pikaMain);
|
||
EXPECT_EQ(pikaMemNow(), 0);
|
||
}
|
||
#endif
|
||
|
||
#if (PIKA_SYNTAX_LEVEL == PIKA_SYNTAX_LEVEL_MAXIMAL)
|
||
TEST(builtin, file2) {
|
||
/* init */
|
||
g_PikaMemInfo.heapUsedMax = 0;
|
||
PikaObj* pikaMain = newRootObj("pikaMain", New_PikaMain);
|
||
/* run */
|
||
__platform_printf("BEGIN\r\n");
|
||
pikaVM_runSingleFile(pikaMain, "../../examples/BuiltIn/file2.py");
|
||
/* collect */
|
||
char* s = obj_getStr(pikaMain, "s");
|
||
/* assert */
|
||
EXPECT_STREQ(s, "import PikaStdLib\n");
|
||
/* deinit */
|
||
obj_deinit(pikaMain);
|
||
EXPECT_EQ(pikaMemNow(), 0);
|
||
}
|
||
#endif
|
||
|
||
#if PIKA_SYNTAX_LEVEL == PIKA_SYNTAX_LEVEL_MAXIMAL
|
||
TEST(builtin, file3) {
|
||
/* init */
|
||
g_PikaMemInfo.heapUsedMax = 0;
|
||
PikaObj* pikaMain = newRootObj("pikaMain", New_PikaMain);
|
||
/* run */
|
||
__platform_printf("BEGIN\r\n");
|
||
pikaVM_runSingleFile(pikaMain, "../../examples/BuiltIn/file3.py");
|
||
/* collect */
|
||
/* assert */
|
||
/* deinit */
|
||
obj_deinit(pikaMain);
|
||
EXPECT_EQ(pikaMemNow(), 0);
|
||
}
|
||
#endif
|
||
|
||
#if (PIKA_SYNTAX_LEVEL == PIKA_SYNTAX_LEVEL_MAXIMAL) && !PIKA_POOL_ENABLE
|
||
TEST(builtin, bigfile) {
|
||
/* init */
|
||
g_PikaMemInfo.heapUsedMax = 0;
|
||
PikaObj* pikaMain = newRootObj("pikaMain", New_PikaMain);
|
||
/* run */
|
||
__platform_printf("BEGIN\r\n");
|
||
pikaVM_runSingleFile(pikaMain, "../../examples/BuiltIn/bigfile.py");
|
||
/* collect */
|
||
// uint8_t* b = obj_getBytes(pikaMain, "b");
|
||
/* assert */
|
||
/* deinit */
|
||
obj_deinit(pikaMain);
|
||
EXPECT_EQ(pikaMemNow(), 0);
|
||
}
|
||
#endif
|
||
|
||
TEST(builtin, nofound) {
|
||
/* init */
|
||
g_PikaMemInfo.heapUsedMax = 0;
|
||
PikaObj* pikaMain = newRootObj("pikaMain", New_PikaMain);
|
||
/* run */
|
||
__platform_printf("BEGIN\r\n");
|
||
pikaVM_runSingleFile(pikaMain, "../../examples/BuiltIn/file_nofound.py");
|
||
/* collect */
|
||
/* assert */
|
||
/* deinit */
|
||
obj_deinit(pikaMain);
|
||
EXPECT_EQ(pikaMemNow(), 0);
|
||
}
|
||
|
||
#if PIKA_SYNTAX_LEVEL == PIKA_SYNTAX_LEVEL_MAXIMAL
|
||
TEST(builtin, callback_1) {
|
||
/* init */
|
||
g_PikaMemInfo.heapUsedMax = 0;
|
||
PikaObj* pikaMain = newRootObj("pikaMain", New_PikaMain);
|
||
/* run */
|
||
__platform_printf("BEGIN\r\n");
|
||
pikaVM_runSingleFile(pikaMain, "test/python/callback/test1.py");
|
||
/* collect */
|
||
/* assert */
|
||
EXPECT_STREQ(log_buff[0], "b\r\n");
|
||
EXPECT_STREQ(log_buff[1], "a\r\n");
|
||
/* deinit */
|
||
obj_deinit(pikaMain);
|
||
EXPECT_EQ(pikaMemNow(), 0);
|
||
}
|
||
#endif
|
||
|
||
#if !PIKA_NANO_ENABLE
|
||
TEST(builtin, utf8) {
|
||
/* init */
|
||
g_PikaMemInfo.heapUsedMax = 0;
|
||
PikaObj* pikaMain = newRootObj("pikaMain", New_PikaMain);
|
||
/* run */
|
||
__platform_printf("BEGIN\r\n");
|
||
pikaVM_runSingleFile(pikaMain, "../../examples/BuiltIn/utf8.py");
|
||
/* collect */
|
||
/* assert */
|
||
EXPECT_STREQ(log_buff[2], "你好,Hello, Bonjour.\r\n");
|
||
EXPECT_STREQ(log_buff[1], "你好,Hello, Bonjour.\r\n");
|
||
EXPECT_STREQ(log_buff[0], "Hi, Hello, Bonjour.\r\n");
|
||
/* deinit */
|
||
obj_deinit(pikaMain);
|
||
EXPECT_EQ(pikaMemNow(), 0);
|
||
}
|
||
#endif
|
||
|
||
TEST_END |