#ifndef OPENMW_COMPONENTS_TESTING_UTIL_H #define OPENMW_COMPONENTS_TESTING_UTIL_H #include #include #include #include #include #include #include #include #include namespace TestingOpenMW { inline std::filesystem::path outputFilePath(const std::string name) { std::filesystem::path dir("tests_output"); std::filesystem::create_directory(dir); return dir / Misc::StringUtils::stringToU8String(name); } inline std::filesystem::path outputFilePathWithSubDir(const std::filesystem::path& subpath) { std::filesystem::path path("tests_output"); path /= subpath; std::filesystem::create_directories(path.parent_path()); return path; } inline std::filesystem::path temporaryFilePath(const std::string name) { return std::filesystem::temp_directory_path() / name; } class VFSTestFile : public VFS::File { public: explicit VFSTestFile(std::string content) : mContent(std::move(content)) { } Files::IStreamPtr open() override { return std::make_unique(mContent, std::ios_base::in); } std::filesystem::path getPath() override { return "TestFile"; } private: const std::string mContent; }; struct VFSTestData : public VFS::Archive { VFS::FileMap mFiles; explicit VFSTestData(VFS::FileMap&& files) : mFiles(std::move(files)) { } void listResources(VFS::FileMap& out) override { out = mFiles; } bool contains(VFS::Path::NormalizedView file) const override { return mFiles.contains(file); } std::string getDescription() const override { return "TestData"; } }; inline std::unique_ptr createTestVFS(VFS::FileMap&& files) { auto vfs = std::make_unique(); vfs->addArchive(std::make_unique(std::move(files))); vfs->buildIndex(); return vfs; } inline std::unique_ptr createTestVFS( std::initializer_list> files) { return createTestVFS(VFS::FileMap(files.begin(), files.end())); } } #endif