diff options
Diffstat (limited to 'o3d/utils/cross/file_path_utils_test.cc')
-rw-r--r-- | o3d/utils/cross/file_path_utils_test.cc | 183 |
1 files changed, 183 insertions, 0 deletions
diff --git a/o3d/utils/cross/file_path_utils_test.cc b/o3d/utils/cross/file_path_utils_test.cc new file mode 100644 index 0000000..e1447fc --- /dev/null +++ b/o3d/utils/cross/file_path_utils_test.cc @@ -0,0 +1,183 @@ +/* + * Copyright 2009, Google Inc. + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions are + * met: + * + * * Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * * Redistributions in binary form must reproduce the above + * copyright notice, this list of conditions and the following disclaimer + * in the documentation and/or other materials provided with the + * distribution. + * * Neither the name of Google Inc. nor the names of its + * contributors may be used to endorse or promote products derived from + * this software without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS + * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT + * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR + * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT + * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, + * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT + * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, + * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY + * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT + * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE + * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + */ + + +// This file contains the tests of the file path utils. +#include <stdio.h> + +#include "base/file_path.h" +#include "base/file_util.h" +#include "tests/common/win/testing_common.h" +#include "utils/cross/file_path_utils.h" + +namespace o3d { + +class FilePathUtilsTest : public testing::Test { +}; + +TEST_F(FilePathUtilsTest, ConvertFilePathToUTF8) { + std::string test_path("/this/is/a/path"); + FilePath source_path(FILE_PATH_LITERAL("/this/is/a/path")); + EXPECT_EQ(test_path, FilePathToUTF8(source_path)); +} + +TEST_F(FilePathUtilsTest, ConvertFilePathToWide) { + std::wstring test_path(L"/this/is/a/path"); + FilePath source_path(FILE_PATH_LITERAL("/this/is/a/path")); + EXPECT_EQ(test_path, FilePathToWide(source_path)); +} + +TEST_F(FilePathUtilsTest, ConvertWideToFilePath) { + std::wstring test_path(L"/this/is/a/path"); + FilePath dest_path = WideToFilePath(test_path); + EXPECT_STREQ(FILE_PATH_LITERAL("/this/is/a/path"), dest_path.value().c_str()); +} + +TEST_F(FilePathUtilsTest, ConvertUTF8ToFilePath) { + std::string test_path("/this/is/a/path"); + FilePath dest_path = UTF8ToFilePath(test_path); + EXPECT_STREQ(FILE_PATH_LITERAL("/this/is/a/path"), dest_path.value().c_str()); +} + +TEST_F(FilePathUtilsTest, AbsolutePathBasic) { + FilePath cwd; + file_util::GetCurrentDirectory(&cwd); +#if defined(OS_WIN) + FilePath test_path(FILE_PATH_LITERAL("this\\is\\a\\path")); +#else + FilePath test_path(FILE_PATH_LITERAL("this/is/a/path")); +#endif + FilePath abs_path = test_path; + bool result = AbsolutePath(&abs_path); + FilePath expected_result = cwd; + expected_result = expected_result.Append(test_path); + EXPECT_STREQ(expected_result.value().c_str(), abs_path.value().c_str()); +} + +TEST_F(FilePathUtilsTest, AbsolutePathAlreadyAbsolute) { +#if defined(OS_WIN) + FilePath test_path(FILE_PATH_LITERAL("c:\\this\\is\\a\\path")); +#else + FilePath test_path(FILE_PATH_LITERAL("/this/is/a/path")); +#endif + FilePath abs_path = test_path; + bool result = AbsolutePath(&abs_path); + EXPECT_STREQ(test_path.value().c_str(), abs_path.value().c_str()); +} + +#if defined(OS_WIN) +TEST_F(FilePathUtilsTest, AbsolutePathAlreadyAbsoluteWindowsUnc) { + FilePath test_path(FILE_PATH_LITERAL("\\\\this\\is\\a\\path")); + FilePath abs_path = test_path; + bool result = AbsolutePath(&abs_path); + EXPECT_STREQ(test_path.value().c_str(), abs_path.value().c_str()); +} +#endif + +TEST_F(FilePathUtilsTest, RelativePathsBasic) { +#if defined(OS_WIN) + FilePath expected_result(FILE_PATH_LITERAL("under\\parent")); +#else + FilePath expected_result(FILE_PATH_LITERAL("under/parent")); +#endif + FilePath base_path(FILE_PATH_LITERAL("/this/is/a/path")); + FilePath child_path(FILE_PATH_LITERAL("/this/is/a/path/under/parent")); + FilePath result; + bool is_relative = GetRelativePathIfPossible(base_path, child_path, &result); + EXPECT_STREQ(expected_result.value().c_str(), result.value().c_str()); + EXPECT_TRUE(is_relative); +} + +#if defined(OS_WIN) +TEST_F(FilePathUtilsTest, RelativePathsWindowsAbsolute) { + FilePath expected_result(FILE_PATH_LITERAL("under\\parent")); + FilePath base_path(FILE_PATH_LITERAL("c:\\this\\is\\a\\path")); + FilePath child_path( + FILE_PATH_LITERAL("c:\\this\\is\\a\\path\\under\\parent")); + FilePath result; + bool is_relative = GetRelativePathIfPossible(base_path, child_path, &result); + EXPECT_STREQ(expected_result.value().c_str(), result.value().c_str()); + EXPECT_TRUE(is_relative); +} + +TEST_F(FilePathUtilsTest, RelativePathsWindowsDifferentDrives) { + FilePath base_path(FILE_PATH_LITERAL("c:\\this\\is\\a\\path")); + FilePath child_path( + FILE_PATH_LITERAL("d:\\this\\is\\a\\path\\not\\under\\parent")); + FilePath result; + bool is_relative = GetRelativePathIfPossible(base_path, child_path, &result); + EXPECT_STREQ(child_path.value().c_str(), result.value().c_str()); + EXPECT_FALSE(is_relative); +} +#endif + +TEST_F(FilePathUtilsTest, RelativePathsCaseDifferent) { + FilePath base_path(FILE_PATH_LITERAL("/This/Is/A/Path")); + FilePath child_path(FILE_PATH_LITERAL("/this/is/a/path/under/parent")); + FilePath result; + bool is_relative = GetRelativePathIfPossible(base_path, child_path, &result); +#if defined(OS_WIN) + EXPECT_STREQ(FILE_PATH_LITERAL("under\\parent"), result.value().c_str()); + EXPECT_TRUE(is_relative); +#else + EXPECT_STREQ(child_path.value().c_str(), result.value().c_str()); + EXPECT_FALSE(is_relative); +#endif +} + +TEST_F(FilePathUtilsTest, RelativePathsTrailingSlash) { +#if defined(OS_WIN) + FilePath expected_result(FILE_PATH_LITERAL("under\\parent")); +#else + FilePath expected_result(FILE_PATH_LITERAL("under/parent")); +#endif + FilePath base_path(FILE_PATH_LITERAL("/this/is/a/path/")); + FilePath child_path(FILE_PATH_LITERAL("/this/is/a/path/under/parent")); + FilePath result; + bool is_relative = GetRelativePathIfPossible(base_path, child_path, &result); + EXPECT_STREQ(expected_result.value().c_str(), result.value().c_str()); + EXPECT_TRUE(is_relative); +} + +TEST_F(FilePathUtilsTest, RelativePathsRelativeInputs) { +#if defined(OS_WIN) + FilePath expected_result(FILE_PATH_LITERAL("under\\parent")); +#else + FilePath expected_result(FILE_PATH_LITERAL("under/parent")); +#endif + FilePath base_path(FILE_PATH_LITERAL("this/is/a/path")); + FilePath child_path(FILE_PATH_LITERAL("this/is/a/path/under/parent")); + FilePath result; + bool is_relative = GetRelativePathIfPossible(base_path, child_path, &result); + EXPECT_STREQ(expected_result.value().c_str(), result.value().c_str()); + EXPECT_TRUE(is_relative); +} +} // namespace o3d |