blob: e61eb6e52f91f8a2c252e372717c85c47d115e16 [file] [log] [blame]
Mike Lockwood94afecf2012-10-24 10:45:23 -07001/*
2 * Copyright (C) 2011 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#include <stdlib.h>
18#include <string.h>
19
Jeff Sharkeyc1149c92017-09-21 14:51:09 -060020#include <android-base/logging.h>
Nikita Ioffe77be2ed2019-01-25 13:54:43 +000021#include <android-base/scopeguard.h>
Mike Lockwood94afecf2012-10-24 10:45:23 -070022#include <gtest/gtest.h>
23
Jeff Sharkeyf3e30b92016-12-09 17:06:57 -070024#include "InstalldNativeService.h"
Jeff Sharkey725ae2b2018-09-28 10:07:14 -060025#include "MatchExtensionGen.h"
Jeff Sharkeyf3e30b92016-12-09 17:06:57 -070026#include "globals.h"
27#include "utils.h"
Jeff Sharkey19803802015-04-07 12:44:51 -070028
29#undef LOG_TAG
30#define LOG_TAG "utils_test"
Mike Lockwood94afecf2012-10-24 10:45:23 -070031
32#define TEST_DATA_DIR "/data/"
Jeff Sharkeyc1149c92017-09-21 14:51:09 -060033#define TEST_ROOT_DIR "/system/"
Mike Lockwood94afecf2012-10-24 10:45:23 -070034#define TEST_APP_DIR "/data/app/"
35#define TEST_APP_PRIVATE_DIR "/data/app-private/"
Jeff Sharkey871a8f22017-02-21 18:30:28 -070036#define TEST_APP_EPHEMERAL_DIR "/data/app-ephemeral/"
Mike Lockwood94afecf2012-10-24 10:45:23 -070037#define TEST_ASEC_DIR "/mnt/asec/"
Jeff Sharkey8fa803a2018-04-09 18:46:45 -060038#define TEST_EXPAND_DIR "/mnt/expand/00000000-0000-0000-0000-000000000000/"
Mike Lockwood94afecf2012-10-24 10:45:23 -070039
40#define TEST_SYSTEM_DIR1 "/system/app/"
41#define TEST_SYSTEM_DIR2 "/vendor/app/"
42
Calin Juravle76268c52017-03-09 13:19:42 -080043#define TEST_PROFILE_DIR "/data/misc/profiles"
44
Mike Lockwood94afecf2012-10-24 10:45:23 -070045namespace android {
Andreas Gampe02d0de52015-11-11 20:43:16 -080046namespace installd {
Mike Lockwood94afecf2012-10-24 10:45:23 -070047
48class UtilsTest : public testing::Test {
49protected:
50 virtual void SetUp() {
Jeff Sharkeyc1149c92017-09-21 14:51:09 -060051 setenv("ANDROID_LOG_TAGS", "*:v", 1);
52 android::base::InitLogging(nullptr);
Mike Lockwood94afecf2012-10-24 10:45:23 -070053
Jeff Sharkeyc1149c92017-09-21 14:51:09 -060054 init_globals_from_data_and_root(TEST_DATA_DIR, TEST_ROOT_DIR);
Mike Lockwood94afecf2012-10-24 10:45:23 -070055 }
56
57 virtual void TearDown() {
Mike Lockwood94afecf2012-10-24 10:45:23 -070058 }
Calin Juravle3760ad32017-07-27 16:31:55 -070059
60 std::string create_too_long_path(const std::string& seed) {
61 std::string result = seed;
62 for (size_t i = seed.size(); i < PKG_PATH_MAX; i++) {
63 result += "a";
64 }
65 return result;
66 }
Mike Lockwood94afecf2012-10-24 10:45:23 -070067};
68
69TEST_F(UtilsTest, IsValidApkPath_BadPrefix) {
70 // Bad prefixes directories
71 const char *badprefix1 = "/etc/passwd";
72 EXPECT_EQ(-1, validate_apk_path(badprefix1))
Jeff Sharkey871a8f22017-02-21 18:30:28 -070073 << badprefix1 << " should not be allowed as a valid path";
Mike Lockwood94afecf2012-10-24 10:45:23 -070074
75 const char *badprefix2 = "../.." TEST_APP_DIR "../../../blah";
76 EXPECT_EQ(-1, validate_apk_path(badprefix2))
Jeff Sharkey871a8f22017-02-21 18:30:28 -070077 << badprefix2 << " should not be allowed as a valid path";
Mike Lockwood94afecf2012-10-24 10:45:23 -070078
79 const char *badprefix3 = "init.rc";
80 EXPECT_EQ(-1, validate_apk_path(badprefix3))
Jeff Sharkey871a8f22017-02-21 18:30:28 -070081 << badprefix3 << " should not be allowed as a valid path";
Mike Lockwood94afecf2012-10-24 10:45:23 -070082
83 const char *badprefix4 = "/init.rc";
84 EXPECT_EQ(-1, validate_apk_path(badprefix4))
Jeff Sharkey871a8f22017-02-21 18:30:28 -070085 << badprefix4 << " should not be allowed as a valid path";
Mike Lockwood94afecf2012-10-24 10:45:23 -070086}
87
88TEST_F(UtilsTest, IsValidApkPath_Internal) {
89 // Internal directories
90 const char *internal1 = TEST_APP_DIR "example.apk";
91 EXPECT_EQ(0, validate_apk_path(internal1))
92 << internal1 << " should be allowed as a valid path";
93
Calin Juravlefd88ff22014-08-15 15:45:51 +010094 // b/16888084
95 const char *path2 = TEST_APP_DIR "example.com/example.apk";
96 EXPECT_EQ(0, validate_apk_path(path2))
97 << path2 << " should be allowed as a valid path";
98
Mike Lockwood94afecf2012-10-24 10:45:23 -070099 const char *badint1 = TEST_APP_DIR "../example.apk";
100 EXPECT_EQ(-1, validate_apk_path(badint1))
101 << badint1 << " should be rejected as a invalid path";
102
103 const char *badint2 = TEST_APP_DIR "/../example.apk";
104 EXPECT_EQ(-1, validate_apk_path(badint2))
105 << badint2 << " should be rejected as a invalid path";
106
Calin Juravlefd88ff22014-08-15 15:45:51 +0100107 // Only one subdir should be allowed.
108 const char *bad_path3 = TEST_APP_DIR "example.com/subdir/pkg.apk";
109 EXPECT_EQ(-1, validate_apk_path(bad_path3))
110 << bad_path3 << " should be rejected as a invalid path";
Calin Juravlec597b6d2014-08-19 17:43:05 +0100111
112 const char *bad_path4 = TEST_APP_DIR "example.com/subdir/../pkg.apk";
113 EXPECT_EQ(-1, validate_apk_path(bad_path4))
114 << bad_path4 << " should be rejected as a invalid path";
115
116 const char *bad_path5 = TEST_APP_DIR "example.com1/../example.com2/pkg.apk";
117 EXPECT_EQ(-1, validate_apk_path(bad_path5))
118 << bad_path5 << " should be rejected as a invalid path";
Mike Lockwood94afecf2012-10-24 10:45:23 -0700119}
120
Jeff Sharkey8fa803a2018-04-09 18:46:45 -0600121TEST_F(UtilsTest, IsValidApkPath_TopDir) {
122 EXPECT_EQ(0, validate_apk_path(TEST_DATA_DIR "app/com.example"));
123 EXPECT_EQ(0, validate_apk_path(TEST_EXPAND_DIR "app/com.example"));
124 EXPECT_EQ(-1, validate_apk_path(TEST_DATA_DIR "data/com.example"));
125 EXPECT_EQ(-1, validate_apk_path(TEST_EXPAND_DIR "data/com.example"));
126}
127
128TEST_F(UtilsTest, IsValidApkPath_TopFile) {
129 EXPECT_EQ(0, validate_apk_path(TEST_DATA_DIR "app/com.example/base.apk"));
130 EXPECT_EQ(0, validate_apk_path(TEST_EXPAND_DIR "app/com.example/base.apk"));
131 EXPECT_EQ(-1, validate_apk_path(TEST_DATA_DIR "data/com.example/base.apk"));
132 EXPECT_EQ(-1, validate_apk_path(TEST_EXPAND_DIR "data/com.example/base.apk"));
133}
134
135TEST_F(UtilsTest, IsValidApkPath_OatDir) {
136 EXPECT_EQ(0, validate_apk_path_subdirs(TEST_DATA_DIR "app/com.example/oat"));
137 EXPECT_EQ(0, validate_apk_path_subdirs(TEST_EXPAND_DIR "app/com.example/oat"));
138 EXPECT_EQ(-1, validate_apk_path_subdirs(TEST_DATA_DIR "data/com.example/oat"));
139 EXPECT_EQ(-1, validate_apk_path_subdirs(TEST_EXPAND_DIR "data/com.example/oat"));
140}
141
142TEST_F(UtilsTest, IsValidApkPath_OatDirDir) {
143 EXPECT_EQ(0, validate_apk_path_subdirs(TEST_DATA_DIR "app/com.example/oat/arm64"));
144 EXPECT_EQ(0, validate_apk_path_subdirs(TEST_EXPAND_DIR "app/com.example/oat/arm64"));
145 EXPECT_EQ(-1, validate_apk_path_subdirs(TEST_DATA_DIR "data/com.example/oat/arm64"));
146 EXPECT_EQ(-1, validate_apk_path_subdirs(TEST_EXPAND_DIR "data/com.example/oat/arm64"));
147}
148
149TEST_F(UtilsTest, IsValidApkPath_OatDirDirFile) {
150 EXPECT_EQ(0, validate_apk_path_subdirs(TEST_DATA_DIR "app/com.example/oat/arm64/base.odex"));
151 EXPECT_EQ(0, validate_apk_path_subdirs(TEST_EXPAND_DIR "app/com.example/oat/arm64/base.odex"));
152 EXPECT_EQ(-1, validate_apk_path_subdirs(TEST_DATA_DIR "data/com.example/oat/arm64/base.odex"));
153 EXPECT_EQ(-1, validate_apk_path_subdirs(TEST_EXPAND_DIR "data/com.example/oat/arm64/base.odex"));
154}
155
Mike Lockwood94afecf2012-10-24 10:45:23 -0700156TEST_F(UtilsTest, IsValidApkPath_Private) {
157 // Internal directories
158 const char *private1 = TEST_APP_PRIVATE_DIR "example.apk";
159 EXPECT_EQ(0, validate_apk_path(private1))
160 << private1 << " should be allowed as a valid path";
161
Calin Juravlefd88ff22014-08-15 15:45:51 +0100162 // b/16888084
163 const char *path2 = TEST_APP_DIR "example.com/example.apk";
164 EXPECT_EQ(0, validate_apk_path(path2))
165 << path2 << " should be allowed as a valid path";
166
Mike Lockwood94afecf2012-10-24 10:45:23 -0700167 const char *badpriv1 = TEST_APP_PRIVATE_DIR "../example.apk";
168 EXPECT_EQ(-1, validate_apk_path(badpriv1))
169 << badpriv1 << " should be rejected as a invalid path";
170
171 const char *badpriv2 = TEST_APP_PRIVATE_DIR "/../example.apk";
172 EXPECT_EQ(-1, validate_apk_path(badpriv2))
173 << badpriv2 << " should be rejected as a invalid path";
174
Calin Juravlefd88ff22014-08-15 15:45:51 +0100175 // Only one subdir should be allowed.
176 const char *bad_path3 = TEST_APP_PRIVATE_DIR "example.com/subdir/pkg.apk";
177 EXPECT_EQ(-1, validate_apk_path(bad_path3))
178 << bad_path3 << " should be rejected as a invalid path";
Calin Juravlec597b6d2014-08-19 17:43:05 +0100179
180 const char *bad_path4 = TEST_APP_PRIVATE_DIR "example.com/subdir/../pkg.apk";
181 EXPECT_EQ(-1, validate_apk_path(bad_path4))
182 << bad_path4 << " should be rejected as a invalid path";
183
184 const char *bad_path5 = TEST_APP_PRIVATE_DIR "example.com1/../example.com2/pkg.apk";
185 EXPECT_EQ(-1, validate_apk_path(bad_path5))
186 << bad_path5 << " should be rejected as a invalid path";
Mike Lockwood94afecf2012-10-24 10:45:23 -0700187}
188
189
190TEST_F(UtilsTest, IsValidApkPath_AsecGood1) {
191 const char *asec1 = TEST_ASEC_DIR "example.apk";
192 EXPECT_EQ(0, validate_apk_path(asec1))
193 << asec1 << " should be allowed as a valid path";
194}
195
196TEST_F(UtilsTest, IsValidApkPath_AsecGood2) {
197 const char *asec2 = TEST_ASEC_DIR "com.example.asec/pkg.apk";
198 EXPECT_EQ(0, validate_apk_path(asec2))
199 << asec2 << " should be allowed as a valid path";
200}
201
202TEST_F(UtilsTest, IsValidApkPath_EscapeFail) {
203 const char *badasec1 = TEST_ASEC_DIR "../example.apk";
204 EXPECT_EQ(-1, validate_apk_path(badasec1))
205 << badasec1 << " should be rejected as a invalid path";
206}
207
Mike Lockwood94afecf2012-10-24 10:45:23 -0700208TEST_F(UtilsTest, IsValidApkPath_SubdirEscapeFail) {
209 const char *badasec3 = TEST_ASEC_DIR "com.example.asec/../../../pkg.apk";
210 EXPECT_EQ(-1, validate_apk_path(badasec3))
211 << badasec3 << " should be rejected as a invalid path";
212}
213
214TEST_F(UtilsTest, IsValidApkPath_SlashEscapeFail) {
215 const char *badasec4 = TEST_ASEC_DIR "/../example.apk";
216 EXPECT_EQ(-1, validate_apk_path(badasec4))
217 << badasec4 << " should be rejected as a invalid path";
218}
219
220TEST_F(UtilsTest, IsValidApkPath_CrazyDirFail) {
221 const char *badasec5 = TEST_ASEC_DIR ".//../..";
222 EXPECT_EQ(-1, validate_apk_path(badasec5))
223 << badasec5 << " should be rejected as a invalid path";
224}
225
226TEST_F(UtilsTest, IsValidApkPath_SubdirEscapeSingleFail) {
227 const char *badasec6 = TEST_ASEC_DIR "com.example.asec/../pkg.apk";
228 EXPECT_EQ(-1, validate_apk_path(badasec6))
229 << badasec6 << " should be rejected as a invalid path";
230}
231
232TEST_F(UtilsTest, IsValidApkPath_TwoSubdirFail) {
233 const char *badasec7 = TEST_ASEC_DIR "com.example.asec/subdir1/pkg.apk";
234 EXPECT_EQ(-1, validate_apk_path(badasec7))
235 << badasec7 << " should be rejected as a invalid path";
236}
237
238TEST_F(UtilsTest, CheckSystemApp_Dir1) {
239 const char *sysapp1 = TEST_SYSTEM_DIR1 "Voice.apk";
240 EXPECT_EQ(0, validate_system_app_path(sysapp1))
241 << sysapp1 << " should be allowed as a system path";
242}
243
244TEST_F(UtilsTest, CheckSystemApp_Dir2) {
245 const char *sysapp2 = TEST_SYSTEM_DIR2 "com.example.myapp.apk";
246 EXPECT_EQ(0, validate_system_app_path(sysapp2))
247 << sysapp2 << " should be allowed as a system path";
248}
249
250TEST_F(UtilsTest, CheckSystemApp_EscapeFail) {
251 const char *badapp1 = TEST_SYSTEM_DIR1 "../com.example.apk";
252 EXPECT_EQ(-1, validate_system_app_path(badapp1))
253 << badapp1 << " should be rejected not a system path";
254}
255
256TEST_F(UtilsTest, CheckSystemApp_DoubleEscapeFail) {
257 const char *badapp2 = TEST_SYSTEM_DIR2 "/../../com.example.apk";
258 EXPECT_EQ(-1, validate_system_app_path(badapp2))
259 << badapp2 << " should be rejected not a system path";
260}
261
262TEST_F(UtilsTest, CheckSystemApp_BadPathEscapeFail) {
263 const char *badapp3 = TEST_APP_DIR "/../../com.example.apk";
264 EXPECT_EQ(-1, validate_system_app_path(badapp3))
265 << badapp3 << " should be rejected not a system path";
266}
267
Calin Juravlec597b6d2014-08-19 17:43:05 +0100268TEST_F(UtilsTest, CheckSystemApp_Subdir) {
269 const char *sysapp = TEST_SYSTEM_DIR1 "com.example/com.example.apk";
270 EXPECT_EQ(0, validate_system_app_path(sysapp))
271 << sysapp << " should be allowed as a system path";
272
273 const char *badapp = TEST_SYSTEM_DIR1 "com.example/subdir/com.example.apk";
274 EXPECT_EQ(-1, validate_system_app_path(badapp))
275 << badapp << " should be rejected not a system path";
276
277 const char *badapp1 = TEST_SYSTEM_DIR1 "com.example/subdir/../com.example.apk";
278 EXPECT_EQ(-1, validate_system_app_path(badapp1))
279 << badapp1 << " should be rejected not a system path";
280
281 const char *badapp2 = TEST_SYSTEM_DIR1 "com.example1/../com.example2/com.example.apk";
282 EXPECT_EQ(-1, validate_system_app_path(badapp2))
283 << badapp2 << " should be rejected not a system path";
284}
285
Jeff Sharkey41ea4242015-04-09 11:34:03 -0700286TEST_F(UtilsTest, CreateDataPath) {
287 EXPECT_EQ("/data", create_data_path(nullptr));
288 EXPECT_EQ("/mnt/expand/57f8f4bc-abf4-655f-bf67-946fc0f9f25b",
289 create_data_path("57f8f4bc-abf4-655f-bf67-946fc0f9f25b"));
290}
291
Jeff Sharkeyd7921182015-04-30 15:58:19 -0700292TEST_F(UtilsTest, CreateDataAppPath) {
293 EXPECT_EQ("/data/app", create_data_app_path(nullptr));
294
295 EXPECT_EQ("/mnt/expand/57f8f4bc-abf4-655f-bf67-946fc0f9f25b/app",
296 create_data_app_path("57f8f4bc-abf4-655f-bf67-946fc0f9f25b"));
297}
298
Jeff Sharkey41ea4242015-04-09 11:34:03 -0700299TEST_F(UtilsTest, CreateDataUserPath) {
Jeff Sharkey2f720f72016-04-10 20:51:40 -0600300 EXPECT_EQ("/data/data", create_data_user_ce_path(nullptr, 0));
301 EXPECT_EQ("/data/user/10", create_data_user_ce_path(nullptr, 10));
Jeff Sharkey41ea4242015-04-09 11:34:03 -0700302
303 EXPECT_EQ("/mnt/expand/57f8f4bc-abf4-655f-bf67-946fc0f9f25b/user/0",
Jeff Sharkey2f720f72016-04-10 20:51:40 -0600304 create_data_user_ce_path("57f8f4bc-abf4-655f-bf67-946fc0f9f25b", 0));
Jeff Sharkey41ea4242015-04-09 11:34:03 -0700305 EXPECT_EQ("/mnt/expand/57f8f4bc-abf4-655f-bf67-946fc0f9f25b/user/10",
Jeff Sharkey2f720f72016-04-10 20:51:40 -0600306 create_data_user_ce_path("57f8f4bc-abf4-655f-bf67-946fc0f9f25b", 10));
Jeff Sharkey41ea4242015-04-09 11:34:03 -0700307}
308
309TEST_F(UtilsTest, CreateDataMediaPath) {
310 EXPECT_EQ("/data/media/0", create_data_media_path(nullptr, 0));
311 EXPECT_EQ("/data/media/10", create_data_media_path(nullptr, 10));
312
313 EXPECT_EQ("/mnt/expand/57f8f4bc-abf4-655f-bf67-946fc0f9f25b/media/0",
314 create_data_media_path("57f8f4bc-abf4-655f-bf67-946fc0f9f25b", 0));
315 EXPECT_EQ("/mnt/expand/57f8f4bc-abf4-655f-bf67-946fc0f9f25b/media/10",
316 create_data_media_path("57f8f4bc-abf4-655f-bf67-946fc0f9f25b", 10));
317}
318
Jeff Sharkeyd7921182015-04-30 15:58:19 -0700319TEST_F(UtilsTest, CreateDataAppPackagePath) {
320 EXPECT_EQ("/data/app/com.example", create_data_app_package_path(nullptr, "com.example"));
321
322 EXPECT_EQ("/mnt/expand/57f8f4bc-abf4-655f-bf67-946fc0f9f25b/app/com.example",
323 create_data_app_package_path("57f8f4bc-abf4-655f-bf67-946fc0f9f25b", "com.example"));
324}
325
326TEST_F(UtilsTest, CreateDataUserPackagePath) {
Jeff Sharkey2f720f72016-04-10 20:51:40 -0600327 EXPECT_EQ("/data/data/com.example", create_data_user_ce_package_path(nullptr, 0, "com.example"));
328 EXPECT_EQ("/data/user/10/com.example", create_data_user_ce_package_path(nullptr, 10, "com.example"));
Jeff Sharkeyc03de092015-04-07 18:14:05 -0700329
330 EXPECT_EQ("/mnt/expand/57f8f4bc-abf4-655f-bf67-946fc0f9f25b/user/0/com.example",
Jeff Sharkey2f720f72016-04-10 20:51:40 -0600331 create_data_user_ce_package_path("57f8f4bc-abf4-655f-bf67-946fc0f9f25b", 0, "com.example"));
Jeff Sharkeyc03de092015-04-07 18:14:05 -0700332 EXPECT_EQ("/mnt/expand/57f8f4bc-abf4-655f-bf67-946fc0f9f25b/user/10/com.example",
Jeff Sharkey2f720f72016-04-10 20:51:40 -0600333 create_data_user_ce_package_path("57f8f4bc-abf4-655f-bf67-946fc0f9f25b", 10, "com.example"));
Jeff Sharkeyc03de092015-04-07 18:14:05 -0700334}
335
Jeff Sharkey367ace22017-03-07 22:12:03 -0700336TEST_F(UtilsTest, IsValidPackageName) {
Jeff Sharkeyab7ac8d2017-03-08 12:39:46 -0700337 EXPECT_EQ(true, is_valid_package_name("android"));
Jeff Sharkey367ace22017-03-07 22:12:03 -0700338 EXPECT_EQ(true, is_valid_package_name("com.example"));
339 EXPECT_EQ(true, is_valid_package_name("com.example-1"));
340 EXPECT_EQ(true, is_valid_package_name("com.example-1024"));
341 EXPECT_EQ(true, is_valid_package_name("com.example.foo---KiJFj4a_tePVw95pSrjg=="));
342 EXPECT_EQ(true, is_valid_package_name("really_LONG.a1234.package_name"));
343
344 EXPECT_EQ(false, is_valid_package_name("1234.package"));
345 EXPECT_EQ(false, is_valid_package_name("com.1234.package"));
Jeff Sharkey367ace22017-03-07 22:12:03 -0700346 EXPECT_EQ(false, is_valid_package_name(""));
347 EXPECT_EQ(false, is_valid_package_name("."));
Jeff Sharkeyab7ac8d2017-03-08 12:39:46 -0700348 EXPECT_EQ(false, is_valid_package_name(".."));
349 EXPECT_EQ(false, is_valid_package_name("../"));
Jeff Sharkey367ace22017-03-07 22:12:03 -0700350 EXPECT_EQ(false, is_valid_package_name("com.example/../com.evil/"));
351 EXPECT_EQ(false, is_valid_package_name("com.example-1/../com.evil/"));
352 EXPECT_EQ(false, is_valid_package_name("/com.evil"));
353}
354
Calin Juravle76268c52017-03-09 13:19:42 -0800355TEST_F(UtilsTest, CreateDataUserProfilePath) {
Calin Juravle114f0812017-03-08 19:05:07 -0800356 EXPECT_EQ("/data/misc/profiles/cur/0", create_primary_cur_profile_dir_path(0));
357 EXPECT_EQ("/data/misc/profiles/cur/1", create_primary_cur_profile_dir_path(1));
Calin Juravle76268c52017-03-09 13:19:42 -0800358}
359
360TEST_F(UtilsTest, CreateDataUserProfilePackagePath) {
361 EXPECT_EQ("/data/misc/profiles/cur/0/com.example",
Calin Juravle114f0812017-03-08 19:05:07 -0800362 create_primary_current_profile_package_dir_path(0, "com.example"));
Calin Juravle76268c52017-03-09 13:19:42 -0800363 EXPECT_EQ("/data/misc/profiles/cur/1/com.example",
Calin Juravle114f0812017-03-08 19:05:07 -0800364 create_primary_current_profile_package_dir_path(1, "com.example"));
Calin Juravle76268c52017-03-09 13:19:42 -0800365}
366
367TEST_F(UtilsTest, CreateDataRefProfilePath) {
Calin Juravle114f0812017-03-08 19:05:07 -0800368 EXPECT_EQ("/data/misc/profiles/ref", create_primary_ref_profile_dir_path());
Calin Juravle76268c52017-03-09 13:19:42 -0800369}
370
371TEST_F(UtilsTest, CreateDataRefProfilePackagePath) {
372 EXPECT_EQ("/data/misc/profiles/ref/com.example",
Calin Juravle114f0812017-03-08 19:05:07 -0800373 create_primary_reference_profile_package_dir_path("com.example"));
Calin Juravle76268c52017-03-09 13:19:42 -0800374}
375
Calin Juravle114f0812017-03-08 19:05:07 -0800376TEST_F(UtilsTest, CreatePrimaryCurrentProfile) {
Calin Juravlecfcd6aa2018-01-18 20:23:17 -0800377 std::string expected_base =
Calin Juravlea40b6e32017-04-12 18:20:44 -0700378 create_primary_current_profile_package_dir_path(0, "com.example") + "/primary.prof";
Calin Juravlecfcd6aa2018-01-18 20:23:17 -0800379 EXPECT_EQ(expected_base,
380 create_current_profile_path(/*user*/0, "com.example", "primary.prof",
381 /*is_secondary*/false));
382
383 std::string expected_split =
384 create_primary_current_profile_package_dir_path(0, "com.example") + "/split.prof";
385 EXPECT_EQ(expected_split,
386 create_current_profile_path(/*user*/0, "com.example", "split.prof",
387 /*is_secondary*/false));
Calin Juravle114f0812017-03-08 19:05:07 -0800388}
389
390TEST_F(UtilsTest, CreatePrimaryReferenceProfile) {
Calin Juravlecfcd6aa2018-01-18 20:23:17 -0800391 std::string expected_base =
Calin Juravle114f0812017-03-08 19:05:07 -0800392 create_primary_reference_profile_package_dir_path("com.example") + "/primary.prof";
Calin Juravlecfcd6aa2018-01-18 20:23:17 -0800393 EXPECT_EQ(expected_base,
394 create_reference_profile_path("com.example", "primary.prof", /*is_secondary*/false));
395
396 std::string expected_split =
397 create_primary_reference_profile_package_dir_path("com.example") + "/split.prof";
398 EXPECT_EQ(expected_split,
399 create_reference_profile_path("com.example", "split.prof", /*is_secondary*/false));
Calin Juravle114f0812017-03-08 19:05:07 -0800400}
401
Calin Juravle29591732017-11-20 17:46:19 -0800402TEST_F(UtilsTest, CreateProfileSnapshot) {
Calin Juravlecfcd6aa2018-01-18 20:23:17 -0800403 std::string expected_base =
Calin Juravle29591732017-11-20 17:46:19 -0800404 create_primary_reference_profile_package_dir_path("com.example") + "/primary.prof.snapshot";
Calin Juravlecfcd6aa2018-01-18 20:23:17 -0800405 EXPECT_EQ(expected_base, create_snapshot_profile_path("com.example", "primary.prof"));
406
407 std::string expected_split =
408 create_primary_reference_profile_package_dir_path("com.example") + "/split.prof.snapshot";
409 EXPECT_EQ(expected_split, create_snapshot_profile_path("com.example", "split.prof"));
Calin Juravle29591732017-11-20 17:46:19 -0800410}
411
Calin Juravle114f0812017-03-08 19:05:07 -0800412TEST_F(UtilsTest, CreateSecondaryCurrentProfile) {
Calin Juravle3760ad32017-07-27 16:31:55 -0700413 EXPECT_EQ("/data/user/0/com.example/oat/secondary.dex.cur.prof",
Calin Juravlecfcd6aa2018-01-18 20:23:17 -0800414 create_current_profile_path(/*user*/0, "com.example",
Calin Juravle114f0812017-03-08 19:05:07 -0800415 "/data/user/0/com.example/secondary.dex", /*is_secondary*/true));
416}
417
418TEST_F(UtilsTest, CreateSecondaryReferenceProfile) {
419 EXPECT_EQ("/data/user/0/com.example/oat/secondary.dex.prof",
Calin Juravlecfcd6aa2018-01-18 20:23:17 -0800420 create_reference_profile_path("com.example",
Calin Juravle114f0812017-03-08 19:05:07 -0800421 "/data/user/0/com.example/secondary.dex", /*is_secondary*/true));
Calin Juravle76268c52017-03-09 13:19:42 -0800422}
423
Calin Juravle3760ad32017-07-27 16:31:55 -0700424static void pass_secondary_dex_validation(const std::string& package_name,
425 const std::string& dex_path, int uid, int storage_flag) {
426 EXPECT_TRUE(validate_secondary_dex_path(package_name, dex_path, /*volume_uuid*/ nullptr, uid,
427 storage_flag))
428 << dex_path << " should be allowed as a valid secondary dex path";
429}
430
431static void fail_secondary_dex_validation(const std::string& package_name,
432 const std::string& dex_path, int uid, int storage_flag) {
433 EXPECT_FALSE(validate_secondary_dex_path(package_name, dex_path, /*volume_uuid*/ nullptr, uid,
434 storage_flag))
435 << dex_path << " should not be allowed as a valid secondary dex path";
436}
437
438TEST_F(UtilsTest, ValidateSecondaryDexFilesPath) {
439 std::string package_name = "com.test.app";
440 std::string app_dir_ce_user_0 = "/data/data/" + package_name;
Calin Juravle7d765462017-09-04 15:57:10 -0700441 std::string app_dir_ce_user_0_link = "/data/user/0/" + package_name;
Calin Juravle3760ad32017-07-27 16:31:55 -0700442 std::string app_dir_ce_user_10 = "/data/user/10/" + package_name;
443
444 std::string app_dir_de_user_0 = "/data/user_de/0/" + package_name;
445 std::string app_dir_de_user_10 = "/data/user_de/10/" + package_name;
446
447 EXPECT_EQ(app_dir_ce_user_0,
448 create_data_user_ce_package_path(nullptr, 0, package_name.c_str()));
449 EXPECT_EQ(app_dir_ce_user_10,
450 create_data_user_ce_package_path(nullptr, 10, package_name.c_str()));
451
452 EXPECT_EQ(app_dir_de_user_0,
453 create_data_user_de_package_path(nullptr, 0, package_name.c_str()));
454 EXPECT_EQ(app_dir_de_user_10,
455 create_data_user_de_package_path(nullptr, 10, package_name.c_str()));
456
457 uid_t app_uid_for_user_0 = multiuser_get_uid(/*user_id*/0, /*app_id*/ 1234);
458 uid_t app_uid_for_user_10 = multiuser_get_uid(/*user_id*/10, /*app_id*/ 1234);
459
460 // Standard path for user 0 on CE storage.
461 pass_secondary_dex_validation(
462 package_name, app_dir_ce_user_0 + "/ce0.dex", app_uid_for_user_0, FLAG_STORAGE_CE);
Calin Juravle7d765462017-09-04 15:57:10 -0700463 pass_secondary_dex_validation(
464 package_name, app_dir_ce_user_0_link + "/ce0.dex", app_uid_for_user_0, FLAG_STORAGE_CE);
Calin Juravle3760ad32017-07-27 16:31:55 -0700465 // Standard path for user 10 on CE storage.
466 pass_secondary_dex_validation(
467 package_name, app_dir_ce_user_10 + "/ce10.dex", app_uid_for_user_10, FLAG_STORAGE_CE);
468
469 // Standard path for user 0 on DE storage.
470 pass_secondary_dex_validation(
471 package_name, app_dir_de_user_0 + "/de0.dex", app_uid_for_user_0, FLAG_STORAGE_DE);
472 // Standard path for user 10 on DE storage.
473 pass_secondary_dex_validation(
474 package_name, app_dir_de_user_10 + "/de0.dex", app_uid_for_user_10, FLAG_STORAGE_DE);
475
476 // Dex path for user 0 accessed from user 10.
477 fail_secondary_dex_validation(
478 package_name, app_dir_ce_user_0 + "/path0_from10.dex",
479 app_uid_for_user_10, FLAG_STORAGE_CE);
480
481 // Dex path for CE storage accessed with DE.
482 fail_secondary_dex_validation(
483 package_name, app_dir_ce_user_0 + "/ce_from_de.dex", app_uid_for_user_0, FLAG_STORAGE_DE);
484
485 // Dex path for DE storage accessed with CE.
486 fail_secondary_dex_validation(
487 package_name, app_dir_de_user_0 + "/de_from_ce.dex", app_uid_for_user_0, FLAG_STORAGE_CE);
488
489 // Location which does not start with '/'.
490 fail_secondary_dex_validation(
491 package_name, "without_slash.dex", app_uid_for_user_10, FLAG_STORAGE_DE);
492
493 // The dex file is not in the specified package directory.
494 fail_secondary_dex_validation(
495 "another.package", app_dir_ce_user_0 + "/for_another_package.dex",
496 app_uid_for_user_0, FLAG_STORAGE_DE);
497
498 // The dex path contains indirect directories.
499 fail_secondary_dex_validation(
500 package_name, app_dir_ce_user_0 + "/1/../foo.dex", app_uid_for_user_0, FLAG_STORAGE_CE);
501 fail_secondary_dex_validation(
502 package_name, app_dir_ce_user_0 + "/1/./foo.dex", app_uid_for_user_0, FLAG_STORAGE_CE);
503
504 // Super long path.
505 std::string too_long = create_too_long_path("too_long_");
506 fail_secondary_dex_validation(
507 package_name, app_dir_ce_user_10 + "/" + too_long, app_uid_for_user_10, FLAG_STORAGE_CE);
508}
509
Jeff Sharkey172fac02017-10-06 13:09:46 -0600510TEST_F(UtilsTest, ValidateApkPath) {
511 EXPECT_EQ(0, validate_apk_path("/data/app/com.example"));
512 EXPECT_EQ(0, validate_apk_path("/data/app/com.example/file"));
513 EXPECT_EQ(0, validate_apk_path("/data/app/com.example//file"));
514 EXPECT_NE(0, validate_apk_path("/data/app/com.example/dir/"));
515 EXPECT_NE(0, validate_apk_path("/data/app/com.example/dir/file"));
516 EXPECT_NE(0, validate_apk_path("/data/app/com.example/dir/dir/file"));
517 EXPECT_NE(0, validate_apk_path("/data/app/com.example/dir/dir//file"));
518 EXPECT_NE(0, validate_apk_path("/data/app/com.example/dir/dir/dir/file"));
519 EXPECT_NE(0, validate_apk_path("/data/app/com.example/dir/dir/dir//file"));
520}
521
522TEST_F(UtilsTest, ValidateApkPathSubdirs) {
523 EXPECT_EQ(0, validate_apk_path_subdirs("/data/app/com.example"));
524 EXPECT_EQ(0, validate_apk_path_subdirs("/data/app/com.example/file"));
525 EXPECT_EQ(0, validate_apk_path_subdirs("/data/app/com.example//file"));
526 EXPECT_EQ(0, validate_apk_path_subdirs("/data/app/com.example/dir/"));
527 EXPECT_EQ(0, validate_apk_path_subdirs("/data/app/com.example/dir/file"));
528 EXPECT_EQ(0, validate_apk_path_subdirs("/data/app/com.example/dir/dir/file"));
529 EXPECT_EQ(0, validate_apk_path_subdirs("/data/app/com.example/dir/dir//file"));
530 EXPECT_NE(0, validate_apk_path_subdirs("/data/app/com.example/dir/dir/dir/file"));
531 EXPECT_NE(0, validate_apk_path_subdirs("/data/app/com.example/dir/dir/dir//file"));
532}
533
Jeff Sharkey725ae2b2018-09-28 10:07:14 -0600534TEST_F(UtilsTest, MatchExtension_Valid) {
535 EXPECT_EQ(AID_MEDIA_VIDEO, MatchExtension("mpg"));
536 EXPECT_EQ(AID_MEDIA_VIDEO, MatchExtension("mpeg"));
537 EXPECT_EQ(AID_MEDIA_VIDEO, MatchExtension("mPeG"));
538 EXPECT_EQ(AID_MEDIA_VIDEO, MatchExtension("MPEG"));
539}
540
541TEST_F(UtilsTest, MatchExtension_Invalid) {
542 EXPECT_EQ(0, MatchExtension("log"));
543 EXPECT_EQ(0, MatchExtension("3amp"));
544 EXPECT_EQ(0, MatchExtension("fpe"));
545 EXPECT_EQ(0, MatchExtension("docx"));
546}
547
Narayan Kamathe63ca7d2019-01-14 15:21:52 +0000548TEST_F(UtilsTest, TestRollbackPaths) {
Nikita Ioffeb68f0d12019-02-04 11:06:37 +0000549 EXPECT_EQ("/data/misc_ce/0/rollback/239/com.foo",
550 create_data_misc_ce_rollback_package_path(nullptr, 0, 239, "com.foo"));
551 EXPECT_EQ("/data/misc_ce/10/rollback/37/com.foo",
552 create_data_misc_ce_rollback_package_path(nullptr, 10, 37, "com.foo"));
Narayan Kamathe63ca7d2019-01-14 15:21:52 +0000553
Nikita Ioffeb68f0d12019-02-04 11:06:37 +0000554 EXPECT_EQ("/data/misc_de/0/rollback/73/com.foo",
555 create_data_misc_de_rollback_package_path(nullptr, 0, 73, "com.foo"));
556 EXPECT_EQ("/data/misc_de/10/rollback/13/com.foo",
557 create_data_misc_de_rollback_package_path(nullptr, 10, 13, "com.foo"));
Narayan Kamathe63ca7d2019-01-14 15:21:52 +0000558
Nikita Ioffeb68f0d12019-02-04 11:06:37 +0000559 EXPECT_EQ("/data/misc_ce/0/rollback/57",
560 create_data_misc_ce_rollback_path(nullptr, 0, 57));
561 EXPECT_EQ("/data/misc_ce/10/rollback/1543",
562 create_data_misc_ce_rollback_path(nullptr, 10, 1543));
Narayan Kamathe63ca7d2019-01-14 15:21:52 +0000563
Nikita Ioffeb68f0d12019-02-04 11:06:37 +0000564 EXPECT_EQ("/data/misc_de/0/rollback/43",
565 create_data_misc_de_rollback_path(nullptr, 0, 43));
566 EXPECT_EQ("/data/misc_de/10/rollback/41",
567 create_data_misc_de_rollback_path(nullptr, 10, 41));
Narayan Kamathe63ca7d2019-01-14 15:21:52 +0000568
Nikita Ioffeb68f0d12019-02-04 11:06:37 +0000569 EXPECT_EQ("/data/misc_ce/0/rollback/17/com.foo",
570 create_data_misc_ce_rollback_package_path(nullptr, 0, 17, "com.foo", 0));
571 EXPECT_EQ("/data/misc_ce/0/rollback/19/com.foo",
572 create_data_misc_ce_rollback_package_path(nullptr, 0, 19, "com.foo", 239));
Nikita Ioffe77be2ed2019-01-25 13:54:43 +0000573
Nikita Ioffeb68f0d12019-02-04 11:06:37 +0000574 auto rollback_ce_path = create_data_misc_ce_rollback_path(nullptr, 0, 53);
575 auto rollback_ce_package_path = create_data_misc_ce_rollback_package_path(nullptr, 0, 53,
576 "com.foo");
577 auto deleter = [&rollback_ce_path]() {
578 delete_dir_contents_and_dir(rollback_ce_path, true /* ignore_if_missing */);
Nikita Ioffe77be2ed2019-01-25 13:54:43 +0000579 };
580 auto scope_guard = android::base::make_scope_guard(deleter);
581
Nikita Ioffeb68f0d12019-02-04 11:06:37 +0000582 EXPECT_NE(-1, mkdir(rollback_ce_path.c_str(), 700));
583 EXPECT_NE(-1, mkdir(rollback_ce_package_path.c_str(), 700));
Nikita Ioffe77be2ed2019-01-25 13:54:43 +0000584
585 ino_t ce_data_inode;
Nikita Ioffeb68f0d12019-02-04 11:06:37 +0000586 EXPECT_EQ(0, get_path_inode(rollback_ce_package_path, &ce_data_inode));
Nikita Ioffe77be2ed2019-01-25 13:54:43 +0000587
Nikita Ioffeb68f0d12019-02-04 11:06:37 +0000588 EXPECT_EQ("/data/misc_ce/0/rollback/53/com.foo",
589 create_data_misc_ce_rollback_package_path(nullptr, 0, 53, "com.foo", ce_data_inode));
Nikita Ioffe77be2ed2019-01-25 13:54:43 +0000590 // Check that path defined by inode is picked even if it's not the same as
591 // the fallback one.
Nikita Ioffeb68f0d12019-02-04 11:06:37 +0000592 EXPECT_EQ("/data/misc_ce/0/rollback/53/com.foo",
593 create_data_misc_ce_rollback_package_path(nullptr, 0, 53, "com.bar", ce_data_inode));
Nikita Ioffe77be2ed2019-01-25 13:54:43 +0000594
Narayan Kamathe63ca7d2019-01-14 15:21:52 +0000595 // These last couple of cases are never exercised in production because we
596 // only snapshot apps in the primary data partition. Exercise them here for
597 // the sake of completeness.
Nikita Ioffeb68f0d12019-02-04 11:06:37 +0000598 EXPECT_EQ("/mnt/expand/57f8f4bc-abf4-655f-bf67-946fc0f9f25b/misc_ce/0/rollback/7/com.example",
599 create_data_misc_ce_rollback_package_path("57f8f4bc-abf4-655f-bf67-946fc0f9f25b", 0, 7,
600 "com.example"));
601 EXPECT_EQ("/mnt/expand/57f8f4bc-abf4-655f-bf67-946fc0f9f25b/misc_de/0/rollback/11/com.example",
602 create_data_misc_de_rollback_package_path("57f8f4bc-abf4-655f-bf67-946fc0f9f25b", 0, 11,
603 "com.example"));
604}
605
606TEST_F(UtilsTest, TestCreateDirIfNeeded) {
607 system("mkdir -p /data/local/tmp/user/0");
608
609 auto deleter = [&]() {
610 delete_dir_contents_and_dir("/data/local/tmp/user/0", true /* ignore_if_missing */);
611 };
612 auto scope_guard = android::base::make_scope_guard(deleter);
613
614 // Create folder and check it's permissions.
615 ASSERT_EQ(0, create_dir_if_needed("/data/local/tmp/user/0/foo", 0700));
616 struct stat st;
617 ASSERT_EQ(0, stat("/data/local/tmp/user/0/foo", &st));
618 ASSERT_EQ(0700, st.st_mode & ALLPERMS);
619
620 // Check that create_dir_if_needed is no-op if folder already exists with
621 // correct permissions.
622 ASSERT_EQ(0, create_dir_if_needed("/data/local/tmp/user/0/foo", 0700));
623
624 // Check -1 is returned if folder exists but with different permissions.
625 ASSERT_EQ(-1, create_dir_if_needed("/data/local/tmp/user/0/foo", 0750));
626
627 // Check that call fails if parent doesn't exist.
628 ASSERT_NE(0, create_dir_if_needed("/data/local/tmp/user/0/bar/baz", 0700));
Narayan Kamathe63ca7d2019-01-14 15:21:52 +0000629}
630
Andreas Gampe02d0de52015-11-11 20:43:16 -0800631} // namespace installd
632} // namespace android