Extend WavReader and WavWriter API.
Add ability to read and write wav files using rtc::PlatformFile instead
of file name.
Bug: webrtc:8946
Change-Id: If18d9465f2155a33547f800edbdac45971a0e878
Reviewed-on: https://webrtc-review.googlesource.com/61424
Commit-Queue: Artem Titov <titovartem@webrtc.org>
Reviewed-by: Karl Wiberg <kwiberg@webrtc.org>
Cr-Commit-Position: refs/heads/master@{#22497}
diff --git a/rtc_base/platform_file_unittest.cc b/rtc_base/platform_file_unittest.cc
new file mode 100644
index 0000000..4e72400
--- /dev/null
+++ b/rtc_base/platform_file_unittest.cc
@@ -0,0 +1,77 @@
+/*
+ * Copyright (c) 2018 The WebRTC project authors. All Rights Reserved.
+ *
+ * Use of this source code is governed by a BSD-style license
+ * that can be found in the LICENSE file in the root of the source
+ * tree. An additional intellectual property rights grant can be found
+ * in the file PATENTS. All contributing project authors may
+ * be found in the AUTHORS file in the root of the source tree.
+ */
+
+#include "rtc_base/platform_file.h"
+#include "test/gtest.h"
+#include "test/testsupport/fileutils.h"
+
+namespace rtc {
+
+void FillWithDummyDataAndClose(FILE* const file, const std::string& filename) {
+ EXPECT_GT(fprintf(file, "%s", "Dummy data"), 0)
+ << "Failed to write to file: " << filename;
+ fclose(file);
+}
+
+TEST(PlatformFileTest, CreateWriteAndDelete) {
+ const std::string filename = webrtc::test::GenerateTempFilename(
+ webrtc::test::OutputPath(), ".testfile");
+ const PlatformFile fd = rtc::CreatePlatformFile(filename);
+ ASSERT_NE(fd, rtc::kInvalidPlatformFileValue)
+ << "Failed to create file descriptor for file: " << filename;
+ FILE* const file = rtc::FdopenPlatformFile(fd, "w");
+ ASSERT_TRUE(file != nullptr) << "Failed to open file: " << filename;
+ FillWithDummyDataAndClose(file, filename);
+ webrtc::test::RemoveFile(filename);
+}
+
+TEST(PlatformFileTest, OpenExistingWriteAndDelete) {
+ const std::string filename = webrtc::test::GenerateTempFilename(
+ webrtc::test::OutputPath(), ".testfile");
+
+ // Create file with dummy data.
+ FILE* file = fopen(filename.c_str(), "wb");
+ ASSERT_TRUE(file != nullptr) << "Failed to open file: " << filename;
+ FillWithDummyDataAndClose(file, filename);
+
+ // Open it for write, write and delete.
+ const PlatformFile fd = rtc::OpenPlatformFile(filename);
+ ASSERT_NE(fd, rtc::kInvalidPlatformFileValue)
+ << "Failed to open file descriptor for file: " << filename;
+ file = rtc::FdopenPlatformFile(fd, "w");
+ ASSERT_TRUE(file != nullptr) << "Failed to open file: " << filename;
+ FillWithDummyDataAndClose(file, filename);
+ webrtc::test::RemoveFile(filename);
+}
+
+TEST(PlatformFileTest, OpenExistingReadOnlyAndDelete) {
+ const std::string filename = webrtc::test::GenerateTempFilename(
+ webrtc::test::OutputPath(), ".testfile");
+
+ // Create file with dummy data.
+ FILE* file = fopen(filename.c_str(), "wb");
+ ASSERT_TRUE(file != nullptr) << "Failed to open file: " << filename;
+ FillWithDummyDataAndClose(file, filename);
+
+ // Open it for read, read and delete.
+ const PlatformFile fd = rtc::OpenPlatformFileReadOnly(filename);
+ ASSERT_NE(fd, rtc::kInvalidPlatformFileValue)
+ << "Failed to open file descriptor for file: " << filename;
+ file = rtc::FdopenPlatformFile(fd, "r");
+ ASSERT_TRUE(file != nullptr) << "Failed to open file: " << filename;
+
+ int buf[]{0};
+ ASSERT_GT(fread(&buf, 1, 1, file), 0u)
+ << "Failed to read from file: " << filename;
+ fclose(file);
+ webrtc::test::RemoveFile(filename);
+}
+
+} // namespace rtc