From 040eee1aa49b49df4698d83a05af57c220127fd1 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Sat, 4 May 2024 13:36:04 +0200 Subject: Adding upstream version 2.2.0. Signed-off-by: Daniel Baumann --- src/lib/util/tests/file_utilities_unittest.cc | 86 +++++++++++++++++++++++++++ 1 file changed, 86 insertions(+) create mode 100644 src/lib/util/tests/file_utilities_unittest.cc (limited to 'src/lib/util/tests/file_utilities_unittest.cc') diff --git a/src/lib/util/tests/file_utilities_unittest.cc b/src/lib/util/tests/file_utilities_unittest.cc new file mode 100644 index 0000000..4ee9093 --- /dev/null +++ b/src/lib/util/tests/file_utilities_unittest.cc @@ -0,0 +1,86 @@ +// Copyright (C) 2015-2022 Internet Systems Consortium, Inc. ("ISC") +// +// This Source Code Form is subject to the terms of the Mozilla Public +// License, v. 2.0. If a copy of the MPL was not distributed with this +// file, You can obtain one at http://mozilla.org/MPL/2.0/. + +#include + +#include +#include +#include +#include + +using namespace isc; +using namespace isc::util::file; +using namespace std; + +namespace { + +/// @brief Test fixture class for testing operations on files. +class FileUtilTest : public ::testing::Test { +public: + + /// @brief Destructor. + /// + /// Deletes the test file if any. + virtual ~FileUtilTest(); +}; + +FileUtilTest::~FileUtilTest() { + string test_file_name = string(TEST_DATA_BUILDDIR) + "/fu.test"; + static_cast(remove(test_file_name.c_str())); +} + +/// @brief Check an error is returned by getContent on not existent file. +TEST_F(FileUtilTest, notExists) { + string file_name("/this/does/not/exists"); + try { + string c = getContent(file_name); + FAIL() << "this test must throw before this line"; + } catch (const BadValue& ex) { + string expected = "can't open file '" + file_name; + expected += "': No such file or directory"; + EXPECT_EQ(string(ex.what()), expected); + } catch (const std::exception& ex) { + FAIL() << "unexpected exception: " << ex.what(); + } +} + +/// @note No easy can't stat. + +/// @brief Check an error is returned by getContent on not regular file. +TEST_F(FileUtilTest, notRegular) { + string file_name("/"); + try { + string c = getContent(file_name); + FAIL() << "this test must throw before this line"; + } catch (const BadValue& ex) { + string expected = "'" + file_name + "' must be a regular file"; + EXPECT_EQ(string(ex.what()), expected); + } catch (const std::exception& ex) { + FAIL() << "unexpected exception: " << ex.what(); + } +} + +/// @brief Check getContent works. +TEST_F(FileUtilTest, basic) { + string file_name = string(TEST_DATA_BUILDDIR) + "/fu.test"; + ofstream fs(file_name.c_str(), ofstream::out | ofstream::trunc); + ASSERT_TRUE(fs.is_open()); + fs << "abdc"; + fs.close(); + string content; + EXPECT_NO_THROW(content = getContent(file_name)); + EXPECT_EQ("abdc", content); +} + +/// @brief Check isDir works. +TEST_F(FileUtilTest, isDir) { + EXPECT_TRUE(isDir("/dev")); + EXPECT_FALSE(isDir("/dev/null")); + EXPECT_FALSE(isDir("/this/does/not/exists")); + EXPECT_FALSE(isDir("/etc/hosts")); +} + +} -- cgit v1.2.3