blob: 39ae15075b008c3de2a09ef90a12158c36f5196a [file] [log] [blame]
Mike Frysinger8155d082012-04-06 15:23:18 -04001// Copyright (c) 2012 The Chromium OS Authors. All rights reserved.
adlr@google.com3defe6a2009-12-04 20:57:17 +00002// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
5#include <sys/stat.h>
6#include <sys/types.h>
7#include <errno.h>
Darin Petkov5c0a8af2010-08-24 13:39:13 -07008
Andrew de los Reyescc92cd32010-10-05 16:56:14 -07009#include <map>
Andrew de los Reyes4fe15d02009-12-10 19:01:36 -080010#include <string>
adlr@google.com3defe6a2009-12-04 20:57:17 +000011#include <vector>
Darin Petkov5c0a8af2010-08-24 13:39:13 -070012
Darin Petkovd3f8c892010-10-12 21:38:45 -070013#include <base/string_util.h>
Mike Frysinger8155d082012-04-06 15:23:18 -040014#include <base/stringprintf.h>
Darin Petkovd3f8c892010-10-12 21:38:45 -070015#include <gtest/gtest.h>
16
17#include "update_engine/test_utils.h"
adlr@google.com3defe6a2009-12-04 20:57:17 +000018#include "update_engine/utils.h"
19
Andrew de los Reyescc92cd32010-10-05 16:56:14 -070020using std::map;
Andrew de los Reyes4fe15d02009-12-10 19:01:36 -080021using std::string;
adlr@google.com3defe6a2009-12-04 20:57:17 +000022using std::vector;
23
24namespace chromeos_update_engine {
25
26class UtilsTest : public ::testing::Test { };
27
Darin Petkov33d30642010-08-04 10:18:57 -070028TEST(UtilsTest, IsOfficialBuild) {
29 // Pretty lame test...
30 EXPECT_TRUE(utils::IsOfficialBuild());
31}
32
Darin Petkovc91dd6b2011-01-10 12:31:34 -080033TEST(UtilsTest, IsNormalBootMode) {
34 // Pretty lame test...
Darin Petkov44d98d92011-03-21 16:08:11 -070035 EXPECT_TRUE(utils::IsNormalBootMode());
Darin Petkovc91dd6b2011-01-10 12:31:34 -080036}
37
adlr@google.com3defe6a2009-12-04 20:57:17 +000038TEST(UtilsTest, NormalizePathTest) {
39 EXPECT_EQ("", utils::NormalizePath("", false));
40 EXPECT_EQ("", utils::NormalizePath("", true));
41 EXPECT_EQ("/", utils::NormalizePath("/", false));
42 EXPECT_EQ("", utils::NormalizePath("/", true));
43 EXPECT_EQ("/", utils::NormalizePath("//", false));
44 EXPECT_EQ("", utils::NormalizePath("//", true));
45 EXPECT_EQ("foo", utils::NormalizePath("foo", false));
46 EXPECT_EQ("foo", utils::NormalizePath("foo", true));
47 EXPECT_EQ("/foo/", utils::NormalizePath("/foo//", false));
48 EXPECT_EQ("/foo", utils::NormalizePath("/foo//", true));
49 EXPECT_EQ("bar/baz/foo/adlr", utils::NormalizePath("bar/baz//foo/adlr",
50 false));
51 EXPECT_EQ("bar/baz/foo/adlr", utils::NormalizePath("bar/baz//foo/adlr",
52 true));
53 EXPECT_EQ("/bar/baz/foo/adlr/", utils::NormalizePath("/bar/baz//foo/adlr/",
54 false));
55 EXPECT_EQ("/bar/baz/foo/adlr", utils::NormalizePath("/bar/baz//foo/adlr/",
56 true));
57 EXPECT_EQ("\\\\", utils::NormalizePath("\\\\", false));
58 EXPECT_EQ("\\\\", utils::NormalizePath("\\\\", true));
59 EXPECT_EQ("\\:/;$PATH\n\\", utils::NormalizePath("\\://;$PATH\n\\", false));
60 EXPECT_EQ("\\:/;$PATH\n\\", utils::NormalizePath("\\://;$PATH\n\\", true));
61 EXPECT_EQ("/spaces s/ ok/s / / /",
62 utils::NormalizePath("/spaces s/ ok/s / / /", false));
63 EXPECT_EQ("/spaces s/ ok/s / / ",
64 utils::NormalizePath("/spaces s/ ok/s / / /", true));
65}
66
67TEST(UtilsTest, ReadFileFailure) {
68 vector<char> empty;
69 EXPECT_FALSE(utils::ReadFile("/this/doesn't/exist", &empty));
70}
71
72TEST(UtilsTest, ErrnoNumberAsStringTest) {
73 EXPECT_EQ("No such file or directory", utils::ErrnoNumberAsString(ENOENT));
74}
75
76TEST(UtilsTest, StringHasSuffixTest) {
77 EXPECT_TRUE(utils::StringHasSuffix("foo", "foo"));
78 EXPECT_TRUE(utils::StringHasSuffix("foo", "o"));
79 EXPECT_TRUE(utils::StringHasSuffix("", ""));
80 EXPECT_TRUE(utils::StringHasSuffix("abcabc", "abc"));
81 EXPECT_TRUE(utils::StringHasSuffix("adlrwashere", "ere"));
82 EXPECT_TRUE(utils::StringHasSuffix("abcdefgh", "gh"));
83 EXPECT_TRUE(utils::StringHasSuffix("abcdefgh", ""));
84 EXPECT_FALSE(utils::StringHasSuffix("foo", "afoo"));
85 EXPECT_FALSE(utils::StringHasSuffix("", "x"));
86 EXPECT_FALSE(utils::StringHasSuffix("abcdefgh", "fg"));
87 EXPECT_FALSE(utils::StringHasSuffix("abcdefgh", "ab"));
88}
89
90TEST(UtilsTest, StringHasPrefixTest) {
91 EXPECT_TRUE(utils::StringHasPrefix("foo", "foo"));
92 EXPECT_TRUE(utils::StringHasPrefix("foo", "f"));
93 EXPECT_TRUE(utils::StringHasPrefix("", ""));
94 EXPECT_TRUE(utils::StringHasPrefix("abcabc", "abc"));
95 EXPECT_TRUE(utils::StringHasPrefix("adlrwashere", "adl"));
96 EXPECT_TRUE(utils::StringHasPrefix("abcdefgh", "ab"));
97 EXPECT_TRUE(utils::StringHasPrefix("abcdefgh", ""));
98 EXPECT_FALSE(utils::StringHasPrefix("foo", "fooa"));
99 EXPECT_FALSE(utils::StringHasPrefix("", "x"));
100 EXPECT_FALSE(utils::StringHasPrefix("abcdefgh", "bc"));
101 EXPECT_FALSE(utils::StringHasPrefix("abcdefgh", "gh"));
102}
103
104TEST(UtilsTest, BootDeviceTest) {
105 // Pretty lame test...
106 EXPECT_FALSE(utils::BootDevice().empty());
107}
108
Andrew de los Reyesf9185172010-05-03 11:07:05 -0700109TEST(UtilsTest, BootKernelDeviceTest) {
110 EXPECT_EQ("", utils::BootKernelDevice("foo"));
111 EXPECT_EQ("", utils::BootKernelDevice("/dev/sda0"));
112 EXPECT_EQ("", utils::BootKernelDevice("/dev/sda1"));
113 EXPECT_EQ("", utils::BootKernelDevice("/dev/sda2"));
114 EXPECT_EQ("/dev/sda2", utils::BootKernelDevice("/dev/sda3"));
115 EXPECT_EQ("", utils::BootKernelDevice("/dev/sda4"));
116 EXPECT_EQ("/dev/sda4", utils::BootKernelDevice("/dev/sda5"));
117 EXPECT_EQ("", utils::BootKernelDevice("/dev/sda6"));
118 EXPECT_EQ("/dev/sda6", utils::BootKernelDevice("/dev/sda7"));
119 EXPECT_EQ("", utils::BootKernelDevice("/dev/sda8"));
120 EXPECT_EQ("", utils::BootKernelDevice("/dev/sda9"));
121}
122
adlr@google.com3defe6a2009-12-04 20:57:17 +0000123TEST(UtilsTest, RecursiveUnlinkDirTest) {
124 EXPECT_EQ(0, mkdir("RecursiveUnlinkDirTest-a", 0755));
125 EXPECT_EQ(0, mkdir("RecursiveUnlinkDirTest-b", 0755));
126 EXPECT_EQ(0, symlink("../RecursiveUnlinkDirTest-a",
127 "RecursiveUnlinkDirTest-b/link"));
128 EXPECT_EQ(0, system("echo hi > RecursiveUnlinkDirTest-b/file"));
129 EXPECT_EQ(0, mkdir("RecursiveUnlinkDirTest-b/dir", 0755));
130 EXPECT_EQ(0, system("echo ok > RecursiveUnlinkDirTest-b/dir/subfile"));
131 EXPECT_TRUE(utils::RecursiveUnlinkDir("RecursiveUnlinkDirTest-b"));
132 EXPECT_TRUE(utils::FileExists("RecursiveUnlinkDirTest-a"));
133 EXPECT_EQ(0, system("rm -rf RecursiveUnlinkDirTest-a"));
134 EXPECT_FALSE(utils::FileExists("RecursiveUnlinkDirTest-b"));
135 EXPECT_TRUE(utils::RecursiveUnlinkDir("/something/that/doesnt/exist"));
136}
137
Darin Petkov002b2fe2010-11-22 13:53:22 -0800138TEST(UtilsTest, IsSymlinkTest) {
139 string temp_dir;
140 EXPECT_TRUE(utils::MakeTempDirectory("/tmp/symlink-test.XXXXXX", &temp_dir));
141 string temp_file = temp_dir + "temp-file";
142 EXPECT_TRUE(utils::WriteFile(temp_file.c_str(), "", 0));
143 string temp_symlink = temp_dir + "temp-symlink";
144 EXPECT_EQ(0, symlink(temp_file.c_str(), temp_symlink.c_str()));
145 EXPECT_FALSE(utils::IsSymlink(temp_dir.c_str()));
146 EXPECT_FALSE(utils::IsSymlink(temp_file.c_str()));
147 EXPECT_TRUE(utils::IsSymlink(temp_symlink.c_str()));
148 EXPECT_FALSE(utils::IsSymlink("/non/existent/path"));
149 EXPECT_TRUE(utils::RecursiveUnlinkDir(temp_dir));
150}
151
adlr@google.com3defe6a2009-12-04 20:57:17 +0000152TEST(UtilsTest, TempFilenameTest) {
153 const string original = "/foo.XXXXXX";
154 const string result = utils::TempFilename(original);
155 EXPECT_EQ(original.size(), result.size());
156 EXPECT_TRUE(utils::StringHasPrefix(result, "/foo."));
157 EXPECT_FALSE(utils::StringHasSuffix(result, "XXXXXX"));
158}
159
Andrew de los Reyesf9714432010-05-04 10:21:23 -0700160TEST(UtilsTest, RootDeviceTest) {
161 EXPECT_EQ("/dev/sda", utils::RootDevice("/dev/sda3"));
162 EXPECT_EQ("/dev/mmc0", utils::RootDevice("/dev/mmc0p3"));
Darin Petkovf74eb652010-08-04 12:08:38 -0700163 EXPECT_EQ("", utils::RootDevice("/dev/foo/bar"));
164 EXPECT_EQ("", utils::RootDevice("/"));
165 EXPECT_EQ("", utils::RootDevice(""));
166}
167
168TEST(UtilsTest, SysfsBlockDeviceTest) {
169 EXPECT_EQ("/sys/block/sda", utils::SysfsBlockDevice("/dev/sda"));
170 EXPECT_EQ("", utils::SysfsBlockDevice("/foo/sda"));
171 EXPECT_EQ("", utils::SysfsBlockDevice("/dev/foo/bar"));
172 EXPECT_EQ("", utils::SysfsBlockDevice("/"));
173 EXPECT_EQ("", utils::SysfsBlockDevice("./"));
174 EXPECT_EQ("", utils::SysfsBlockDevice(""));
175}
176
177TEST(UtilsTest, IsRemovableDeviceTest) {
178 EXPECT_FALSE(utils::IsRemovableDevice(""));
179 EXPECT_FALSE(utils::IsRemovableDevice("/dev/non-existent-device"));
Andrew de los Reyesf9714432010-05-04 10:21:23 -0700180}
181
182TEST(UtilsTest, PartitionNumberTest) {
183 EXPECT_EQ("3", utils::PartitionNumber("/dev/sda3"));
184 EXPECT_EQ("3", utils::PartitionNumber("/dev/mmc0p3"));
185}
186
Darin Petkov002b2fe2010-11-22 13:53:22 -0800187
188TEST(UtilsTest, RunAsRootSetProcessPriorityTest) {
189 // getpriority may return -1 on error so the getpriority logic needs to be
190 // enhanced if any of the pre-defined priority constants are changed to -1.
191 ASSERT_NE(-1, utils::kProcessPriorityLow);
192 ASSERT_NE(-1, utils::kProcessPriorityNormal);
193 ASSERT_NE(-1, utils::kProcessPriorityHigh);
194 EXPECT_EQ(utils::kProcessPriorityNormal, getpriority(PRIO_PROCESS, 0));
195 EXPECT_TRUE(utils::SetProcessPriority(utils::kProcessPriorityHigh));
196 EXPECT_EQ(utils::kProcessPriorityHigh, getpriority(PRIO_PROCESS, 0));
197 EXPECT_TRUE(utils::SetProcessPriority(utils::kProcessPriorityLow));
198 EXPECT_EQ(utils::kProcessPriorityLow, getpriority(PRIO_PROCESS, 0));
199 EXPECT_TRUE(utils::SetProcessPriority(utils::kProcessPriorityNormal));
200 EXPECT_EQ(utils::kProcessPriorityNormal, getpriority(PRIO_PROCESS, 0));
201}
202
Darin Petkov5c0a8af2010-08-24 13:39:13 -0700203TEST(UtilsTest, ComparePrioritiesTest) {
Darin Petkovc6c135c2010-08-11 13:36:18 -0700204 EXPECT_LT(utils::ComparePriorities(utils::kProcessPriorityLow,
205 utils::kProcessPriorityNormal), 0);
206 EXPECT_GT(utils::ComparePriorities(utils::kProcessPriorityNormal,
207 utils::kProcessPriorityLow), 0);
208 EXPECT_EQ(utils::ComparePriorities(utils::kProcessPriorityNormal,
209 utils::kProcessPriorityNormal), 0);
210 EXPECT_GT(utils::ComparePriorities(utils::kProcessPriorityHigh,
211 utils::kProcessPriorityNormal), 0);
212}
213
Darin Petkov5c0a8af2010-08-24 13:39:13 -0700214TEST(UtilsTest, FuzzIntTest) {
215 static const unsigned int kRanges[] = { 0, 1, 2, 20 };
216 for (size_t r = 0; r < arraysize(kRanges); ++r) {
217 unsigned int range = kRanges[r];
218 const int kValue = 50;
219 for (int tries = 0; tries < 100; ++tries) {
220 int value = utils::FuzzInt(kValue, range);
221 EXPECT_GE(value, kValue - range / 2);
222 EXPECT_LE(value, kValue + range - range / 2);
223 }
224 }
225}
226
Andrew de los Reyescc92cd32010-10-05 16:56:14 -0700227TEST(UtilsTest, ApplyMapTest) {
228 int initial_values[] = {1, 2, 3, 4, 6};
229 vector<int> collection(&initial_values[0],
230 initial_values + arraysize(initial_values));
231 EXPECT_EQ(arraysize(initial_values), collection.size());
232 int expected_values[] = {1, 2, 5, 4, 8};
233 map<int, int> value_map;
234 value_map[3] = 5;
235 value_map[6] = 8;
236 value_map[5] = 10;
237
238 utils::ApplyMap(&collection, value_map);
239
240 size_t index = 0;
241 for (vector<int>::iterator it = collection.begin(), e = collection.end();
242 it != e; ++it) {
243 EXPECT_EQ(expected_values[index++], *it);
244 }
245}
246
Darin Petkovd3f8c892010-10-12 21:38:45 -0700247TEST(UtilsTest, RunAsRootGetFilesystemSizeTest) {
248 string img;
249 EXPECT_TRUE(utils::MakeTempFile("/tmp/img.XXXXXX", &img, NULL));
250 ScopedPathUnlinker img_unlinker(img);
251 CreateExtImageAtPath(img, NULL);
252 // Extend the "partition" holding the file system from 10MiB to 20MiB.
253 EXPECT_EQ(0, System(base::StringPrintf(
254 "dd if=/dev/zero of=%s seek=20971519 bs=1 count=1",
255 img.c_str())));
256 EXPECT_EQ(20 * 1024 * 1024, utils::FileSize(img));
257 int block_count = 0;
258 int block_size = 0;
259 EXPECT_TRUE(utils::GetFilesystemSize(img, &block_count, &block_size));
260 EXPECT_EQ(4096, block_size);
261 EXPECT_EQ(10 * 1024 * 1024 / 4096, block_count);
262}
263
Andrew de los Reyes712b3ac2011-01-07 13:47:52 -0800264namespace {
265gboolean TerminateScheduleCrashReporterUploadTest(void* arg) {
266 GMainLoop* loop = reinterpret_cast<GMainLoop*>(arg);
267 g_main_loop_quit(loop);
268 return FALSE; // Don't call this callback again
269}
270} // namespace {}
271
272TEST(UtilsTest, ScheduleCrashReporterUploadTest) {
273 // Not much to test. At least this tests for memory leaks, crashes,
274 // log errors.
275 GMainLoop* loop = g_main_loop_new(g_main_context_default(), FALSE);
276 utils::ScheduleCrashReporterUpload();
277 g_timeout_add_seconds(1, &TerminateScheduleCrashReporterUploadTest, loop);
278 g_main_loop_run(loop);
279 g_main_loop_unref(loop);
280}
281
adlr@google.com3defe6a2009-12-04 20:57:17 +0000282} // namespace chromeos_update_engine