| // Licensed under the Apache License, Version 2.0 (the "License"); |
| // you may not use this file except in compliance with the License. |
| // You may obtain a copy of the License at |
| // |
| // http://www.apache.org/licenses/LICENSE-2.0 |
| // |
| // Unless required by applicable law or agreed to in writing, software |
| // distributed under the License is distributed on an "AS IS" BASIS, |
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| // See the License for the specific language governing permissions and |
| // limitations under the License. |
| |
| #ifndef __STOUT_TESTS_UTILS_HPP__ |
| #define __STOUT_TESTS_UTILS_HPP__ |
| |
| #include <string> |
| |
| #include <gtest/gtest.h> |
| |
| #include <stout/gtest.hpp> |
| #include <stout/try.hpp> |
| |
| #include <stout/os/chdir.hpp> |
| #include <stout/os/getcwd.hpp> |
| #include <stout/os/mkdtemp.hpp> |
| #include <stout/os/realpath.hpp> |
| #include <stout/os/rmdir.hpp> |
| |
| #if __FreeBSD__ |
| #include <stout/os/sysctl.hpp> |
| #endif |
| |
| class TemporaryDirectoryTest : public ::testing::Test |
| { |
| protected: |
| void SetUp() override |
| { |
| // Save the current working directory. |
| cwd = os::getcwd(); |
| |
| // Create a temporary directory for the test. |
| Try<std::string> directory = os::mkdtemp(); |
| ASSERT_SOME(directory) << "Failed to mkdtemp"; |
| |
| // We get the `realpath` of the temporary directory because some |
| // platforms, like macOS, symlink `/tmp` to `/private/var`, but |
| // return the symlink name when creating temporary directories. |
| // This is problematic because a lot of tests compare the |
| // `realpath` of a temporary file. |
| Result<std::string> realpath = os::realpath(directory.get()); |
| ASSERT_SOME(realpath) << "Failed to get realpath of '" << directory.get() |
| << "': " |
| << (realpath.isError() ? realpath.error() |
| : "No such directory"); |
| sandbox = realpath.get(); |
| |
| // Run the test out of the temporary directory we created. |
| ASSERT_SOME(os::chdir(sandbox.get())) |
| << "Failed to chdir into '" << sandbox.get() << "'"; |
| } |
| |
| void TearDown() override |
| { |
| // Return to previous working directory and cleanup the sandbox. |
| ASSERT_SOME(os::chdir(cwd)); |
| |
| if (sandbox.isSome()) { |
| ASSERT_SOME(os::rmdir(sandbox.get())); |
| } |
| } |
| |
| // A temporary directory for test purposes. |
| // Not to be confused with the "sandbox" that tasks are run in. |
| Option<std::string> sandbox; |
| |
| private: |
| std::string cwd; |
| }; |
| |
| |
| #ifdef __FreeBSD__ |
| inline bool isJailed() { |
| int mib[4]; |
| size_t len = 4; |
| ::sysctlnametomib("security.jail.jailed", mib, &len); |
| Try<int> jailed = os::sysctl(mib[0], mib[1], mib[2]).integer(); |
| if (jailed.isSome()) { |
| return jailed.get() == 1; |
| } |
| |
| return false; |
| } |
| #endif |
| |
| #endif // __STOUT_TESTS_UTILS_HPP__ |