summaryrefslogtreecommitdiff
path: root/src/fs/files_unittest.cc
diff options
context:
space:
mode:
authorAndrei Karas <akaras@inbox.ru>2017-04-21 23:48:08 +0300
committerAndrei Karas <akaras@inbox.ru>2017-04-22 00:04:12 +0300
commitc99419ad2458153e3bf7f6463baf7a93ee6ed57f (patch)
tree51a6d94212475655f7661ef2e41a4111b847f1d7 /src/fs/files_unittest.cc
parent155b8814e84a4f5cfa3f91f8dcc096c6f8136dcd (diff)
downloadmanaplus-c99419ad2458153e3bf7f6463baf7a93ee6ed57f.tar.gz
manaplus-c99419ad2458153e3bf7f6463baf7a93ee6ed57f.tar.bz2
manaplus-c99419ad2458153e3bf7f6463baf7a93ee6ed57f.tar.xz
manaplus-c99419ad2458153e3bf7f6463baf7a93ee6ed57f.zip
Add tests for some functions in files.
Diffstat (limited to 'src/fs/files_unittest.cc')
-rw-r--r--src/fs/files_unittest.cc62
1 files changed, 62 insertions, 0 deletions
diff --git a/src/fs/files_unittest.cc b/src/fs/files_unittest.cc
index bc4c2dbf6..f6d1c91df 100644
--- a/src/fs/files_unittest.cc
+++ b/src/fs/files_unittest.cc
@@ -27,6 +27,7 @@
#include "fs/virtfs/virtfstools.h"
#include "utils/delete2.h"
+#include "utils/stringutils.h"
#include "resources/resourcemanager/resourcemanager.h"
@@ -142,6 +143,67 @@ TEST_CASE("Files saveTextFile")
// VirtFs::deinit();
}
+TEST_CASE("Files copyFile1")
+{
+ logger = new Logger();
+ VirtFs::mountDirSilent("data", Append_false);
+ VirtFs::mountDirSilent("../data", Append_false);
+
+ const std::string dir = VirtFs::getPath("test");
+ REQUIRE(dir.size() > 0);
+ SECTION("copy")
+ {
+ REQUIRE(Files::copyFile(pathJoin(dir, "test.txt"),
+ pathJoin(dir, "tempfile.txt")) == 0);
+ std::string data = VirtFs::loadTextFileString("test/tempfile.txt");
+ ::remove((dir + "/tempfile.txt").c_str());
+#ifdef WIN32
+ REQUIRE(data == "test line 1\r\ntest line 2");
+#else // WIN32
+
+ REQUIRE(data == "test line 1\ntest line 2");
+#endif // WIN32
+ }
+
+ SECTION("errors")
+ {
+ REQUIRE(Files::copyFile(pathJoin(dir, "test_not_exists.txt"),
+ pathJoin(dir, "tempfile.txt")) == -1);
+ REQUIRE(Files::copyFile(pathJoin(dir, "test.txt"),
+ "/nonexist/root/dir123") == -1);
+ }
+
+ ResourceManager::deleteInstance();
+ VirtFs::unmountDirSilent("data");
+ VirtFs::unmountDirSilent("../data");
+ delete2(logger);
+// VirtFs::deinit();
+}
+
+TEST_CASE("Files loadTextFileLocal")
+{
+ logger = new Logger();
+ VirtFs::mountDirSilent("data", Append_false);
+ VirtFs::mountDirSilent("../data", Append_false);
+
+ const std::string dir = VirtFs::getPath("test");
+ REQUIRE(dir.size() > 0);
+ Files::saveTextFile(dir, "tempfile.txt", "test line\ntext line2");
+ StringVect lines;
+ REQUIRE(Files::loadTextFileLocal(pathJoin(dir, "tempfile.txt"),
+ lines));
+ ::remove((dir + "/tempfile.txt").c_str());
+ REQUIRE(lines.size() == 2);
+ REQUIRE(lines[0] == "test line");
+ REQUIRE(lines[1] == "text line2");
+
+ ResourceManager::deleteInstance();
+ VirtFs::unmountDirSilent("data");
+ VirtFs::unmountDirSilent("../data");
+ delete2(logger);
+// VirtFs::deinit();
+}
+
TEST_CASE("Files getFilesInDir")
{
logger = new Logger();