之所以使用lua进行单元测试,而不用cunit,我觉得主要是考虑一下几点:
1)lua测试命令行,优势明显
2)cunit对函数进行单元测试的功能,用lua也可以做到。而且参数可以通过lua传递,更加灵活,修改测试用例不需要重新编译。
以前用cunit写的时候,修改一下就要重新编译,而且还要继续内存的管理。测试用例写多了有点厌烦。
下面主要看看Lua调用c函数进行单元测试:
这是lua代码,
local iptable = {} --组织输入参数 for num = 1,5 do local newip = {["ip"]="192.168.1."..num, ["up"]=0, ["down"]=0} iptable[num] = newip print(iptable[num].ip, iptable[num].up, iptable[num].down) end --调用被测试的c函数 qostest.qos_add_e(iptable) --检测返回结果是否是预期结果,这里只是简单的打印了一下,没有用assert for num = 1,5 do print(iptable[num].ip, iptable[num].up, iptable[num].down) end下面是对应的c函数的实现:
其中最容易出错的地方就是对于当前栈的层次,要时刻记住每一个lua_* 相关的操作后,栈会变成什么样子。
建议全部使用正数代表index,混合使用正数和负数比较容易出错。
static int qos_add_e (lua_State *L) { __u32 *handle,ip; int i = 0, ipnum = 0; ipnum = lua_objlen(L, 1); printf("in libqostst qID = %u pID = %u ipnum = %d\n" , qID, pID, ipnum); const char *ipstr = NULL; for ( i = 1; i <= ipnum; i++ ) { lua_pushnumber(L, i);//push key lua_gettable(L, 1);//get value ,get level 1 table lua_getfield(L, 2, "ip"); ipstr = luaL_checkstring(L, 3); printf("%d=%s\n", i, ipstr); ip = ntohl(inet_addr(ipstr)); //传入ip,返回上下行的handle testfunc(ip, handle) //return handle to lua lua_pushnumber(L, handle[0]); lua_setfield(L, 2, "up"); lua_pop(L, 2); } return 1; }