/** * server/test/lua/to_enum.cpp * * This file is part of the traintastic test suite. * * Copyright (C) 2021-2022 Reinder Feenstra * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License * as published by the Free Software Foundation; either version 2 * of the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ #include #include "../../src/lua/enums.hpp" #include "../../src/lua/to.hpp" #include #include #define REQUIRE_TRY_TO_FAIL() \ { \ TestType v = EnumValues::value.begin()->first; \ REQUIRE_FALSE(Lua::to(L, -1, v)); \ REQUIRE(v == EnumValues::value.begin()->first); \ v = EnumValues::value.rbegin()->first; \ REQUIRE_FALSE(Lua::to(L, -1, v)); \ REQUIRE(v == EnumValues::value.rbegin()->first); \ } template struct other_enum_type { using type = WorldEvent; }; template<> struct other_enum_type { using type = DecoderProtocol; }; TEMPLATE_TEST_CASE("Lua::to<>", "[lua][lua-to]", LUA_ENUMS) { using OtherEnumType = typename other_enum_type::type; const TestType firstValue = EnumValues::value.begin()->first; const TestType lastValue = EnumValues::value.rbegin()->first; lua_State* L = luaL_newstate(); INFO("nil"); lua_pushnil(L); REQUIRE(Lua::to(L, -1) == firstValue); REQUIRE_TRY_TO_FAIL(); lua_pop(L, 1); INFO("false"); lua_pushboolean(L, false); REQUIRE(Lua::to(L, -1) == firstValue); REQUIRE_TRY_TO_FAIL(); lua_pop(L, 1); INFO("true"); lua_pushboolean(L, true); REQUIRE(Lua::to(L, -1) == firstValue); REQUIRE_TRY_TO_FAIL(); lua_pop(L, 1); INFO("enum"); Lua::Enum::registerType(L); Lua::Enum::push(L, lastValue); REQUIRE(Lua::to(L, -1) == lastValue); { TestType v = firstValue; REQUIRE(Lua::to(L, -1, v)); REQUIRE(v == lastValue); } lua_pop(L, 1); INFO("other enum"); Lua::Enum::registerType(L); Lua::Enum::push(L, EnumValues::value.rbegin()->first); REQUIRE(Lua::to(L, -1) == firstValue); REQUIRE_TRY_TO_FAIL(); lua_pop(L, 1); INFO("123"); lua_pushinteger(L, 123); REQUIRE(Lua::to(L, -1) == firstValue); REQUIRE_TRY_TO_FAIL(); lua_pop(L, 1); INFO("0.5"); lua_pushnumber(L, 0.5); REQUIRE(Lua::to(L, -1) == firstValue); REQUIRE_TRY_TO_FAIL(); lua_pop(L, 1); INFO("\"test\""); lua_pushliteral(L, "test"); REQUIRE(Lua::to(L, -1) == firstValue); REQUIRE_TRY_TO_FAIL(); lua_pop(L, 1); INFO("table"); lua_newtable(L); REQUIRE(Lua::to(L, -1) == firstValue); REQUIRE_TRY_TO_FAIL(); lua_pop(L, 1); INFO("userdata"); lua_newuserdata(L, 0); REQUIRE(Lua::to(L, -1) == firstValue); REQUIRE_TRY_TO_FAIL(); lua_pop(L, 1); INFO("lightuserdata"); lua_pushlightuserdata(L, nullptr); REQUIRE(Lua::to(L, -1) == firstValue); REQUIRE_TRY_TO_FAIL(); lua_pop(L, 1); lua_close(L); }