Alex Deymo | aea4c1c | 2015-08-19 20:24:43 -0700 | [diff] [blame] | 1 | // |
| 2 | // Copyright (C) 2014 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 | // |
Alex Deymo | 23949d4 | 2014-02-05 15:20:59 -0800 | [diff] [blame] | 16 | |
Alex Deymo | aab50e3 | 2014-11-10 19:55:35 -0800 | [diff] [blame] | 17 | #include "update_engine/update_manager/boxed_value.h" |
| 18 | |
Alex Deymo | 23949d4 | 2014-02-05 15:20:59 -0800 | [diff] [blame] | 19 | #include <gtest/gtest.h> |
| 20 | #include <list> |
| 21 | #include <map> |
David Zeuthen | fe225c1 | 2014-04-29 10:37:35 -0700 | [diff] [blame] | 22 | #include <set> |
Alex Deymo | 23949d4 | 2014-02-05 15:20:59 -0800 | [diff] [blame] | 23 | #include <string> |
Aaron Wood | c73fdc1 | 2017-12-06 11:09:15 -0800 | [diff] [blame] | 24 | #include <utility> |
Alex Deymo | 23949d4 | 2014-02-05 15:20:59 -0800 | [diff] [blame] | 25 | |
David Zeuthen | fe225c1 | 2014-04-29 10:37:35 -0700 | [diff] [blame] | 26 | #include <base/strings/stringprintf.h> |
| 27 | #include <base/time/time.h> |
| 28 | |
Marton Hunyady | 0e0e354 | 2018-02-21 18:51:39 +0100 | [diff] [blame] | 29 | #include "update_engine/update_manager/rollback_prefs.h" |
Alex Deymo | 63784a5 | 2014-05-28 10:46:14 -0700 | [diff] [blame] | 30 | #include "update_engine/update_manager/shill_provider.h" |
| 31 | #include "update_engine/update_manager/umtest_utils.h" |
| 32 | #include "update_engine/update_manager/updater_provider.h" |
Adolfo Victoria | 94ffe13 | 2018-06-28 16:14:56 -0700 | [diff] [blame] | 33 | #include "update_engine/update_manager/weekly_time.h" |
Alex Deymo | 23949d4 | 2014-02-05 15:20:59 -0800 | [diff] [blame] | 34 | |
David Zeuthen | fe225c1 | 2014-04-29 10:37:35 -0700 | [diff] [blame] | 35 | using base::Time; |
| 36 | using base::TimeDelta; |
Sen Jiang | 255e22b | 2016-05-20 16:15:29 -0700 | [diff] [blame] | 37 | using chromeos_update_engine::ConnectionTethering; |
| 38 | using chromeos_update_engine::ConnectionType; |
Alex Deymo | 23949d4 | 2014-02-05 15:20:59 -0800 | [diff] [blame] | 39 | using std::list; |
| 40 | using std::map; |
Alex Deymo | 63784a5 | 2014-05-28 10:46:14 -0700 | [diff] [blame] | 41 | using std::set; |
Alex Deymo | 23949d4 | 2014-02-05 15:20:59 -0800 | [diff] [blame] | 42 | using std::string; |
| 43 | |
Alex Deymo | 63784a5 | 2014-05-28 10:46:14 -0700 | [diff] [blame] | 44 | namespace chromeos_update_manager { |
Alex Deymo | 23949d4 | 2014-02-05 15:20:59 -0800 | [diff] [blame] | 45 | |
| 46 | // The DeleterMarker flags a bool variable when the class is destroyed. |
| 47 | class DeleterMarker { |
| 48 | public: |
Alex Vakulenko | 072359c | 2014-07-18 11:41:07 -0700 | [diff] [blame] | 49 | explicit DeleterMarker(bool* marker) : marker_(marker) { *marker_ = false; } |
Alex Deymo | 23949d4 | 2014-02-05 15:20:59 -0800 | [diff] [blame] | 50 | |
| 51 | ~DeleterMarker() { *marker_ = true; } |
| 52 | |
| 53 | private: |
Amin Hassani | 4b71743 | 2019-01-14 16:24:20 -0800 | [diff] [blame] | 54 | friend string BoxedValue::ValuePrinter<DeleterMarker>(const void*); |
David Zeuthen | fe225c1 | 2014-04-29 10:37:35 -0700 | [diff] [blame] | 55 | |
Alex Deymo | 23949d4 | 2014-02-05 15:20:59 -0800 | [diff] [blame] | 56 | // Pointer to the bool marker. |
| 57 | bool* marker_; |
| 58 | }; |
| 59 | |
Amin Hassani | 4b71743 | 2019-01-14 16:24:20 -0800 | [diff] [blame] | 60 | template <> |
| 61 | string BoxedValue::ValuePrinter<DeleterMarker>(const void* value) { |
David Zeuthen | fe225c1 | 2014-04-29 10:37:35 -0700 | [diff] [blame] | 62 | const DeleterMarker* val = reinterpret_cast<const DeleterMarker*>(value); |
| 63 | return base::StringPrintf("DeleterMarker:%s", |
| 64 | *val->marker_ ? "true" : "false"); |
| 65 | } |
| 66 | |
Alex Deymo | 63784a5 | 2014-05-28 10:46:14 -0700 | [diff] [blame] | 67 | TEST(UmBoxedValueTest, Deleted) { |
Alex Deymo | 23949d4 | 2014-02-05 15:20:59 -0800 | [diff] [blame] | 68 | bool marker = true; |
| 69 | const DeleterMarker* deleter_marker = new DeleterMarker(&marker); |
| 70 | |
| 71 | EXPECT_FALSE(marker); |
| 72 | BoxedValue* box = new BoxedValue(deleter_marker); |
| 73 | EXPECT_FALSE(marker); |
| 74 | delete box; |
| 75 | EXPECT_TRUE(marker); |
| 76 | } |
| 77 | |
Alex Deymo | 63784a5 | 2014-05-28 10:46:14 -0700 | [diff] [blame] | 78 | TEST(UmBoxedValueTest, MoveConstructor) { |
Alex Deymo | 23949d4 | 2014-02-05 15:20:59 -0800 | [diff] [blame] | 79 | bool marker = true; |
| 80 | const DeleterMarker* deleter_marker = new DeleterMarker(&marker); |
| 81 | |
| 82 | BoxedValue* box = new BoxedValue(deleter_marker); |
| 83 | BoxedValue* new_box = new BoxedValue(std::move(*box)); |
| 84 | // box is now undefined but valid. |
| 85 | delete box; |
| 86 | EXPECT_FALSE(marker); |
| 87 | // The deleter_marker gets deleted at this point. |
| 88 | delete new_box; |
| 89 | EXPECT_TRUE(marker); |
| 90 | } |
| 91 | |
Alex Deymo | 63784a5 | 2014-05-28 10:46:14 -0700 | [diff] [blame] | 92 | TEST(UmBoxedValueTest, MixedList) { |
Alex Deymo | 23949d4 | 2014-02-05 15:20:59 -0800 | [diff] [blame] | 93 | list<BoxedValue> lst; |
| 94 | // This is mostly a compile test. |
Gilad Arnold | ec7f916 | 2014-07-15 13:24:46 -0700 | [diff] [blame] | 95 | lst.emplace_back(new const int{42}); |
Alex Deymo | 23949d4 | 2014-02-05 15:20:59 -0800 | [diff] [blame] | 96 | lst.emplace_back(new const string("Hello world!")); |
| 97 | bool marker; |
| 98 | lst.emplace_back(new const DeleterMarker(&marker)); |
| 99 | EXPECT_FALSE(marker); |
| 100 | lst.clear(); |
| 101 | EXPECT_TRUE(marker); |
| 102 | } |
| 103 | |
Alex Deymo | 63784a5 | 2014-05-28 10:46:14 -0700 | [diff] [blame] | 104 | TEST(UmBoxedValueTest, MixedMap) { |
Alex Deymo | 23949d4 | 2014-02-05 15:20:59 -0800 | [diff] [blame] | 105 | map<int, BoxedValue> m; |
Yunlian Jiang | cef5cd6 | 2015-05-27 15:22:32 -0700 | [diff] [blame] | 106 | m.emplace(42, BoxedValue(new const string("Hola mundo!"))); |
Alex Deymo | 23949d4 | 2014-02-05 15:20:59 -0800 | [diff] [blame] | 107 | |
| 108 | auto it = m.find(42); |
| 109 | ASSERT_NE(it, m.end()); |
Alex Vakulenko | 88b591f | 2014-08-28 16:48:57 -0700 | [diff] [blame] | 110 | EXPECT_NE(nullptr, it->second.value()); |
| 111 | EXPECT_EQ(nullptr, m[33].value()); |
Alex Deymo | 23949d4 | 2014-02-05 15:20:59 -0800 | [diff] [blame] | 112 | } |
| 113 | |
Alex Deymo | 63784a5 | 2014-05-28 10:46:14 -0700 | [diff] [blame] | 114 | TEST(UmBoxedValueTest, StringToString) { |
Amin Hassani | 4b71743 | 2019-01-14 16:24:20 -0800 | [diff] [blame] | 115 | EXPECT_EQ("Hej Verden!", BoxedValue(new string("Hej Verden!")).ToString()); |
David Zeuthen | fe225c1 | 2014-04-29 10:37:35 -0700 | [diff] [blame] | 116 | } |
| 117 | |
Alex Deymo | 63784a5 | 2014-05-28 10:46:14 -0700 | [diff] [blame] | 118 | TEST(UmBoxedValueTest, IntToString) { |
David Zeuthen | fe225c1 | 2014-04-29 10:37:35 -0700 | [diff] [blame] | 119 | EXPECT_EQ("42", BoxedValue(new int(42)).ToString()); |
| 120 | } |
| 121 | |
Alex Deymo | 63784a5 | 2014-05-28 10:46:14 -0700 | [diff] [blame] | 122 | TEST(UmBoxedValueTest, Int64ToString) { |
Alex Vakulenko | 072359c | 2014-07-18 11:41:07 -0700 | [diff] [blame] | 123 | // -123456789012345 doesn't fit in 32-bit integers. |
Amin Hassani | 4b71743 | 2019-01-14 16:24:20 -0800 | [diff] [blame] | 124 | EXPECT_EQ("-123456789012345", |
| 125 | BoxedValue(new int64_t(-123456789012345LL)).ToString()); |
Alex Deymo | f967ebe | 2014-05-05 14:46:17 -0700 | [diff] [blame] | 126 | } |
| 127 | |
Alex Deymo | 63784a5 | 2014-05-28 10:46:14 -0700 | [diff] [blame] | 128 | TEST(UmBoxedValueTest, UnsignedIntToString) { |
David Zeuthen | fe225c1 | 2014-04-29 10:37:35 -0700 | [diff] [blame] | 129 | // 4294967295 is the biggest possible 32-bit unsigned integer. |
Alex Vakulenko | 072359c | 2014-07-18 11:41:07 -0700 | [diff] [blame] | 130 | EXPECT_EQ("4294967295", |
| 131 | BoxedValue(new unsigned int(4294967295U)).ToString()); // NOLINT |
David Zeuthen | fe225c1 | 2014-04-29 10:37:35 -0700 | [diff] [blame] | 132 | } |
| 133 | |
Alex Deymo | 63784a5 | 2014-05-28 10:46:14 -0700 | [diff] [blame] | 134 | TEST(UmBoxedValueTest, UnsignedInt64ToString) { |
David Zeuthen | fe225c1 | 2014-04-29 10:37:35 -0700 | [diff] [blame] | 135 | // 18446744073709551615 is the biggest possible 64-bit unsigned integer. |
Amin Hassani | 4b71743 | 2019-01-14 16:24:20 -0800 | [diff] [blame] | 136 | EXPECT_EQ("18446744073709551615", |
| 137 | BoxedValue(new uint64_t(18446744073709551615ULL)).ToString()); |
David Zeuthen | fe225c1 | 2014-04-29 10:37:35 -0700 | [diff] [blame] | 138 | } |
| 139 | |
Alex Deymo | 63784a5 | 2014-05-28 10:46:14 -0700 | [diff] [blame] | 140 | TEST(UmBoxedValueTest, BoolToString) { |
David Zeuthen | fe225c1 | 2014-04-29 10:37:35 -0700 | [diff] [blame] | 141 | EXPECT_EQ("false", BoxedValue(new bool(false)).ToString()); |
| 142 | EXPECT_EQ("true", BoxedValue(new bool(true)).ToString()); |
| 143 | } |
| 144 | |
Alex Deymo | 63784a5 | 2014-05-28 10:46:14 -0700 | [diff] [blame] | 145 | TEST(UmBoxedValueTest, DoubleToString) { |
David Zeuthen | fe225c1 | 2014-04-29 10:37:35 -0700 | [diff] [blame] | 146 | EXPECT_EQ("1.501", BoxedValue(new double(1.501)).ToString()); |
| 147 | } |
| 148 | |
Alex Deymo | 63784a5 | 2014-05-28 10:46:14 -0700 | [diff] [blame] | 149 | TEST(UmBoxedValueTest, TimeToString) { |
David Zeuthen | fe225c1 | 2014-04-29 10:37:35 -0700 | [diff] [blame] | 150 | // Tue Apr 29 22:30:55 UTC 2014 is 1398810655 seconds since the Unix Epoch. |
| 151 | EXPECT_EQ("4/29/2014 22:30:55 GMT", |
| 152 | BoxedValue(new Time(Time::FromTimeT(1398810655))).ToString()); |
| 153 | } |
| 154 | |
Alex Deymo | 63784a5 | 2014-05-28 10:46:14 -0700 | [diff] [blame] | 155 | TEST(UmBoxedValueTest, TimeDeltaToString) { |
David Zeuthen | fe225c1 | 2014-04-29 10:37:35 -0700 | [diff] [blame] | 156 | // 12345 seconds is 3 hours, 25 minutes and 45 seconds. |
Amin Hassani | 4b71743 | 2019-01-14 16:24:20 -0800 | [diff] [blame] | 157 | EXPECT_EQ( |
| 158 | "3h25m45s", |
| 159 | BoxedValue(new TimeDelta(TimeDelta::FromSeconds(12345))).ToString()); |
David Zeuthen | fe225c1 | 2014-04-29 10:37:35 -0700 | [diff] [blame] | 160 | } |
| 161 | |
Alex Deymo | 63784a5 | 2014-05-28 10:46:14 -0700 | [diff] [blame] | 162 | TEST(UmBoxedValueTest, ConnectionTypeToString) { |
Colin Howes | c9e98d6 | 2018-09-18 10:35:20 -0700 | [diff] [blame] | 163 | EXPECT_EQ( |
| 164 | "Disconnected", |
| 165 | BoxedValue(new ConnectionType(ConnectionType::kDisconnected)).ToString()); |
Amin Hassani | 4b71743 | 2019-01-14 16:24:20 -0800 | [diff] [blame] | 166 | EXPECT_EQ( |
| 167 | "ethernet", |
| 168 | BoxedValue(new ConnectionType(ConnectionType::kEthernet)).ToString()); |
Sen Jiang | 675d0d2 | 2016-06-08 14:59:05 -0700 | [diff] [blame] | 169 | EXPECT_EQ("wifi", |
David Zeuthen | fe225c1 | 2014-04-29 10:37:35 -0700 | [diff] [blame] | 170 | BoxedValue(new ConnectionType(ConnectionType::kWifi)).ToString()); |
Amin Hassani | 4b71743 | 2019-01-14 16:24:20 -0800 | [diff] [blame] | 171 | EXPECT_EQ( |
| 172 | "cellular", |
| 173 | BoxedValue(new ConnectionType(ConnectionType::kCellular)).ToString()); |
| 174 | EXPECT_EQ( |
| 175 | "Unknown", |
| 176 | BoxedValue(new ConnectionType(ConnectionType::kUnknown)).ToString()); |
David Zeuthen | fe225c1 | 2014-04-29 10:37:35 -0700 | [diff] [blame] | 177 | } |
| 178 | |
Alex Deymo | 63784a5 | 2014-05-28 10:46:14 -0700 | [diff] [blame] | 179 | TEST(UmBoxedValueTest, ConnectionTetheringToString) { |
Amin Hassani | 4b71743 | 2019-01-14 16:24:20 -0800 | [diff] [blame] | 180 | EXPECT_EQ( |
| 181 | "Not Detected", |
| 182 | BoxedValue(new ConnectionTethering(ConnectionTethering::kNotDetected)) |
| 183 | .ToString()); |
David Zeuthen | fe225c1 | 2014-04-29 10:37:35 -0700 | [diff] [blame] | 184 | EXPECT_EQ("Suspected", |
| 185 | BoxedValue(new ConnectionTethering(ConnectionTethering::kSuspected)) |
Amin Hassani | 4b71743 | 2019-01-14 16:24:20 -0800 | [diff] [blame] | 186 | .ToString()); |
David Zeuthen | fe225c1 | 2014-04-29 10:37:35 -0700 | [diff] [blame] | 187 | EXPECT_EQ("Confirmed", |
| 188 | BoxedValue(new ConnectionTethering(ConnectionTethering::kConfirmed)) |
Amin Hassani | 4b71743 | 2019-01-14 16:24:20 -0800 | [diff] [blame] | 189 | .ToString()); |
David Zeuthen | fe225c1 | 2014-04-29 10:37:35 -0700 | [diff] [blame] | 190 | EXPECT_EQ("Unknown", |
| 191 | BoxedValue(new ConnectionTethering(ConnectionTethering::kUnknown)) |
Amin Hassani | 4b71743 | 2019-01-14 16:24:20 -0800 | [diff] [blame] | 192 | .ToString()); |
David Zeuthen | fe225c1 | 2014-04-29 10:37:35 -0700 | [diff] [blame] | 193 | } |
| 194 | |
Marton Hunyady | 0e0e354 | 2018-02-21 18:51:39 +0100 | [diff] [blame] | 195 | TEST(UmBoxedValueTest, RollbackToTargetVersionToString) { |
| 196 | EXPECT_EQ("Unspecified", |
| 197 | BoxedValue(new RollbackToTargetVersion( |
| 198 | RollbackToTargetVersion::kUnspecified)) |
| 199 | .ToString()); |
| 200 | EXPECT_EQ("Disabled", |
| 201 | BoxedValue( |
| 202 | new RollbackToTargetVersion(RollbackToTargetVersion::kDisabled)) |
| 203 | .ToString()); |
Marton Hunyady | d4bc462 | 2018-08-30 15:52:23 +0200 | [diff] [blame] | 204 | EXPECT_EQ("Rollback and powerwash", |
Marton Hunyady | 0e0e354 | 2018-02-21 18:51:39 +0100 | [diff] [blame] | 205 | BoxedValue(new RollbackToTargetVersion( |
Marton Hunyady | d4bc462 | 2018-08-30 15:52:23 +0200 | [diff] [blame] | 206 | RollbackToTargetVersion::kRollbackAndPowerwash)) |
Marton Hunyady | 0e0e354 | 2018-02-21 18:51:39 +0100 | [diff] [blame] | 207 | .ToString()); |
Marton Hunyady | 31aefb9 | 2018-08-29 16:17:03 +0200 | [diff] [blame] | 208 | EXPECT_EQ( |
| 209 | "Rollback and restore if possible", |
| 210 | BoxedValue(new RollbackToTargetVersion( |
| 211 | RollbackToTargetVersion::kRollbackAndRestoreIfPossible)) |
| 212 | .ToString()); |
Marton Hunyady | 0e0e354 | 2018-02-21 18:51:39 +0100 | [diff] [blame] | 213 | } |
| 214 | |
Alex Deymo | 63784a5 | 2014-05-28 10:46:14 -0700 | [diff] [blame] | 215 | TEST(UmBoxedValueTest, SetConnectionTypeToString) { |
David Zeuthen | fe225c1 | 2014-04-29 10:37:35 -0700 | [diff] [blame] | 216 | set<ConnectionType>* set1 = new set<ConnectionType>; |
Alex Khouderchah | bfa8226 | 2019-08-13 15:00:34 -0700 | [diff] [blame] | 217 | set1->insert(ConnectionType::kCellular); |
David Zeuthen | fe225c1 | 2014-04-29 10:37:35 -0700 | [diff] [blame] | 218 | set1->insert(ConnectionType::kEthernet); |
Alex Khouderchah | bfa8226 | 2019-08-13 15:00:34 -0700 | [diff] [blame] | 219 | EXPECT_EQ("ethernet,cellular", BoxedValue(set1).ToString()); |
David Zeuthen | fe225c1 | 2014-04-29 10:37:35 -0700 | [diff] [blame] | 220 | |
| 221 | set<ConnectionType>* set2 = new set<ConnectionType>; |
| 222 | set2->insert(ConnectionType::kWifi); |
Sen Jiang | 675d0d2 | 2016-06-08 14:59:05 -0700 | [diff] [blame] | 223 | EXPECT_EQ("wifi", BoxedValue(set2).ToString()); |
David Zeuthen | fe225c1 | 2014-04-29 10:37:35 -0700 | [diff] [blame] | 224 | } |
| 225 | |
Alex Deymo | 63784a5 | 2014-05-28 10:46:14 -0700 | [diff] [blame] | 226 | TEST(UmBoxedValueTest, StageToString) { |
Amin Hassani | 4b71743 | 2019-01-14 16:24:20 -0800 | [diff] [blame] | 227 | EXPECT_EQ("Idle", BoxedValue(new Stage(Stage::kIdle)).ToString()); |
David Zeuthen | fe225c1 | 2014-04-29 10:37:35 -0700 | [diff] [blame] | 228 | EXPECT_EQ("Checking For Update", |
| 229 | BoxedValue(new Stage(Stage::kCheckingForUpdate)).ToString()); |
| 230 | EXPECT_EQ("Update Available", |
| 231 | BoxedValue(new Stage(Stage::kUpdateAvailable)).ToString()); |
| 232 | EXPECT_EQ("Downloading", |
| 233 | BoxedValue(new Stage(Stage::kDownloading)).ToString()); |
Amin Hassani | 4b71743 | 2019-01-14 16:24:20 -0800 | [diff] [blame] | 234 | EXPECT_EQ("Verifying", BoxedValue(new Stage(Stage::kVerifying)).ToString()); |
| 235 | EXPECT_EQ("Finalizing", BoxedValue(new Stage(Stage::kFinalizing)).ToString()); |
David Zeuthen | fe225c1 | 2014-04-29 10:37:35 -0700 | [diff] [blame] | 236 | EXPECT_EQ("Updated, Need Reboot", |
| 237 | BoxedValue(new Stage(Stage::kUpdatedNeedReboot)).ToString()); |
| 238 | EXPECT_EQ("Reporting Error Event", |
| 239 | BoxedValue(new Stage(Stage::kReportingErrorEvent)).ToString()); |
| 240 | EXPECT_EQ("Attempting Rollback", |
| 241 | BoxedValue(new Stage(Stage::kAttemptingRollback)).ToString()); |
| 242 | } |
| 243 | |
Alex Deymo | 63784a5 | 2014-05-28 10:46:14 -0700 | [diff] [blame] | 244 | TEST(UmBoxedValueTest, DeleterMarkerToString) { |
David Zeuthen | fe225c1 | 2014-04-29 10:37:35 -0700 | [diff] [blame] | 245 | bool marker = false; |
| 246 | BoxedValue value = BoxedValue(new DeleterMarker(&marker)); |
| 247 | EXPECT_EQ("DeleterMarker:false", value.ToString()); |
| 248 | marker = true; |
| 249 | EXPECT_EQ("DeleterMarker:true", value.ToString()); |
| 250 | } |
| 251 | |
Aaron Wood | bf5a252 | 2017-10-04 10:58:36 -0700 | [diff] [blame] | 252 | TEST(UmBoxedValueTest, UpdateRestrictionsToString) { |
| 253 | EXPECT_EQ( |
| 254 | "None", |
| 255 | BoxedValue(new UpdateRestrictions(UpdateRestrictions::kNone)).ToString()); |
| 256 | EXPECT_EQ("Flags: RestrictDownloading", |
| 257 | BoxedValue(new UpdateRestrictions( |
| 258 | UpdateRestrictions::kRestrictDownloading)) |
| 259 | .ToString()); |
| 260 | } |
| 261 | |
Adolfo Victoria | 94ffe13 | 2018-06-28 16:14:56 -0700 | [diff] [blame] | 262 | TEST(UmBoxedValueTest, WeeklyTimeIntervalToString) { |
| 263 | EXPECT_EQ("Start: day_of_week=2 time=100\nEnd: day_of_week=4 time=200", |
| 264 | BoxedValue(new WeeklyTimeInterval( |
| 265 | WeeklyTime(2, TimeDelta::FromMinutes(100)), |
| 266 | WeeklyTime(4, TimeDelta::FromMinutes(200)))) |
| 267 | .ToString()); |
| 268 | EXPECT_EQ("Start: day_of_week=1 time=10\nEnd: day_of_week=1 time=20", |
| 269 | BoxedValue(new WeeklyTimeInterval( |
| 270 | WeeklyTime(1, TimeDelta::FromMinutes(10)), |
| 271 | WeeklyTime(1, TimeDelta::FromMinutes(20)))) |
| 272 | .ToString()); |
| 273 | } |
| 274 | |
| 275 | TEST(UmBoxedValueTest, WeeklyTimeIntervalVectorToString) { |
| 276 | WeeklyTimeIntervalVector intervals; |
| 277 | intervals.emplace_back(WeeklyTime(5, TimeDelta::FromMinutes(10)), |
| 278 | WeeklyTime(1, TimeDelta::FromMinutes(30))); |
| 279 | EXPECT_EQ( |
| 280 | "Disallowed intervals:\nStart: day_of_week=5 time=10\nEnd: " |
| 281 | "day_of_week=1 time=30\n", |
| 282 | BoxedValue(new WeeklyTimeIntervalVector(intervals)).ToString()); |
| 283 | intervals.emplace_back(WeeklyTime(1, TimeDelta::FromMinutes(5)), |
| 284 | WeeklyTime(6, TimeDelta::FromMinutes(1000))); |
| 285 | EXPECT_EQ( |
| 286 | "Disallowed intervals:\nStart: day_of_week=5 time=10\nEnd: " |
| 287 | "day_of_week=1 time=30\nStart: day_of_week=1 time=5\nEnd: day_of_week=6 " |
| 288 | "time=1000\n", |
| 289 | BoxedValue(new WeeklyTimeIntervalVector(intervals)).ToString()); |
| 290 | } |
| 291 | |
Alex Deymo | 63784a5 | 2014-05-28 10:46:14 -0700 | [diff] [blame] | 292 | } // namespace chromeos_update_manager |