xref: /aosp_15_r20/external/webrtc/test/logging/file_log_writer.cc (revision d9f758449e529ab9291ac668be2861e7a55c2422)
1*d9f75844SAndroid Build Coastguard Worker /*
2*d9f75844SAndroid Build Coastguard Worker  *  Copyright 2019 The WebRTC project authors. All Rights Reserved.
3*d9f75844SAndroid Build Coastguard Worker  *
4*d9f75844SAndroid Build Coastguard Worker  *  Use of this source code is governed by a BSD-style license
5*d9f75844SAndroid Build Coastguard Worker  *  that can be found in the LICENSE file in the root of the source
6*d9f75844SAndroid Build Coastguard Worker  *  tree. An additional intellectual property rights grant can be found
7*d9f75844SAndroid Build Coastguard Worker  *  in the file PATENTS.  All contributing project authors may
8*d9f75844SAndroid Build Coastguard Worker  *  be found in the AUTHORS file in the root of the source tree.
9*d9f75844SAndroid Build Coastguard Worker  */
10*d9f75844SAndroid Build Coastguard Worker #include "test/logging/file_log_writer.h"
11*d9f75844SAndroid Build Coastguard Worker 
12*d9f75844SAndroid Build Coastguard Worker #include <memory>
13*d9f75844SAndroid Build Coastguard Worker 
14*d9f75844SAndroid Build Coastguard Worker #include "absl/strings/string_view.h"
15*d9f75844SAndroid Build Coastguard Worker #include "rtc_base/checks.h"
16*d9f75844SAndroid Build Coastguard Worker #include "rtc_base/logging.h"
17*d9f75844SAndroid Build Coastguard Worker #include "test/testsupport/file_utils.h"
18*d9f75844SAndroid Build Coastguard Worker 
19*d9f75844SAndroid Build Coastguard Worker namespace webrtc {
20*d9f75844SAndroid Build Coastguard Worker namespace webrtc_impl {
21*d9f75844SAndroid Build Coastguard Worker 
FileLogWriter(absl::string_view file_path)22*d9f75844SAndroid Build Coastguard Worker FileLogWriter::FileLogWriter(absl::string_view file_path)
23*d9f75844SAndroid Build Coastguard Worker     : out_(std::fopen(std::string(file_path).c_str(), "wb")) {
24*d9f75844SAndroid Build Coastguard Worker   RTC_CHECK(out_ != nullptr)
25*d9f75844SAndroid Build Coastguard Worker       << "Failed to open file: '" << file_path << "' for writing.";
26*d9f75844SAndroid Build Coastguard Worker }
27*d9f75844SAndroid Build Coastguard Worker 
~FileLogWriter()28*d9f75844SAndroid Build Coastguard Worker FileLogWriter::~FileLogWriter() {
29*d9f75844SAndroid Build Coastguard Worker   std::fclose(out_);
30*d9f75844SAndroid Build Coastguard Worker }
31*d9f75844SAndroid Build Coastguard Worker 
IsActive() const32*d9f75844SAndroid Build Coastguard Worker bool FileLogWriter::IsActive() const {
33*d9f75844SAndroid Build Coastguard Worker   return true;
34*d9f75844SAndroid Build Coastguard Worker }
35*d9f75844SAndroid Build Coastguard Worker 
Write(absl::string_view value)36*d9f75844SAndroid Build Coastguard Worker bool FileLogWriter::Write(absl::string_view value) {
37*d9f75844SAndroid Build Coastguard Worker   // We don't expect the write to fail. If it does, we don't want to risk
38*d9f75844SAndroid Build Coastguard Worker   // silently ignoring it.
39*d9f75844SAndroid Build Coastguard Worker   RTC_CHECK_EQ(std::fwrite(value.data(), 1, value.size(), out_), value.size())
40*d9f75844SAndroid Build Coastguard Worker       << "fwrite failed unexpectedly: " << errno;
41*d9f75844SAndroid Build Coastguard Worker   return true;
42*d9f75844SAndroid Build Coastguard Worker }
43*d9f75844SAndroid Build Coastguard Worker 
Flush()44*d9f75844SAndroid Build Coastguard Worker void FileLogWriter::Flush() {
45*d9f75844SAndroid Build Coastguard Worker   RTC_CHECK_EQ(fflush(out_), 0) << "fflush failed unexpectedly: " << errno;
46*d9f75844SAndroid Build Coastguard Worker }
47*d9f75844SAndroid Build Coastguard Worker 
48*d9f75844SAndroid Build Coastguard Worker }  // namespace webrtc_impl
49*d9f75844SAndroid Build Coastguard Worker 
FileLogWriterFactory(absl::string_view base_path)50*d9f75844SAndroid Build Coastguard Worker FileLogWriterFactory::FileLogWriterFactory(absl::string_view base_path)
51*d9f75844SAndroid Build Coastguard Worker     : base_path_(base_path) {
52*d9f75844SAndroid Build Coastguard Worker   for (size_t i = 0; i < base_path.size(); ++i) {
53*d9f75844SAndroid Build Coastguard Worker     if (base_path[i] == '/')
54*d9f75844SAndroid Build Coastguard Worker       test::CreateDir(base_path.substr(0, i));
55*d9f75844SAndroid Build Coastguard Worker   }
56*d9f75844SAndroid Build Coastguard Worker }
57*d9f75844SAndroid Build Coastguard Worker 
~FileLogWriterFactory()58*d9f75844SAndroid Build Coastguard Worker FileLogWriterFactory::~FileLogWriterFactory() {}
59*d9f75844SAndroid Build Coastguard Worker 
Create(absl::string_view filename)60*d9f75844SAndroid Build Coastguard Worker std::unique_ptr<RtcEventLogOutput> FileLogWriterFactory::Create(
61*d9f75844SAndroid Build Coastguard Worker     absl::string_view filename) {
62*d9f75844SAndroid Build Coastguard Worker   return std::make_unique<webrtc_impl::FileLogWriter>(base_path_ +
63*d9f75844SAndroid Build Coastguard Worker                                                       std::string(filename));
64*d9f75844SAndroid Build Coastguard Worker }
65*d9f75844SAndroid Build Coastguard Worker }  // namespace webrtc
66