mirror of https://github.com/pvnis/srsRAN_4G.git
You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
116 lines
3.5 KiB
C++
116 lines
3.5 KiB
C++
5 years ago
|
/*
|
||
|
* Copyright 2013-2020 Software Radio Systems Limited
|
||
|
*
|
||
|
* This file is part of srsLTE.
|
||
|
*
|
||
|
* srsLTE is free software: you can redistribute it and/or modify
|
||
|
* it under the terms of the GNU Affero General Public License as
|
||
|
* published by the Free Software Foundation, either version 3 of
|
||
|
* the License, or (at your option) any later version.
|
||
|
*
|
||
|
* srsLTE is distributed in the hope that it will be useful,
|
||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
|
* GNU Affero General Public License for more details.
|
||
|
*
|
||
|
* A copy of the GNU Affero General Public License can be found in
|
||
|
* the LICENSE file in the top-level directory of this distribution
|
||
|
* and at http://www.gnu.org/licenses/.
|
||
|
*
|
||
|
*/
|
||
|
|
||
|
#include "src/srslog/sinks/file_sink.h"
|
||
|
#include "file_test_utils.h"
|
||
|
#include "testing_helpers.h"
|
||
|
|
||
|
using namespace srslog;
|
||
|
|
||
|
static const char* const log_filename = "testfile.log";
|
||
|
|
||
|
static bool when_data_is_written_to_file_then_contents_are_valid()
|
||
|
{
|
||
|
file_test_utils::scoped_file_deleter deleter(log_filename);
|
||
|
file_sink file(log_filename, 0);
|
||
|
|
||
|
std::vector<std::string> entries;
|
||
|
for (unsigned i = 0; i != 10; ++i) {
|
||
|
std::string entry = "Test log entry - " + std::to_string(i) + '\n';
|
||
|
file.write(detail::memory_buffer(entry));
|
||
|
entries.push_back(entry);
|
||
|
}
|
||
|
|
||
|
file.flush();
|
||
|
|
||
|
ASSERT_EQ(file_test_utils::file_exists(log_filename), true);
|
||
|
ASSERT_EQ(file_test_utils::compare_file_contents(log_filename, entries),
|
||
|
true);
|
||
|
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
static bool when_data_written_exceeds_size_threshold_then_new_file_is_created()
|
||
|
{
|
||
|
std::string filename0 =
|
||
|
file_utils::build_filename_with_index(log_filename, 0);
|
||
|
std::string filename1 =
|
||
|
file_utils::build_filename_with_index(log_filename, 1);
|
||
|
std::string filename2 =
|
||
|
file_utils::build_filename_with_index(log_filename, 2);
|
||
|
file_test_utils::scoped_file_deleter deleter = {
|
||
|
filename0, filename1, filename2};
|
||
|
|
||
|
file_sink file(log_filename, 5001);
|
||
|
|
||
|
// Build a 1000 byte entry.
|
||
|
std::string entry(1000, 'a');
|
||
|
|
||
|
// Fill in the file with 5000 bytes, one byte less than the threshold.
|
||
|
for (unsigned i = 0; i != 5; ++i) {
|
||
|
file.write(detail::memory_buffer(entry));
|
||
|
}
|
||
|
file.flush();
|
||
|
|
||
|
// Only one file should exist.
|
||
|
ASSERT_EQ(file_test_utils::file_exists(filename0), true);
|
||
|
ASSERT_EQ(file_test_utils::file_exists(filename1), false);
|
||
|
|
||
|
// Trigger a file rotation.
|
||
|
file.write(detail::memory_buffer(entry));
|
||
|
file.flush();
|
||
|
|
||
|
// A second file should be created.
|
||
|
ASSERT_EQ(file_test_utils::file_exists(filename0), true);
|
||
|
ASSERT_EQ(file_test_utils::file_exists(filename1), true);
|
||
|
|
||
|
// Fill in the second file with 4000 bytes, one byte less than the threshold.
|
||
|
for (unsigned i = 0; i != 4; ++i) {
|
||
|
file.write(detail::memory_buffer(entry));
|
||
|
}
|
||
|
file.flush();
|
||
|
|
||
|
// Two file should exist, third should not be created yet.
|
||
|
ASSERT_EQ(file_test_utils::file_exists(filename0), true);
|
||
|
ASSERT_EQ(file_test_utils::file_exists(filename1), true);
|
||
|
ASSERT_EQ(file_test_utils::file_exists(filename2), false);
|
||
|
|
||
|
// Trigger a file rotation.
|
||
|
file.write(detail::memory_buffer(entry));
|
||
|
file.flush();
|
||
|
|
||
|
// Three files should exist.
|
||
|
ASSERT_EQ(file_test_utils::file_exists(filename0), true);
|
||
|
ASSERT_EQ(file_test_utils::file_exists(filename1), true);
|
||
|
ASSERT_EQ(file_test_utils::file_exists(filename2), true);
|
||
|
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
int main()
|
||
|
{
|
||
|
TEST_FUNCTION(when_data_is_written_to_file_then_contents_are_valid);
|
||
|
TEST_FUNCTION(
|
||
|
when_data_written_exceeds_size_threshold_then_new_file_is_created);
|
||
|
|
||
|
return 0;
|
||
|
}
|