mirror of
https://github.com/minetest/minetest.git
synced 2025-01-11 15:57:29 +01:00
Add unittests on ActiveObject and BanManager class (#6866)
* Add unittests on ActiveObject and BanManager class This also permit to fix a bug in ban manager setting bans modified when no modification occurs
This commit is contained in:
parent
9f6d84aee3
commit
0d6b58a772
@ -1,6 +1,7 @@
|
||||
/*
|
||||
Minetest
|
||||
Copyright (C) 2013 celeron55, Perttu Ahola <celeron55@gmail.com>
|
||||
Copyright (C) 2018 nerzhul, Loic BLOT <loic.blot@unix-experience.fr>
|
||||
|
||||
This program is free software; you can redistribute it and/or modify
|
||||
it under the terms of the GNU Lesser General Public License as published by
|
||||
@ -125,11 +126,11 @@ void BanManager::remove(const std::string &ip_or_name)
|
||||
for (StringMap::iterator it = m_ips.begin(); it != m_ips.end();) {
|
||||
if ((it->first == ip_or_name) || (it->second == ip_or_name)) {
|
||||
m_ips.erase(it++);
|
||||
m_modified = true;
|
||||
} else {
|
||||
++it;
|
||||
}
|
||||
}
|
||||
m_modified = true;
|
||||
}
|
||||
|
||||
|
||||
|
@ -1,6 +1,8 @@
|
||||
set (UNITTEST_SRCS
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/test.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/test_activeobject.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/test_areastore.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/test_ban.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/test_collision.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/test_compression.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/test_connection.cpp
|
||||
|
60
src/unittest/test_activeobject.cpp
Normal file
60
src/unittest/test_activeobject.cpp
Normal file
@ -0,0 +1,60 @@
|
||||
/*
|
||||
Minetest
|
||||
Copyright (C) 2018 nerzhul, Loic BLOT <loic.blot@unix-experience.fr>
|
||||
|
||||
This program is free software; you can redistribute it and/or modify
|
||||
it under the terms of the GNU Lesser General Public License as published by
|
||||
the Free Software Foundation; either version 2.1 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 Lesser General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU Lesser 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 "test.h"
|
||||
|
||||
#include "activeobject.h"
|
||||
|
||||
class TestActiveObject : public TestBase
|
||||
{
|
||||
public:
|
||||
TestActiveObject() { TestManager::registerTestModule(this); }
|
||||
const char *getName() { return "TestActiveObject"; }
|
||||
|
||||
void runTests(IGameDef *gamedef);
|
||||
|
||||
void testAOAttributes();
|
||||
};
|
||||
|
||||
static TestActiveObject g_test_instance;
|
||||
|
||||
void TestActiveObject::runTests(IGameDef *gamedef)
|
||||
{
|
||||
TEST(testAOAttributes);
|
||||
}
|
||||
|
||||
class TestAO : public ActiveObject
|
||||
{
|
||||
public:
|
||||
TestAO(u16 id) : ActiveObject(id) {}
|
||||
|
||||
virtual ActiveObjectType getType() const { return ACTIVEOBJECT_TYPE_TEST; }
|
||||
virtual bool getCollisionBox(aabb3f *toset) const { return false; }
|
||||
virtual bool getSelectionBox(aabb3f *toset) const { return false; }
|
||||
virtual bool collideWithObjects() const { return false; }
|
||||
};
|
||||
|
||||
void TestActiveObject::testAOAttributes()
|
||||
{
|
||||
TestAO ao(44);
|
||||
UASSERT(ao.getId() == 44);
|
||||
|
||||
ao.setId(558);
|
||||
UASSERT(ao.getId() == 558);
|
||||
}
|
167
src/unittest/test_ban.cpp
Normal file
167
src/unittest/test_ban.cpp
Normal file
@ -0,0 +1,167 @@
|
||||
/*
|
||||
Minetest
|
||||
Copyright (C) 2018 nerzhul, Loic BLOT <loic.blot@unix-experience.fr>
|
||||
|
||||
This program is free software; you can redistribute it and/or modify
|
||||
it under the terms of the GNU Lesser General Public License as published by
|
||||
the Free Software Foundation; either version 2.1 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 Lesser General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU Lesser 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 "test.h"
|
||||
|
||||
#include "ban.h"
|
||||
|
||||
class TestBan : public TestBase
|
||||
{
|
||||
public:
|
||||
TestBan() { TestManager::registerTestModule(this); }
|
||||
const char *getName() { return "TestBan"; }
|
||||
|
||||
void runTests(IGameDef *gamedef);
|
||||
|
||||
private:
|
||||
void testCreate();
|
||||
void testAdd();
|
||||
void testRemove();
|
||||
void testModificationFlag();
|
||||
void testGetBanName();
|
||||
void testGetBanDescription();
|
||||
|
||||
void reinitTestEnv();
|
||||
};
|
||||
|
||||
static TestBan g_test_instance;
|
||||
|
||||
void TestBan::runTests(IGameDef *gamedef)
|
||||
{
|
||||
reinitTestEnv();
|
||||
TEST(testCreate);
|
||||
|
||||
reinitTestEnv();
|
||||
TEST(testAdd);
|
||||
|
||||
reinitTestEnv();
|
||||
TEST(testRemove);
|
||||
|
||||
reinitTestEnv();
|
||||
TEST(testModificationFlag);
|
||||
|
||||
reinitTestEnv();
|
||||
TEST(testGetBanName);
|
||||
|
||||
reinitTestEnv();
|
||||
TEST(testGetBanDescription);
|
||||
}
|
||||
|
||||
// This module is stateful due to disk writes, add helper to remove files
|
||||
void TestBan::reinitTestEnv()
|
||||
{
|
||||
fs::DeleteSingleFileOrEmptyDirectory("testbm.txt");
|
||||
fs::DeleteSingleFileOrEmptyDirectory("testbm2.txt");
|
||||
}
|
||||
|
||||
void TestBan::testCreate()
|
||||
{
|
||||
// test save on object removal
|
||||
{
|
||||
BanManager bm("testbm.txt");
|
||||
}
|
||||
|
||||
UASSERT(std::ifstream("testbm.txt", std::ios::binary).is_open());
|
||||
|
||||
// test manual save
|
||||
{
|
||||
BanManager bm("testbm2.txt");
|
||||
bm.save();
|
||||
UASSERT(std::ifstream("testbm2.txt", std::ios::binary).is_open());
|
||||
}
|
||||
}
|
||||
|
||||
void TestBan::testAdd()
|
||||
{
|
||||
std::string bm_test1_entry = "192.168.0.246";
|
||||
std::string bm_test1_result = "test_username";
|
||||
|
||||
BanManager bm("testbm.txt");
|
||||
bm.add(bm_test1_entry, bm_test1_result);
|
||||
|
||||
UASSERT(bm.getBanName(bm_test1_entry) == bm_test1_result);
|
||||
}
|
||||
|
||||
void TestBan::testRemove()
|
||||
{
|
||||
std::string bm_test1_entry = "192.168.0.249";
|
||||
std::string bm_test1_result = "test_username";
|
||||
|
||||
std::string bm_test2_entry = "192.168.0.250";
|
||||
std::string bm_test2_result = "test_username7";
|
||||
|
||||
BanManager bm("testbm.txt");
|
||||
|
||||
// init data
|
||||
bm.add(bm_test1_entry, bm_test1_result);
|
||||
bm.add(bm_test2_entry, bm_test2_result);
|
||||
|
||||
// the test
|
||||
bm.remove(bm_test1_entry);
|
||||
UASSERT(bm.getBanName(bm_test1_entry).empty());
|
||||
|
||||
bm.remove(bm_test2_result);
|
||||
UASSERT(bm.getBanName(bm_test2_result).empty());
|
||||
}
|
||||
|
||||
void TestBan::testModificationFlag()
|
||||
{
|
||||
BanManager bm("testbm.txt");
|
||||
bm.add("192.168.0.247", "test_username");
|
||||
UASSERT(bm.isModified());
|
||||
|
||||
bm.remove("192.168.0.247");
|
||||
UASSERT(bm.isModified());
|
||||
|
||||
// Clear the modification flag
|
||||
bm.save();
|
||||
|
||||
// Test modification flag is entry was not present
|
||||
bm.remove("test_username");
|
||||
UASSERT(!bm.isModified());
|
||||
}
|
||||
|
||||
void TestBan::testGetBanName()
|
||||
{
|
||||
std::string bm_test1_entry = "192.168.0.247";
|
||||
std::string bm_test1_result = "test_username";
|
||||
|
||||
BanManager bm("testbm.txt");
|
||||
bm.add(bm_test1_entry, bm_test1_result);
|
||||
|
||||
// Test with valid entry
|
||||
UASSERT(bm.getBanName(bm_test1_entry) == bm_test1_result);
|
||||
|
||||
// Test with invalid entry
|
||||
UASSERT(bm.getBanName("---invalid---").empty());
|
||||
}
|
||||
|
||||
void TestBan::testGetBanDescription()
|
||||
{
|
||||
std::string bm_test1_entry = "192.168.0.247";
|
||||
std::string bm_test1_entry2 = "test_username";
|
||||
|
||||
std::string bm_test1_result = "192.168.0.247|test_username";
|
||||
|
||||
BanManager bm("testbm.txt");
|
||||
bm.add(bm_test1_entry, bm_test1_entry2);
|
||||
|
||||
UASSERT(bm.getBanDescription(bm_test1_entry) == bm_test1_result);
|
||||
UASSERT(bm.getBanDescription(bm_test1_entry2) == bm_test1_result);
|
||||
}
|
Loading…
Reference in New Issue
Block a user