|
|
@ -51,6 +51,9 @@ return {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
)X");
|
|
|
|
)X");
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
TestingOpenMW::VFSTestFile metaIndexErrorFile(
|
|
|
|
|
|
|
|
"return setmetatable({}, { __index = function(t, key) error('meta index error') end })");
|
|
|
|
|
|
|
|
|
|
|
|
std::string genBigScript()
|
|
|
|
std::string genBigScript()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
std::stringstream buf;
|
|
|
|
std::stringstream buf;
|
|
|
@ -70,7 +73,7 @@ return {
|
|
|
|
{
|
|
|
|
{
|
|
|
|
std::unique_ptr<VFS::Manager> mVFS = TestingOpenMW::createTestVFS({ { "aaa/counter.lua", &counterFile },
|
|
|
|
std::unique_ptr<VFS::Manager> mVFS = TestingOpenMW::createTestVFS({ { "aaa/counter.lua", &counterFile },
|
|
|
|
{ "bbb/tests.lua", &testsFile }, { "invalid.lua", &invalidScriptFile }, { "big.lua", &bigScriptFile },
|
|
|
|
{ "bbb/tests.lua", &testsFile }, { "invalid.lua", &invalidScriptFile }, { "big.lua", &bigScriptFile },
|
|
|
|
{ "requireBig.lua", &requireBigScriptFile } });
|
|
|
|
{ "requireBig.lua", &requireBigScriptFile }, { "metaIndexError.lua", &metaIndexErrorFile } });
|
|
|
|
|
|
|
|
|
|
|
|
LuaUtil::ScriptsConfiguration mCfg;
|
|
|
|
LuaUtil::ScriptsConfiguration mCfg;
|
|
|
|
LuaUtil::LuaState mLua{ mVFS.get(), &mCfg };
|
|
|
|
LuaUtil::LuaState mLua{ mVFS.get(), &mCfg };
|
|
|
@ -223,4 +226,11 @@ return {
|
|
|
|
// At this moment all instances of the script should be garbage-collected.
|
|
|
|
// At this moment all instances of the script should be garbage-collected.
|
|
|
|
EXPECT_LT(memWithoutScript, memWithScript);
|
|
|
|
EXPECT_LT(memWithoutScript, memWithScript);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
TEST_F(LuaStateTest, SafeIndexMetamethod)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
sol::table t = mLua.runInNewSandbox("metaIndexError.lua");
|
|
|
|
|
|
|
|
// without safe get we crash here
|
|
|
|
|
|
|
|
EXPECT_ERROR(LuaUtil::safeGet(t, "any key"), "meta index error");
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|