FileTest.cpp 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393
  1. /*
  2. * Author: Patrick-Christopher Mattulat
  3. * Co-Author: Claude Sonnet 4.6 (LLM)
  4. * Company: Lynar Studios
  5. * E-Mail: webmaster@lynarstudios.com
  6. * Created: 2020-08-15
  7. * Changed: 2026-06-23
  8. *
  9. * */
  10. #include <classes/TestHelper.hpp>
  11. #include <gtest/gtest.h>
  12. #include <ls-std/ls-std-core.hpp>
  13. #include <ls-std/ls-std-io.hpp>
  14. using ls::standard::core::FileOperationException;
  15. using ls::standard::io::File;
  16. using ls::standard::io::FilePathSeparator;
  17. using ls::standard::test::TestHelper;
  18. using std::list;
  19. using std::string;
  20. using testing::Test;
  21. namespace
  22. {
  23. class FileTest : public Test
  24. {
  25. public:
  26. FileTest() = default;
  27. ~FileTest() override = default;
  28. string fileLocation = TestHelper::getResourcesFolderLocation() + "simple.txt";
  29. static bool hasFileInDirectory(const list<string> &_fileNamesInDirectory, const string &_fileName)
  30. {
  31. return find(_fileNamesInDirectory.begin(), _fileNamesInDirectory.end(), _fileName) != _fileNamesInDirectory.end();
  32. }
  33. };
  34. // comparison operators
  35. TEST_F(FileTest, operator_equals)
  36. {
  37. File file{this->fileLocation};
  38. File file2{this->fileLocation};
  39. File file3{"/home/bla/text.txt"};
  40. File file4{"\\home/bla\\text.txt"};
  41. ASSERT_TRUE(file == file2);
  42. ASSERT_TRUE(file2 == file);
  43. ASSERT_TRUE(file3 == file4);
  44. ASSERT_TRUE(file4 == file3);
  45. }
  46. TEST_F(FileTest, operator_not_equals)
  47. {
  48. const File file{this->fileLocation};
  49. const File file2{TestHelper::getResourcesFolderLocation() + "app.exe"};
  50. ASSERT_TRUE(file != file2);
  51. ASSERT_TRUE(file2 != file);
  52. }
  53. // additional functionality
  54. TEST_F(FileTest, canExecute)
  55. {
  56. #ifdef _WIN32
  57. const File executableFile{TestHelper::getResourcesFolderLocation() + "app.exe"};
  58. #endif
  59. #if defined(unix) || defined(__APPLE__)
  60. const File executableFile{TestHelper::getResourcesFolderLocation() + "app"};
  61. #endif
  62. ASSERT_TRUE(executableFile.canExecute());
  63. }
  64. TEST_F(FileTest, canExecute_not_executable)
  65. {
  66. const File file{this->fileLocation};
  67. ASSERT_FALSE(file.canExecute());
  68. }
  69. TEST_F(FileTest, canRead)
  70. {
  71. const File readableFile{this->fileLocation};
  72. ASSERT_TRUE(readableFile.canRead());
  73. }
  74. TEST_F(FileTest, canRead_file_does_not_exist)
  75. {
  76. const File file{""};
  77. EXPECT_THROW(
  78. {
  79. try
  80. {
  81. bool isReadable = file.canRead();
  82. }
  83. catch (const FileOperationException &_exception)
  84. {
  85. throw;
  86. }
  87. },
  88. FileOperationException);
  89. }
  90. TEST_F(FileTest, canWrite)
  91. {
  92. const File readableFile{this->fileLocation};
  93. ASSERT_TRUE(readableFile.canWrite());
  94. }
  95. TEST_F(FileTest, canWrite_not_writable)
  96. {
  97. #if defined(unix) || defined(__APPLE__)
  98. const File noWritableFile{TestHelper::getResourcesFolderLocation() + "no-writable.txt"};
  99. ASSERT_FALSE(noWritableFile.canWrite());
  100. #endif
  101. #ifdef _WIN32
  102. const File noWritableFile{TestHelper::getResourcesFolderLocation() + "no-writable-windows.txt"};
  103. ASSERT_FALSE(noWritableFile.canWrite());
  104. #endif
  105. }
  106. TEST_F(FileTest, createNewFile)
  107. {
  108. const File file{TestHelper::getResourcesFolderLocation() + "tmp.txt"};
  109. ASSERT_FALSE(file.exists());
  110. file.createNewFile();
  111. ASSERT_TRUE(file.exists());
  112. file.remove();
  113. ASSERT_FALSE(file.exists());
  114. }
  115. TEST_F(FileTest, createNewFile_file_does_already_exist)
  116. {
  117. const File file{TestHelper::getResourcesFolderLocation() + "simple.txt"};
  118. EXPECT_THROW(
  119. {
  120. try
  121. {
  122. file.createNewFile();
  123. }
  124. catch (const FileOperationException &_exception)
  125. {
  126. const string expected = _exception.getName() + R"lit( thrown - file ")lit" + TestHelper::getResourcesFolderLocation() + R"lit(simple.txt" could not be created!)lit";
  127. const string actual = _exception.what();
  128. ASSERT_STREQ(expected.c_str(), actual.c_str());
  129. throw;
  130. }
  131. },
  132. FileOperationException);
  133. }
  134. TEST_F(FileTest, exists)
  135. {
  136. const File file{this->fileLocation};
  137. const File directory{TestHelper::getResourcesFolderLocation()};
  138. ASSERT_TRUE(file.exists());
  139. ASSERT_TRUE(directory.exists());
  140. }
  141. TEST_F(FileTest, exists_does_not_exist)
  142. {
  143. const File file{TestHelper::getResourcesFolderLocation() + "bla.txt"};
  144. ASSERT_FALSE(file.exists());
  145. }
  146. TEST_F(FileTest, getAbsoluteFilePath)
  147. {
  148. const File file{this->fileLocation};
  149. ASSERT_STREQ(this->fileLocation.c_str(), file.getAbsoluteFilePath().c_str());
  150. string s = {FilePathSeparator::get()};
  151. const string wrongFilePath = "home" + s + s + s + "user" + s + "bla" + s + s + "sub_folder";
  152. const string expectedFilePath = "home" + s + "user" + s + "bla" + s + "sub_folder";
  153. const File anotherFile{wrongFilePath};
  154. ASSERT_STREQ(expectedFilePath.c_str(), anotherFile.getAbsoluteFilePath().c_str());
  155. }
  156. TEST_F(FileTest, getName)
  157. {
  158. File file{this->fileLocation};
  159. File executableFile{TestHelper::getResourcesFolderLocation() + "app.exe"};
  160. File anotherFile{"bla.txt"};
  161. File directory{TestHelper::getResourcesFolderLocation()};
  162. ASSERT_STREQ("simple.txt", file.getName().c_str());
  163. ASSERT_STREQ("app.exe", executableFile.getName().c_str());
  164. ASSERT_STREQ("bla.txt", anotherFile.getName().c_str());
  165. ASSERT_STREQ("resources", directory.getName().c_str());
  166. }
  167. TEST_F(FileTest, getParent)
  168. {
  169. const File file{this->fileLocation};
  170. ASSERT_STREQ(TestHelper::getResourcesFolderLocation().c_str(), file.getParent().c_str());
  171. }
  172. TEST_F(FileTest, getWorkingDirectory)
  173. {
  174. const string workingDirectory = File::getWorkingDirectory();
  175. ASSERT_FALSE(workingDirectory.empty());
  176. }
  177. TEST_F(FileTest, getSize)
  178. {
  179. const File file{this->fileLocation};
  180. const size_t size = file.getSize();
  181. ASSERT_TRUE(size == 7 || size == 8); // different OS specific new lines
  182. }
  183. TEST_F(FileTest, isDirectory)
  184. {
  185. const File directory{TestHelper::getResourcesFolderLocation()};
  186. ASSERT_TRUE(directory.isDirectory());
  187. }
  188. TEST_F(FileTest, isDirectory_is_a_file)
  189. {
  190. const File file{this->fileLocation};
  191. ASSERT_FALSE(file.isDirectory());
  192. }
  193. TEST_F(FileTest, isFile)
  194. {
  195. const char separator = FilePathSeparator::get();
  196. const File file{this->fileLocation};
  197. ASSERT_TRUE(file.isFile());
  198. const File file2{TestHelper::getResourcesFolderLocation() + "list-test" + separator + "bla.txt"};
  199. ASSERT_TRUE(file2.isFile());
  200. }
  201. TEST_F(FileTest, isFile_is_a_directory)
  202. {
  203. const File directory{TestHelper::getResourcesFolderLocation()};
  204. ASSERT_FALSE(directory.isFile());
  205. }
  206. TEST_F(FileTest, lastModified)
  207. {
  208. const File file{this->fileLocation};
  209. ASSERT_TRUE(file.lastModified() > 1590000000);
  210. }
  211. TEST_F(FileTest, list)
  212. {
  213. const File file{TestHelper::getResourcesFolderLocation() + "list-test"};
  214. const list<string> filesInDirectory = file.list();
  215. string expectedFile{};
  216. const char separator = FilePathSeparator::get();
  217. ASSERT_FALSE(filesInDirectory.empty());
  218. ASSERT_EQ(7, filesInDirectory.size());
  219. expectedFile = file.getAbsoluteFilePath() + separator + ".";
  220. ASSERT_TRUE(FileTest::hasFileInDirectory(filesInDirectory, expectedFile));
  221. expectedFile = file.getAbsoluteFilePath() + separator + "..";
  222. ASSERT_TRUE(FileTest::hasFileInDirectory(filesInDirectory, expectedFile));
  223. expectedFile = file.getAbsoluteFilePath() + separator + "another-file.txt";
  224. ASSERT_TRUE(FileTest::hasFileInDirectory(filesInDirectory, expectedFile));
  225. expectedFile = file.getAbsoluteFilePath() + separator + "bla.txt";
  226. ASSERT_TRUE(FileTest::hasFileInDirectory(filesInDirectory, expectedFile));
  227. expectedFile = file.getAbsoluteFilePath() + separator + "hello.txt";
  228. ASSERT_TRUE(FileTest::hasFileInDirectory(filesInDirectory, expectedFile));
  229. expectedFile = file.getAbsoluteFilePath() + separator + "list-test-sub";
  230. ASSERT_TRUE(FileTest::hasFileInDirectory(filesInDirectory, expectedFile));
  231. expectedFile = file.getAbsoluteFilePath() + separator + ".hidden-file.txt";
  232. ASSERT_TRUE(FileTest::hasFileInDirectory(filesInDirectory, expectedFile));
  233. }
  234. TEST_F(FileTest, listFiles)
  235. {
  236. const File file{TestHelper::getResourcesFolderLocation() + "list-test"};
  237. const list<string> filesInDirectory = file.listFiles();
  238. string expectedFile{};
  239. const char separator = FilePathSeparator::get();
  240. ASSERT_FALSE(filesInDirectory.empty());
  241. ASSERT_EQ(4, filesInDirectory.size());
  242. expectedFile = file.getAbsoluteFilePath() + separator + "another-file.txt";
  243. ASSERT_TRUE(FileTest::hasFileInDirectory(filesInDirectory, expectedFile));
  244. expectedFile = file.getAbsoluteFilePath() + separator + "bla.txt";
  245. ASSERT_TRUE(FileTest::hasFileInDirectory(filesInDirectory, expectedFile));
  246. expectedFile = file.getAbsoluteFilePath() + separator + "hello.txt";
  247. ASSERT_TRUE(FileTest::hasFileInDirectory(filesInDirectory, expectedFile));
  248. expectedFile = file.getAbsoluteFilePath() + separator + ".hidden-file.txt";
  249. ASSERT_TRUE(FileTest::hasFileInDirectory(filesInDirectory, expectedFile));
  250. }
  251. TEST_F(FileTest, makeDirectory)
  252. {
  253. const File directory{TestHelper::getResourcesFolderLocation() + "testDir"};
  254. ASSERT_FALSE(directory.exists());
  255. directory.makeDirectory();
  256. ASSERT_TRUE(directory.exists());
  257. directory.remove();
  258. ASSERT_FALSE(directory.exists());
  259. }
  260. TEST_F(FileTest, makeDirectory_directory_already_exists)
  261. {
  262. const File directory{TestHelper::getResourcesFolderLocation() + "list-test"};
  263. EXPECT_THROW(
  264. {
  265. try
  266. {
  267. directory.makeDirectory();
  268. }
  269. catch (const FileOperationException &_exception)
  270. {
  271. const string expected = _exception.getName() + R"lit( thrown - directory ")lit" + TestHelper::getResourcesFolderLocation() + R"lit(list-test" could not be created!)lit";
  272. const string actual = _exception.what();
  273. ASSERT_STREQ(expected.c_str(), actual.c_str());
  274. throw;
  275. }
  276. },
  277. FileOperationException);
  278. }
  279. TEST_F(FileTest, makeDirectories)
  280. {
  281. File directory{TestHelper::getResourcesFolderLocation() + "testDir/sub/tmp/bla"};
  282. ASSERT_FALSE(directory.exists());
  283. directory.makeDirectories();
  284. ASSERT_TRUE(directory.exists());
  285. // clean up
  286. directory.remove();
  287. directory = File(TestHelper::getResourcesFolderLocation() + "testDir/sub/tmp");
  288. directory.remove();
  289. directory = File(TestHelper::getResourcesFolderLocation() + "testDir/sub");
  290. directory.remove();
  291. directory = File(TestHelper::getResourcesFolderLocation() + "testDir");
  292. directory.remove();
  293. }
  294. TEST_F(FileTest, remove)
  295. {
  296. const string fileName = TestHelper::getResourcesFolderLocation() + "removable-file.txt";
  297. const File file{fileName};
  298. file.createNewFile();
  299. ASSERT_TRUE(file.exists());
  300. file.remove();
  301. ASSERT_FALSE(file.exists());
  302. }
  303. TEST_F(FileTest, renameTo)
  304. {
  305. const string currentName = TestHelper::getResourcesFolderLocation() + "tmp-rename-to.txt";
  306. const string newName = TestHelper::getResourcesFolderLocation() + "tmp-rename-to-better-name.txt";
  307. File file{currentName};
  308. file.createNewFile();
  309. ASSERT_TRUE(file.exists());
  310. ASSERT_STREQ(currentName.c_str(), file.getAbsoluteFilePath().c_str());
  311. file.renameTo(newName);
  312. ASSERT_TRUE(file.exists());
  313. ASSERT_STREQ(newName.c_str(), file.getAbsoluteFilePath().c_str());
  314. file.remove();
  315. }
  316. TEST_F(FileTest, reset)
  317. {
  318. File file{this->fileLocation};
  319. ASSERT_TRUE(file.exists());
  320. file.reset(TestHelper::getResourcesFolderLocation() + "list-test/hello.txt");
  321. ASSERT_TRUE(file.exists());
  322. }
  323. }