From 570e95f4551385a81eb2cf6f2e386e3b0cb291a8 Mon Sep 17 00:00:00 2001 From: crupest Date: Sat, 15 Jan 2022 22:41:11 +0800 Subject: ... --- test/common/CMakeLists.txt | 6 ++++++ test/common/io/UnixFileStreamTest.cpp | 32 ++++++++++++++++++++++++++++++++ 2 files changed, 38 insertions(+) create mode 100644 test/common/io/UnixFileStreamTest.cpp (limited to 'test') diff --git a/test/common/CMakeLists.txt b/test/common/CMakeLists.txt index 810c68d5..1c669dcc 100644 --- a/test/common/CMakeLists.txt +++ b/test/common/CMakeLists.txt @@ -6,4 +6,10 @@ add_executable(cru_base_test ) target_link_libraries(cru_base_test PRIVATE cru_base cru_test_base) +if (UNIX) + target_sources(cru_base_test PRIVATE + io/UnixFileStreamTest.cpp + ) +endif() + gtest_discover_tests(cru_base_test) diff --git a/test/common/io/UnixFileStreamTest.cpp b/test/common/io/UnixFileStreamTest.cpp new file mode 100644 index 00000000..1b73dd3b --- /dev/null +++ b/test/common/io/UnixFileStreamTest.cpp @@ -0,0 +1,32 @@ +#include "cru/common/io/OpenFileFlag.hpp" +#include "cru/common/io/UnixFileStream.hpp" + +#include + +#include +#include + +TEST(UnixFileStream, Work) { + using namespace cru; + using namespace cru::io; + + auto temp_file_path = + (std::filesystem::temp_directory_path() / "cru_test_temp.XXXXXX") + .generic_string(); + mktemp(temp_file_path.data()); + + String path = String::FromUtf8(temp_file_path); + + UnixFileStream file(path, OpenFileFlags::Write | OpenFileFlags::Create); + file.Write("abc", 3); + file.Close(); + + UnixFileStream file2(path, OpenFileFlags::Read); + auto buffer = std::make_unique(3); + file2.Read(buffer.get(), 3); + ASSERT_EQ(std::string_view(reinterpret_cast(buffer.get()), 3), + "abc"); + file2.Close(); + + std::filesystem::remove(temp_file_path); +} -- cgit v1.2.3