// Copyright 2014 The Chromium OS Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #include "brillo/file_utils.h" #include <sys/stat.h> #include <unistd.h> #include <string> #include <base/files/file_util.h> #include <base/files/scoped_temp_dir.h> #include <gtest/gtest.h> namespace brillo { class FileUtilsTest : public testing::Test { public: FileUtilsTest() { CHECK(temp_dir_.CreateUniqueTempDir()); file_path_ = temp_dir_.path().Append("test.temp"); } protected: base::FilePath file_path_; base::ScopedTempDir temp_dir_; // Writes |contents| to |file_path_|. Pulled into a separate function just // to improve readability of tests. void WriteFile(const std::string& contents) { EXPECT_EQ(contents.length(), base::WriteFile(file_path_, contents.c_str(), contents.length())); } // Verifies that the file at |file_path_| exists and contains |contents|. void ExpectFileContains(const std::string& contents) { EXPECT_TRUE(base::PathExists(file_path_)); std::string new_contents; EXPECT_TRUE(base::ReadFileToString(file_path_, &new_contents)); EXPECT_EQ(contents, new_contents); } // Verifies that the file at |file_path_| has |permissions|. void ExpectFilePermissions(int permissions) { int actual_permissions; EXPECT_TRUE(base::GetPosixFilePermissions(file_path_, &actual_permissions)); EXPECT_EQ(permissions, actual_permissions); } }; namespace { enum { kPermissions600 = base::FILE_PERMISSION_READ_BY_USER | base::FILE_PERMISSION_WRITE_BY_USER, kPermissions700 = base::FILE_PERMISSION_USER_MASK, kPermissions777 = base::FILE_PERMISSION_MASK }; } // namespace TEST_F(FileUtilsTest, TouchFileCreate) { EXPECT_TRUE(TouchFile(file_path_)); ExpectFileContains(""); ExpectFilePermissions(kPermissions600); } TEST_F(FileUtilsTest, TouchFileCreateThroughUmask) { mode_t old_umask = umask(kPermissions777); EXPECT_TRUE(TouchFile(file_path_)); umask(old_umask); ExpectFileContains(""); ExpectFilePermissions(kPermissions600); } TEST_F(FileUtilsTest, TouchFileCreateDirectoryStructure) { file_path_ = temp_dir_.path().Append("foo/bar/baz/test.temp"); EXPECT_TRUE(TouchFile(file_path_)); ExpectFileContains(""); } TEST_F(FileUtilsTest, TouchFileExisting) { WriteFile("abcd"); EXPECT_TRUE(TouchFile(file_path_)); ExpectFileContains("abcd"); } TEST_F(FileUtilsTest, TouchFileReplaceDirectory) { EXPECT_TRUE(base::CreateDirectory(file_path_)); EXPECT_TRUE(TouchFile(file_path_)); EXPECT_FALSE(base::DirectoryExists(file_path_)); ExpectFileContains(""); } TEST_F(FileUtilsTest, TouchFileReplaceSymlink) { base::FilePath symlink_target = temp_dir_.path().Append("target.temp"); EXPECT_TRUE(base::CreateSymbolicLink(symlink_target, file_path_)); EXPECT_TRUE(TouchFile(file_path_)); EXPECT_FALSE(base::IsLink(file_path_)); ExpectFileContains(""); } TEST_F(FileUtilsTest, TouchFileReplaceOtherUser) { WriteFile("abcd"); EXPECT_TRUE(TouchFile(file_path_, kPermissions777, geteuid() + 1, getegid())); ExpectFileContains(""); } TEST_F(FileUtilsTest, TouchFileReplaceOtherGroup) { WriteFile("abcd"); EXPECT_TRUE(TouchFile(file_path_, kPermissions777, geteuid(), getegid() + 1)); ExpectFileContains(""); } TEST_F(FileUtilsTest, TouchFileCreateWithAllPermissions) { EXPECT_TRUE(TouchFile(file_path_, kPermissions777, geteuid(), getegid())); ExpectFileContains(""); ExpectFilePermissions(kPermissions777); } TEST_F(FileUtilsTest, TouchFileCreateWithOwnerPermissions) { EXPECT_TRUE(TouchFile(file_path_, kPermissions700, geteuid(), getegid())); ExpectFileContains(""); ExpectFilePermissions(kPermissions700); } TEST_F(FileUtilsTest, TouchFileExistingPermissionsUnchanged) { EXPECT_TRUE(TouchFile(file_path_, kPermissions777, geteuid(), getegid())); EXPECT_TRUE(TouchFile(file_path_, kPermissions700, geteuid(), getegid())); ExpectFileContains(""); ExpectFilePermissions(kPermissions777); } } // namespace brillo