[97276] | 1 | /* $Id */
|
---|
| 2 | /** @file
|
---|
| 3 | * Guest Control path test cases.
|
---|
| 4 | */
|
---|
| 5 |
|
---|
| 6 | /*
|
---|
[98103] | 7 | * Copyright (C) 2022-2023 Oracle and/or its affiliates.
|
---|
[97276] | 8 | *
|
---|
| 9 | * This file is part of VirtualBox base platform packages, as
|
---|
| 10 | * available from https://www.virtualbox.org.
|
---|
| 11 | *
|
---|
| 12 | * This program is free software; you can redistribute it and/or
|
---|
| 13 | * modify it under the terms of the GNU General Public License
|
---|
| 14 | * as published by the Free Software Foundation, in version 3 of the
|
---|
| 15 | * License.
|
---|
| 16 | *
|
---|
| 17 | * This program is distributed in the hope that it will be useful, but
|
---|
| 18 | * WITHOUT ANY WARRANTY; without even the implied warranty of
|
---|
| 19 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
---|
| 20 | * General Public License for more details.
|
---|
| 21 | *
|
---|
| 22 | * You should have received a copy of the GNU General Public License
|
---|
| 23 | * along with this program; if not, see <https://www.gnu.org/licenses>.
|
---|
| 24 | *
|
---|
| 25 | * SPDX-License-Identifier: GPL-3.0-only
|
---|
| 26 | */
|
---|
| 27 |
|
---|
| 28 | #define LOG_ENABLED
|
---|
| 29 | #define LOG_GROUP LOG_GROUP_MAIN
|
---|
| 30 | #include <VBox/log.h>
|
---|
| 31 |
|
---|
| 32 | #include "../include/GuestCtrlImplPrivate.h"
|
---|
| 33 |
|
---|
| 34 | using namespace com;
|
---|
| 35 |
|
---|
[97993] | 36 | #include <iprt/assert.h>
|
---|
[97276] | 37 | #include <iprt/env.h>
|
---|
| 38 | #include <iprt/rand.h>
|
---|
| 39 | #include <iprt/stream.h>
|
---|
| 40 | #include <iprt/test.h>
|
---|
| 41 |
|
---|
| 42 |
|
---|
[97538] | 43 | DECLINLINE(void) tstPathBuildDestination(const Utf8Str &strSrcPath, PathStyle_T enmSrcPathStyle,
|
---|
| 44 | const Utf8Str &strDstPath, PathStyle_T enmDstPathStyle,
|
---|
| 45 | int rcExp, Utf8Str strPathExp)
|
---|
| 46 | {
|
---|
| 47 | Utf8Str strDstPath2 = strDstPath;
|
---|
| 48 | int vrc = GuestPath::BuildDestinationPath(strSrcPath, enmSrcPathStyle, strDstPath2, enmDstPathStyle);
|
---|
| 49 | RTTESTI_CHECK_MSG_RETV(vrc == rcExp, ("Expected %Rrc, got %Rrc for '%s'\n", rcExp, vrc, strDstPath.c_str()));
|
---|
| 50 | RTTESTI_CHECK_MSG_RETV(strDstPath2 == strPathExp, ("Expected '%s', got '%s'\n", strPathExp.c_str(), strDstPath2.c_str()));
|
---|
| 51 | }
|
---|
| 52 |
|
---|
[97276] | 53 | DECLINLINE(void) tstPathTranslate(Utf8Str strPath, PathStyle_T enmSrcPathStyle, PathStyle_T enmDstPathStyle, int rcExp, Utf8Str strPathExp)
|
---|
| 54 | {
|
---|
[97538] | 55 | Utf8Str strPath2 = strPath;
|
---|
[97276] | 56 | int vrc = GuestPath::Translate(strPath2, enmSrcPathStyle, enmDstPathStyle);
|
---|
| 57 | RTTESTI_CHECK_MSG_RETV(vrc == rcExp, ("Expected %Rrc, got %Rrc for '%s'\n", rcExp, vrc, strPath.c_str()));
|
---|
| 58 | RTTESTI_CHECK_MSG_RETV(strPath2 == strPathExp, ("Expected '%s', got '%s'\n", strPathExp.c_str(), strPath2.c_str()));
|
---|
| 59 | }
|
---|
| 60 |
|
---|
| 61 | int main()
|
---|
| 62 | {
|
---|
| 63 | RTTEST hTest;
|
---|
| 64 | int vrc = RTTestInitAndCreate("tstGuestCtrlPaths", &hTest);
|
---|
| 65 | if (vrc)
|
---|
| 66 | return vrc;
|
---|
| 67 | RTTestBanner(hTest);
|
---|
| 68 |
|
---|
| 69 | RTTestIPrintf(RTTESTLVL_DEBUG, "Initializing COM...\n");
|
---|
| 70 | HRESULT hrc = com::Initialize();
|
---|
| 71 | if (FAILED(hrc))
|
---|
| 72 | {
|
---|
| 73 | RTTestFailed(hTest, "Failed to initialize COM (%Rhrc)!\n", hrc);
|
---|
| 74 | return RTEXITCODE_FAILURE;
|
---|
| 75 | }
|
---|
| 76 |
|
---|
| 77 | /* Don't let the assertions trigger here
|
---|
| 78 | * -- we rely on the return values in the test(s) below. */
|
---|
| 79 | RTAssertSetQuiet(true);
|
---|
| 80 |
|
---|
[97538] | 81 | /*
|
---|
| 82 | * Path translation testing.
|
---|
| 83 | */
|
---|
[97276] | 84 | tstPathTranslate("", PathStyle_DOS, PathStyle_DOS, VINF_SUCCESS, "");
|
---|
| 85 |
|
---|
| 86 | tstPathTranslate("foo", PathStyle_DOS, PathStyle_DOS, VINF_SUCCESS, "foo");
|
---|
| 87 | tstPathTranslate("foo", PathStyle_UNIX, PathStyle_UNIX, VINF_SUCCESS, "foo");
|
---|
| 88 | tstPathTranslate("foo", PathStyle_DOS, PathStyle_UNIX, VINF_SUCCESS, "foo");
|
---|
| 89 | tstPathTranslate("foo", PathStyle_UNIX, PathStyle_UNIX, VINF_SUCCESS, "foo");
|
---|
| 90 |
|
---|
| 91 | tstPathTranslate("foo\\bar", PathStyle_DOS, PathStyle_DOS, VINF_SUCCESS, "foo\\bar");
|
---|
| 92 | tstPathTranslate("foo/bar", PathStyle_UNIX, PathStyle_UNIX, VINF_SUCCESS, "foo/bar");
|
---|
| 93 |
|
---|
| 94 | tstPathTranslate("foo\\bar\\", PathStyle_DOS, PathStyle_DOS, VINF_SUCCESS, "foo\\bar\\");
|
---|
| 95 | tstPathTranslate("foo/bar/", PathStyle_UNIX, PathStyle_UNIX, VINF_SUCCESS, "foo/bar/");
|
---|
| 96 | /* Actually also allowed on Windows. */
|
---|
| 97 | tstPathTranslate("foo/bar/", PathStyle_DOS, PathStyle_UNIX, VINF_SUCCESS, "foo/bar/");
|
---|
| 98 |
|
---|
| 99 | tstPathTranslate("foo\\bar\\BAZ", PathStyle_DOS, PathStyle_DOS, VINF_SUCCESS, "foo\\bar\\BAZ");
|
---|
| 100 | tstPathTranslate("foo/bar/BAZ", PathStyle_UNIX, PathStyle_UNIX, VINF_SUCCESS, "foo/bar/BAZ");
|
---|
| 101 |
|
---|
| 102 | tstPathTranslate("foo\\bar\\dir with space\\", PathStyle_DOS, PathStyle_UNIX, VINF_SUCCESS, "foo/bar/dir with space/");
|
---|
| 103 | tstPathTranslate("foo/bar/dir with space/", PathStyle_UNIX, PathStyle_UNIX, VINF_SUCCESS, "foo/bar/dir with space/");
|
---|
| 104 |
|
---|
[97538] | 105 | #if 0
|
---|
[97276] | 106 | /** Do a mapping of "\", which marks an escape sequence for paths on UNIX-y OSes to DOS-based OSes (like Windows),
|
---|
| 107 | * however, on DOS "\" is a path separator. See @bugref{21095} */
|
---|
[97304] | 108 | tstPathTranslate("foo/bar/dir_with_escape_sequence\\ space", PathStyle_UNIX, PathStyle_UNIX, VINF_SUCCESS, "foo/bar/dir_with_escape_sequence\\ space");
|
---|
| 109 | tstPathTranslate("foo/bar/dir_with_escape_sequence\\ space", PathStyle_UNIX, PathStyle_DOS, VINF_SUCCESS, "foo\\bar\\dir_with_escape_sequence space");
|
---|
| 110 | tstPathTranslate("foo/bar/1_dir_with_escape_sequence/the\\ space", PathStyle_UNIX, PathStyle_DOS, VINF_SUCCESS, "foo\\bar\\1_dir_with_escape_sequence\\the space");
|
---|
| 111 | tstPathTranslate("foo/bar/2_dir_with_escape_sequence/the\\ \\ space", PathStyle_UNIX, PathStyle_DOS, VINF_SUCCESS, "foo\\bar\\2_dir_with_escape_sequence\\the space");
|
---|
[97276] | 112 | tstPathTranslate("foo/bar/dir_with_escape_sequence/spaces at end\\ \\ ", PathStyle_UNIX, PathStyle_DOS, VINF_SUCCESS, "foo\\bar\\dir_with_escape_sequence\\spaces at end ");
|
---|
[97538] | 113 | #endif
|
---|
[97276] | 114 |
|
---|
| 115 | /* Filter out double slashes (cosmetic only). */
|
---|
| 116 | tstPathTranslate("\\\\", PathStyle_DOS, PathStyle_DOS, VINF_SUCCESS, "\\");
|
---|
| 117 | tstPathTranslate("foo\\\\bar\\", PathStyle_DOS, PathStyle_DOS, VINF_SUCCESS, "foo\\bar\\");
|
---|
| 118 |
|
---|
| 119 | /* Mixed slashes. */
|
---|
[97538] | 120 | tstPathTranslate("\\\\foo/bar\\\\baz", PathStyle_UNIX, PathStyle_UNIX, VINF_SUCCESS, "\\\\foo/bar\\\\baz");
|
---|
| 121 | #if 0 /** @todo Not clear what to expect here. */
|
---|
[97276] | 122 | tstPathTranslate("with spaces\\ foo/\\ bar", PathStyle_UNIX, PathStyle_DOS, VINF_SUCCESS, "with spaces foo\\ bar");
|
---|
[97538] | 123 | #endif
|
---|
[97276] | 124 |
|
---|
[97538] | 125 | /*
|
---|
| 126 | * Destination path building testing.
|
---|
| 127 | */
|
---|
[97993] | 128 | bool fQuiet = RTAssertSetQuiet(true);
|
---|
| 129 | bool fMayPanic = RTAssertSetMayPanic(false);
|
---|
[97538] | 130 | tstPathBuildDestination("", PathStyle_UNIX, "", PathStyle_UNIX, VERR_PATH_ZERO_LENGTH, "");
|
---|
| 131 | tstPathBuildDestination(".", PathStyle_UNIX, ".", PathStyle_UNIX, VINF_SUCCESS, ".");
|
---|
| 132 | tstPathBuildDestination("..", PathStyle_UNIX, "..", PathStyle_UNIX, VERR_INVALID_PARAMETER, "..");
|
---|
| 133 | tstPathBuildDestination("/tmp/", PathStyle_UNIX, "/root/../foo", PathStyle_UNIX, VERR_INVALID_PARAMETER, "/root/../foo");
|
---|
| 134 | /* ".." in actual file names are allowed. */
|
---|
| 135 | tstPathBuildDestination("/tmp/", PathStyle_UNIX, "/root/foo..bar", PathStyle_UNIX, VINF_SUCCESS, "/root/foo..bar");
|
---|
| 136 | /* Ditto for path names which consist of more than just "..". */
|
---|
| 137 | tstPathBuildDestination("/tmp/", PathStyle_UNIX, "/root/foo..bar/baz", PathStyle_UNIX, VINF_SUCCESS, "/root/foo..bar/baz");
|
---|
| 138 | tstPathBuildDestination("...", PathStyle_UNIX, "...", PathStyle_UNIX, VINF_SUCCESS, "...");
|
---|
| 139 | tstPathBuildDestination("foo", PathStyle_UNIX, "bar", PathStyle_UNIX, VINF_SUCCESS, "bar");
|
---|
| 140 | tstPathBuildDestination("foo/", PathStyle_UNIX, "bar/", PathStyle_UNIX, VINF_SUCCESS, "bar/");
|
---|
| 141 | tstPathBuildDestination("foo/", PathStyle_UNIX, "bar/baz", PathStyle_UNIX, VINF_SUCCESS, "bar/baz");
|
---|
| 142 | tstPathBuildDestination("foo/baz", PathStyle_UNIX, "bar/", PathStyle_UNIX, VINF_SUCCESS, "bar/baz");
|
---|
| 143 | tstPathBuildDestination("foo/baz", PathStyle_UNIX, "bar\\", PathStyle_DOS, VINF_SUCCESS, "bar\\baz");
|
---|
| 144 |
|
---|
| 145 | tstPathBuildDestination("c:\\temp\\", PathStyle_DOS, "/tmp/", PathStyle_UNIX, VINF_SUCCESS, "/tmp/");
|
---|
| 146 | tstPathBuildDestination("c:\\TEMP\\", PathStyle_DOS, "/TmP/", PathStyle_UNIX, VINF_SUCCESS, "/TmP/");
|
---|
| 147 | tstPathBuildDestination("c:\\temp\\foo.txt", PathStyle_DOS, "/tmp/foo.txt", PathStyle_UNIX, VINF_SUCCESS, "/tmp/foo.txt");
|
---|
| 148 | tstPathBuildDestination("c:\\temp\\bar\\foo.txt", PathStyle_DOS, "/tmp/foo2.txt", PathStyle_UNIX, VINF_SUCCESS, "/tmp/foo2.txt");
|
---|
| 149 | tstPathBuildDestination("c:\\temp\\bar\\foo3.txt", PathStyle_DOS, "/tmp/", PathStyle_UNIX, VINF_SUCCESS, "/tmp/foo3.txt");
|
---|
| 150 |
|
---|
| 151 | tstPathBuildDestination("/tmp/bar/", PathStyle_UNIX, "c:\\temp\\", PathStyle_DOS, VINF_SUCCESS, "c:\\temp\\");
|
---|
| 152 | tstPathBuildDestination("/tmp/BaR/", PathStyle_UNIX, "c:\\tEmP\\", PathStyle_DOS, VINF_SUCCESS, "c:\\tEmP\\");
|
---|
| 153 | tstPathBuildDestination("/tmp/foo.txt", PathStyle_UNIX, "c:\\temp\\foo.txt", PathStyle_DOS, VINF_SUCCESS, "c:\\temp\\foo.txt");
|
---|
| 154 | tstPathBuildDestination("/tmp/bar/foo.txt", PathStyle_UNIX, "c:\\temp\\foo2.txt", PathStyle_DOS, VINF_SUCCESS, "c:\\temp\\foo2.txt");
|
---|
| 155 | tstPathBuildDestination("/tmp/bar/foo3.txt", PathStyle_UNIX, "c:\\temp\\", PathStyle_DOS, VINF_SUCCESS, "c:\\temp\\foo3.txt");
|
---|
[97993] | 156 | RTAssertSetMayPanic(fMayPanic);
|
---|
| 157 | RTAssertSetQuiet(fQuiet);
|
---|
[97538] | 158 |
|
---|
[97276] | 159 | RTTestIPrintf(RTTESTLVL_DEBUG, "Shutting down COM...\n");
|
---|
| 160 | com::Shutdown();
|
---|
| 161 |
|
---|
| 162 | /*
|
---|
| 163 | * Summary.
|
---|
| 164 | */
|
---|
| 165 | return RTTestSummaryAndDestroy(hTest);
|
---|
| 166 | }
|
---|
| 167 |
|
---|