aboutsummaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
Diffstat (limited to 'test')
-rw-r--r--test/common/CMakeLists.txt5
-rw-r--r--test/common/platform/unix/UnixFileStreamTest.cpp (renamed from test/common/io/UnixFileStreamTest.cpp)0
-rw-r--r--test/common/platform/win/StreamConvertTest.cpp38
-rw-r--r--test/common/platform/win/Win32FileStreamTest.cpp (renamed from test/common/io/Win32FileStreamTest.cpp)2
4 files changed, 42 insertions, 3 deletions
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/platform/unix/UnixFileStreamTest.cpp
index cdc749ba..cdc749ba 100644
--- a/test/common/io/UnixFileStreamTest.cpp
+++ b/test/common/platform/unix/UnixFileStreamTest.cpp
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 <gtest/gtest.h>
+
+#include <cstdio>
+#include <filesystem>
+
+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<char[]>(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/io/Win32FileStreamTest.cpp b/test/common/platform/win/Win32FileStreamTest.cpp
index 0e35bb8d..deb981f9 100644
--- a/test/common/io/Win32FileStreamTest.cpp
+++ b/test/common/platform/win/Win32FileStreamTest.cpp
@@ -6,7 +6,7 @@
#include <cstdio>
#include <filesystem>
-TEST(UnixFileStream, Work) {
+TEST(Win32FileStream, Work) {
using namespace cru;
using namespace cru::io;
using namespace cru::platform::win;