From 5aca7b099c46a87a859f40110efce708200a4bc8 Mon Sep 17 00:00:00 2001 From: crupest Date: Thu, 3 Feb 2022 17:55:00 +0800 Subject: ... --- test/common/CMakeLists.txt | 5 ++-- test/common/io/UnixFileStreamTest.cpp | 33 -------------------- test/common/io/Win32FileStreamTest.cpp | 33 -------------------- test/common/platform/unix/UnixFileStreamTest.cpp | 33 ++++++++++++++++++++ test/common/platform/win/StreamConvertTest.cpp | 38 ++++++++++++++++++++++++ test/common/platform/win/Win32FileStreamTest.cpp | 33 ++++++++++++++++++++ 6 files changed, 107 insertions(+), 68 deletions(-) delete mode 100644 test/common/io/UnixFileStreamTest.cpp delete mode 100644 test/common/io/Win32FileStreamTest.cpp create mode 100644 test/common/platform/unix/UnixFileStreamTest.cpp create mode 100644 test/common/platform/win/StreamConvertTest.cpp create mode 100644 test/common/platform/win/Win32FileStreamTest.cpp (limited to 'test/common') diff --git a/test/common/CMakeLists.txt b/test/common/CMakeLists.txt index 38c15000..600c18c3 100644 --- a/test/common/CMakeLists.txt +++ b/test/common/CMakeLists.txt @@ -8,13 +8,14 @@ target_link_libraries(cru_base_test PRIVATE cru_base cru_test_base) if (UNIX) target_sources(cru_base_test PRIVATE - io/UnixFileStreamTest.cpp + platform/unix/UnixFileStreamTest.cpp ) endif() if (WIN32) target_sources(cru_base_test PRIVATE - io/Win32FileStreamTest.cpp + platform/win/StreamConvertTest.cpp + platform/win/Win32FileStreamTest.cpp ) add_custom_command(TARGET cru_base_test POST_BUILD diff --git a/test/common/io/UnixFileStreamTest.cpp b/test/common/io/UnixFileStreamTest.cpp deleted file mode 100644 index cdc749ba..00000000 --- a/test/common/io/UnixFileStreamTest.cpp +++ /dev/null @@ -1,33 +0,0 @@ -#include "cru/common/io/OpenFileFlag.hpp" -#include "cru/common/platform/unix/UnixFileStream.hpp" - -#include - -#include -#include - -TEST(UnixFileStream, Work) { - using namespace cru; - using namespace cru::io; - using namespace cru::platform::unix; - - 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); -} diff --git a/test/common/io/Win32FileStreamTest.cpp b/test/common/io/Win32FileStreamTest.cpp deleted file mode 100644 index 0e35bb8d..00000000 --- a/test/common/io/Win32FileStreamTest.cpp +++ /dev/null @@ -1,33 +0,0 @@ -#include "cru/common/io/OpenFileFlag.hpp" -#include "cru/common/platform/win/Win32FileStream.hpp" - -#include - -#include -#include - -TEST(UnixFileStream, Work) { - using namespace cru; - using namespace cru::io; - using namespace cru::platform::win; - - auto temp_file_path = - (std::filesystem::temp_directory_path() / "cru_test_temp.XXXXXX") - .native(); - _wmktemp(temp_file_path.data()); - - String path = temp_file_path; - - Win32FileStream file(path, OpenFileFlags::Write | OpenFileFlags::Create); - file.Write("abc", 3); - file.Close(); - - Win32FileStream 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); -} diff --git a/test/common/platform/unix/UnixFileStreamTest.cpp b/test/common/platform/unix/UnixFileStreamTest.cpp new file mode 100644 index 00000000..cdc749ba --- /dev/null +++ b/test/common/platform/unix/UnixFileStreamTest.cpp @@ -0,0 +1,33 @@ +#include "cru/common/io/OpenFileFlag.hpp" +#include "cru/common/platform/unix/UnixFileStream.hpp" + +#include + +#include +#include + +TEST(UnixFileStream, Work) { + using namespace cru; + using namespace cru::io; + using namespace cru::platform::unix; + + 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); +} diff --git a/test/common/platform/win/StreamConvertTest.cpp b/test/common/platform/win/StreamConvertTest.cpp new file mode 100644 index 00000000..43c6f46c --- /dev/null +++ b/test/common/platform/win/StreamConvertTest.cpp @@ -0,0 +1,38 @@ +#include "cru/common/io/OpenFileFlag.hpp" +#include "cru/common/platform/win/Exception.hpp" +#include "cru/common/platform/win/StreamConvert.hpp" +#include "cru/common/platform/win/Win32FileStream.hpp" + +#include + +#include +#include + +TEST(StreamConvert, FileStreamWork) { + using namespace cru; + using namespace cru::io; + using namespace cru::platform::win; + + auto temp_file_path = + (std::filesystem::temp_directory_path() / "cru_test_temp.XXXXXX") + .native(); + _wmktemp(temp_file_path.data()); + + String path = temp_file_path; + + Win32FileStream file( + path, OpenFileFlags::Read | OpenFileFlags::Write | OpenFileFlags::Create); + file.Write("abc", 3); + + IStream* com_stream = ConvertStreamToComStream(&file); + LARGE_INTEGER position; + position.QuadPart = 0; + ThrowIfFailed(com_stream->Seek(position, SEEK_SET, nullptr)); + auto buffer = std::make_unique(3); + ThrowIfFailed(com_stream->Read(buffer.get(), 3, nullptr)); + ASSERT_EQ(std::string_view(buffer.get(), 3), "abc"); + com_stream->Release(); + file.Close(); + + std::filesystem::remove(temp_file_path); +} diff --git a/test/common/platform/win/Win32FileStreamTest.cpp b/test/common/platform/win/Win32FileStreamTest.cpp new file mode 100644 index 00000000..deb981f9 --- /dev/null +++ b/test/common/platform/win/Win32FileStreamTest.cpp @@ -0,0 +1,33 @@ +#include "cru/common/io/OpenFileFlag.hpp" +#include "cru/common/platform/win/Win32FileStream.hpp" + +#include + +#include +#include + +TEST(Win32FileStream, Work) { + using namespace cru; + using namespace cru::io; + using namespace cru::platform::win; + + auto temp_file_path = + (std::filesystem::temp_directory_path() / "cru_test_temp.XXXXXX") + .native(); + _wmktemp(temp_file_path.data()); + + String path = temp_file_path; + + Win32FileStream file(path, OpenFileFlags::Write | OpenFileFlags::Create); + file.Write("abc", 3); + file.Close(); + + Win32FileStream 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