You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
295 lines
10 KiB
295 lines
10 KiB
//
|
|
// Copyright (C) 2011 The Android Open Source Project
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
//
|
|
|
|
#include "update_engine/cros/omaha_request_params.h"
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <string>
|
|
|
|
#include <base/files/file_util.h>
|
|
#include <base/files/scoped_temp_dir.h>
|
|
#include <gtest/gtest.h>
|
|
|
|
#include "update_engine/common/constants.h"
|
|
#include "update_engine/common/platform_constants.h"
|
|
#include "update_engine/common/test_utils.h"
|
|
#include "update_engine/common/utils.h"
|
|
#include "update_engine/cros/fake_system_state.h"
|
|
|
|
using chromeos_update_engine::test_utils::WriteFileString;
|
|
using std::string;
|
|
|
|
namespace chromeos_update_engine {
|
|
|
|
class OmahaRequestParamsTest : public ::testing::Test {
|
|
public:
|
|
OmahaRequestParamsTest() : params_() {}
|
|
|
|
protected:
|
|
void SetUp() override {
|
|
// Create a uniquely named test directory.
|
|
ASSERT_TRUE(tempdir_.CreateUniqueTempDir());
|
|
params_.set_root(tempdir_.GetPath().value());
|
|
FakeSystemState::CreateInstance();
|
|
SetLockDown(false);
|
|
}
|
|
|
|
void SetLockDown(bool locked_down) {
|
|
FakeSystemState::Get()->fake_hardware()->SetIsOfficialBuild(locked_down);
|
|
FakeSystemState::Get()->fake_hardware()->SetIsNormalBootMode(locked_down);
|
|
}
|
|
|
|
OmahaRequestParams params_;
|
|
base::ScopedTempDir tempdir_;
|
|
};
|
|
|
|
namespace {
|
|
string GetMachineType() {
|
|
string machine_type;
|
|
if (!utils::ReadPipe("uname -m", &machine_type))
|
|
return "";
|
|
// Strip anything from the first newline char.
|
|
size_t newline_pos = machine_type.find('\n');
|
|
if (newline_pos != string::npos)
|
|
machine_type.erase(newline_pos);
|
|
return machine_type;
|
|
}
|
|
} // namespace
|
|
|
|
TEST_F(OmahaRequestParamsTest, MissingChannelTest) {
|
|
EXPECT_TRUE(params_.Init("", "", {}));
|
|
// By default, if no channel is set, we should track the stable-channel.
|
|
EXPECT_EQ("stable-channel", params_.target_channel());
|
|
}
|
|
|
|
TEST_F(OmahaRequestParamsTest, ForceVersionTest) {
|
|
EXPECT_TRUE(params_.Init("ForcedVersion", "", {}));
|
|
EXPECT_EQ(string("ForcedVersion_") + GetMachineType(), params_.os_sp());
|
|
EXPECT_EQ("ForcedVersion", params_.app_version());
|
|
}
|
|
|
|
TEST_F(OmahaRequestParamsTest, ForcedURLTest) {
|
|
EXPECT_TRUE(params_.Init("", "http://forced.google.com", {}));
|
|
EXPECT_EQ("http://forced.google.com", params_.update_url());
|
|
}
|
|
|
|
TEST_F(OmahaRequestParamsTest, MissingURLTest) {
|
|
EXPECT_TRUE(params_.Init("", "", {}));
|
|
EXPECT_EQ(constants::kOmahaDefaultProductionURL, params_.update_url());
|
|
}
|
|
|
|
TEST_F(OmahaRequestParamsTest, DeltaOKTest) {
|
|
EXPECT_TRUE(params_.Init("", "", {}));
|
|
EXPECT_TRUE(params_.delta_okay());
|
|
}
|
|
|
|
TEST_F(OmahaRequestParamsTest, NoDeltasTest) {
|
|
ASSERT_TRUE(
|
|
WriteFileString(tempdir_.GetPath().Append(".nodelta").value(), ""));
|
|
EXPECT_TRUE(params_.Init("", "", {}));
|
|
EXPECT_FALSE(params_.delta_okay());
|
|
}
|
|
|
|
TEST_F(OmahaRequestParamsTest, SetTargetChannelTest) {
|
|
{
|
|
OmahaRequestParams params;
|
|
params.set_root(tempdir_.GetPath().value());
|
|
EXPECT_TRUE(params.Init("", "", {}));
|
|
EXPECT_TRUE(params.SetTargetChannel("canary-channel", false, nullptr));
|
|
EXPECT_FALSE(params.mutable_image_props_.is_powerwash_allowed);
|
|
}
|
|
params_.set_root(tempdir_.GetPath().value());
|
|
EXPECT_TRUE(params_.Init("", "", {}));
|
|
EXPECT_EQ("canary-channel", params_.target_channel());
|
|
EXPECT_FALSE(params_.mutable_image_props_.is_powerwash_allowed);
|
|
}
|
|
|
|
TEST_F(OmahaRequestParamsTest, SetIsPowerwashAllowedTest) {
|
|
{
|
|
OmahaRequestParams params;
|
|
params.set_root(tempdir_.GetPath().value());
|
|
EXPECT_TRUE(params.Init("", "", {}));
|
|
EXPECT_TRUE(params.SetTargetChannel("canary-channel", true, nullptr));
|
|
EXPECT_TRUE(params.mutable_image_props_.is_powerwash_allowed);
|
|
}
|
|
params_.set_root(tempdir_.GetPath().value());
|
|
EXPECT_TRUE(params_.Init("", "", {}));
|
|
EXPECT_EQ("canary-channel", params_.target_channel());
|
|
EXPECT_TRUE(params_.mutable_image_props_.is_powerwash_allowed);
|
|
}
|
|
|
|
TEST_F(OmahaRequestParamsTest, SetTargetChannelInvalidTest) {
|
|
{
|
|
OmahaRequestParams params;
|
|
params.set_root(tempdir_.GetPath().value());
|
|
SetLockDown(true);
|
|
EXPECT_TRUE(params.Init("", "", {}));
|
|
params.image_props_.allow_arbitrary_channels = false;
|
|
string error_message;
|
|
EXPECT_FALSE(
|
|
params.SetTargetChannel("dogfood-channel", true, &error_message));
|
|
// The error message should include a message about the valid channels.
|
|
EXPECT_NE(string::npos, error_message.find("stable-channel"));
|
|
EXPECT_FALSE(params.mutable_image_props_.is_powerwash_allowed);
|
|
}
|
|
params_.set_root(tempdir_.GetPath().value());
|
|
EXPECT_TRUE(params_.Init("", "", {}));
|
|
EXPECT_EQ("stable-channel", params_.target_channel());
|
|
EXPECT_FALSE(params_.mutable_image_props_.is_powerwash_allowed);
|
|
}
|
|
|
|
TEST_F(OmahaRequestParamsTest, IsValidChannelTest) {
|
|
EXPECT_TRUE(params_.IsValidChannel("canary-channel"));
|
|
EXPECT_TRUE(params_.IsValidChannel("stable-channel"));
|
|
EXPECT_TRUE(params_.IsValidChannel("beta-channel"));
|
|
EXPECT_TRUE(params_.IsValidChannel("dev-channel"));
|
|
EXPECT_FALSE(params_.IsValidChannel("testimage-channel"));
|
|
EXPECT_FALSE(params_.IsValidChannel("dogfood-channel"));
|
|
EXPECT_FALSE(params_.IsValidChannel("some-channel"));
|
|
EXPECT_FALSE(params_.IsValidChannel(""));
|
|
params_.image_props_.allow_arbitrary_channels = true;
|
|
EXPECT_TRUE(params_.IsValidChannel("some-channel"));
|
|
EXPECT_FALSE(params_.IsValidChannel("wrong-suffix"));
|
|
EXPECT_FALSE(params_.IsValidChannel(""));
|
|
}
|
|
|
|
TEST_F(OmahaRequestParamsTest, SetTargetChannelWorks) {
|
|
params_.set_target_channel("dev-channel");
|
|
EXPECT_EQ("dev-channel", params_.target_channel());
|
|
|
|
// When an invalid value is set, it should be ignored.
|
|
EXPECT_FALSE(params_.SetTargetChannel("invalid-channel", false, nullptr));
|
|
EXPECT_EQ("dev-channel", params_.target_channel());
|
|
|
|
// When set to a valid value, it should take effect.
|
|
EXPECT_TRUE(params_.SetTargetChannel("beta-channel", true, nullptr));
|
|
EXPECT_EQ("beta-channel", params_.target_channel());
|
|
|
|
// When set to the same value, it should be idempotent.
|
|
EXPECT_TRUE(params_.SetTargetChannel("beta-channel", true, nullptr));
|
|
EXPECT_EQ("beta-channel", params_.target_channel());
|
|
|
|
// When set to a valid value while a change is already pending, it should
|
|
// succeed.
|
|
EXPECT_TRUE(params_.SetTargetChannel("stable-channel", true, nullptr));
|
|
EXPECT_EQ("stable-channel", params_.target_channel());
|
|
|
|
// Set a different channel in mutable_image_props_.
|
|
params_.set_target_channel("stable-channel");
|
|
|
|
// When set to a valid value while a change is already pending, it should
|
|
// succeed.
|
|
params_.Init("", "", {});
|
|
EXPECT_TRUE(params_.SetTargetChannel("beta-channel", true, nullptr));
|
|
// The target channel should reflect the change, but the download channel
|
|
// should continue to retain the old value ...
|
|
EXPECT_EQ("beta-channel", params_.target_channel());
|
|
EXPECT_EQ("stable-channel", params_.download_channel());
|
|
|
|
// ... until we update the download channel explicitly.
|
|
params_.UpdateDownloadChannel();
|
|
EXPECT_EQ("beta-channel", params_.download_channel());
|
|
EXPECT_EQ("beta-channel", params_.target_channel());
|
|
}
|
|
|
|
TEST_F(OmahaRequestParamsTest, ChannelIndexTest) {
|
|
int canary = params_.GetChannelIndex("canary-channel");
|
|
int dev = params_.GetChannelIndex("dev-channel");
|
|
int beta = params_.GetChannelIndex("beta-channel");
|
|
int stable = params_.GetChannelIndex("stable-channel");
|
|
EXPECT_LE(canary, dev);
|
|
EXPECT_LE(dev, beta);
|
|
EXPECT_LE(beta, stable);
|
|
|
|
// testimage-channel or other names are not recognized, so index will be -1.
|
|
int testimage = params_.GetChannelIndex("testimage-channel");
|
|
int bogus = params_.GetChannelIndex("bogus-channel");
|
|
EXPECT_EQ(-1, testimage);
|
|
EXPECT_EQ(-1, bogus);
|
|
}
|
|
|
|
TEST_F(OmahaRequestParamsTest, ToMoreStableChannelFlagTest) {
|
|
params_.image_props_.current_channel = "canary-channel";
|
|
params_.download_channel_ = "stable-channel";
|
|
EXPECT_TRUE(params_.ToMoreStableChannel());
|
|
params_.image_props_.current_channel = "stable-channel";
|
|
EXPECT_FALSE(params_.ToMoreStableChannel());
|
|
params_.download_channel_ = "beta-channel";
|
|
EXPECT_FALSE(params_.ToMoreStableChannel());
|
|
}
|
|
|
|
TEST_F(OmahaRequestParamsTest, TargetChannelHintTest) {
|
|
EXPECT_TRUE(params_.Init("", "", {}));
|
|
const string kHint("foo-hint");
|
|
params_.set_lts_tag(kHint);
|
|
EXPECT_EQ(kHint, params_.lts_tag());
|
|
}
|
|
|
|
TEST_F(OmahaRequestParamsTest, ShouldPowerwashTest) {
|
|
params_.mutable_image_props_.is_powerwash_allowed = false;
|
|
EXPECT_FALSE(params_.ShouldPowerwash());
|
|
params_.mutable_image_props_.is_powerwash_allowed = true;
|
|
params_.image_props_.allow_arbitrary_channels = true;
|
|
params_.image_props_.current_channel = "foo-channel";
|
|
params_.download_channel_ = "bar-channel";
|
|
EXPECT_TRUE(params_.ShouldPowerwash());
|
|
params_.image_props_.allow_arbitrary_channels = false;
|
|
params_.image_props_.current_channel = "canary-channel";
|
|
params_.download_channel_ = "stable-channel";
|
|
EXPECT_TRUE(params_.ShouldPowerwash());
|
|
}
|
|
|
|
TEST_F(OmahaRequestParamsTest, RequisitionIsSetTest) {
|
|
EXPECT_TRUE(params_.Init("", "", {}));
|
|
EXPECT_EQ("fake_requisition", params_.device_requisition());
|
|
}
|
|
|
|
TEST_F(OmahaRequestParamsTest, GetMissingDlcId) {
|
|
EXPECT_TRUE(params_.Init("", "", {}));
|
|
|
|
string dlc_id;
|
|
EXPECT_FALSE(params_.GetDlcId("some-dlc-app-id", &dlc_id));
|
|
}
|
|
|
|
TEST_F(OmahaRequestParamsTest, GetDlcId) {
|
|
EXPECT_TRUE(params_.Init("", "", {}));
|
|
const string kExpectedDlcId = "test-dlc";
|
|
const string dlc_app_id = params_.GetDlcAppId(kExpectedDlcId);
|
|
params_.set_dlc_apps_params({{dlc_app_id, {.name = kExpectedDlcId}}});
|
|
|
|
string dlc_id;
|
|
EXPECT_TRUE(params_.GetDlcId(dlc_app_id, &dlc_id));
|
|
EXPECT_EQ(kExpectedDlcId, dlc_id);
|
|
}
|
|
|
|
TEST_F(OmahaRequestParamsTest, GetDlcAppId) {
|
|
EXPECT_TRUE(params_.Init("", "", {}));
|
|
const string kAppId = "test-app-id";
|
|
params_.set_app_id(kAppId);
|
|
const string kDlcId = "test-dlc";
|
|
const string expected_dlc_app_id = kAppId + "_" + kDlcId;
|
|
|
|
EXPECT_EQ(expected_dlc_app_id, params_.GetDlcAppId(kDlcId));
|
|
}
|
|
|
|
TEST_F(OmahaRequestParamsTest, AutoUpdateTokenTest) {
|
|
EXPECT_TRUE(params_.Init("", "", {.quick_fix_build_token = "foo-token"}));
|
|
EXPECT_EQ("foo-token", params_.autoupdate_token());
|
|
}
|
|
|
|
} // namespace chromeos_update_engine
|