summaryrefslogtreecommitdiff
path: root/src/fs/physfs/virtfsphys_unittest.cc
diff options
context:
space:
mode:
Diffstat (limited to 'src/fs/physfs/virtfsphys_unittest.cc')
-rw-r--r--src/fs/physfs/virtfsphys_unittest.cc539
1 files changed, 539 insertions, 0 deletions
diff --git a/src/fs/physfs/virtfsphys_unittest.cc b/src/fs/physfs/virtfsphys_unittest.cc
new file mode 100644
index 000000000..8e81cfe2b
--- /dev/null
+++ b/src/fs/physfs/virtfsphys_unittest.cc
@@ -0,0 +1,539 @@
+/*
+ * The ManaPlus Client
+ * Copyright (C) 2016-2017 The ManaPlus Developers
+ *
+ * This file is part of The ManaPlus Client.
+ *
+ * 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
+ * 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, see <http://www.gnu.org/licenses/>.
+ */
+
+#include "catch.hpp"
+
+#include "fs/paths.h"
+#include "fs/virtfs.h"
+#include "fs/virtfstools.h"
+#include "fs/virtlist.h"
+
+#include "fs/physfs/virtfsphys.h"
+
+#include "utils/checkutils.h"
+#include "utils/delete2.h"
+
+#include "debug.h"
+
+TEST_CASE("VirtFsPhys dirSeparator")
+{
+ VirtFsPhys::initFuncs();
+ REQUIRE(VirtFs::getDirSeparator() != nullptr);
+ REQUIRE(VirtFsPhys::getDirSeparator() ==
+ std::string(VirtFs::getDirSeparator()));
+ VirtFsPhys::updateDirSeparator();
+ REQUIRE(VirtFs::getDirSeparator() != nullptr);
+ REQUIRE(VirtFsPhys::getDirSeparator() ==
+ std::string(VirtFs::getDirSeparator()));
+}
+
+TEST_CASE("VirtFsPhys getBaseDir")
+{
+ VirtFsPhys::initFuncs();
+ REQUIRE(VirtFsPhys::getBaseDir() != nullptr);
+}
+
+TEST_CASE("VirtFsPhys getUserDir")
+{
+ VirtFsPhys::initFuncs();
+ REQUIRE(VirtFsPhys::getUserDir() != nullptr);
+ REQUIRE(VirtFsPhys::getUserDir() == getHomePath());
+}
+
+TEST_CASE("VirtFsPhys exists")
+{
+ VirtFsPhys::initFuncs();
+ logger = new Logger();
+ VirtFsPhys::addDirToSearchPath("data", Append_false);
+ VirtFsPhys::addDirToSearchPath("../data", Append_false);
+
+ REQUIRE(VirtFsPhys::exists("test/units.xml") == true);
+ REQUIRE(VirtFsPhys::exists("test/units123.xml") == false);
+ REQUIRE(VirtFsPhys::exists("tesQ/units.xml") == false);
+ REQUIRE(VirtFsPhys::exists("units.xml") == false);
+
+ VirtFsPhys::addDirToSearchPath("data/test", Append_false);
+ VirtFsPhys::addDirToSearchPath("../data/test", Append_false);
+
+ REQUIRE(VirtFsPhys::exists("test/units.xml") == true);
+ REQUIRE(VirtFsPhys::exists("test/units123.xml") == false);
+ REQUIRE(VirtFsPhys::exists("tesQ/units.xml") == false);
+ REQUIRE(VirtFsPhys::exists("units.xml") == true);
+
+ VirtFsPhys::removeDirFromSearchPath("data/test");
+ VirtFsPhys::removeDirFromSearchPath("../data/test");
+
+ REQUIRE(VirtFsPhys::exists("test/units.xml") == true);
+ REQUIRE(VirtFsPhys::exists("test/units123.xml") == false);
+ REQUIRE(VirtFsPhys::exists("tesQ/units.xml") == false);
+ REQUIRE(VirtFsPhys::exists("units.xml") == false);
+
+ VirtFsPhys::removeDirFromSearchPath("data");
+ VirtFsPhys::removeDirFromSearchPath("../data");
+ delete2(logger);
+}
+
+TEST_CASE("VirtFsPhys exists2")
+{
+ VirtFsPhys::initFuncs();
+ logger = new Logger();
+ VirtFsPhys::addZipToSearchPath("data/test/test2.zip", Append_false);
+ VirtFsPhys::addZipToSearchPath("../data/test/test2.zip", Append_false);
+
+ REQUIRE(VirtFsPhys::exists("test/units.xml") == false);
+ REQUIRE(VirtFsPhys::exists("test.txt") == true);
+ REQUIRE(VirtFsPhys::exists("units123.xml") == false);
+ REQUIRE(VirtFsPhys::exists("tesQ/units.xml") == false);
+ REQUIRE(VirtFsPhys::exists("units.xml") == true);
+
+ VirtFsPhys::removeZipFromSearchPath("data/test/test2.zip");
+ VirtFsPhys::removeZipFromSearchPath("../data/test/test2.zip");
+ delete2(logger);
+}
+
+static void removeTemp(StringVect &restrict list)
+{
+ int cnt = 0;
+ std::sort(list.begin(), list.end());
+
+ FOR_EACH (StringVectIter, it, list)
+ {
+ if (*it != "serverlistplus.xml.part")
+ {
+ logger->log("file: %d %s",
+ cnt,
+ (*it).c_str());
+ cnt ++;
+ }
+ }
+
+ FOR_EACH (StringVectIter, it, list)
+ {
+ if (*it == "serverlistplus.xml.part")
+ {
+ list.erase(it);
+ return;
+ }
+ }
+}
+
+TEST_CASE("VirtFsPhys enumerateFiles1")
+{
+ VirtFsPhys::initFuncs();
+ logger = new Logger;
+
+ VirtFsPhys::addDirToSearchPath("data", Append_false);
+ VirtFsPhys::addDirToSearchPath("../data", Append_false);
+
+ VirtList *list = nullptr;
+
+ const int cnt1 = VirtFsPhys::exists("test/test2.txt") ? 27 : 26;
+ const int cnt2 = 27;
+
+ VirtFsPhys::permitLinks(false);
+ list = VirtFsPhys::enumerateFiles("test");
+ removeTemp(list->names);
+ const size_t sz = list->names.size();
+ REQUIRE(sz == cnt1);
+ VirtFsPhys::freeList(list);
+
+ VirtFsPhys::permitLinks(true);
+ list = VirtFsPhys::enumerateFiles("test");
+ removeTemp(list->names);
+ REQUIRE(list->names.size() == cnt2);
+ VirtFsPhys::freeList(list);
+
+ VirtFsPhys::permitLinks(false);
+ list = VirtFsPhys::enumerateFiles("test");
+ removeTemp(list->names);
+ REQUIRE(list->names.size() == cnt1);
+ VirtFsPhys::freeList(list);
+
+ VirtFsPhys::removeDirFromSearchPath("data");
+ VirtFsPhys::removeDirFromSearchPath("../data");
+ delete2(logger);
+}
+
+TEST_CASE("VirtFsPhys enumerateFiles2")
+{
+ VirtFsPhys::initFuncs();
+ logger = new Logger;
+
+ VirtFsPhys::addDirToSearchPath("data/test/dir1",
+ Append_false);
+ VirtFsPhys::addDirToSearchPath("../data/test/dir1",
+ Append_false);
+
+ VirtList *list = nullptr;
+
+ list = VirtFsPhys::enumerateFiles("/");
+ const size_t sz = list->names.size();
+ REQUIRE(list->names.size() == 5);
+ VirtFsPhys::freeList(list);
+
+ VirtFsPhys::removeDirFromSearchPath("data/test/dir1");
+ VirtFsPhys::removeDirFromSearchPath("../data/test/dir1");
+ delete2(logger);
+}
+
+static bool inList(VirtList *list,
+ const std::string &name)
+{
+ FOR_EACH (StringVectCIter, it, list->names)
+ {
+ if (*it == name)
+ return true;
+ }
+ return false;
+}
+
+TEST_CASE("VirtFsPhys enumerateFiles3")
+{
+ VirtFsPhys::initFuncs();
+ logger = new Logger;
+
+ VirtFsPhys::addZipToSearchPath("data/test/test.zip",
+ Append_false);
+ VirtFsPhys::addZipToSearchPath("../data/test/test.zip",
+ Append_false);
+
+ VirtList *list = nullptr;
+
+ list = VirtFsPhys::enumerateFiles("/");
+ REQUIRE(inList(list, "units.xml") == false);
+ REQUIRE(inList(list, "test.txt") == false);
+ VirtFsPhys::freeList(list);
+
+ VirtFsPhys::removeZipFromSearchPath("data/test/test.zip");
+ VirtFsPhys::removeZipFromSearchPath("../data/test/test.zip");
+ delete2(logger);
+}
+
+TEST_CASE("VirtFsPhys enumerateFiles4")
+{
+ VirtFsPhys::initFuncs();
+ logger = new Logger;
+
+ VirtFsPhys::addZipToSearchPath("data/test/test2.zip",
+ Append_false);
+ VirtFsPhys::addZipToSearchPath("../data/test/test2.zip",
+ Append_false);
+
+ VirtList *list = nullptr;
+
+ list = VirtFsPhys::enumerateFiles("/");
+ REQUIRE(inList(list, "units.xml") == true);
+ REQUIRE(inList(list, "test.txt") == true);
+ VirtFsPhys::freeList(list);
+
+ VirtFsPhys::removeZipFromSearchPath("data/test/test2.zip");
+ VirtFsPhys::removeZipFromSearchPath("../data/test/test2.zip");
+ delete2(logger);
+}
+
+TEST_CASE("VirtFsPhys isDirectory")
+{
+ VirtFsPhys::initFuncs();
+ logger = new Logger();
+ VirtFsPhys::addDirToSearchPath("data", Append_false);
+ VirtFsPhys::addDirToSearchPath("../data", Append_false);
+
+ REQUIRE(VirtFsPhys::isDirectory("test/units.xml") == false);
+ REQUIRE(VirtFsPhys::isDirectory("test/units.xml/") == false);
+ REQUIRE(VirtFsPhys::isDirectory("test//units.xml") == false);
+ REQUIRE(VirtFsPhys::isDirectory("test/units123.xml") == false);
+ REQUIRE(VirtFsPhys::isDirectory("test//units123.xml") == false);
+ REQUIRE(VirtFsPhys::isDirectory("tesQ/units.xml") == false);
+ REQUIRE(VirtFsPhys::isDirectory("tesQ//units.xml") == false);
+ REQUIRE(VirtFsPhys::isDirectory("units.xml") == false);
+ REQUIRE(VirtFsPhys::isDirectory("test") == true);
+ REQUIRE(VirtFsPhys::isDirectory("test/") == true);
+ REQUIRE(VirtFsPhys::isDirectory("test//") == true);
+ REQUIRE(VirtFsPhys::isDirectory("test/dir1") == true);
+ REQUIRE(VirtFsPhys::isDirectory("test//dir1") == true);
+ REQUIRE(VirtFsPhys::isDirectory("test//dir1/") == true);
+ REQUIRE(VirtFsPhys::isDirectory("test//dir1//") == true);
+ REQUIRE(VirtFsPhys::isDirectory("test/dir1/") == true);
+ REQUIRE(VirtFsPhys::isDirectory("test/dir1//") == true);
+ REQUIRE(VirtFsPhys::isDirectory("testQ") == false);
+ REQUIRE(VirtFsPhys::isDirectory("testQ/") == false);
+ REQUIRE(VirtFsPhys::isDirectory("testQ//") == false);
+
+ VirtFsPhys::addDirToSearchPath("data/test", Append_false);
+ VirtFsPhys::addDirToSearchPath("../data/test", Append_false);
+
+ REQUIRE(VirtFsPhys::isDirectory("test/units.xml") == false);
+ REQUIRE(VirtFsPhys::isDirectory("test/units.xml/") == false);
+ REQUIRE(VirtFsPhys::isDirectory("test//units.xml") == false);
+ REQUIRE(VirtFsPhys::isDirectory("test/units123.xml") == false);
+ REQUIRE(VirtFsPhys::isDirectory("tesQ/units.xml") == false);
+ REQUIRE(VirtFsPhys::isDirectory("units.xml") == false);
+ REQUIRE(VirtFsPhys::isDirectory("test") == true);
+ REQUIRE(VirtFsPhys::isDirectory("testQ") == false);
+ REQUIRE(VirtFsPhys::isDirectory("test/dir1") == true);
+
+ VirtFsPhys::removeDirFromSearchPath("data/test");
+ VirtFsPhys::removeDirFromSearchPath("../data/test");
+
+ REQUIRE(VirtFsPhys::isDirectory("test/units.xml") == false);
+ REQUIRE(VirtFsPhys::isDirectory("test/units123.xml") == false);
+ REQUIRE(VirtFsPhys::isDirectory("tesQ/units.xml") == false);
+ REQUIRE(VirtFsPhys::isDirectory("units.xml") == false);
+ REQUIRE(VirtFsPhys::isDirectory("units.xml/") == false);
+ REQUIRE(VirtFsPhys::isDirectory("test") == true);
+ REQUIRE(VirtFsPhys::isDirectory("test/") == true);
+ REQUIRE(VirtFsPhys::isDirectory("testQ") == false);
+ REQUIRE(VirtFsPhys::isDirectory("test/dir1") == true);
+
+ VirtFsPhys::removeDirFromSearchPath("data");
+ VirtFsPhys::removeDirFromSearchPath("../data");
+ delete2(logger);
+}
+
+TEST_CASE("VirtFsPhys openRead")
+{
+ VirtFsPhys::initFuncs();
+ logger = new Logger();
+ VirtFsPhys::addDirToSearchPath("data", Append_false);
+ VirtFsPhys::addDirToSearchPath("../data", Append_false);
+
+ VirtFile *file = nullptr;
+
+ file = VirtFsPhys::openRead("test/units.xml");
+ REQUIRE(file != nullptr);
+ VirtFsPhys::close(file);
+ file = VirtFsPhys::openRead("test/units123.xml");
+ REQUIRE(file == nullptr);
+ file = VirtFsPhys::openRead("tesQ/units.xml");
+ REQUIRE(file == nullptr);
+ file = VirtFsPhys::openRead("units.xml");
+ REQUIRE(file == nullptr);
+// file = VirtFsPhys::openRead("test");
+// REQUIRE(file == nullptr);
+ file = VirtFsPhys::openRead("testQ");
+ REQUIRE(file == nullptr);
+
+ VirtFsPhys::addDirToSearchPath("data/test", Append_false);
+ VirtFsPhys::addDirToSearchPath("../data/test", Append_false);
+
+ file = VirtFsPhys::openRead("test/units.xml");
+ REQUIRE(file != nullptr);
+ VirtFsPhys::close(file);
+ file = VirtFsPhys::openRead("test/units123.xml");
+ REQUIRE(file == nullptr);
+ file = VirtFsPhys::openRead("tesQ/units.xml");
+ REQUIRE(file == nullptr);
+ file = VirtFsPhys::openRead("units.xml");
+ REQUIRE(file != nullptr);
+ VirtFsPhys::close(file);
+// file = VirtFsPhys::openRead("test");
+// REQUIRE(file == nullptr);
+ file = VirtFsPhys::openRead("testQ");
+ REQUIRE(file == nullptr);
+
+ VirtFsPhys::removeDirFromSearchPath("data/test");
+ VirtFsPhys::removeDirFromSearchPath("../data/test");
+
+ file = VirtFsPhys::openRead("test/units.xml");
+ REQUIRE(file != nullptr);
+ VirtFsPhys::close(file);
+ file = VirtFsPhys::openRead("test/units123.xml");
+ REQUIRE(file == nullptr);
+ file = VirtFsPhys::openRead("tesQ/units.xml");
+ REQUIRE(file == nullptr);
+ file = VirtFsPhys::openRead("units.xml");
+ REQUIRE(file == nullptr);
+// file = VirtFsPhys::openRead("test");
+// REQUIRE(file == nullptr);
+ file = VirtFsPhys::openRead("testQ");
+ REQUIRE(file == nullptr);
+
+ VirtFsPhys::removeDirFromSearchPath("data");
+ VirtFsPhys::removeDirFromSearchPath("../data");
+ delete2(logger);
+}
+
+TEST_CASE("VirtFsPhys addZipToSearchPath")
+{
+ // +++ need implement
+}
+
+TEST_CASE("VirtFsPhys removeZipFromSearchPath")
+{
+ // +++ need implement
+}
+
+TEST_CASE("VirtFsPhys getRealDir")
+{
+ VirtFsPhys::initFuncs();
+ logger = new Logger();
+ REQUIRE(VirtFsPhys::getRealDir(".") == "");
+ REQUIRE(VirtFsPhys::getRealDir("..") == "");
+ const bool dir1 = VirtFsPhys::addDirToSearchPath("data", Append_false);
+ REQUIRE((dir1 || VirtFsPhys::addDirToSearchPath(
+ "../data", Append_false)) == true);
+ if (dir1 == true)
+ {
+ REQUIRE(VirtFsPhys::getRealDir("test") == "data");
+ REQUIRE(VirtFsPhys::getRealDir("test/test.txt") ==
+ "data");
+ }
+ else
+ {
+ REQUIRE(VirtFsPhys::getRealDir("test") == "../data");
+ REQUIRE(VirtFsPhys::getRealDir("test/test.txt") ==
+ "../data");
+ }
+ REQUIRE(VirtFsPhys::getRealDir("zzz") == "");
+
+ VirtFsPhys::addDirToSearchPath("data/test", Append_false);
+ VirtFsPhys::addDirToSearchPath("../data/test", Append_false);
+ if (dir1 == true)
+ {
+ REQUIRE(VirtFsPhys::getRealDir("test") == "data");
+ REQUIRE(VirtFsPhys::getRealDir("test/test.txt") ==
+ "data");
+ REQUIRE(VirtFsPhys::getRealDir("test.txt") ==
+ "data/test");
+ }
+ else
+ {
+ REQUIRE(VirtFsPhys::getRealDir("test") == "../data");
+ REQUIRE(VirtFsPhys::getRealDir("test/test.txt") ==
+ "../data");
+ REQUIRE(VirtFsPhys::getRealDir("test.txt") ==
+ "../data/test");
+ }
+ REQUIRE(VirtFsPhys::getRealDir("zzz") == "");
+
+ if (dir1 == true)
+ {
+ VirtFsPhys::addZipToSearchPath("data/test/test.zip", Append_false);
+ REQUIRE(VirtFsPhys::getRealDir("dir/brimmedhat.png") ==
+ "data/test/test.zip");
+ REQUIRE(VirtFsPhys::getRealDir("hide.png") == "data/test");
+ }
+ else
+ {
+ VirtFsPhys::addZipToSearchPath("../data/test/test.zip", Append_false);
+ REQUIRE(VirtFsPhys::getRealDir("dir/brimmedhat.png") ==
+ "../data/test/test.zip");
+ REQUIRE(VirtFsPhys::getRealDir("hide.png") == "../data/test");
+ }
+
+ VirtFsPhys::removeDirFromSearchPath("data/test");
+ VirtFsPhys::removeDirFromSearchPath("../data/test");
+
+ if (dir1 == true)
+ {
+ REQUIRE(VirtFsPhys::getRealDir("test") == "data");
+ REQUIRE(VirtFsPhys::getRealDir("test/test.txt") ==
+ "data");
+ REQUIRE(VirtFsPhys::getRealDir("dir/hide.png") ==
+ "data/test/test.zip");
+ }
+ else
+ {
+ REQUIRE(VirtFsPhys::getRealDir("test") == "../data");
+ REQUIRE(VirtFsPhys::getRealDir("test/test.txt") ==
+ "../data");
+ REQUIRE(VirtFsPhys::getRealDir("dir/hide.png") ==
+ "../data/test/test.zip");
+ }
+ REQUIRE(VirtFsPhys::exists("dir/hide.png"));
+ REQUIRE(VirtFsPhys::getRealDir("zzz") == "");
+
+ VirtFsPhys::removeDirFromSearchPath("data");
+ VirtFsPhys::removeDirFromSearchPath("../data");
+ VirtFsPhys::removeZipFromSearchPath("data/test/test.zip");
+ VirtFsPhys::removeZipFromSearchPath("../data/test/test.zip");
+ delete2(logger);
+}
+
+TEST_CASE("VirtFsPhys permitLinks")
+{
+ VirtFsPhys::initFuncs();
+ logger = new Logger();
+ VirtFsPhys::addDirToSearchPath("data", Append_false);
+ VirtFsPhys::addDirToSearchPath("../data", Append_false);
+
+ const int cnt1 = VirtFsPhys::exists("test/test2.txt") ? 25 : 24;
+ const int cnt2 = 25;
+
+ StringVect list;
+ VirtFsPhys::permitLinks(false);
+ VirtFsPhys::getFiles("test", list);
+ removeTemp(list);
+ const size_t sz = list.size();
+ REQUIRE(sz == cnt1);
+
+ list.clear();
+ VirtFsPhys::permitLinks(true);
+ VirtFsPhys::getFiles("test", list);
+ removeTemp(list);
+ REQUIRE(list.size() == cnt2);
+
+ list.clear();
+ VirtFsPhys::permitLinks(false);
+ VirtFsPhys::getFiles("test", list);
+ removeTemp(list);
+ REQUIRE(list.size() == cnt1);
+
+ VirtFsPhys::removeDirFromSearchPath("data");
+ VirtFsPhys::removeDirFromSearchPath("../data");
+ delete2(logger);
+}
+
+TEST_CASE("VirtFsPhys read")
+{
+ VirtFsPhys::initFuncs();
+ logger = new Logger();
+ VirtFsPhys::addDirToSearchPath("data", Append_false);
+ VirtFsPhys::addDirToSearchPath("../data", Append_false);
+
+ VirtFile *file = VirtFsPhys::openRead("test/test.txt");
+ REQUIRE(file != nullptr);
+ REQUIRE(VirtFsPhys::fileLength(file) == 23);
+ const int fileSize = VirtFsPhys::fileLength(file);
+
+ void *restrict buffer = calloc(fileSize + 1, 1);
+ REQUIRE(VirtFsPhys::read(file, buffer, 1, fileSize) == fileSize);
+ REQUIRE(strcmp(static_cast<char*>(buffer),
+ "test line 1\ntest line 2") == 0);
+ REQUIRE(VirtFsPhys::tell(file) == fileSize);
+ REQUIRE(VirtFsPhys::eof(file) == true);
+
+ free(buffer);
+ buffer = calloc(fileSize + 1, 1);
+ REQUIRE(VirtFsPhys::seek(file, 12) != 0);
+ REQUIRE(VirtFsPhys::eof(file) == false);
+ REQUIRE(VirtFsPhys::tell(file) == 12);
+ REQUIRE(VirtFsPhys::read(file, buffer, 1, 11) == 11);
+ REQUIRE(strcmp(static_cast<char*>(buffer),
+ "test line 2") == 0);
+ REQUIRE(VirtFsPhys::eof(file) == true);
+
+ VirtFsPhys::close(file);
+ free(buffer);
+
+ VirtFsPhys::removeDirFromSearchPath("data");
+ VirtFsPhys::removeDirFromSearchPath("../data");
+ delete2(logger);
+}