blob: 762e891566dcd09e21b8fdc133d96d5a6995687d [file] [log] [blame]
Alex Deymoaea4c1c2015-08-19 20:24:43 -07001//
2// Copyright (C) 2012 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//
adlr@google.com3defe6a2009-12-04 20:57:17 +000016
Alex Deymo39910dc2015-11-09 17:04:30 -080017#include "update_engine/common/utils.h"
Alex Deymo2c0db7b2014-11-04 12:23:39 -080018
Ben Chan9abb7632014-08-07 00:10:53 -070019#include <stdint.h>
adlr@google.com3defe6a2009-12-04 20:57:17 +000020#include <sys/stat.h>
21#include <sys/types.h>
Darin Petkov5c0a8af2010-08-24 13:39:13 -070022
Andrew de los Reyes4fe15d02009-12-10 19:01:36 -080023#include <string>
adlr@google.com3defe6a2009-12-04 20:57:17 +000024#include <vector>
Darin Petkov5c0a8af2010-08-24 13:39:13 -070025
Alex Deymoc1711e22014-08-08 13:16:23 -070026#include <base/files/file_path.h>
Alex Deymo2c0db7b2014-11-04 12:23:39 -080027#include <base/files/file_util.h>
Alex Vakulenko3f39d5c2015-10-13 09:27:13 -070028#include <brillo/message_loops/fake_message_loop.h>
29#include <brillo/message_loops/message_loop_utils.h>
Darin Petkovd3f8c892010-10-12 21:38:45 -070030#include <gtest/gtest.h>
31
Alex Deymo39910dc2015-11-09 17:04:30 -080032#include "update_engine/common/test_utils.h"
adlr@google.com3defe6a2009-12-04 20:57:17 +000033
Alex Vakulenko3f39d5c2015-10-13 09:27:13 -070034using brillo::FakeMessageLoop;
Andrew de los Reyes4fe15d02009-12-10 19:01:36 -080035using std::string;
adlr@google.com3defe6a2009-12-04 20:57:17 +000036using std::vector;
37
38namespace chromeos_update_engine {
39
40class UtilsTest : public ::testing::Test { };
41
Chris Sosac1972482013-04-30 22:31:10 -070042TEST(UtilsTest, CanParseECVersion) {
Chris Sosac1972482013-04-30 22:31:10 -070043 // Should be able to parse and valid key value line.
J. Richard Barnette63137e52013-10-28 10:57:29 -070044 EXPECT_EQ("12345", utils::ParseECVersion("fw_version=12345"));
45 EXPECT_EQ("123456", utils::ParseECVersion(
46 "b=1231a fw_version=123456 a=fasd2"));
47 EXPECT_EQ("12345", utils::ParseECVersion("fw_version=12345"));
48 EXPECT_EQ("00VFA616", utils::ParseECVersion(
Chris Sosac1972482013-04-30 22:31:10 -070049 "vendor=\"sam\" fw_version=\"00VFA616\""));
50
51 // For invalid entries, should return the empty string.
J. Richard Barnette63137e52013-10-28 10:57:29 -070052 EXPECT_EQ("", utils::ParseECVersion("b=1231a fw_version a=fasd2"));
Chris Sosac1972482013-04-30 22:31:10 -070053}
54
adlr@google.com3defe6a2009-12-04 20:57:17 +000055TEST(UtilsTest, ReadFileFailure) {
Alex Vakulenko3f39d5c2015-10-13 09:27:13 -070056 brillo::Blob empty;
adlr@google.com3defe6a2009-12-04 20:57:17 +000057 EXPECT_FALSE(utils::ReadFile("/this/doesn't/exist", &empty));
58}
59
Darin Petkov8e447e02013-04-16 16:23:50 +020060TEST(UtilsTest, ReadFileChunk) {
Alex Vakulenko75039d72014-03-25 12:36:28 -070061 base::FilePath file;
62 EXPECT_TRUE(base::CreateTemporaryFile(&file));
Darin Petkov8e447e02013-04-16 16:23:50 +020063 ScopedPathUnlinker unlinker(file.value());
Alex Vakulenko3f39d5c2015-10-13 09:27:13 -070064 brillo::Blob data;
Darin Petkov8e447e02013-04-16 16:23:50 +020065 const size_t kSize = 1024 * 1024;
66 for (size_t i = 0; i < kSize; i++) {
67 data.push_back(i % 255);
68 }
Alex Vakulenkof68bbbc2015-02-09 12:53:18 -080069 EXPECT_TRUE(utils::WriteFile(file.value().c_str(), data.data(), data.size()));
Alex Vakulenko3f39d5c2015-10-13 09:27:13 -070070 brillo::Blob in_data;
Darin Petkov8e447e02013-04-16 16:23:50 +020071 EXPECT_TRUE(utils::ReadFileChunk(file.value().c_str(), kSize, 10, &in_data));
72 EXPECT_TRUE(in_data.empty());
73 EXPECT_TRUE(utils::ReadFileChunk(file.value().c_str(), 0, -1, &in_data));
74 EXPECT_TRUE(data == in_data);
75 in_data.clear();
76 EXPECT_TRUE(utils::ReadFileChunk(file.value().c_str(), 10, 20, &in_data));
Alex Vakulenko3f39d5c2015-10-13 09:27:13 -070077 EXPECT_TRUE(brillo::Blob(data.begin() + 10, data.begin() + 10 + 20) ==
Darin Petkov8e447e02013-04-16 16:23:50 +020078 in_data);
79}
80
adlr@google.com3defe6a2009-12-04 20:57:17 +000081TEST(UtilsTest, ErrnoNumberAsStringTest) {
82 EXPECT_EQ("No such file or directory", utils::ErrnoNumberAsString(ENOENT));
83}
84
Darin Petkov002b2fe2010-11-22 13:53:22 -080085TEST(UtilsTest, IsSymlinkTest) {
86 string temp_dir;
Gilad Arnolda6742b32014-01-11 00:18:34 -080087 EXPECT_TRUE(utils::MakeTempDirectory("symlink-test.XXXXXX", &temp_dir));
Alex Deymo8d925292014-05-21 19:15:25 -070088 string temp_file = temp_dir + "/temp-file";
Darin Petkov002b2fe2010-11-22 13:53:22 -080089 EXPECT_TRUE(utils::WriteFile(temp_file.c_str(), "", 0));
Alex Deymo8d925292014-05-21 19:15:25 -070090 string temp_symlink = temp_dir + "/temp-symlink";
Darin Petkov002b2fe2010-11-22 13:53:22 -080091 EXPECT_EQ(0, symlink(temp_file.c_str(), temp_symlink.c_str()));
92 EXPECT_FALSE(utils::IsSymlink(temp_dir.c_str()));
93 EXPECT_FALSE(utils::IsSymlink(temp_file.c_str()));
94 EXPECT_TRUE(utils::IsSymlink(temp_symlink.c_str()));
95 EXPECT_FALSE(utils::IsSymlink("/non/existent/path"));
Alex Deymo110e0302015-10-19 20:35:21 -070096 EXPECT_TRUE(base::DeleteFile(base::FilePath(temp_dir), true));
Darin Petkov002b2fe2010-11-22 13:53:22 -080097}
98
Alex Deymo763e7db2015-08-27 21:08:08 -070099TEST(UtilsTest, SplitPartitionNameTest) {
100 string disk;
101 int part_num;
Darin Petkovf74eb652010-08-04 12:08:38 -0700102
Alex Deymo763e7db2015-08-27 21:08:08 -0700103 EXPECT_TRUE(utils::SplitPartitionName("/dev/sda3", &disk, &part_num));
104 EXPECT_EQ("/dev/sda", disk);
105 EXPECT_EQ(3, part_num);
Darin Petkovf74eb652010-08-04 12:08:38 -0700106
Alex Deymo763e7db2015-08-27 21:08:08 -0700107 EXPECT_TRUE(utils::SplitPartitionName("/dev/sdp1234", &disk, &part_num));
108 EXPECT_EQ("/dev/sdp", disk);
109 EXPECT_EQ(1234, part_num);
Andrew de los Reyesf9714432010-05-04 10:21:23 -0700110
Alex Deymo763e7db2015-08-27 21:08:08 -0700111 EXPECT_TRUE(utils::SplitPartitionName("/dev/mmcblk0p3", &disk, &part_num));
112 EXPECT_EQ("/dev/mmcblk0", disk);
113 EXPECT_EQ(3, part_num);
114
115 EXPECT_TRUE(utils::SplitPartitionName("/dev/ubiblock3_2", &disk, &part_num));
116 EXPECT_EQ("/dev/ubiblock", disk);
117 EXPECT_EQ(3, part_num);
118
119 EXPECT_TRUE(utils::SplitPartitionName("/dev/loop10", &disk, &part_num));
120 EXPECT_EQ("/dev/loop", disk);
121 EXPECT_EQ(10, part_num);
122
123 EXPECT_TRUE(utils::SplitPartitionName("/dev/loop28p11", &disk, &part_num));
124 EXPECT_EQ("/dev/loop28", disk);
125 EXPECT_EQ(11, part_num);
126
127 EXPECT_TRUE(utils::SplitPartitionName("/dev/loop10_0", &disk, &part_num));
128 EXPECT_EQ("/dev/loop", disk);
129 EXPECT_EQ(10, part_num);
130
131 EXPECT_TRUE(utils::SplitPartitionName("/dev/loop28p11_0", &disk, &part_num));
132 EXPECT_EQ("/dev/loop28", disk);
133 EXPECT_EQ(11, part_num);
134
135 EXPECT_FALSE(utils::SplitPartitionName("/dev/mmcblk0p", &disk, &part_num));
136 EXPECT_FALSE(utils::SplitPartitionName("/dev/sda", &disk, &part_num));
137 EXPECT_FALSE(utils::SplitPartitionName("/dev/foo/bar", &disk, &part_num));
138 EXPECT_FALSE(utils::SplitPartitionName("/", &disk, &part_num));
139 EXPECT_FALSE(utils::SplitPartitionName("", &disk, &part_num));
Andrew de los Reyesf9714432010-05-04 10:21:23 -0700140}
141
Alex Vakulenkof3f85bb2014-03-26 16:36:35 -0700142TEST(UtilsTest, MakePartitionNameTest) {
143 EXPECT_EQ("/dev/sda4", utils::MakePartitionName("/dev/sda", 4));
144 EXPECT_EQ("/dev/sda123", utils::MakePartitionName("/dev/sda", 123));
145 EXPECT_EQ("/dev/mmcblk2", utils::MakePartitionName("/dev/mmcblk", 2));
146 EXPECT_EQ("/dev/mmcblk0p2", utils::MakePartitionName("/dev/mmcblk0", 2));
147 EXPECT_EQ("/dev/loop8", utils::MakePartitionName("/dev/loop", 8));
148 EXPECT_EQ("/dev/loop12p2", utils::MakePartitionName("/dev/loop12", 2));
Nam T. Nguyena78b28c2015-03-06 22:30:12 -0800149 EXPECT_EQ("/dev/ubi5_0", utils::MakePartitionName("/dev/ubiblock", 5));
150 EXPECT_EQ("/dev/mtd4", utils::MakePartitionName("/dev/ubiblock", 4));
151 EXPECT_EQ("/dev/ubi3_0", utils::MakePartitionName("/dev/ubiblock", 3));
152 EXPECT_EQ("/dev/mtd2", utils::MakePartitionName("/dev/ubiblock", 2));
153 EXPECT_EQ("/dev/ubi1_0", utils::MakePartitionName("/dev/ubiblock", 1));
154}
155
156TEST(UtilsTest, MakePartitionNameForMountTest) {
157 EXPECT_EQ("/dev/sda4", utils::MakePartitionNameForMount("/dev/sda4"));
158 EXPECT_EQ("/dev/sda123", utils::MakePartitionNameForMount("/dev/sda123"));
159 EXPECT_EQ("/dev/mmcblk2", utils::MakePartitionNameForMount("/dev/mmcblk2"));
160 EXPECT_EQ("/dev/mmcblk0p2",
161 utils::MakePartitionNameForMount("/dev/mmcblk0p2"));
162 EXPECT_EQ("/dev/loop0", utils::MakePartitionNameForMount("/dev/loop0"));
163 EXPECT_EQ("/dev/loop8", utils::MakePartitionNameForMount("/dev/loop8"));
164 EXPECT_EQ("/dev/loop12p2",
165 utils::MakePartitionNameForMount("/dev/loop12p2"));
166 EXPECT_EQ("/dev/ubiblock5_0",
167 utils::MakePartitionNameForMount("/dev/ubiblock5_0"));
168 EXPECT_EQ("/dev/mtd4",
169 utils::MakePartitionNameForMount("/dev/ubi4_0"));
170 EXPECT_EQ("/dev/ubiblock3_0",
171 utils::MakePartitionNameForMount("/dev/ubiblock3"));
172 EXPECT_EQ("/dev/mtd2", utils::MakePartitionNameForMount("/dev/ubi2"));
173 EXPECT_EQ("/dev/ubi1_0",
174 utils::MakePartitionNameForMount("/dev/ubiblock1"));
Alex Vakulenkof3f85bb2014-03-26 16:36:35 -0700175}
176
Darin Petkov5c0a8af2010-08-24 13:39:13 -0700177TEST(UtilsTest, FuzzIntTest) {
Alex Deymo80f70ff2016-02-10 16:08:11 -0800178 static const uint32_t kRanges[] = { 0, 1, 2, 20 };
179 for (uint32_t range : kRanges) {
Darin Petkov5c0a8af2010-08-24 13:39:13 -0700180 const int kValue = 50;
181 for (int tries = 0; tries < 100; ++tries) {
Alex Deymo80f70ff2016-02-10 16:08:11 -0800182 uint32_t value = utils::FuzzInt(kValue, range);
Darin Petkov5c0a8af2010-08-24 13:39:13 -0700183 EXPECT_GE(value, kValue - range / 2);
184 EXPECT_LE(value, kValue + range - range / 2);
185 }
186 }
187}
188
Andrew de los Reyes712b3ac2011-01-07 13:47:52 -0800189namespace {
Alex Deymo032e7722014-03-25 17:53:56 -0700190void GetFileFormatTester(const string& expected,
Ben Chan9abb7632014-08-07 00:10:53 -0700191 const vector<uint8_t>& contents) {
Alex Deymo10875d92014-11-10 21:52:57 -0800192 test_utils::ScopedTempFile file;
Alex Deymobffa0602016-02-12 17:16:29 -0800193 ASSERT_TRUE(utils::WriteFile(file.path().c_str(),
Alex Deymo032e7722014-03-25 17:53:56 -0700194 reinterpret_cast<const char*>(contents.data()),
195 contents.size()));
Alex Deymobffa0602016-02-12 17:16:29 -0800196 EXPECT_EQ(expected, utils::GetFileFormat(file.path()));
Alex Deymo032e7722014-03-25 17:53:56 -0700197}
Alex Deymo10875d92014-11-10 21:52:57 -0800198} // namespace
Alex Deymo032e7722014-03-25 17:53:56 -0700199
200TEST(UtilsTest, GetFileFormatTest) {
201 EXPECT_EQ("File not found.", utils::GetFileFormat("/path/to/nowhere"));
Ben Chan9abb7632014-08-07 00:10:53 -0700202 GetFileFormatTester("data", vector<uint8_t>{1, 2, 3, 4, 5, 6, 7, 8});
203 GetFileFormatTester("ELF", vector<uint8_t>{0x7f, 0x45, 0x4c, 0x46});
Alex Deymo032e7722014-03-25 17:53:56 -0700204
205 // Real tests from cros_installer on different boards.
206 // ELF 32-bit LSB executable, Intel 80386
207 GetFileFormatTester(
208 "ELF 32-bit little-endian x86",
Ben Chan9abb7632014-08-07 00:10:53 -0700209 vector<uint8_t>{0x7f, 0x45, 0x4c, 0x46, 0x01, 0x01, 0x01, 0x00,
210 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
211 0x02, 0x00, 0x03, 0x00, 0x01, 0x00, 0x00, 0x00,
212 0x90, 0x83, 0x04, 0x08, 0x34, 0x00, 0x00, 0x00});
Alex Deymo032e7722014-03-25 17:53:56 -0700213
Alex Deymoc1711e22014-08-08 13:16:23 -0700214 // ELF 32-bit LSB executable, MIPS
215 GetFileFormatTester(
216 "ELF 32-bit little-endian mips",
217 vector<uint8_t>{0x7f, 0x45, 0x4c, 0x46, 0x01, 0x01, 0x01, 0x00,
218 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
219 0x03, 0x00, 0x08, 0x00, 0x01, 0x00, 0x00, 0x00,
220 0xc0, 0x12, 0x00, 0x00, 0x34, 0x00, 0x00, 0x00});
221
Alex Deymo032e7722014-03-25 17:53:56 -0700222 // ELF 32-bit LSB executable, ARM
223 GetFileFormatTester(
224 "ELF 32-bit little-endian arm",
Ben Chan9abb7632014-08-07 00:10:53 -0700225 vector<uint8_t>{0x7f, 0x45, 0x4c, 0x46, 0x01, 0x01, 0x01, 0x00,
226 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
227 0x02, 0x00, 0x28, 0x00, 0x01, 0x00, 0x00, 0x00,
228 0x85, 0x8b, 0x00, 0x00, 0x34, 0x00, 0x00, 0x00});
Alex Deymo032e7722014-03-25 17:53:56 -0700229
230 // ELF 64-bit LSB executable, x86-64
231 GetFileFormatTester(
232 "ELF 64-bit little-endian x86-64",
Ben Chan9abb7632014-08-07 00:10:53 -0700233 vector<uint8_t>{0x7f, 0x45, 0x4c, 0x46, 0x02, 0x01, 0x01, 0x00,
234 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
235 0x02, 0x00, 0x3e, 0x00, 0x01, 0x00, 0x00, 0x00,
236 0xb0, 0x04, 0x40, 0x00, 0x00, 0x00, 0x00, 0x00});
Alex Deymo032e7722014-03-25 17:53:56 -0700237}
238
Andrew de los Reyes712b3ac2011-01-07 13:47:52 -0800239TEST(UtilsTest, ScheduleCrashReporterUploadTest) {
240 // Not much to test. At least this tests for memory leaks, crashes,
241 // log errors.
Alex Deymo60ca1a72015-06-18 18:19:15 -0700242 FakeMessageLoop loop(nullptr);
243 loop.SetAsCurrent();
Andrew de los Reyes712b3ac2011-01-07 13:47:52 -0800244 utils::ScheduleCrashReporterUpload();
Alex Deymo60ca1a72015-06-18 18:19:15 -0700245 // Test that we scheduled one callback from the crash reporter.
Alex Vakulenko3f39d5c2015-10-13 09:27:13 -0700246 EXPECT_EQ(1, brillo::MessageLoopRunMaxIterations(&loop, 100));
Alex Deymo60ca1a72015-06-18 18:19:15 -0700247 EXPECT_FALSE(loop.PendingTasks());
Andrew de los Reyes712b3ac2011-01-07 13:47:52 -0800248}
249
David Zeuthen674c3182013-04-18 14:05:20 -0700250TEST(UtilsTest, FormatTimeDeltaTest) {
251 // utils::FormatTimeDelta() is not locale-aware (it's only used for logging
252 // which is not localized) so we only need to test the C locale
253 EXPECT_EQ(utils::FormatTimeDelta(base::TimeDelta::FromMilliseconds(100)),
254 "0.1s");
255 EXPECT_EQ(utils::FormatTimeDelta(base::TimeDelta::FromSeconds(0)),
256 "0s");
257 EXPECT_EQ(utils::FormatTimeDelta(base::TimeDelta::FromSeconds(1)),
258 "1s");
259 EXPECT_EQ(utils::FormatTimeDelta(base::TimeDelta::FromSeconds(59)),
260 "59s");
261 EXPECT_EQ(utils::FormatTimeDelta(base::TimeDelta::FromSeconds(60)),
262 "1m0s");
263 EXPECT_EQ(utils::FormatTimeDelta(base::TimeDelta::FromSeconds(61)),
264 "1m1s");
265 EXPECT_EQ(utils::FormatTimeDelta(base::TimeDelta::FromSeconds(90)),
266 "1m30s");
267 EXPECT_EQ(utils::FormatTimeDelta(base::TimeDelta::FromSeconds(1205)),
268 "20m5s");
269 EXPECT_EQ(utils::FormatTimeDelta(base::TimeDelta::FromSeconds(3600)),
270 "1h0m0s");
271 EXPECT_EQ(utils::FormatTimeDelta(base::TimeDelta::FromSeconds(3601)),
272 "1h0m1s");
273 EXPECT_EQ(utils::FormatTimeDelta(base::TimeDelta::FromSeconds(3661)),
274 "1h1m1s");
275 EXPECT_EQ(utils::FormatTimeDelta(base::TimeDelta::FromSeconds(7261)),
276 "2h1m1s");
277 EXPECT_EQ(utils::FormatTimeDelta(base::TimeDelta::FromSeconds(86400)),
278 "1d0h0m0s");
279 EXPECT_EQ(utils::FormatTimeDelta(base::TimeDelta::FromSeconds(86401)),
280 "1d0h0m1s");
281 EXPECT_EQ(utils::FormatTimeDelta(base::TimeDelta::FromSeconds(200000)),
282 "2d7h33m20s");
283 EXPECT_EQ(utils::FormatTimeDelta(base::TimeDelta::FromSeconds(200000) +
284 base::TimeDelta::FromMilliseconds(1)),
285 "2d7h33m20.001s");
David Zeuthen973449e2014-08-18 16:18:23 -0400286 EXPECT_EQ(utils::FormatTimeDelta(base::TimeDelta::FromSeconds(-1)),
287 "-1s");
David Zeuthen674c3182013-04-18 14:05:20 -0700288}
289
David Zeuthen27a48bc2013-08-06 12:06:29 -0700290TEST(UtilsTest, TimeFromStructTimespecTest) {
291 struct timespec ts;
292
293 // Unix epoch (Thursday 00:00:00 UTC on Jan 1, 1970)
294 ts = (struct timespec) {.tv_sec = 0, .tv_nsec = 0};
295 EXPECT_EQ(base::Time::UnixEpoch(), utils::TimeFromStructTimespec(&ts));
296
297 // 42 ms after the Unix billennium (Sunday 01:46:40 UTC on September 9, 2001)
298 ts = (struct timespec) {.tv_sec = 1000 * 1000 * 1000,
299 .tv_nsec = 42 * 1000 * 1000};
300 base::Time::Exploded exploded = (base::Time::Exploded) {
301 .year = 2001, .month = 9, .day_of_week = 0, .day_of_month = 9,
302 .hour = 1, .minute = 46, .second = 40, .millisecond = 42};
303 EXPECT_EQ(base::Time::FromUTCExploded(exploded),
304 utils::TimeFromStructTimespec(&ts));
305}
306
David Zeuthene7f89172013-10-31 10:21:04 -0700307TEST(UtilsTest, DecodeAndStoreBase64String) {
308 base::FilePath path;
309
310 // Ensure we return false on empty strings or invalid base64.
311 EXPECT_FALSE(utils::DecodeAndStoreBase64String("", &path));
312 EXPECT_FALSE(utils::DecodeAndStoreBase64String("not valid base64", &path));
313
314 // Pass known base64 and check that it matches. This string was generated
315 // the following way:
316 //
317 // $ echo "Update Engine" | base64
318 // VXBkYXRlIEVuZ2luZQo=
319 EXPECT_TRUE(utils::DecodeAndStoreBase64String("VXBkYXRlIEVuZ2luZQo=",
320 &path));
321 ScopedPathUnlinker unlinker(path.value());
322 string expected_contents = "Update Engine\n";
323 string contents;
324 EXPECT_TRUE(utils::ReadFile(path.value(), &contents));
325 EXPECT_EQ(contents, expected_contents);
Alex Deymo5fe0c4e2016-02-16 18:46:24 -0800326 EXPECT_EQ(static_cast<off_t>(expected_contents.size()),
327 utils::FileSize(path.value()));
David Zeuthene7f89172013-10-31 10:21:04 -0700328}
329
David Zeuthen639aa362014-02-03 16:23:44 -0800330TEST(UtilsTest, ConvertToOmahaInstallDate) {
331 // The Omaha Epoch starts at Jan 1, 2007 0:00 PST which is a
332 // Monday. In Unix time, this point in time is easily obtained via
333 // the date(1) command like this:
334 //
335 // $ date +"%s" --date="Jan 1, 2007 0:00 PST"
336 const time_t omaha_epoch = 1167638400;
337 int value;
338
339 // Points in time *on and after* the Omaha epoch should not fail.
340 EXPECT_TRUE(utils::ConvertToOmahaInstallDate(
341 base::Time::FromTimeT(omaha_epoch), &value));
342 EXPECT_GE(value, 0);
343
344 // Anything before the Omaha epoch should fail. We test it for two points.
345 EXPECT_FALSE(utils::ConvertToOmahaInstallDate(
346 base::Time::FromTimeT(omaha_epoch - 1), &value));
347 EXPECT_FALSE(utils::ConvertToOmahaInstallDate(
348 base::Time::FromTimeT(omaha_epoch - 100*24*3600), &value));
349
350 // Check that we jump from 0 to 7 exactly on the one-week mark, e.g.
351 // on Jan 8, 2007 0:00 PST.
352 EXPECT_TRUE(utils::ConvertToOmahaInstallDate(
353 base::Time::FromTimeT(omaha_epoch + 7*24*3600 - 1), &value));
354 EXPECT_EQ(value, 0);
355 EXPECT_TRUE(utils::ConvertToOmahaInstallDate(
356 base::Time::FromTimeT(omaha_epoch + 7*24*3600), &value));
357 EXPECT_EQ(value, 7);
358
359 // Check a couple of more values.
360 EXPECT_TRUE(utils::ConvertToOmahaInstallDate(
361 base::Time::FromTimeT(omaha_epoch + 10*24*3600), &value));
362 EXPECT_EQ(value, 7);
363 EXPECT_TRUE(utils::ConvertToOmahaInstallDate(
364 base::Time::FromTimeT(omaha_epoch + 20*24*3600), &value));
365 EXPECT_EQ(value, 14);
366 EXPECT_TRUE(utils::ConvertToOmahaInstallDate(
367 base::Time::FromTimeT(omaha_epoch + 26*24*3600), &value));
368 EXPECT_EQ(value, 21);
369 EXPECT_TRUE(utils::ConvertToOmahaInstallDate(
370 base::Time::FromTimeT(omaha_epoch + 29*24*3600), &value));
371 EXPECT_EQ(value, 28);
372
373 // The date Jun 4, 2007 0:00 PDT is a Monday and is hence a point
374 // where the Omaha InstallDate jumps 7 days. Its unix time is
375 // 1180940400. Notably, this is a point in time where Daylight
376 // Savings Time (DST) was is in effect (e.g. it's PDT, not PST).
377 //
378 // Note that as utils::ConvertToOmahaInstallDate() _deliberately_
379 // ignores DST (as it's hard to implement in a thread-safe way using
380 // glibc, see comments in utils.h) we have to fudge by the DST
381 // offset which is one hour. Conveniently, if the function were
382 // someday modified to be DST aware, this test would have to be
383 // modified as well.
Alex Vakulenkod2779df2014-06-16 13:19:00 -0700384 const time_t dst_time = 1180940400; // Jun 4, 2007 0:00 PDT.
David Zeuthen639aa362014-02-03 16:23:44 -0800385 const time_t fudge = 3600;
386 int value1, value2;
387 EXPECT_TRUE(utils::ConvertToOmahaInstallDate(
388 base::Time::FromTimeT(dst_time + fudge - 1), &value1));
389 EXPECT_TRUE(utils::ConvertToOmahaInstallDate(
390 base::Time::FromTimeT(dst_time + fudge), &value2));
391 EXPECT_EQ(value1, value2 - 7);
392}
393
Allie Wood78750a42015-02-11 15:42:11 -0800394TEST(UtilsTest, GetMinorVersion) {
395 // Test GetMinorVersion by verifying that it parses the conf file and returns
396 // the correct value.
Allie Wood78750a42015-02-11 15:42:11 -0800397 uint32_t minor_version;
398
Alex Vakulenko3f39d5c2015-10-13 09:27:13 -0700399 brillo::KeyValueStore store;
Alex Deymob42b98d2015-07-06 17:42:38 -0700400 EXPECT_FALSE(utils::GetMinorVersion(store, &minor_version));
Allie Wood78750a42015-02-11 15:42:11 -0800401
Alex Deymob42b98d2015-07-06 17:42:38 -0700402 EXPECT_TRUE(store.LoadFromString("PAYLOAD_MINOR_VERSION=one-two-three\n"));
403 EXPECT_FALSE(utils::GetMinorVersion(store, &minor_version));
Allie Wood78750a42015-02-11 15:42:11 -0800404
Alex Deymob42b98d2015-07-06 17:42:38 -0700405 EXPECT_TRUE(store.LoadFromString("PAYLOAD_MINOR_VERSION=123\n"));
406 EXPECT_TRUE(utils::GetMinorVersion(store, &minor_version));
Alex Deymo80f70ff2016-02-10 16:08:11 -0800407 EXPECT_EQ(123U, minor_version);
Allie Wood78750a42015-02-11 15:42:11 -0800408}
409
Nam T. Nguyen2b67a592014-12-03 14:56:00 -0800410static bool BoolMacroTestHelper() {
411 int i = 1;
412 unsigned int ui = 1;
413 bool b = 1;
414 std::unique_ptr<char> cptr(new char);
415
416 TEST_AND_RETURN_FALSE(i);
417 TEST_AND_RETURN_FALSE(ui);
418 TEST_AND_RETURN_FALSE(b);
419 TEST_AND_RETURN_FALSE(cptr);
420
421 TEST_AND_RETURN_FALSE_ERRNO(i);
422 TEST_AND_RETURN_FALSE_ERRNO(ui);
423 TEST_AND_RETURN_FALSE_ERRNO(b);
424 TEST_AND_RETURN_FALSE_ERRNO(cptr);
425
426 return true;
427}
428
429static void VoidMacroTestHelper(bool* ret) {
430 int i = 1;
431 unsigned int ui = 1;
432 bool b = 1;
433 std::unique_ptr<char> cptr(new char);
434
435 *ret = false;
436
437 TEST_AND_RETURN(i);
438 TEST_AND_RETURN(ui);
439 TEST_AND_RETURN(b);
440 TEST_AND_RETURN(cptr);
441
442 TEST_AND_RETURN_ERRNO(i);
443 TEST_AND_RETURN_ERRNO(ui);
444 TEST_AND_RETURN_ERRNO(b);
445 TEST_AND_RETURN_ERRNO(cptr);
446
447 *ret = true;
448}
449
450TEST(UtilsTest, TestMacros) {
451 bool void_test = false;
452 VoidMacroTestHelper(&void_test);
453 EXPECT_TRUE(void_test);
454
455 EXPECT_TRUE(BoolMacroTestHelper());
456}
457
adlr@google.com3defe6a2009-12-04 20:57:17 +0000458} // namespace chromeos_update_engine