chromium/tools/disable_tests/tests/expectations-bug-comment.json

{
  "args": [
    "./disable",
    "-b",
    "9191919",
    "8802549688048524353",
    ".*WallpaperControllerTest.UpdateDailyWallpaperVariantOnColorModeChanged_RefreshTimerDoesntReset.*"
  ],
  "requests": "{\"QueryTestResults/{\\\"invocations\\\": [\\\"invocations/build-8802549688048524353\\\"], \\\"readMask\\\": {\\\"paths\\\": [\\\"test_id\\\", \\\"test_metadata\\\"]}, \\\"pageSize\\\": 1000, \\\"predicate\\\": {\\\"testIdRegexp\\\": \\\".*WallpaperControllerTest.UpdateDailyWallpaperVariantOnColorModeChanged_RefreshTimerDoesntReset.*\\\"}}\": \"{\\\"testResults\\\":[{\\\"name\\\":\\\"invocations/task-chromium-swarm.appspot.com-5d70fea42230d311/tests/ninja:%2F%2Fash:ash_unittests%2FWallpaperControllerTest.UpdateDailyWallpaperVariantOnColorModeChanged_RefreshTimerDoesntReset/results/bb5ad544-02155\\\",\\\"testId\\\":\\\"ninja://ash:ash_unittests/WallpaperControllerTest.UpdateDailyWallpaperVariantOnColorModeChanged_RefreshTimerDoesntReset\\\",\\\"testMetadata\\\":{\\\"name\\\":\\\"WallpaperControllerTest.UpdateDailyWallpaperVariantOnColorModeChanged_RefreshTimerDoesntReset\\\",\\\"location\\\":{\\\"repo\\\":\\\"https://chromium.googlesource.com/chromium/src\\\",\\\"fileName\\\":\\\"//ash/wallpaper/wallpaper_controller_unittest.cc\\\",\\\"line\\\":4012}}},{\\\"name\\\":\\\"invocations/task-chromium-swarm.appspot.com-5d70fea42230d311/tests/ninja:%2F%2Fash:ash_unittests%2FWallpaperControllerTest.UpdateDailyWallpaperVariantOnColorModeChanged_RefreshTimerDoesntReset/results/bb5ad544-02156\\\",\\\"testId\\\":\\\"ninja://ash:ash_unittests/WallpaperControllerTest.UpdateDailyWallpaperVariantOnColorModeChanged_RefreshTimerDoesntReset\\\",\\\"testMetadata\\\":{\\\"name\\\":\\\"WallpaperControllerTest.UpdateDailyWallpaperVariantOnColorModeChanged_RefreshTimerDoesntReset\\\",\\\"location\\\":{\\\"repo\\\":\\\"https://chromium.googlesource.com/chromium/src\\\",\\\"fileName\\\":\\\"//ash/wallpaper/wallpaper_controller_unittest.cc\\\",\\\"line\\\":4012}}}]}\\n\"}",
  "read_data": {
    "ash/wallpaper/wallpaper_controller_unittest.cc": "// Copyright 2012 The Chromium Authors\n// Use of this source code is governed by a BSD-style license that can be\n// found in the LICENSE file.\n\n#include \"ash/wallpaper/wallpaper_controller_impl.h\"\n\n#include <cmath>\n#include <cstdlib>\n#include <memory>\n#include <vector>\n\n#include \"ash/constants/ash_features.h\"\n#include \"ash/constants/ash_pref_names.h\"\n#include \"ash/constants/ash_switches.h\"\n#include \"ash/public/cpp/shell_window_ids.h\"\n#include \"ash/public/cpp/test/shell_test_api.h\"\n#include \"ash/public/cpp/test/test_image_downloader.h\"\n#include \"ash/public/cpp/wallpaper/online_wallpaper_params.h\"\n#include \"ash/public/cpp/wallpaper/online_wallpaper_variant.h\"\n#include \"ash/public/cpp/wallpaper/wallpaper_controller_client.h\"\n#include \"ash/public/cpp/wallpaper/wallpaper_controller_observer.h\"\n#include \"ash/public/cpp/wallpaper/wallpaper_types.h\"\n#include \"ash/root_window_controller.h\"\n#include \"ash/session/session_controller_impl.h\"\n#include \"ash/session/test_session_controller_client.h\"\n#include \"ash/shell.h\"\n#include \"ash/style/dark_light_mode_controller_impl.h\"\n#include \"ash/test/ash_test_base.h\"\n#include \"ash/wallpaper/test_wallpaper_controller_client.h\"\n#include \"ash/wallpaper/wallpaper_pref_manager.h\"\n#include \"ash/wallpaper/wallpaper_utils/wallpaper_resizer.h\"\n#include \"ash/wallpaper/wallpaper_view.h\"\n#include \"ash/wallpaper/wallpaper_widget_controller.h\"\n#include \"ash/webui/personalization_app/proto/backdrop_wallpaper.pb.h\"\n#include \"ash/wm/overview/overview_controller.h\"\n#include \"ash/wm/window_cycle/window_cycle_controller.h\"\n#include \"ash/wm/window_state.h\"\n#include \"base/callback_helpers.h\"\n#include \"base/command_line.h\"\n#include \"base/files/file_util.h\"\n#include \"base/files/scoped_temp_dir.h\"\n#include \"base/metrics/metrics_hashes.h\"\n#include \"base/run_loop.h\"\n#include \"base/strings/stringprintf.h\"\n#include \"base/task/current_thread.h\"\n#include \"base/task/task_observer.h\"\n#include \"base/task/thread_pool/thread_pool_instance.h\"\n#include \"base/test/bind.h\"\n#include \"base/test/metrics/histogram_tester.h\"\n#include \"base/test/scoped_feature_list.h\"\n#include \"base/test/task_environment.h\"\n#include \"base/test/test_future.h\"\n#include \"base/threading/thread_restrictions.h\"\n#include \"base/time/time_override.h\"\n#include \"chromeos/constants/chromeos_features.h\"\n#include \"components/prefs/scoped_user_pref_update.h\"\n#include \"components/user_manager/user_names.h\"\n#include \"components/user_manager/user_type.h\"\n#include \"services/data_decoder/public/cpp/test_support/in_process_data_decoder.h\"\n#include \"testing/gmock/include/gmock/gmock-matchers.h\"\n#include \"third_party/skia/include/core/SkBitmap.h\"\n#include \"third_party/skia/include/core/SkColor.h\"\n#include \"ui/aura/window.h\"\n#include \"ui/compositor/layer.h\"\n#include \"ui/compositor/layer_tree_owner.h\"\n#include \"ui/compositor/scoped_animation_duration_scale_mode.h\"\n#include \"ui/compositor/test/layer_animator_test_controller.h\"\n#include \"ui/display/display.h\"\n#include \"ui/display/screen.h\"\n#include \"ui/gfx/canvas.h\"\n#include \"ui/gfx/codec/jpeg_codec.h\"\n#include \"ui/gfx/color_analysis.h\"\n#include \"ui/views/view_tracker.h\"\n#include \"ui/views/widget/widget.h\"\n\nusing session_manager::SessionState;\n\nnamespace ash {\nnamespace {\n\n// Containers IDs used for tests.\nconstexpr int kWallpaperId = kShellWindowId_WallpaperContainer;\nconstexpr int kLockScreenWallpaperId =\n    kShellWindowId_LockScreenWallpaperContainer;\nconstexpr int kAlwaysOnTopWallpaperId =\n    kShellWindowId_AlwaysOnTopWallpaperContainer;\n\nconstexpr char kDefaultSmallWallpaperName[] = \"small.jpg\";\nconstexpr char kDefaultLargeWallpaperName[] = \"large.jpg\";\nconstexpr char kGuestSmallWallpaperName[] = \"guest_small.jpg\";\nconstexpr char kGuestLargeWallpaperName[] = \"guest_large.jpg\";\nconstexpr char kChildSmallWallpaperName[] = \"child_small.jpg\";\nconstexpr char kChildLargeWallpaperName[] = \"child_large.jpg\";\n\nconstexpr char kCustomizationSmallWallpaperName[] = \"small_customization.jpeg\";\nconstexpr char kCustomizationLargeWallpaperName[] = \"large_customization.jpeg\";\n\n// Colors used to distinguish between wallpapers with large and small\n// resolution.\nconstexpr SkColor kLargeCustomWallpaperColor = SK_ColorDKGRAY;\nconstexpr SkColor kSmallCustomWallpaperColor = SK_ColorLTGRAY;\n\n// A color that can be passed to |CreateImage|. Specifically chosen to not\n// conflict with any of the custom wallpaper colors.\nconstexpr SkColor kWallpaperColor = SK_ColorMAGENTA;\n\nstd::string GetDummyFileId(const AccountId& account_id) {\n  return account_id.GetUserEmail() + \"-hash\";\n}\n\nstd::string GetDummyFileName(const AccountId& account_id) {\n  return account_id.GetUserEmail() + \"-file\";\n}\n\nconstexpr char kUser1[] = \"[email protected]\";\nconst AccountId account_id_1 = AccountId::FromUserEmailGaiaId(kUser1, kUser1);\nconst std::string wallpaper_files_id_1 = GetDummyFileId(account_id_1);\nconst std::string file_name_1 = GetDummyFileName(account_id_1);\n\nconstexpr char kUser2[] = \"[email protected]\";\nconst AccountId account_id_2 = AccountId::FromUserEmailGaiaId(kUser2, kUser2);\nconst std::string wallpaper_files_id_2 = GetDummyFileId(account_id_2);\nconst std::string file_name_2 = GetDummyFileName(account_id_2);\n\nconstexpr char kChildEmail[] = \"[email protected]\";\n\nconst std::string kDummyUrl = \"https://best_wallpaper/1\";\nconst std::string kDummyUrl2 = \"https://best_wallpaper/2\";\n\nconst uint64_t kAssetId = 1;\nconst uint64_t kAssetId2 = 2;\nconst uint64_t kUnitId = 1;\nconst uint64_t kUnitId2 = 2;\n\nconst std::string kFakeGooglePhotosAlbumId = \"fake_album\";\nconst std::string kFakeGooglePhotosPhotoId = \"fake_photo\";\n\n// Creates an image of size |size|.\ngfx::ImageSkia CreateImage(int width, int height, SkColor color) {\n  SkBitmap bitmap;\n  bitmap.allocN32Pixels(width, height);\n  bitmap.eraseColor(color);\n  gfx::ImageSkia image = gfx::ImageSkia::CreateFrom1xBitmap(bitmap);\n  return image;\n}\n\n// Returns number of child windows in a shell window container.\nint ChildCountForContainer(int container_id) {\n  aura::Window* root = Shell::Get()->GetPrimaryRootWindow();\n  aura::Window* container = root->GetChildById(container_id);\n  return static_cast<int>(container->children().size());\n}\n\n// Steps a layer animation until it is completed. Animations must be enabled.\nvoid RunAnimationForLayer(ui::Layer* layer) {\n  // Animations must be enabled for stepping to work.\n  ASSERT_NE(ui::ScopedAnimationDurationScaleMode::duration_multiplier(),\n            ui::ScopedAnimationDurationScaleMode::ZERO_DURATION);\n\n  ui::LayerAnimatorTestController controller(layer->GetAnimator());\n  // Multiple steps are required to complete complex animations.\n  // TODO(vollick): This should not be necessary. crbug.com/154017\n  while (controller.animator()->is_animating()) {\n    controller.StartThreadedAnimationsIfNeeded();\n    base::TimeTicks step_time = controller.animator()->last_step_time();\n    layer->GetAnimator()->Step(step_time + base::Milliseconds(1000));\n  }\n}\n\n// Writes a JPEG image of the specified size and color to |path|. Returns true\n// on success.\nbool WriteJPEGFile(const base::FilePath& path,\n                   int width,\n                   int height,\n                   SkColor color) {\n  base::ScopedAllowBlockingForTesting allow_blocking;\n  SkBitmap bitmap;\n  bitmap.allocN32Pixels(width, height);\n  bitmap.eraseColor(color);\n  std::vector<unsigned char> output;\n  if (!gfx::JPEGCodec::Encode(bitmap, 80 /*quality*/, &output)) {\n    LOG(ERROR) << \"Unable to encode \" << width << \"x\" << height << \" bitmap\";\n    return false;\n  }\n\n  size_t bytes_written = base::WriteFile(\n      path, reinterpret_cast<const char*>(&output[0]), output.size());\n  if (bytes_written != output.size()) {\n    LOG(ERROR) << \"Wrote \" << bytes_written << \" byte(s) instead of \"\n               << output.size() << \" to \" << path.value();\n    return false;\n  }\n  return true;\n}\n\n// Returns custom wallpaper path. Creates the directory if it doesn't exist.\nbase::FilePath GetCustomWallpaperPath(const char* sub_dir,\n                                      const std::string& wallpaper_files_id,\n                                      const std::string& file_name) {\n  base::ScopedAllowBlockingForTesting allow_blocking;\n  base::FilePath wallpaper_path =\n      WallpaperControllerImpl::GetCustomWallpaperPath(\n          sub_dir, wallpaper_files_id, file_name);\n  if (!base::DirectoryExists(wallpaper_path.DirName()))\n    base::CreateDirectory(wallpaper_path.DirName());\n\n  return wallpaper_path;\n}\n\nvoid WaitUntilCustomWallpapersDeleted(const AccountId& account_id) {\n  const std::string wallpaper_file_id = GetDummyFileId(account_id);\n\n  base::FilePath small_wallpaper_dir =\n      WallpaperControllerImpl::GetCustomWallpaperDir(\n          WallpaperControllerImpl::kSmallWallpaperSubDir)\n          .Append(wallpaper_file_id);\n  base::FilePath large_wallpaper_dir =\n      WallpaperControllerImpl::GetCustomWallpaperDir(\n          WallpaperControllerImpl::kLargeWallpaperSubDir)\n          .Append(wallpaper_file_id);\n  base::FilePath original_wallpaper_dir =\n      WallpaperControllerImpl::GetCustomWallpaperDir(\n          WallpaperControllerImpl::kOriginalWallpaperSubDir)\n          .Append(wallpaper_file_id);\n\n  while (base::PathExists(small_wallpaper_dir) ||\n         base::PathExists(large_wallpaper_dir) ||\n         base::PathExists(original_wallpaper_dir)) {\n  }\n}\n\n// Monitors if any task is processed by the message loop.\nclass TaskObserver : public base::TaskObserver {\n public:\n  TaskObserver() : processed_(false) {}\n\n  TaskObserver(const TaskObserver&) = delete;\n  TaskObserver& operator=(const TaskObserver&) = delete;\n\n  ~TaskObserver() override = default;\n\n  // TaskObserver:\n  void WillProcessTask(const base::PendingTask& /* pending_task */,\n                       bool /* was_blocked_or_low_priority */) override {}\n  void DidProcessTask(const base::PendingTask& pending_task) override {\n    processed_ = true;\n  }\n\n  // Returns true if any task was processed.\n  bool processed() const { return processed_; }\n\n private:\n  bool processed_;\n};\n\n// See content::RunAllTasksUntilIdle().\nvoid RunAllTasksUntilIdle() {\n  while (true) {\n    TaskObserver task_observer;\n    base::CurrentThread::Get()->AddTaskObserver(&task_observer);\n    // May spin message loop.\n    base::ThreadPoolInstance::Get()->FlushForTesting();\n\n    base::RunLoop().RunUntilIdle();\n    base::CurrentThread::Get()->RemoveTaskObserver(&task_observer);\n\n    if (!task_observer.processed())\n      break;\n  }\n}\n\nPrefService* GetProfilePrefService(const AccountId& account_id) {\n  return Shell::Get()->session_controller()->GetUserPrefServiceForUser(\n      account_id);\n}\n\nWallpaperInfo InfoWithType(WallpaperType type) {\n  WallpaperInfo info(std::string(), WALLPAPER_LAYOUT_CENTER_CROPPED, type,\n                     base::Time::Now());\n  if (type == WallpaperType::kDaily || type == WallpaperType::kOnline) {\n    // Daily and Online types require asset id and collection id.\n    info.asset_id = 1234;\n    info.collection_id = \"placeholder collection\";\n    info.location = \"https://example.com/example.jpeg\";\n  }\n  if (type == WallpaperType::kOnceGooglePhotos)\n    info.dedup_key = \"dedup_key\";\n  return info;\n}\n\nbase::Time DayBeforeYesterdayish() {\n  base::TimeDelta today_delta =\n      base::Time::Now().LocalMidnight().ToDeltaSinceWindowsEpoch();\n  base::TimeDelta yesterday_delta = today_delta - base::Days(2);\n  return base::Time::FromDeltaSinceWindowsEpoch(yesterday_delta);\n}\n\n// A test implementation of the WallpaperControllerObserver interface.\nclass TestWallpaperControllerObserver : public WallpaperControllerObserver {\n public:\n  explicit TestWallpaperControllerObserver(WallpaperController* controller)\n      : controller_(controller) {\n    controller_->AddObserver(this);\n  }\n\n  TestWallpaperControllerObserver(const TestWallpaperControllerObserver&) =\n      delete;\n  TestWallpaperControllerObserver& operator=(\n      const TestWallpaperControllerObserver&) = delete;\n\n  ~TestWallpaperControllerObserver() override {\n    controller_->RemoveObserver(this);\n  }\n\n  // WallpaperControllerObserver\n  void OnWallpaperChanged() override { ++wallpaper_changed_count_; }\n  void OnWallpaperColorsChanged() override { ++colors_changed_count_; }\n  void OnWallpaperBlurChanged() override { ++blur_changed_count_; }\n  void OnFirstWallpaperShown() override { ++first_shown_count_; }\n  void OnWallpaperPreviewStarted() override {\n    DCHECK(!is_in_wallpaper_preview_);\n    is_in_wallpaper_preview_ = true;\n  }\n  void OnWallpaperPreviewEnded() override {\n    DCHECK(is_in_wallpaper_preview_);\n    is_in_wallpaper_preview_ = false;\n  }\n\n  int colors_changed_count() const { return colors_changed_count_; }\n  int blur_changed_count() const { return blur_changed_count_; }\n  int first_shown_count() const { return first_shown_count_; }\n  int wallpaper_changed_count() const { return wallpaper_changed_count_; }\n  bool is_in_wallpaper_preview() const { return is_in_wallpaper_preview_; }\n\n private:\n  WallpaperController* controller_;\n  int colors_changed_count_ = 0;\n  int blur_changed_count_ = 0;\n  int first_shown_count_ = 0;\n  int wallpaper_changed_count_ = 0;\n  bool is_in_wallpaper_preview_ = false;\n};\n\n}  // namespace\n\nclass WallpaperControllerTest : public AshTestBase {\n public:\n  WallpaperControllerTest()\n      : AshTestBase(base::test::TaskEnvironment::TimeSource::MOCK_TIME) {}\n\n  WallpaperControllerTest(const WallpaperControllerTest&) = delete;\n  WallpaperControllerTest& operator=(const WallpaperControllerTest&) = delete;\n\n  void SetUp() override {\n    auto pref_manager = WallpaperPrefManager::Create(local_state());\n    pref_manager_ = pref_manager.get();\n    // Override the pref manager that will be used to construct the\n    // WallpaperController.\n    WallpaperControllerImpl::SetWallpaperPrefManagerForTesting(\n        std::move(pref_manager));\n\n    AshTestBase::SetUp();\n\n    TestSessionControllerClient* const client = GetSessionControllerClient();\n    client->ProvidePrefServiceForUser(account_id_1);\n    client->ProvidePrefServiceForUser(account_id_2);\n    client->ProvidePrefServiceForUser(\n        AccountId::FromUserEmail(user_manager::kGuestUserName));\n    client->ProvidePrefServiceForUser(kChildAccountId);\n\n    // This is almost certainly not what was originally intended for these\n    // tests, but they have never actually exercised properly decoded\n    // wallpapers, as they've never actually been connected to a Data Decoder.\n    // We simulate a \"crashing\" ImageDcoder to get the behavior the tests were\n    // written around, but at some point they should probably be fixed.\n    in_process_data_decoder_.service().SimulateImageDecoderCrashForTesting(\n        true);\n\n    test_image_downloader_ = std::make_unique<TestImageDownloader>();\n\n    controller_ = Shell::Get()->wallpaper_controller();\n    controller_->set_wallpaper_reload_no_delay_for_test();\n\n    ASSERT_TRUE(user_data_dir_.CreateUniqueTempDir());\n    ASSERT_TRUE(online_wallpaper_dir_.CreateUniqueTempDir());\n    ASSERT_TRUE(custom_wallpaper_dir_.CreateUniqueTempDir());\n    base::FilePath policy_wallpaper;\n    controller_->Init(user_data_dir_.GetPath(), online_wallpaper_dir_.GetPath(),\n                      custom_wallpaper_dir_.GetPath(), policy_wallpaper);\n    client_.ResetCounts();\n    controller_->SetClient(&client_);\n    client_.set_fake_files_id_for_account_id(account_id_1,\n                                             wallpaper_files_id_1);\n    client_.set_fake_files_id_for_account_id(account_id_2,\n                                             wallpaper_files_id_2);\n  }\n\n  void TearDown() override {\n    // Although pref services outlive wallpaper controller in the os, in ash\n    // tests, they are destroyed in tear down (See |AshTestHelper|). We don't\n    // want this timer to run a task after tear down, since it relies on a pref\n    // service being around.\n    controller_->GetUpdateWallpaperTimerForTesting().Stop();\n\n    AshTestBase::TearDown();\n  }\n\n  WallpaperView* wallpaper_view() {\n    return Shell::Get()\n        ->GetPrimaryRootWindowController()\n        ->wallpaper_widget_controller()\n        ->wallpaper_view();\n  }\n\n protected:\n  // Helper function that tests the wallpaper is always fitted to the native\n  // display resolution when the layout is WALLPAPER_LAYOUT_CENTER.\n  void WallpaperFitToNativeResolution(WallpaperView* view,\n                                      float device_scale_factor,\n                                      int image_width,\n                                      int image_height,\n                                      SkColor color) {\n    gfx::Size size = view->bounds().size();\n    gfx::Canvas canvas(size, device_scale_factor, true);\n    view->OnPaint(&canvas);\n\n    SkBitmap bitmap = canvas.GetBitmap();\n    int bitmap_width = bitmap.width();\n    int bitmap_height = bitmap.height();\n    for (int i = 0; i < bitmap_width; i++) {\n      for (int j = 0; j < bitmap_height; j++) {\n        if (i >= (bitmap_width - image_width) / 2 &&\n            i < (bitmap_width + image_width) / 2 &&\n            j >= (bitmap_height - image_height) / 2 &&\n            j < (bitmap_height + image_height) / 2) {\n          EXPECT_EQ(color, bitmap.getColor(i, j));\n        } else {\n          EXPECT_EQ(SK_ColorBLACK, bitmap.getColor(i, j));\n        }\n      }\n    }\n  }\n\n  // Runs AnimatingWallpaperWidgetController's animation to completion.\n  void RunDesktopControllerAnimation() {\n    WallpaperWidgetController* controller =\n        Shell::Get()\n            ->GetPrimaryRootWindowController()\n            ->wallpaper_widget_controller();\n    ASSERT_TRUE(controller);\n\n    ui::LayerTreeOwner* owner = controller->old_layer_tree_owner_for_testing();\n    if (!owner)\n      return;\n\n    ASSERT_NO_FATAL_FAILURE(RunAnimationForLayer(owner->root()));\n  }\n\n  // Convenience function to ensure ShouldCalculateColors() returns true.\n  void EnableShelfColoring() {\n    const gfx::ImageSkia kImage = CreateImage(10, 10, kWallpaperColor);\n    controller_->ShowWallpaperImage(\n        kImage, CreateWallpaperInfo(WALLPAPER_LAYOUT_STRETCH),\n        /*preview_mode=*/false, /*always_on_top=*/false);\n    SetSessionState(SessionState::ACTIVE);\n\n    EXPECT_TRUE(ShouldCalculateColors());\n  }\n\n  // Convenience function to set the SessionState.\n  void SetSessionState(SessionState session_state) {\n    GetSessionControllerClient()->SetSessionState(session_state);\n  }\n\n  // Helper function to create a |WallpaperInfo| struct with dummy values\n  // given the desired layout.\n  WallpaperInfo CreateWallpaperInfo(WallpaperLayout layout) {\n    return WallpaperInfo(std::string(), layout, WallpaperType::kDefault,\n                         base::Time::Now().LocalMidnight());\n  }\n\n  // Saves wallpaper images in the appropriate location for |account_id| and\n  // returns the relative path of the file.\n  base::FilePath PrecacheWallpapers(const AccountId& account_id) {\n    std::string wallpaper_files_id = GetDummyFileId(account_id);\n\n    std::string file_name = GetDummyFileName(account_id);\n    base::FilePath small_wallpaper_path =\n        GetCustomWallpaperPath(WallpaperControllerImpl::kSmallWallpaperSubDir,\n                               wallpaper_files_id, file_name);\n    base::FilePath large_wallpaper_path =\n        GetCustomWallpaperPath(WallpaperControllerImpl::kLargeWallpaperSubDir,\n                               wallpaper_files_id, file_name);\n\n    // Saves the small/large resolution wallpapers to small/large custom\n    // wallpaper paths.\n    CHECK(WriteJPEGFile(small_wallpaper_path, kSmallWallpaperMaxWidth,\n                        kSmallWallpaperMaxHeight, kSmallCustomWallpaperColor));\n    CHECK(WriteJPEGFile(large_wallpaper_path, kLargeWallpaperMaxWidth,\n                        kLargeWallpaperMaxHeight, kLargeCustomWallpaperColor));\n\n    return base::FilePath(wallpaper_files_id).Append(file_name);\n  }\n\n  // Saves images with different resolution to corresponding paths and saves\n  // wallpaper info to local state, so that subsequent calls of |ShowWallpaper|\n  // can retrieve the images and info.\n  void CreateAndSaveWallpapers(const AccountId& account_id) {\n    base::FilePath relative_path = PrecacheWallpapers(account_id);\n    // Saves wallpaper info to local state for user.\n    WallpaperInfo info = {\n        relative_path.value(), WALLPAPER_LAYOUT_CENTER_CROPPED,\n        WallpaperType::kCustomized, base::Time::Now().LocalMidnight()};\n    ASSERT_TRUE(pref_manager_->SetUserWallpaperInfo(account_id, info));\n  }\n\n  // Simulates setting a custom wallpaper by directly setting the wallpaper\n  // info.\n  void SimulateSettingCustomWallpaper(const AccountId& account_id) {\n    ASSERT_TRUE(pref_manager_->SetUserWallpaperInfo(\n        account_id,\n        WallpaperInfo(\"dummy_file_location\", WALLPAPER_LAYOUT_CENTER,\n                      WallpaperType::kCustomized,\n                      base::Time::Now().LocalMidnight())));\n  }\n\n  // Initializes default wallpaper paths \"*default_*file\" and writes JPEG\n  // wallpaper images to them. Only needs to be called (once) by tests that\n  // want to test loading of default wallpapers.\n  void CreateDefaultWallpapers() {\n    base::ScopedAllowBlockingForTesting allow_blocking;\n    ASSERT_TRUE(default_wallpaper_dir_.CreateUniqueTempDir());\n    const base::FilePath default_wallpaper_path =\n        default_wallpaper_dir_.GetPath();\n\n    base::CommandLine* command_line = base::CommandLine::ForCurrentProcess();\n    const base::FilePath small_file =\n        default_wallpaper_path.Append(kDefaultSmallWallpaperName);\n    command_line->AppendSwitchASCII(switches::kDefaultWallpaperSmall,\n                                    small_file.value());\n    const base::FilePath large_file =\n        default_wallpaper_path.Append(kDefaultLargeWallpaperName);\n    command_line->AppendSwitchASCII(switches::kDefaultWallpaperLarge,\n                                    large_file.value());\n\n    const base::FilePath guest_small_file =\n        default_wallpaper_path.Append(kGuestSmallWallpaperName);\n    command_line->AppendSwitchASCII(switches::kGuestWallpaperSmall,\n                                    guest_small_file.value());\n    const base::FilePath guest_large_file =\n        default_wallpaper_path.Append(kGuestLargeWallpaperName);\n    command_line->AppendSwitchASCII(switches::kGuestWallpaperLarge,\n                                    guest_large_file.value());\n\n    const base::FilePath child_small_file =\n        default_wallpaper_path.Append(kChildSmallWallpaperName);\n    command_line->AppendSwitchASCII(switches::kChildWallpaperSmall,\n                                    child_small_file.value());\n    const base::FilePath child_large_file =\n        default_wallpaper_path.Append(kChildLargeWallpaperName);\n    command_line->AppendSwitchASCII(switches::kChildWallpaperLarge,\n                                    child_large_file.value());\n\n    const int kWallpaperSize = 2;\n    ASSERT_TRUE(WriteJPEGFile(small_file, kWallpaperSize, kWallpaperSize,\n                              kWallpaperColor));\n    ASSERT_TRUE(WriteJPEGFile(large_file, kWallpaperSize, kWallpaperSize,\n                              kWallpaperColor));\n\n    ASSERT_TRUE(WriteJPEGFile(guest_small_file, kWallpaperSize, kWallpaperSize,\n                              kWallpaperColor));\n    ASSERT_TRUE(WriteJPEGFile(guest_large_file, kWallpaperSize, kWallpaperSize,\n                              kWallpaperColor));\n\n    ASSERT_TRUE(WriteJPEGFile(child_small_file, kWallpaperSize, kWallpaperSize,\n                              kWallpaperColor));\n    ASSERT_TRUE(WriteJPEGFile(child_large_file, kWallpaperSize, kWallpaperSize,\n                              kWallpaperColor));\n  }\n\n  // Returns the paths of a small and large jpeg for use with customized default\n  // wallpapers.\n  [[nodiscard]] std::pair<const base::FilePath, const base::FilePath>\n  CreateCustomizationWallpapers() {\n    base::ScopedAllowBlockingForTesting allow_blocking;\n    CHECK(customization_wallpaper_dir_.CreateUniqueTempDir());\n\n    base::FilePath root = customization_wallpaper_dir_.GetPath();\n\n    const base::FilePath small_file =\n        root.Append(kCustomizationSmallWallpaperName);\n    const base::FilePath large_file =\n        root.Append(kCustomizationLargeWallpaperName);\n\n    CHECK(WriteJPEGFile(small_file, 800, 800, SK_ColorGREEN));\n    CHECK(WriteJPEGFile(large_file, 2000, 2000, SK_ColorBLUE));\n\n    return {small_file, large_file};\n  }\n\n  // A helper to test the behavior of setting online wallpaper after the image\n  // is decoded. This is needed because image decoding is not supported in unit\n  // tests.\n  void SetOnlineWallpaperFromImage(\n      const AccountId& account_id,\n      uint64_t asset_id,\n      const gfx::ImageSkia& image,\n      const std::string& url,\n      const std::string& collection_id,\n      WallpaperLayout layout,\n      bool save_file,\n      bool preview_mode,\n      bool from_user,\n      uint64_t unit_id,\n      const std::vector<OnlineWallpaperVariant>& variants,\n      WallpaperController::SetWallpaperCallback callback) {\n    const OnlineWallpaperParams params = {\n        account_id, asset_id,     GURL(url), collection_id,\n        layout,     preview_mode, from_user, /*daily_refresh_enabled=*/false,\n        unit_id,    variants};\n    controller_->OnOnlineWallpaperDecoded(params, save_file,\n                                          std::move(callback), image);\n  }\n\n  // Returns color of the current wallpaper. Note: this function assumes the\n  // wallpaper has a solid color.\n  SkColor GetWallpaperColor() {\n    const gfx::ImageSkiaRep& representation =\n        controller_->GetWallpaper().GetRepresentation(1.0f);\n    return representation.GetBitmap().getColor(0, 0);\n  }\n\n  // Wrapper for private ShouldCalculateColors().\n  bool ShouldCalculateColors() { return controller_->ShouldCalculateColors(); }\n\n  // Wrapper for private IsDevicePolicyWallpaper().\n  bool IsDevicePolicyWallpaper() {\n    return controller_->IsDevicePolicyWallpaper();\n  }\n\n  int GetWallpaperCount() { return controller_->wallpaper_count_for_testing_; }\n\n  const std::vector<base::FilePath>& GetDecodeFilePaths() {\n    return controller_->decode_requests_for_testing_;\n  }\n\n  // Returns the `WallpaperInfo` associated with the current\n  // `WallpaperResizer`. Usually, this is the same as\n  // `GetActiveUserWallpaperInfo()` except when the user is not logged in.\n  const WallpaperInfo GetCurrentWallpaperInfo() {\n    WallpaperResizer* wallpaper = controller_->current_wallpaper_.get();\n    if (!wallpaper)\n      return WallpaperInfo();\n\n    return wallpaper->wallpaper_info();\n  }\n\n  void SetBypassDecode() { controller_->set_bypass_decode_for_testing(); }\n\n  void ClearWallpaperCount() { controller_->wallpaper_count_for_testing_ = 0; }\n\n  void ClearDecodeFilePaths() {\n    controller_->decode_requests_for_testing_.clear();\n  }\n\n  void ClearWallpaper() { controller_->current_wallpaper_.reset(); }\n\n  int GetWallpaperContainerId() {\n    return controller_->GetWallpaperContainerId(controller_->locked_);\n  }\n\n  const base::HistogramTester& histogram_tester() const {\n    return histogram_tester_;\n  }\n\n  void CacheOnlineWallpaper(std::string path) {\n    // Set an Online Wallpaper from Data, so syncing in doesn't need to download\n    // an Online Wallpaper.\n    SetBypassDecode();\n    SimulateUserLogin(account_id_1);\n    ClearWallpaperCount();\n    controller_->SetOnlineWallpaperFromData(\n        OnlineWallpaperParams(\n            account_id_1, kAssetId, GURL(path),\n            /*collection_id=*/std::string(), WALLPAPER_LAYOUT_CENTER_CROPPED,\n            /*preview_mode=*/false, /*from_user=*/false,\n            /*daily_refresh_enabled=*/false, kUnitId,\n            /*variants=*/std::vector<OnlineWallpaperVariant>()),\n        /*image_data=*/std::string(),\n        WallpaperController::SetWallpaperCallback());\n    RunAllTasksUntilIdle();\n\n    // Change the on-screen wallpaper to a different one. (Otherwise the\n    // subsequent calls will be no-op since we intentionally prevent reloading\n    // the same wallpaper.)\n    ClearWallpaperCount();\n    controller_->SetCustomWallpaper(\n        account_id_1, file_name_1, WALLPAPER_LAYOUT_CENTER_CROPPED,\n        CreateImage(640, 480, kWallpaperColor), false /*preview_mode=*/);\n    RunAllTasksUntilIdle();\n  }\n\n  WallpaperControllerImpl* controller_;\n  WallpaperPrefManager* pref_manager_ = nullptr;  // owned by controller\n\n  base::ScopedTempDir user_data_dir_;\n  base::ScopedTempDir online_wallpaper_dir_;\n  base::ScopedTempDir custom_wallpaper_dir_;\n  base::ScopedTempDir default_wallpaper_dir_;\n  base::ScopedTempDir customization_wallpaper_dir_;\n  base::HistogramTester histogram_tester_;\n\n  TestWallpaperControllerClient client_;\n  std::unique_ptr<TestImageDownloader> test_image_downloader_;\n\n  const AccountId kChildAccountId =\n      AccountId::FromUserEmailGaiaId(kChildEmail, kChildEmail);\n\n private:\n  data_decoder::test::InProcessDataDecoder in_process_data_decoder_;\n};\n\nTEST_F(WallpaperControllerTest, Client) {\n  base::FilePath empty_path;\n  controller_->Init(empty_path, empty_path, empty_path, empty_path);\n\n  EXPECT_EQ(0u, client_.open_count());\n  EXPECT_TRUE(controller_->CanOpenWallpaperPicker());\n  controller_->OpenWallpaperPickerIfAllowed();\n  EXPECT_EQ(1u, client_.open_count());\n}\n\nTEST_F(WallpaperControllerTest, BasicReparenting) {\n  WallpaperControllerImpl* controller = Shell::Get()->wallpaper_controller();\n  controller->CreateEmptyWallpaperForTesting();\n\n  // Wallpaper view/window exists in the wallpaper container and nothing is in\n  // the lock screen wallpaper container.\n  EXPECT_EQ(1, ChildCountForContainer(kWallpaperId));\n  EXPECT_EQ(0, ChildCountForContainer(kLockScreenWallpaperId));\n\n  controller->OnSessionStateChanged(session_manager::SessionState::LOCKED);\n\n  // One window is moved from desktop to lock container.\n  EXPECT_EQ(0, ChildCountForContainer(kWallpaperId));\n  EXPECT_EQ(1, ChildCountForContainer(kLockScreenWallpaperId));\n\n  controller->OnSessionStateChanged(session_manager::SessionState::ACTIVE);\n\n  // One window is moved from lock to desktop container.\n  EXPECT_EQ(1, ChildCountForContainer(kWallpaperId));\n  EXPECT_EQ(0, ChildCountForContainer(kLockScreenWallpaperId));\n}\n\nTEST_F(WallpaperControllerTest, SwitchWallpapersWhenNewWallpaperAnimationEnds) {\n  // We cannot short-circuit animations for this test.\n  ui::ScopedAnimationDurationScaleMode test_duration_mode(\n      ui::ScopedAnimationDurationScaleMode::NON_ZERO_DURATION);\n\n  // Create the wallpaper and its view.\n  WallpaperControllerImpl* controller = Shell::Get()->wallpaper_controller();\n  controller->CreateEmptyWallpaperForTesting();\n\n  // The new wallpaper is ready to animate.\n  WallpaperWidgetController* widget_controller =\n      Shell::Get()\n          ->GetPrimaryRootWindowController()\n          ->wallpaper_widget_controller();\n  EXPECT_TRUE(widget_controller->IsAnimating());\n\n  // Force the animation to play to completion.\n  RunDesktopControllerAnimation();\n  EXPECT_FALSE(widget_controller->IsAnimating());\n}\n\n// Test for crbug.com/149043 \"Unlock screen, no launcher appears\". Ensure we\n// move all wallpaper views if there are more than one.\nTEST_F(WallpaperControllerTest, WallpaperMovementDuringUnlock) {\n  // We cannot short-circuit animations for this test.\n  ui::ScopedAnimationDurationScaleMode test_duration_mode(\n      ui::ScopedAnimationDurationScaleMode::NON_ZERO_DURATION);\n\n  // Reset wallpaper state, see ControllerOwnership above.\n  WallpaperControllerImpl* controller = Shell::Get()->wallpaper_controller();\n  controller->CreateEmptyWallpaperForTesting();\n\n  // Run wallpaper show animation to completion.\n  RunDesktopControllerAnimation();\n\n  // User locks the screen, which moves the wallpaper forward.\n  controller->OnSessionStateChanged(session_manager::SessionState::LOCKED);\n\n  // Suspend/resume cycle causes wallpaper to refresh, loading a new wallpaper\n  // that will animate in on top of the old one.\n  controller->CreateEmptyWallpaperForTesting();\n\n  // In this state we have a wallpaper views stored in\n  // LockScreenWallpaperContainer.\n  WallpaperWidgetController* widget_controller =\n      Shell::Get()\n          ->GetPrimaryRootWindowController()\n          ->wallpaper_widget_controller();\n  EXPECT_TRUE(widget_controller->IsAnimating());\n  EXPECT_EQ(0, ChildCountForContainer(kWallpaperId));\n  EXPECT_EQ(1, ChildCountForContainer(kLockScreenWallpaperId));\n  // There must be three layers, shield, original and old layers.\n  ASSERT_EQ(3u, wallpaper_view()->layer()->parent()->children().size());\n\n  // Before the wallpaper's animation completes, user unlocks the screen, which\n  // moves the wallpaper to the back.\n  controller->OnSessionStateChanged(session_manager::SessionState::ACTIVE);\n\n  // Ensure that widget has moved.\n  EXPECT_EQ(1, ChildCountForContainer(kWallpaperId));\n  // There must be two layers, original and old layers while animating.\n  ASSERT_EQ(2u, wallpaper_view()->layer()->parent()->children().size());\n  EXPECT_EQ(0, ChildCountForContainer(kLockScreenWallpaperId));\n\n  // Finish the new wallpaper animation.\n  RunDesktopControllerAnimation();\n\n  // Now there is one wallpaper and layer.\n  EXPECT_EQ(1, ChildCountForContainer(kWallpaperId));\n  ASSERT_EQ(1u, wallpaper_view()->layer()->parent()->children().size());\n  EXPECT_EQ(0, ChildCountForContainer(kLockScreenWallpaperId));\n}\n\n// Test for crbug.com/156542. Animating wallpaper should immediately finish\n// animation and replace current wallpaper before next animation starts.\nTEST_F(WallpaperControllerTest, ChangeWallpaperQuick) {\n  // We cannot short-circuit animations for this test.\n  ui::ScopedAnimationDurationScaleMode test_duration_mode(\n      ui::ScopedAnimationDurationScaleMode::NON_ZERO_DURATION);\n\n  // Reset wallpaper state, see ControllerOwnership above.\n  WallpaperControllerImpl* controller = Shell::Get()->wallpaper_controller();\n  controller->CreateEmptyWallpaperForTesting();\n\n  // Run wallpaper show animation to completion.\n  RunDesktopControllerAnimation();\n\n  // Change to a new wallpaper.\n  controller->CreateEmptyWallpaperForTesting();\n\n  WallpaperWidgetController* widget_controller =\n      Shell::Get()\n          ->GetPrimaryRootWindowController()\n          ->wallpaper_widget_controller();\n  EXPECT_TRUE(widget_controller->IsAnimating());\n\n  // Change to another wallpaper before animation finished.\n  controller->CreateEmptyWallpaperForTesting();\n\n  // Run wallpaper show animation to completion.\n  RunDesktopControllerAnimation();\n\n  EXPECT_FALSE(widget_controller->IsAnimating());\n}\n\nTEST_F(WallpaperControllerTest, ResizeCustomWallpaper) {\n  UpdateDisplay(\"320x200\");\n\n  gfx::ImageSkia image = CreateImage(640, 480, kWallpaperColor);\n\n  // Set the image as custom wallpaper, wait for the resize to finish, and check\n  // that the resized image is the expected size.\n  controller_->ShowWallpaperImage(\n      image, CreateWallpaperInfo(WALLPAPER_LAYOUT_STRETCH),\n      /*preview_mode=*/false, /*always_on_top=*/false);\n  EXPECT_TRUE(image.BackedBySameObjectAs(controller_->GetWallpaper()));\n  RunAllTasksUntilIdle();\n  gfx::ImageSkia resized_image = controller_->GetWallpaper();\n  EXPECT_FALSE(image.BackedBySameObjectAs(resized_image));\n  EXPECT_EQ(gfx::Size(320, 200).ToString(), resized_image.size().ToString());\n\n  // Load the original wallpaper again and check that we're still using the\n  // previously-resized image instead of doing another resize\n  // (http://crbug.com/321402).\n  controller_->ShowWallpaperImage(\n      image, CreateWallpaperInfo(WALLPAPER_LAYOUT_STRETCH),\n      /*preview_mode=*/false, /*always_on_top=*/false);\n  RunAllTasksUntilIdle();\n  EXPECT_TRUE(resized_image.BackedBySameObjectAs(controller_->GetWallpaper()));\n}\n\nTEST_F(WallpaperControllerTest, GetMaxDisplaySize) {\n  // Device scale factor shouldn't affect the native size.\n  UpdateDisplay(\"1000x300*2\");\n  EXPECT_EQ(\"1000x300\",\n            WallpaperControllerImpl::GetMaxDisplaySizeInNative().ToString());\n\n  // Rotated display should return the rotated size.\n  UpdateDisplay(\"1000x300*2/r\");\n  EXPECT_EQ(\"300x1000\",\n            WallpaperControllerImpl::GetMaxDisplaySizeInNative().ToString());\n\n  // UI Scaling shouldn't affect the native size.\n  UpdateDisplay(\"1000x300*[email protected]\");\n  EXPECT_EQ(\"1000x300\",\n            WallpaperControllerImpl::GetMaxDisplaySizeInNative().ToString());\n\n  // First display has maximum size.\n  UpdateDisplay(\"400x300,200x100\");\n  EXPECT_EQ(\"400x300\",\n            WallpaperControllerImpl::GetMaxDisplaySizeInNative().ToString());\n\n  // Second display has maximum size.\n  UpdateDisplay(\"400x300,500x600\");\n  EXPECT_EQ(\"500x600\",\n            WallpaperControllerImpl::GetMaxDisplaySizeInNative().ToString());\n\n  // Maximum width and height belongs to different displays.\n  UpdateDisplay(\"400x300,100x500\");\n  EXPECT_EQ(\"400x500\",\n            WallpaperControllerImpl::GetMaxDisplaySizeInNative().ToString());\n}\n\n// Test that the wallpaper is always fitted to the native display resolution\n// when the layout is WALLPAPER_LAYOUT_CENTER to prevent blurry images.\nTEST_F(WallpaperControllerTest, DontScaleWallpaperWithCenterLayout) {\n  // We cannot short-circuit animations for this test.\n  ui::ScopedAnimationDurationScaleMode test_duration_mode(\n      ui::ScopedAnimationDurationScaleMode::NON_ZERO_DURATION);\n\n  const gfx::Size high_resolution(3600, 2400);\n  const gfx::Size low_resolution(360, 240);\n  const float high_dsf = 2.0f;\n  const float low_dsf = 1.0f;\n\n  gfx::ImageSkia image_high_res = CreateImage(\n      high_resolution.width(), high_resolution.height(), kWallpaperColor);\n  gfx::ImageSkia image_low_res = CreateImage(\n      low_resolution.width(), low_resolution.height(), kWallpaperColor);\n\n  UpdateDisplay(\"1200x600*2\");\n  {\n    SCOPED_TRACE(base::StringPrintf(\"1200x600*2 high resolution\"));\n    controller_->ShowWallpaperImage(\n        image_high_res, CreateWallpaperInfo(WALLPAPER_LAYOUT_CENTER),\n        /*preview_mode=*/false, /*always_on_top=*/false);\n    WallpaperFitToNativeResolution(wallpaper_view(), high_dsf,\n                                   high_resolution.width(),\n                                   high_resolution.height(), kWallpaperColor);\n  }\n  {\n    SCOPED_TRACE(base::StringPrintf(\"1200x600*2 low resolution\"));\n    controller_->ShowWallpaperImage(\n        image_low_res, CreateWallpaperInfo(WALLPAPER_LAYOUT_CENTER),\n        /*preview_mode=*/false, /*always_on_top=*/false);\n    WallpaperFitToNativeResolution(wallpaper_view(), high_dsf,\n                                   low_resolution.width(),\n                                   low_resolution.height(), kWallpaperColor);\n  }\n\n  UpdateDisplay(\"1200x600\");\n  {\n    SCOPED_TRACE(base::StringPrintf(\"1200x600 high resolution\"));\n    controller_->ShowWallpaperImage(\n        image_high_res, CreateWallpaperInfo(WALLPAPER_LAYOUT_CENTER),\n        /*preview_mode=*/false, /*always_on_top=*/false);\n    WallpaperFitToNativeResolution(wallpaper_view(), low_dsf,\n                                   high_resolution.width(),\n                                   high_resolution.height(), kWallpaperColor);\n  }\n  {\n    SCOPED_TRACE(base::StringPrintf(\"1200x600 low resolution\"));\n    controller_->ShowWallpaperImage(\n        image_low_res, CreateWallpaperInfo(WALLPAPER_LAYOUT_CENTER),\n        /*preview_mode=*/false, /*always_on_top=*/false);\n    WallpaperFitToNativeResolution(wallpaper_view(), low_dsf,\n                                   low_resolution.width(),\n                                   low_resolution.height(), kWallpaperColor);\n  }\n\n  UpdateDisplay(\"1200x600/[email protected]\");  // 1.5 ui scale\n  {\n    SCOPED_TRACE(base::StringPrintf(\"1200x600/[email protected] high resolution\"));\n    controller_->ShowWallpaperImage(\n        image_high_res, CreateWallpaperInfo(WALLPAPER_LAYOUT_CENTER),\n        /*preview_mode=*/false, /*always_on_top=*/false);\n    WallpaperFitToNativeResolution(wallpaper_view(), low_dsf,\n                                   high_resolution.width(),\n                                   high_resolution.height(), kWallpaperColor);\n  }\n  {\n    SCOPED_TRACE(base::StringPrintf(\"1200x600/[email protected] low resolution\"));\n    controller_->ShowWallpaperImage(\n        image_low_res, CreateWallpaperInfo(WALLPAPER_LAYOUT_CENTER),\n        /*preview_mode=*/false, /*always_on_top=*/false);\n    WallpaperFitToNativeResolution(wallpaper_view(), low_dsf,\n                                   low_resolution.width(),\n                                   low_resolution.height(), kWallpaperColor);\n  }\n}\n\nTEST_F(WallpaperControllerTest, ShouldCalculateColorsBasedOnImage) {\n  EnableShelfColoring();\n  EXPECT_TRUE(ShouldCalculateColors());\n\n  controller_->CreateEmptyWallpaperForTesting();\n  EXPECT_FALSE(ShouldCalculateColors());\n}\n\nTEST_F(WallpaperControllerTest, ShouldCalculateColorsBasedOnSessionState) {\n  EnableShelfColoring();\n\n  SetSessionState(SessionState::UNKNOWN);\n  EXPECT_FALSE(ShouldCalculateColors());\n\n  SetSessionState(SessionState::OOBE);\n  EXPECT_FALSE(ShouldCalculateColors());\n\n  SetSessionState(SessionState::LOGIN_PRIMARY);\n  EXPECT_FALSE(ShouldCalculateColors());\n\n  SetSessionState(SessionState::LOGGED_IN_NOT_ACTIVE);\n  EXPECT_FALSE(ShouldCalculateColors());\n\n  SetSessionState(SessionState::ACTIVE);\n  EXPECT_TRUE(ShouldCalculateColors());\n\n  SetSessionState(SessionState::LOCKED);\n  EXPECT_FALSE(ShouldCalculateColors());\n\n  SetSessionState(SessionState::LOGIN_SECONDARY);\n  EXPECT_FALSE(ShouldCalculateColors());\n}\n\nTEST_F(WallpaperControllerTest, EnableShelfColoringNotifiesObservers) {\n  TestWallpaperControllerObserver observer(controller_);\n  EXPECT_EQ(0, observer.colors_changed_count());\n\n  // Enable shelf coloring will set a customized wallpaper image and change\n  // session state to ACTIVE, which will trigger wallpaper colors calculation.\n  EnableShelfColoring();\n  base::RunLoop().RunUntilIdle();\n  EXPECT_EQ(1, observer.colors_changed_count());\n}\n\nTEST_F(WallpaperControllerTest, ProminentColor_CachedColorsAvailableAtLogin) {\n  SetBypassDecode();\n  // Cache some wallpapers and store that in the local prefs. Otherwise, we\n  // can't cache colors.\n  base::FilePath relative_path = PrecacheWallpapers(account_id_1);\n  WallpaperInfo info = InfoWithType(WallpaperType::kCustomized);\n  info.location = relative_path.value();\n  ASSERT_TRUE(pref_manager_->SetLocalWallpaperInfo(account_id_1, info));\n\n  // Store colors in local prefs simulating cache behavior.\n  const std::vector<SkColor> prominent_colors = {SK_ColorGREEN, SK_ColorRED,\n                                                 SK_ColorBLUE,  SK_ColorWHITE,\n                                                 SK_ColorWHITE, SK_ColorWHITE};\n  pref_manager_->CacheProminentColors(account_id_1, prominent_colors);\n  const SkColor k_means_color = SK_ColorLTGRAY;\n  pref_manager_->CacheKMeanColor(account_id_1, k_means_color);\n\n  // Reset to login screen.\n  GetSessionControllerClient()->RequestSignOut();\n\n  TestWallpaperControllerObserver observer(controller_);\n  ASSERT_EQ(0, observer.colors_changed_count());\n\n  // Show user wallpaper in login screen. We are *not* logged in yet.\n  controller_->ShowUserWallpaper(account_id_1,\n                                 user_manager::UserType::USER_TYPE_REGULAR);\n  task_environment()->RunUntilIdle();\n\n  // Showing a user wallpaper should cause the cached colors to be fetched and\n  // reported.\n  EXPECT_EQ(1, observer.colors_changed_count());\n\n  // DARK_VIBRANT happens to be prominent color 0.\n  EXPECT_EQ(SK_ColorGREEN, controller_->GetProminentColor(\n                               {color_utils::LumaRange::DARK,\n                                color_utils::SaturationRange::VIBRANT}));\n  EXPECT_EQ(k_means_color, controller_->GetKMeanColor());\n}\n\nTEST_F(WallpaperControllerTest, ProminentColor_ClearedBetweenUsers) {\n  SetBypassDecode();\n  // Setup prominent colors for account 1.\n  base::FilePath relative_path = PrecacheWallpapers(account_id_1);\n  WallpaperInfo info = InfoWithType(WallpaperType::kCustomized);\n  info.location = relative_path.value();\n  ASSERT_TRUE(pref_manager_->SetLocalWallpaperInfo(account_id_1, info));\n\n  const std::vector<SkColor> prominent_colors = {SK_ColorGREEN, SK_ColorRED,\n                                                 SK_ColorBLUE,  SK_ColorWHITE,\n                                                 SK_ColorWHITE, SK_ColorWHITE};\n  pref_manager_->CacheProminentColors(account_id_1, prominent_colors);\n  const SkColor k_means_color = SK_ColorLTGRAY;\n  pref_manager_->CacheKMeanColor(account_id_1, k_means_color);\n\n  // Set a wallpaper for account 2.\n  WallpaperInfo info2 = InfoWithType(WallpaperType::kDefault);\n  ASSERT_TRUE(pref_manager_->SetLocalWallpaperInfo(account_id_2, info2));\n\n  // Reset to login screen.\n  GetSessionControllerClient()->RequestSignOut();\n\n  TestWallpaperControllerObserver observer(controller_);\n\n  // Show wallpaper for account 1.\n  controller_->ShowUserWallpaper(account_id_1,\n                                 user_manager::UserType::USER_TYPE_REGULAR);\n  task_environment()->RunUntilIdle();\n\n  // Verify that we can retrieve the prominent color.\n  EXPECT_EQ(SK_ColorGREEN, controller_->GetProminentColor(\n                               {color_utils::LumaRange::DARK,\n                                color_utils::SaturationRange::VIBRANT}));\n\n  // Show wallpaper for account 2.\n  controller_->ShowUserWallpaper(account_id_2,\n                                 user_manager::UserType::USER_TYPE_REGULAR);\n  task_environment()->RunUntilIdle();\n  // Since account 2 has not cached colors, the prominent color should be\n  // invalid.\n  EXPECT_EQ(\n      kInvalidWallpaperColor,\n      controller_->GetProminentColor({color_utils::LumaRange::DARK,\n                                      color_utils::SaturationRange::VIBRANT}));\n  EXPECT_EQ(2, observer.colors_changed_count());\n}\n\nTEST_F(WallpaperControllerTest, SetOnlineWallpaperFromDataSavesFile) {\n  SetBypassDecode();\n  gfx::ImageSkia image = CreateImage(640, 480, kWallpaperColor);\n  SimulateUserLogin(account_id_1);\n\n  // Verify that there's no offline wallpaper available in the beginning.\n  std::unique_ptr<base::RunLoop> run_loop = std::make_unique<base::RunLoop>();\n  controller_->GetOfflineWallpaperList(base::BindLambdaForTesting(\n      [&run_loop](const std::vector<std::string>& url_list) {\n        EXPECT_TRUE(url_list.empty());\n        run_loop->Quit();\n      }));\n  run_loop->Run();\n\n  // Set an online wallpaper with image data.\n  ClearWallpaperCount();\n  controller_->SetOnlineWallpaperFromData(\n      OnlineWallpaperParams(account_id_1, kAssetId, GURL(kDummyUrl),\n                            /*collection_id=*/std::string(),\n                            WALLPAPER_LAYOUT_CENTER_CROPPED,\n                            /*preview_mode=*/false, /*from_user=*/false,\n                            /*daily_refresh_enabled=*/false, kUnitId,\n                            /*variants=*/std::vector<OnlineWallpaperVariant>()),\n      /*image_data=*/std::string(),\n      WallpaperController::SetWallpaperCallback());\n  RunAllTasksUntilIdle();\n\n  // Verify that the wallpaper with |url| is available offline, and the returned\n  // file name should not contain the small wallpaper suffix.\n  run_loop = std::make_unique<base::RunLoop>();\n  controller_->GetOfflineWallpaperList(base::BindLambdaForTesting(\n      [&run_loop](const std::vector<std::string>& url_list) {\n        EXPECT_EQ(1U, url_list.size());\n        EXPECT_EQ(GURL(kDummyUrl).ExtractFileName(), url_list[0]);\n        run_loop->Quit();\n      }));\n  run_loop->Run();\n}\n\nTEST_F(WallpaperControllerTest,\n       UpdatePrimaryUserWallpaperWhileSecondUserActive) {\n  SetBypassDecode();\n  WallpaperInfo wallpaper_info;\n\n  SimulateUserLogin(account_id_1);\n\n  // Set an online wallpaper with image data. Verify that the wallpaper is set\n  // successfully.\n  const OnlineWallpaperParams& params = OnlineWallpaperParams(\n      account_id_1, kAssetId, GURL(kDummyUrl),\n      /*collection_id=*/std::string(), WALLPAPER_LAYOUT_CENTER_CROPPED,\n      /*preview_mode=*/false, /*from_user=*/false,\n      /*daily_refresh_enabled=*/false, kUnitId,\n      /*variants=*/std::vector<OnlineWallpaperVariant>());\n  controller_->SetOnlineWallpaperFromData(\n      params,\n      /*image_data=*/std::string(),\n      WallpaperController::SetWallpaperCallback());\n  RunAllTasksUntilIdle();\n  // Verify that the user wallpaper info is updated.\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  WallpaperInfo expected_wallpaper_info(params);\n  EXPECT_EQ(wallpaper_info, expected_wallpaper_info);\n\n  // Log in |kUser2|, and set another online wallpaper for |kUser1|. Verify that\n  // the on-screen wallpaper doesn't change since |kUser1| is not active, but\n  // wallpaper info is updated properly.\n  SimulateUserLogin(account_id_2);\n  ClearWallpaperCount();\n  const OnlineWallpaperParams& new_params = OnlineWallpaperParams(\n      account_id_1, kAssetId2, GURL(kDummyUrl2),\n      /*collection_id=*/std::string(), WALLPAPER_LAYOUT_CENTER_CROPPED,\n      /*preview_mode=*/false, /*from_user=*/false,\n      /*daily_refresh_enabled=*/false, kUnitId2,\n      /*variants=*/std::vector<OnlineWallpaperVariant>());\n  controller_->SetOnlineWallpaperFromData(\n      new_params,\n      /*image_data=*/std::string(),\n      WallpaperController::SetWallpaperCallback());\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(0, GetWallpaperCount());\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  WallpaperInfo expected_wallpaper_info_2(new_params);\n  EXPECT_EQ(wallpaper_info, expected_wallpaper_info_2);\n}\n\nTEST_F(WallpaperControllerTest, SetOnlineWallpaper) {\n  SetBypassDecode();\n\n  gfx::ImageSkia image = CreateImage(640, 480, kWallpaperColor);\n  WallpaperLayout layout = WALLPAPER_LAYOUT_CENTER_CROPPED;\n  SimulateUserLogin(account_id_1);\n\n  // Verify that calling |SetOnlineWallpaper| will download the image data if it\n  // does not exist. Verify that the wallpaper is set successfully.\n  auto run_loop = std::make_unique<base::RunLoop>();\n  ClearWallpaperCount();\n  const OnlineWallpaperParams& params = OnlineWallpaperParams(\n      account_id_1, kAssetId, GURL(kDummyUrl),\n      TestWallpaperControllerClient::kDummyCollectionId, layout,\n      /*preview_mode=*/false, /*from_user=*/true,\n      /*daily_refresh_enabled=*/false, kUnitId,\n      /*variants=*/std::vector<OnlineWallpaperVariant>());\n  controller_->SetOnlineWallpaper(\n      params, base::BindLambdaForTesting([&run_loop](bool success) {\n        EXPECT_TRUE(success);\n        run_loop->Quit();\n      }));\n  run_loop->Run();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kOnline);\n  // Verify that the user wallpaper info is updated.\n  WallpaperInfo wallpaper_info;\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  WallpaperInfo expected_wallpaper_info(params);\n  EXPECT_EQ(wallpaper_info, expected_wallpaper_info);\n  // Verify that wallpaper & collection metrics are logged.\n  histogram_tester().ExpectBucketCount(\"Ash.Wallpaper.Image\", kUnitId, 1);\n  histogram_tester().ExpectBucketCount(\n      \"Ash.Wallpaper.Collection\",\n      static_cast<int>(base::PersistentHash(\n          TestWallpaperControllerClient::kDummyCollectionId)),\n      1);\n  histogram_tester().ExpectBucketCount(\"Ash.Wallpaper.Type\",\n                                       WallpaperType::kOnline, 1);\n\n  // Verify that the wallpaper with |url| is available offline, and the returned\n  // file name should not contain the small wallpaper suffix.\n  run_loop = std::make_unique<base::RunLoop>();\n  controller_->GetOfflineWallpaperList(base::BindLambdaForTesting(\n      [&run_loop](const std::vector<std::string>& url_list) {\n        EXPECT_EQ(1U, url_list.size());\n        EXPECT_EQ(GURL(kDummyUrl).ExtractFileName(), url_list[0]);\n        run_loop->Quit();\n      }));\n  run_loop->Run();\n}\n\nTEST_F(WallpaperControllerTest, SetAndRemovePolicyWallpaper) {\n  SetBypassDecode();\n  // Simulate the login screen.\n  ClearLogin();\n\n  // The user starts with no wallpaper info and is not controlled by policy.\n  WallpaperInfo wallpaper_info;\n  EXPECT_FALSE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  EXPECT_FALSE(controller_->IsWallpaperControlledByPolicy(account_id_1));\n  // A default wallpaper is shown for the user.\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  EXPECT_EQ(1, GetWallpaperCount());\n  ASSERT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n\n  // Set a policy wallpaper. Verify that the user becomes policy controlled and\n  // the wallpaper info is updated.\n  ClearWallpaperCount();\n  controller_->SetPolicyWallpaper(account_id_1, user_manager::USER_TYPE_REGULAR,\n                                  std::string() /*data=*/);\n  RunAllTasksUntilIdle();\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  WallpaperInfo policy_wallpaper_info(base::FilePath(wallpaper_files_id_1)\n                                          .Append(\"policy-controlled.jpeg\")\n                                          .value(),\n                                      WALLPAPER_LAYOUT_CENTER_CROPPED,\n                                      WallpaperType::kPolicy,\n                                      base::Time::Now().LocalMidnight());\n  EXPECT_EQ(wallpaper_info, policy_wallpaper_info);\n  EXPECT_TRUE(controller_->IsWallpaperControlledByPolicy(account_id_1));\n  // Verify the wallpaper is not updated since the user hasn't logged in.\n  EXPECT_EQ(0, GetWallpaperCount());\n\n  // Log in the user. Verify the policy wallpaper is now being shown.\n  SimulateUserLogin(account_id_1);\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  EXPECT_EQ(1, GetWallpaperCount());\n  ASSERT_EQ(controller_->GetWallpaperType(), WallpaperType::kPolicy);\n\n  // Clear the wallpaper and log out the user. Verify the policy wallpaper is\n  // shown in the login screen.\n  ClearWallpaper();\n  ClearLogin();\n  controller_->ClearPrefChangeObserverForTesting();\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kPolicy);\n  EXPECT_TRUE(controller_->IsWallpaperControlledByPolicy(account_id_1));\n  // Remove the policy wallpaper. Verify the wallpaper info is reset to default\n  // and the user is no longer policy controlled.\n  ClearWallpaperCount();\n  controller_->RemovePolicyWallpaper(account_id_1);\n  WaitUntilCustomWallpapersDeleted(account_id_1);\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  WallpaperInfo default_wallpaper_info(\n      std::string(), WALLPAPER_LAYOUT_CENTER_CROPPED, WallpaperType::kDefault,\n      base::Time::Now().LocalMidnight());\n  EXPECT_EQ(wallpaper_info, default_wallpaper_info);\n  EXPECT_FALSE(controller_->IsWallpaperControlledByPolicy(account_id_1));\n  // Verify the wallpaper is not updated since the user hasn't logged in (to\n  // avoid abrupt wallpaper change in login screen).\n  EXPECT_EQ(0, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kPolicy);\n\n  // Log in the user. Verify the default wallpaper is now being shown.\n  SimulateUserLogin(account_id_1);\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n}\n\n// Simulates the scenario where the wallpaper are not yet resized and only the\n// original size image is available.\nTEST_F(WallpaperControllerTest, ShowUserWallpaper_OriginalFallback) {\n  SetBypassDecode();\n  CreateDefaultWallpapers();\n\n  // Simulate the login screen.\n  ClearLogin();\n\n  // Set a wallpaper.\n  CreateAndSaveWallpapers(account_id_1);\n  RunAllTasksUntilIdle();\n\n  // Verify the wallpaper was set.\n  WallpaperInfo wallpaper_info;\n  ASSERT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  ASSERT_EQ(WallpaperType::kCustomized, wallpaper_info.type);\n  ASSERT_EQ(\"[email protected]/[email protected]\", wallpaper_info.location);\n\n  // Move the wallpaper file to the original folder.\n  base::FilePath saved_wallpaper = custom_wallpaper_dir_.GetPath().Append(\n      \"small/[email protected]/[email protected]\");\n  ASSERT_TRUE(base::PathExists(saved_wallpaper));\n  base::CreateDirectory(\n      WallpaperControllerImpl::GetCustomWallpaperDir(\"original\")\n          .Append(\"[email protected]\"));\n  ASSERT_TRUE(base::PathExists(\n      WallpaperControllerImpl::GetCustomWallpaperDir(\"original\")));\n  ASSERT_TRUE(\n      base::Move(saved_wallpaper,\n                 WallpaperControllerImpl::GetCustomWallpaperDir(\"original\")\n                     .Append(wallpaper_info.location)));\n  ASSERT_FALSE(base::PathExists(saved_wallpaper));\n  ClearDecodeFilePaths();\n\n  // Show wallpaper\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n\n  // Verify the wallpaper was found in the original folder.\n  EXPECT_FALSE(GetDecodeFilePaths().empty());\n  EXPECT_THAT(\n      GetDecodeFilePaths().back().value(),\n      testing::EndsWith(\"original/[email protected]/[email protected]\"));\n}\n\n// Simulates a missing wallpaper due (possibly) an outdated preference. In this\n// situation, we fallback to the default.\nTEST_F(WallpaperControllerTest, ShowUserWallpaper_MissingFile) {\n  CreateDefaultWallpapers();\n\n  // Simulate the login screen.\n  ClearLogin();\n\n  // Set a wallpaper.\n  CreateAndSaveWallpapers(account_id_1);\n  RunAllTasksUntilIdle();\n\n  // Verify the wallpaper was set.\n  WallpaperInfo wallpaper_info;\n  ASSERT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  ASSERT_EQ(WallpaperType::kCustomized, wallpaper_info.type);\n  ASSERT_EQ(\"[email protected]/[email protected]\", wallpaper_info.location);\n\n  // Delete wallpaper file.\n  EXPECT_TRUE(base::DeleteFile(\n      user_data_dir_.GetPath().Append(wallpaper_info.location)));\n  ClearDecodeFilePaths();\n\n  // Show wallpaper\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n\n  // Verify the default wallpaper was used because the stored wallpaper was\n  // missing.\n  EXPECT_FALSE(GetDecodeFilePaths().empty());\n  EXPECT_THAT(GetDecodeFilePaths().back().value(),\n              testing::EndsWith(kDefaultSmallWallpaperName));\n}\n\nTEST_F(WallpaperControllerTest, RemovePolicyWallpaperNoOp) {\n  auto verify_custom_wallpaper_info = [&]() {\n    EXPECT_EQ(WallpaperType::kCustomized, controller_->GetWallpaperType());\n    EXPECT_EQ(kWallpaperColor, GetWallpaperColor());\n\n    WallpaperInfo wallpaper_info;\n    EXPECT_TRUE(\n        pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n    WallpaperInfo expected_wallpaper_info(\n        base::FilePath(wallpaper_files_id_1).Append(file_name_1).value(),\n        WALLPAPER_LAYOUT_CENTER, WallpaperType::kCustomized,\n        base::Time::Now().LocalMidnight());\n    EXPECT_EQ(expected_wallpaper_info, wallpaper_info);\n  };\n\n  // Set a custom wallpaper. Verify the user is not policy controlled and the\n  // wallpaper info is correct.\n  SimulateUserLogin(account_id_1);\n  ClearWallpaperCount();\n  controller_->SetCustomWallpaper(\n      account_id_1, file_name_1, WALLPAPER_LAYOUT_CENTER,\n      CreateImage(640, 480, kWallpaperColor), false /*preview_mode=*/);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_FALSE(controller_->IsWallpaperControlledByPolicy(account_id_1));\n  verify_custom_wallpaper_info();\n\n  // Verify RemovePolicyWallpaper() is a no-op when the user doesn't have a\n  // policy wallpaper.\n  controller_->RemovePolicyWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  verify_custom_wallpaper_info();\n}\n\nTEST_F(WallpaperControllerTest, SetThirdPartyWallpaper) {\n  SetBypassDecode();\n  SimulateUserLogin(account_id_1);\n\n  // Verify the user starts with no wallpaper info.\n  WallpaperInfo wallpaper_info;\n  EXPECT_FALSE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n\n  // Set a third-party wallpaper for |kUser1|.\n  const WallpaperLayout layout = WALLPAPER_LAYOUT_CENTER;\n  gfx::ImageSkia third_party_wallpaper = CreateImage(640, 480, kWallpaperColor);\n  ClearWallpaperCount();\n  EXPECT_TRUE(controller_->SetThirdPartyWallpaper(\n      account_id_1, file_name_1, layout, third_party_wallpaper));\n  RunAllTasksUntilIdle();\n  // Verify the wallpaper is shown.\n  EXPECT_EQ(1, GetWallpaperCount());\n  // Verify the user wallpaper info is updated.\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  WallpaperInfo expected_wallpaper_info(\n      base::FilePath(wallpaper_files_id_1).Append(file_name_1).value(), layout,\n      WallpaperType::kCustomized, base::Time::Now().LocalMidnight());\n  EXPECT_EQ(wallpaper_info, expected_wallpaper_info);\n  EXPECT_EQ(account_id_1, client_.get_save_wallpaper_to_drive_fs_account_id());\n\n  // Switch active user to |kUser2|, but set another third-party wallpaper for\n  // |kUser1|; the operation should not be allowed, because |kUser1| is not the\n  // active user.\n  SimulateUserLogin(account_id_2);\n  ClearWallpaperCount();\n  EXPECT_FALSE(controller_->SetThirdPartyWallpaper(\n      account_id_1, file_name_2, layout, third_party_wallpaper));\n  // Verify the wallpaper is not shown.\n  EXPECT_EQ(0, GetWallpaperCount());\n  // Verify the wallpaper info for |kUser1| is updated, because setting\n  // wallpaper is still allowed for non-active users.\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  WallpaperInfo expected_wallpaper_info_2(\n      base::FilePath(wallpaper_files_id_1).Append(file_name_2).value(), layout,\n      WallpaperType::kCustomized, base::Time::Now().LocalMidnight());\n  EXPECT_EQ(wallpaper_info, expected_wallpaper_info_2);\n\n  // Set a policy wallpaper for |kUser2|. Verify that |kUser2| becomes policy\n  // controlled.\n  controller_->SetPolicyWallpaper(account_id_2, user_manager::USER_TYPE_REGULAR,\n                                  std::string() /*data=*/);\n  RunAllTasksUntilIdle();\n  EXPECT_TRUE(controller_->IsWallpaperControlledByPolicy(account_id_2));\n  EXPECT_TRUE(controller_->IsActiveUserWallpaperControlledByPolicy());\n\n  // Setting a third-party wallpaper for |kUser2| should not be allowed, because\n  // third-party wallpapers cannot be set for policy controlled users.\n  ClearWallpaperCount();\n  EXPECT_FALSE(controller_->SetThirdPartyWallpaper(\n      account_id_2, file_name_1, layout, third_party_wallpaper));\n  // Verify the wallpaper is not shown.\n  EXPECT_EQ(0, GetWallpaperCount());\n  // Verify |kUser2| is still policy controlled and has the policy wallpaper\n  // info.\n  EXPECT_TRUE(controller_->IsWallpaperControlledByPolicy(account_id_2));\n  EXPECT_TRUE(controller_->IsActiveUserWallpaperControlledByPolicy());\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_2, &wallpaper_info));\n  WallpaperInfo policy_wallpaper_info(base::FilePath(wallpaper_files_id_2)\n                                          .Append(\"policy-controlled.jpeg\")\n                                          .value(),\n                                      WALLPAPER_LAYOUT_CENTER_CROPPED,\n                                      WallpaperType::kPolicy,\n                                      base::Time::Now().LocalMidnight());\n  EXPECT_EQ(wallpaper_info, policy_wallpaper_info);\n}\n\nTEST_F(WallpaperControllerTest, SetDefaultWallpaperForRegularAccount) {\n  CreateDefaultWallpapers();\n  SimulateUserLogin(account_id_1);\n\n  // First, simulate setting a user custom wallpaper.\n  SimulateSettingCustomWallpaper(account_id_1);\n  WallpaperInfo wallpaper_info;\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  WallpaperInfo default_wallpaper_info(\n      std::string(), WALLPAPER_LAYOUT_CENTER_CROPPED, WallpaperType::kDefault,\n      base::Time::Now().LocalMidnight());\n  EXPECT_NE(wallpaper_info.type, default_wallpaper_info.type);\n\n  // Verify |SetDefaultWallpaper| removes the previously set custom wallpaper\n  // info, and the large default wallpaper is set successfully with the correct\n  // file path.\n  UpdateDisplay(\"1600x1200\");\n  RunAllTasksUntilIdle();\n  ClearWallpaperCount();\n  ClearDecodeFilePaths();\n  controller_->SetDefaultWallpaper(account_id_1, true /*show_wallpaper=*/,\n                                   base::DoNothing());\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  ASSERT_EQ(1u, GetDecodeFilePaths().size());\n  EXPECT_EQ(default_wallpaper_dir_.GetPath().Append(kDefaultLargeWallpaperName),\n            GetDecodeFilePaths()[0]);\n\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  // The user wallpaper info has been reset to the default value.\n  EXPECT_EQ(wallpaper_info, default_wallpaper_info);\n\n  SimulateSettingCustomWallpaper(account_id_1);\n  // Verify |SetDefaultWallpaper| removes the previously set custom wallpaper\n  // info, and the small default wallpaper is set successfully with the correct\n  // file path.\n  UpdateDisplay(\"800x600\");\n  RunAllTasksUntilIdle();\n  ClearWallpaperCount();\n  ClearDecodeFilePaths();\n  controller_->SetDefaultWallpaper(account_id_1, true /*show_wallpaper=*/,\n                                   base::DoNothing());\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  ASSERT_EQ(1u, GetDecodeFilePaths().size());\n  EXPECT_EQ(default_wallpaper_dir_.GetPath().Append(kDefaultSmallWallpaperName),\n            GetDecodeFilePaths()[0]);\n\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  // The user wallpaper info has been reset to the default value.\n  EXPECT_EQ(wallpaper_info, default_wallpaper_info);\n\n  SimulateSettingCustomWallpaper(account_id_1);\n  // Verify that when screen is rotated, |SetDefaultWallpaper| removes the\n  // previously set custom wallpaper info, and the small default wallpaper is\n  // set successfully with the correct file path.\n  UpdateDisplay(\"800x600/r\");\n  RunAllTasksUntilIdle();\n  ClearWallpaperCount();\n  ClearDecodeFilePaths();\n  controller_->SetDefaultWallpaper(account_id_1, true /*show_wallpaper=*/,\n                                   base::DoNothing());\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  ASSERT_EQ(1u, GetDecodeFilePaths().size());\n  EXPECT_EQ(default_wallpaper_dir_.GetPath().Append(kDefaultSmallWallpaperName),\n            GetDecodeFilePaths()[0]);\n\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  // The user wallpaper info has been reset to the default value.\n  EXPECT_EQ(wallpaper_info, default_wallpaper_info);\n}\n\nTEST_F(WallpaperControllerTest, SetDefaultWallpaperForChildAccount) {\n  CreateDefaultWallpapers();\n\n  SimulateUserLogin(kChildAccountId, user_manager::USER_TYPE_CHILD);\n\n  // Verify the large child wallpaper is set successfully with the correct file\n  // path.\n  UpdateDisplay(\"1600x1200\");\n  RunAllTasksUntilIdle();\n  ClearWallpaperCount();\n  ClearDecodeFilePaths();\n  controller_->SetDefaultWallpaper(kChildAccountId, true /*show_wallpaper=*/,\n                                   base::DoNothing());\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  ASSERT_EQ(1u, GetDecodeFilePaths().size());\n  EXPECT_EQ(default_wallpaper_dir_.GetPath().Append(kChildLargeWallpaperName),\n            GetDecodeFilePaths()[0]);\n\n  // Verify the small child wallpaper is set successfully with the correct file\n  // path.\n  UpdateDisplay(\"800x600\");\n  RunAllTasksUntilIdle();\n  ClearWallpaperCount();\n  ClearDecodeFilePaths();\n  controller_->SetDefaultWallpaper(kChildAccountId, true /*show_wallpaper=*/,\n                                   base::DoNothing());\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  ASSERT_EQ(1u, GetDecodeFilePaths().size());\n  EXPECT_EQ(default_wallpaper_dir_.GetPath().Append(kChildSmallWallpaperName),\n            GetDecodeFilePaths()[0]);\n}\n\n// Verify that the |ShowWallpaperImage| will be called with the default image\n// for the guest session only even if there's a policy that has been set for\n// another user which invokes |SetPolicyWallpaper|.\nTEST_F(WallpaperControllerTest,\n       SetDefaultWallpaperForGuestSessionUnaffectedByWallpaperPolicy) {\n  SetBypassDecode();\n  // Simulate the login screen.\n  ClearLogin();\n  CreateDefaultWallpapers();\n  ClearWallpaperCount();\n\n  // First, simulate settings for a guest user which will show the default\n  // wallpaper image by invoking |ShowWallpaperImage|.\n  SimulateGuestLogin();\n\n  UpdateDisplay(\"1600x1200\");\n  RunAllTasksUntilIdle();\n  ClearWallpaperCount();\n  ClearDecodeFilePaths();\n\n  const AccountId guest_id =\n      AccountId::FromUserEmail(user_manager::kGuestUserName);\n  SimulateUserLogin(guest_id, user_manager::USER_TYPE_GUEST);\n  controller_->SetDefaultWallpaper(guest_id, /*show_wallpaper=*/true,\n                                   base::DoNothing());\n\n  WallpaperInfo wallpaper_info;\n  WallpaperInfo default_wallpaper_info(\n      std::string(), WALLPAPER_LAYOUT_CENTER_CROPPED, WallpaperType::kDefault,\n      base::Time::Now().LocalMidnight());\n  // Verify that the current displayed wallpaper is the default one inside the\n  // guest session.\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  EXPECT_TRUE(pref_manager_->GetUserWallpaperInfo(guest_id, &wallpaper_info));\n  EXPECT_EQ(wallpaper_info, default_wallpaper_info);\n  ASSERT_EQ(1u, GetDecodeFilePaths().size());\n  EXPECT_EQ(default_wallpaper_dir_.GetPath().Append(kGuestLargeWallpaperName),\n            GetDecodeFilePaths()[0]);\n\n  // Second, set a user policy for which is being set for another\n  // user and verifying that the policy has been applied successfully.\n  WallpaperInfo policy_wallpaper_info;\n  controller_->SetPolicyWallpaper(account_id_1, user_manager::USER_TYPE_REGULAR,\n                                  /*data=*/std::string());\n  EXPECT_TRUE(pref_manager_->GetUserWallpaperInfo(account_id_1,\n                                                  &policy_wallpaper_info));\n  WallpaperInfo expected_policy_wallpaper_info(\n      base::FilePath(wallpaper_files_id_1)\n          .Append(\"policy-controlled.jpeg\")\n          .value(),\n      WALLPAPER_LAYOUT_CENTER_CROPPED, WallpaperType::kPolicy,\n      base::Time::Now().LocalMidnight());\n  EXPECT_EQ(policy_wallpaper_info, expected_policy_wallpaper_info);\n  EXPECT_TRUE(controller_->IsWallpaperControlledByPolicy(account_id_1));\n\n  // Finally, verifying that the guest session hasn't been affected by the new\n  // policy and |ShowWallpaperImage| hasn't been invoked another time.\n\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  EXPECT_TRUE(pref_manager_->GetUserWallpaperInfo(guest_id, &wallpaper_info));\n  EXPECT_EQ(wallpaper_info, default_wallpaper_info);\n  ASSERT_EQ(1u, GetDecodeFilePaths().size());\n  EXPECT_EQ(default_wallpaper_dir_.GetPath().Append(kGuestLargeWallpaperName),\n            GetDecodeFilePaths()[0]);\n}\n\nTEST_F(WallpaperControllerTest, SetDefaultWallpaperForGuestSession) {\n  CreateDefaultWallpapers();\n\n  // First, simulate setting a custom wallpaper for a regular user.\n  SimulateUserLogin(account_id_1);\n  SimulateSettingCustomWallpaper(account_id_1);\n  WallpaperInfo wallpaper_info;\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  WallpaperInfo default_wallpaper_info(\n      std::string(), WALLPAPER_LAYOUT_CENTER_CROPPED, WallpaperType::kDefault,\n      base::Time::Now().LocalMidnight());\n  EXPECT_NE(wallpaper_info.type, default_wallpaper_info.type);\n\n  const AccountId guest_id =\n      AccountId::FromUserEmail(user_manager::kGuestUserName);\n  SimulateUserLogin(guest_id, user_manager::USER_TYPE_GUEST);\n\n  // Verify that during a guest session, |SetDefaultWallpaper| removes the user\n  // custom wallpaper info, but a guest specific wallpaper should be set,\n  // instead of the regular default wallpaper.\n  UpdateDisplay(\"1600x1200\");\n  RunAllTasksUntilIdle();\n  ClearWallpaperCount();\n  ClearDecodeFilePaths();\n  controller_->SetDefaultWallpaper(guest_id, true /*show_wallpaper=*/,\n                                   base::DoNothing());\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  EXPECT_TRUE(pref_manager_->GetUserWallpaperInfo(guest_id, &wallpaper_info));\n  EXPECT_EQ(wallpaper_info, default_wallpaper_info);\n  ASSERT_EQ(1u, GetDecodeFilePaths().size());\n  EXPECT_EQ(default_wallpaper_dir_.GetPath().Append(kGuestLargeWallpaperName),\n            GetDecodeFilePaths()[0]);\n\n  UpdateDisplay(\"800x600\");\n  RunAllTasksUntilIdle();\n  ClearWallpaperCount();\n  ClearDecodeFilePaths();\n  controller_->SetDefaultWallpaper(guest_id, true /*show_wallpaper=*/,\n                                   base::DoNothing());\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  ASSERT_EQ(1u, GetDecodeFilePaths().size());\n  EXPECT_EQ(default_wallpaper_dir_.GetPath().Append(kGuestSmallWallpaperName),\n            GetDecodeFilePaths()[0]);\n}\n\nTEST_F(WallpaperControllerTest, SetDefaultWallpaperCallbackTiming) {\n  SetBypassDecode();\n  SimulateUserLogin(account_id_1);\n\n  // First, simulate setting a user custom wallpaper.\n  SimulateSettingCustomWallpaper(account_id_1);\n  WallpaperInfo wallpaper_info;\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  EXPECT_NE(wallpaper_info.type, WallpaperType::kDefault);\n\n  TestWallpaperControllerObserver observer(controller_);\n\n  // Set default wallpaper and wait for success callback.\n  base::RunLoop loop;\n  controller_->SetDefaultWallpaper(\n      account_id_1, /*show_wallpaper=*/true,\n      base::BindLambdaForTesting([&loop, &observer](bool success) {\n        ASSERT_TRUE(success);\n        // Success callback should run before wallpaper observer is notified of\n        // change.\n        ASSERT_EQ(0, observer.wallpaper_changed_count());\n        loop.Quit();\n      }));\n  loop.Run();\n  // Wallpaper observer should have been notified of wallpaper change.\n  EXPECT_EQ(1, observer.wallpaper_changed_count());\n}\n\nTEST_F(WallpaperControllerTest, IgnoreWallpaperRequestInKioskMode) {\n  gfx::ImageSkia image = CreateImage(640, 480, kWallpaperColor);\n  SimulateUserLogin(\"kiosk\", user_manager::USER_TYPE_KIOSK_APP);\n\n  // Verify that |SetCustomWallpaper| doesn't set wallpaper in kiosk mode, and\n  // |account_id_1|'s wallpaper info is not updated.\n  ClearWallpaperCount();\n  controller_->SetCustomWallpaper(account_id_1, file_name_1,\n                                  WALLPAPER_LAYOUT_CENTER, image,\n                                  false /*preview_mode=*/);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(0, GetWallpaperCount());\n  WallpaperInfo wallpaper_info;\n  EXPECT_FALSE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n\n  // Verify that |SetOnlineWallpaperFromData| doesn't set wallpaper in kiosk\n  // mode, and |account_id_1|'s wallpaper info is not updated.\n  std::unique_ptr<base::RunLoop> run_loop = std::make_unique<base::RunLoop>();\n  ClearWallpaperCount();\n  controller_->SetOnlineWallpaperFromData(\n      OnlineWallpaperParams(account_id_1, kAssetId, GURL(kDummyUrl),\n                            /*collection_id=*/std::string(),\n                            WALLPAPER_LAYOUT_CENTER,\n                            /*preview_mode=*/false, /*from_user=*/false,\n                            /*daily_refresh_enabled=*/false, kUnitId,\n                            /*variants=*/std::vector<OnlineWallpaperVariant>()),\n      /*image_data=*/std::string(),\n      base::BindLambdaForTesting([&run_loop](bool success) {\n        EXPECT_FALSE(success);\n        run_loop->Quit();\n      }));\n  run_loop->Run();\n  EXPECT_EQ(0, GetWallpaperCount());\n  EXPECT_FALSE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n\n  // Verify that |SetDefaultWallpaper| doesn't set wallpaper in kiosk mode, and\n  // |account_id_1|'s wallpaper info is not updated.\n  ClearWallpaperCount();\n  controller_->SetDefaultWallpaper(account_id_1, true /*show_wallpaper=*/,\n                                   base::DoNothing());\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(0, GetWallpaperCount());\n  EXPECT_FALSE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n}\n\n// Disable the wallpaper setting for public session since it is ephemeral.\nTEST_F(WallpaperControllerTest, NotShowWallpaperSettingInPublicSession) {\n  SimulateUserLogin(\"public_session\", user_manager::USER_TYPE_PUBLIC_ACCOUNT);\n  EXPECT_FALSE(controller_->ShouldShowWallpaperSetting());\n}\n\nTEST_F(WallpaperControllerTest, IgnoreWallpaperRequestWhenPolicyIsEnforced) {\n  SetBypassDecode();\n  gfx::ImageSkia image = CreateImage(640, 480, kWallpaperColor);\n  SimulateUserLogin(account_id_1);\n\n  // Set a policy wallpaper for the user. Verify the user is policy controlled.\n  controller_->SetPolicyWallpaper(account_id_1, user_manager::USER_TYPE_REGULAR,\n                                  std::string() /*data=*/);\n  RunAllTasksUntilIdle();\n  EXPECT_TRUE(controller_->IsWallpaperControlledByPolicy(account_id_1));\n\n  WallpaperInfo wallpaper_info;\n  WallpaperInfo policy_wallpaper_info(base::FilePath(wallpaper_files_id_1)\n                                          .Append(\"policy-controlled.jpeg\")\n                                          .value(),\n                                      WALLPAPER_LAYOUT_CENTER_CROPPED,\n                                      WallpaperType::kPolicy,\n                                      base::Time::Now().LocalMidnight());\n\n  {\n    // Verify that |SetCustomWallpaper| doesn't set wallpaper when policy is\n    // enforced, and the user wallpaper info is not updated.\n    ClearWallpaperCount();\n    controller_->SetCustomWallpaper(account_id_1, file_name_1,\n                                    WALLPAPER_LAYOUT_CENTER, image,\n                                    false /*preview_mode=*/);\n    RunAllTasksUntilIdle();\n    EXPECT_EQ(0, GetWallpaperCount());\n    EXPECT_TRUE(\n        pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n    EXPECT_EQ(wallpaper_info, policy_wallpaper_info);\n  }\n\n  {\n    // Verify that |SetCustomWallpaper| with callback doesn't set wallpaper when\n    // policy is enforced, and the user wallpaper info is not updated.\n    std::unique_ptr<base::RunLoop> run_loop = std::make_unique<base::RunLoop>();\n    ClearWallpaperCount();\n    controller_->SetCustomWallpaper(\n        account_id_1, base::FilePath(file_name_1), WALLPAPER_LAYOUT_CENTER,\n        /*preview_mode=*/false,\n        base::BindLambdaForTesting([&run_loop](bool success) {\n          EXPECT_FALSE(success);\n          run_loop->Quit();\n        }));\n    run_loop->Run();\n    EXPECT_EQ(0, GetWallpaperCount());\n    EXPECT_TRUE(\n        pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n    EXPECT_EQ(wallpaper_info, policy_wallpaper_info);\n  }\n\n  {\n    // Verify that |SetOnlineWallpaperFromData| doesn't set wallpaper when\n    // policy is enforced, and the user wallpaper info is not updated.\n    std::unique_ptr<base::RunLoop> run_loop = std::make_unique<base::RunLoop>();\n    ClearWallpaperCount();\n    controller_->SetOnlineWallpaperFromData(\n        OnlineWallpaperParams(\n            account_id_1, kAssetId, GURL(kDummyUrl),\n            /*collection_id=*/std::string(), WALLPAPER_LAYOUT_CENTER_CROPPED,\n            /*preview_mode=*/false, /*from_user=*/false,\n            /*daily_refresh_enabled=*/false, kUnitId,\n            /*variants=*/std::vector<OnlineWallpaperVariant>()),\n        /*image_data=*/std::string(),\n        base::BindLambdaForTesting([&run_loop](bool success) {\n          EXPECT_FALSE(success);\n          run_loop->Quit();\n        }));\n    run_loop->Run();\n    EXPECT_EQ(0, GetWallpaperCount());\n    EXPECT_TRUE(\n        pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n    EXPECT_EQ(wallpaper_info, policy_wallpaper_info);\n  }\n\n  {\n    // Verify that |SetOnlineWallpaper| doesn't set wallpaper when policy is\n    // enforced, and the user wallpaper info is not updated.\n    std::unique_ptr<base::RunLoop> run_loop = std::make_unique<base::RunLoop>();\n    ClearWallpaperCount();\n    controller_->SetOnlineWallpaper(\n        OnlineWallpaperParams(\n            account_id_1, kAssetId, GURL(kDummyUrl),\n            /*collection_id=*/std::string(), WALLPAPER_LAYOUT_CENTER_CROPPED,\n            /*preview_mode=*/false, /*from_user=*/false,\n            /*daily_refresh_enabled=*/false, kUnitId,\n            /*variants=*/std::vector<OnlineWallpaperVariant>()),\n        base::BindLambdaForTesting([&run_loop](bool success) {\n          EXPECT_FALSE(success);\n          run_loop->Quit();\n        }));\n    run_loop->Run();\n    EXPECT_EQ(0, GetWallpaperCount());\n    EXPECT_TRUE(\n        pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n    EXPECT_EQ(wallpaper_info, policy_wallpaper_info);\n  }\n\n  {\n    // Verify that |SetDefaultWallpaper| doesn't set wallpaper when policy is\n    // enforced, and the user wallpaper info is not updated.\n    ClearWallpaperCount();\n    controller_->SetDefaultWallpaper(account_id_1, true /*show_wallpaper=*/,\n                                     base::DoNothing());\n    RunAllTasksUntilIdle();\n    EXPECT_EQ(0, GetWallpaperCount());\n    EXPECT_TRUE(\n        pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n    EXPECT_EQ(wallpaper_info, policy_wallpaper_info);\n  }\n}\n\nTEST_F(WallpaperControllerTest, VerifyWallpaperCache) {\n  SetBypassDecode();\n  gfx::ImageSkia image = CreateImage(640, 480, kWallpaperColor);\n  SimulateUserLogin(account_id_1);\n\n  // |kUser1| doesn't have wallpaper cache in the beginning.\n  gfx::ImageSkia cached_wallpaper;\n  EXPECT_FALSE(\n      controller_->GetWallpaperFromCache(account_id_1, &cached_wallpaper));\n  base::FilePath path;\n  EXPECT_FALSE(controller_->GetPathFromCache(account_id_1, &path));\n\n  // Verify |SetOnlineWallpaperFromData| updates wallpaper cache for |user1|.\n  controller_->SetOnlineWallpaperFromData(\n      OnlineWallpaperParams(account_id_1, kAssetId, GURL(kDummyUrl),\n                            /*collection_id=*/std::string(),\n                            WALLPAPER_LAYOUT_CENTER,\n                            /*preview_mode=*/false, /*from_user=*/false,\n                            /*daily_refresh_enabled=*/false, kUnitId,\n                            /*variants=*/std::vector<OnlineWallpaperVariant>()),\n      /*image_data=*/std::string(),\n      WallpaperController::SetWallpaperCallback());\n  RunAllTasksUntilIdle();\n  EXPECT_TRUE(\n      controller_->GetWallpaperFromCache(account_id_1, &cached_wallpaper));\n  EXPECT_TRUE(controller_->GetPathFromCache(account_id_1, &path));\n\n  // After |kUser2| is logged in, |user1|'s wallpaper cache should still be kept\n  // (crbug.com/339576). Note the active user is still |user1|.\n  TestSessionControllerClient* session = GetSessionControllerClient();\n  session->AddUserSession(kUser2);\n  EXPECT_TRUE(\n      controller_->GetWallpaperFromCache(account_id_1, &cached_wallpaper));\n  EXPECT_TRUE(controller_->GetPathFromCache(account_id_1, &path));\n\n  // Verify |SetDefaultWallpaper| clears wallpaper cache.\n  controller_->SetDefaultWallpaper(account_id_1, true /*show_wallpaper=*/,\n                                   base::DoNothing());\n  EXPECT_FALSE(\n      controller_->GetWallpaperFromCache(account_id_1, &cached_wallpaper));\n  EXPECT_FALSE(controller_->GetPathFromCache(account_id_1, &path));\n\n  // Verify |SetCustomWallpaper| updates wallpaper cache for |user1|.\n  controller_->SetCustomWallpaper(account_id_1, file_name_1,\n                                  WALLPAPER_LAYOUT_CENTER, image,\n                                  false /*preview_mode=*/);\n  RunAllTasksUntilIdle();\n  EXPECT_TRUE(\n      controller_->GetWallpaperFromCache(account_id_1, &cached_wallpaper));\n  EXPECT_TRUE(controller_->GetPathFromCache(account_id_1, &path));\n\n  // Verify |RemoveUserWallpaper| clears wallpaper cache.\n  controller_->RemoveUserWallpaper(account_id_1);\n  EXPECT_FALSE(\n      controller_->GetWallpaperFromCache(account_id_1, &cached_wallpaper));\n  EXPECT_FALSE(controller_->GetPathFromCache(account_id_1, &path));\n}\n\n// Tests that the appropriate wallpaper (large vs. small) is shown depending\n// on the desktop resolution.\nTEST_F(WallpaperControllerTest, ShowCustomWallpaperWithCorrectResolution) {\n  CreateDefaultWallpapers();\n  const base::FilePath small_custom_wallpaper_path =\n      GetCustomWallpaperPath(WallpaperControllerImpl::kSmallWallpaperSubDir,\n                             wallpaper_files_id_1, file_name_1);\n  const base::FilePath large_custom_wallpaper_path =\n      GetCustomWallpaperPath(WallpaperControllerImpl::kLargeWallpaperSubDir,\n                             wallpaper_files_id_1, file_name_1);\n  const base::FilePath small_default_wallpaper_path =\n      default_wallpaper_dir_.GetPath().Append(kDefaultSmallWallpaperName);\n  const base::FilePath large_default_wallpaper_path =\n      default_wallpaper_dir_.GetPath().Append(kDefaultLargeWallpaperName);\n\n  CreateAndSaveWallpapers(account_id_1);\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  // Display is initialized to 800x600. The small resolution custom wallpaper is\n  // expected. A second decode request with small resolution default wallpaper\n  // is also expected. (Because unit tests don't support actual wallpaper\n  // decoding, it falls back to the default wallpaper.)\n  EXPECT_EQ(1, GetWallpaperCount());\n  ASSERT_EQ(2u, GetDecodeFilePaths().size());\n  EXPECT_EQ(small_custom_wallpaper_path, GetDecodeFilePaths()[0]);\n  EXPECT_EQ(small_default_wallpaper_path, GetDecodeFilePaths()[1]);\n\n  // Hook up another 800x600 display. This shouldn't trigger a reload.\n  ClearWallpaperCount();\n  ClearDecodeFilePaths();\n  UpdateDisplay(\"800x600,800x600\");\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(0, GetWallpaperCount());\n  EXPECT_EQ(0u, GetDecodeFilePaths().size());\n\n  // Detach the secondary display.\n  UpdateDisplay(\"800x600\");\n  RunAllTasksUntilIdle();\n  // Hook up a 2000x2000 display. The large resolution custom wallpaper should\n  // be loaded.\n  ClearWallpaperCount();\n  ClearDecodeFilePaths();\n  UpdateDisplay(\"800x600,3000x2000\");\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  ASSERT_EQ(2u, GetDecodeFilePaths().size());\n  EXPECT_EQ(large_custom_wallpaper_path, GetDecodeFilePaths()[0]);\n  EXPECT_EQ(large_default_wallpaper_path, GetDecodeFilePaths()[1]);\n\n  // Detach the secondary display.\n  UpdateDisplay(\"800x600\");\n  RunAllTasksUntilIdle();\n  // Hook up the 3000x2000 display again. The large resolution default wallpaper\n  // should persist. Test for crbug/165788.\n  ClearWallpaperCount();\n  ClearDecodeFilePaths();\n  UpdateDisplay(\"800x600,3000x2000\");\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  ASSERT_EQ(2u, GetDecodeFilePaths().size());\n  EXPECT_EQ(large_custom_wallpaper_path, GetDecodeFilePaths()[0]);\n  EXPECT_EQ(large_default_wallpaper_path, GetDecodeFilePaths()[1]);\n}\n\n// After the display is rotated, the sign in wallpaper should be kept. Test for\n// crbug.com/794725.\nTEST_F(WallpaperControllerTest, SigninWallpaperIsKeptAfterRotation) {\n  CreateDefaultWallpapers();\n\n  UpdateDisplay(\"800x600\");\n  RunAllTasksUntilIdle();\n  controller_->ShowSigninWallpaper();\n  RunAllTasksUntilIdle();\n  // Display is initialized to 800x600. The small resolution default wallpaper\n  // is expected.\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  ASSERT_EQ(1u, GetDecodeFilePaths().size());\n  EXPECT_EQ(default_wallpaper_dir_.GetPath().Append(kDefaultSmallWallpaperName),\n            GetDecodeFilePaths()[0]);\n\n  ClearWallpaperCount();\n  ClearDecodeFilePaths();\n  // After rotating the display, the small resolution default wallpaper should\n  // still be expected, instead of a custom wallpaper.\n  UpdateDisplay(\"800x600/r\");\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  ASSERT_EQ(1u, GetDecodeFilePaths().size());\n  EXPECT_EQ(default_wallpaper_dir_.GetPath().Append(kDefaultSmallWallpaperName),\n            GetDecodeFilePaths()[0]);\n}\n\n// Display size change should trigger wallpaper reload.\nTEST_F(WallpaperControllerTest, ReloadWallpaper) {\n  CreateAndSaveWallpapers(account_id_1);\n\n  // Show a user wallpaper.\n  UpdateDisplay(\"800x600\");\n  RunAllTasksUntilIdle();\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  // Rotating the display should trigger a wallpaper reload.\n  ClearWallpaperCount();\n  UpdateDisplay(\"800x600/r\");\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  // Calling |ShowUserWallpaper| again with the same account id and display\n  // size should not trigger wallpaper reload (crbug.com/158383).\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(0, GetWallpaperCount());\n\n  // Start wallpaper preview.\n  SimulateUserLogin(account_id_1);\n  std::unique_ptr<aura::Window> wallpaper_picker_window(\n      CreateTestWindow(gfx::Rect(0, 0, 100, 100)));\n  WindowState::Get(wallpaper_picker_window.get())->Activate();\n  ClearWallpaperCount();\n  controller_->SetCustomWallpaper(\n      account_id_1, file_name_1, WALLPAPER_LAYOUT_CENTER,\n      CreateImage(640, 480, kWallpaperColor), true /*preview_mode=*/);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  // Rotating the display should trigger a wallpaper reload.\n  ClearWallpaperCount();\n  UpdateDisplay(\"800x600\");\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  ClearWallpaperCount();\n  controller_->CancelPreviewWallpaper();\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n\n  // Show an always-on-top wallpaper.\n  const base::FilePath image_path =\n      base::CommandLine::ForCurrentProcess()->GetSwitchValuePath(\n          switches::kGuestWallpaperLarge);\n  CreateDefaultWallpapers();\n  SetBypassDecode();\n  ClearWallpaperCount();\n  controller_->ShowAlwaysOnTopWallpaper(image_path);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  // Rotating the display should trigger a wallpaper reload.\n  ClearWallpaperCount();\n  UpdateDisplay(\"800x600/r\");\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n}\n\nTEST_F(WallpaperControllerTest, UpdateCurrentWallpaperLayout) {\n  SetBypassDecode();\n  gfx::ImageSkia image = CreateImage(640, 480, kSmallCustomWallpaperColor);\n  WallpaperLayout layout = WALLPAPER_LAYOUT_STRETCH;\n  WallpaperLayout new_layout = WALLPAPER_LAYOUT_CENTER;\n  SimulateUserLogin(account_id_1);\n\n  // Set a custom wallpaper for the user. Verify that it's set successfully\n  // and the wallpaper info is updated.\n  ClearWallpaperCount();\n  controller_->SetCustomWallpaper(account_id_1, file_name_1, layout, image,\n                                  false /*preview_mode=*/);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperLayout(), layout);\n  WallpaperInfo wallpaper_info;\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  WallpaperInfo expected_custom_wallpaper_info(\n      base::FilePath(wallpaper_files_id_1).Append(file_name_1).value(), layout,\n      WallpaperType::kCustomized, base::Time::Now().LocalMidnight());\n  EXPECT_EQ(wallpaper_info, expected_custom_wallpaper_info);\n\n  // Now change to a different layout. Verify that the layout is updated for\n  // both the current wallpaper and the saved wallpaper info.\n  ClearWallpaperCount();\n  controller_->UpdateCurrentWallpaperLayout(account_id_1, new_layout);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperLayout(), new_layout);\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  expected_custom_wallpaper_info.layout = new_layout;\n  EXPECT_EQ(wallpaper_info, expected_custom_wallpaper_info);\n\n  {\n    base::test::ScopedFeatureList scoped_feature_list;\n    scoped_feature_list.InitWithFeatures(\n        {ash::features::kWallpaperGooglePhotosIntegration}, {});\n\n    // Now set a Google Photos wallpaper. Verify that it's set successfully and\n    // the wallpaper info is updated.\n    ClearWallpaperCount();\n    controller_->SetGooglePhotosWallpaper(\n        GooglePhotosWallpaperParams(account_id_1, \"id\",\n                                    /*daily_refresh_enabled=*/false, layout,\n                                    /*preview_mode=*/false, \"dedup_key\"),\n        base::DoNothing());\n    RunAllTasksUntilIdle();\n    EXPECT_EQ(1, GetWallpaperCount());\n    EXPECT_EQ(controller_->GetWallpaperType(),\n              WallpaperType::kOnceGooglePhotos);\n    EXPECT_EQ(controller_->GetWallpaperLayout(), layout);\n    EXPECT_TRUE(\n        pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n    EXPECT_EQ(wallpaper_info,\n              WallpaperInfo(GooglePhotosWallpaperParams(\n                  account_id_1, \"id\", /*daily_refresh_enabled=*/false, layout,\n                  /*preview_mode=*/false, \"dedup_key\")));\n\n    // Now change to a different layout. Verify that the layout is updated for\n    // both the current wallpaper and the saved wallpaper info.\n    ClearWallpaperCount();\n    controller_->UpdateCurrentWallpaperLayout(account_id_1, new_layout);\n    RunAllTasksUntilIdle();\n    EXPECT_EQ(1, GetWallpaperCount());\n    EXPECT_EQ(controller_->GetWallpaperLayout(), new_layout);\n    EXPECT_TRUE(\n        pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n    EXPECT_EQ(wallpaper_info,\n              WallpaperInfo(GooglePhotosWallpaperParams(\n                  account_id_1, \"id\", /*daily_refresh_enabled=*/false,\n                  new_layout, /*preview_mode=*/false, \"dedup_key\")));\n  }\n\n  // Now set an online wallpaper. Verify that it's set successfully and the\n  // wallpaper info is updated.\n  image = CreateImage(640, 480, kWallpaperColor);\n  ClearWallpaperCount();\n  const OnlineWallpaperParams& params =\n      OnlineWallpaperParams(account_id_1, kAssetId, GURL(kDummyUrl),\n                            /*collection_id=*/std::string(), layout,\n                            /*preview_mode=*/false, /*from_user=*/false,\n                            /*daily_refresh_enabled=*/false, kUnitId,\n                            /*variants=*/std::vector<OnlineWallpaperVariant>());\n  controller_->SetOnlineWallpaperFromData(\n      params,\n      /*image_data=*/std::string(),\n      WallpaperController::SetWallpaperCallback());\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kOnline);\n  EXPECT_EQ(controller_->GetWallpaperLayout(), layout);\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  WallpaperInfo expected_online_wallpaper_info(params);\n  EXPECT_EQ(wallpaper_info, expected_online_wallpaper_info);\n\n  // Now change the layout of the online wallpaper. Verify that it's a no-op.\n  ClearWallpaperCount();\n  controller_->UpdateCurrentWallpaperLayout(account_id_1, new_layout);\n  RunAllTasksUntilIdle();\n  // The wallpaper is not updated.\n  EXPECT_EQ(0, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperLayout(), layout);\n  // The saved wallpaper info is not updated.\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  EXPECT_EQ(wallpaper_info, expected_online_wallpaper_info);\n}\n\n// Tests that if a user who has a custom wallpaper is removed from the device,\n// only the directory that contains the user's custom wallpapers gets removed.\n// The other user's custom wallpaper is not affected.\nTEST_F(WallpaperControllerTest, RemoveUserWithCustomWallpaper) {\n  SimulateUserLogin(account_id_1);\n  base::FilePath small_wallpaper_path_1 =\n      GetCustomWallpaperPath(WallpaperControllerImpl::kSmallWallpaperSubDir,\n                             wallpaper_files_id_1, file_name_1);\n\n  // Set a custom wallpaper for |kUser1| and verify the wallpaper exists.\n  CreateAndSaveWallpapers(account_id_1);\n  EXPECT_TRUE(base::PathExists(small_wallpaper_path_1));\n\n  // Now login another user and set a custom wallpaper for the user.\n  SimulateUserLogin(account_id_2);\n  base::FilePath small_wallpaper_path_2 = GetCustomWallpaperPath(\n      WallpaperControllerImpl::kSmallWallpaperSubDir, wallpaper_files_id_2,\n      GetDummyFileName(account_id_2));\n  CreateAndSaveWallpapers(account_id_2);\n  EXPECT_TRUE(base::PathExists(small_wallpaper_path_2));\n\n  // Simulate the removal of |kUser2|.\n  controller_->RemoveUserWallpaper(account_id_2);\n  // Wait until all files under the user's custom wallpaper directory are\n  // removed.\n  WaitUntilCustomWallpapersDeleted(account_id_2);\n  EXPECT_FALSE(base::PathExists(small_wallpaper_path_2));\n\n  // Verify that the other user's wallpaper is not affected.\n  EXPECT_TRUE(base::PathExists(small_wallpaper_path_1));\n}\n\n// Tests that if a user who has a default wallpaper is removed from the device,\n// the other user's custom wallpaper is not affected.\nTEST_F(WallpaperControllerTest, RemoveUserWithDefaultWallpaper) {\n  SimulateUserLogin(account_id_1);\n  base::FilePath small_wallpaper_path_1 =\n      GetCustomWallpaperPath(WallpaperControllerImpl::kSmallWallpaperSubDir,\n                             wallpaper_files_id_1, file_name_1);\n  // Set a custom wallpaper for |kUser1| and verify the wallpaper exists.\n  CreateAndSaveWallpapers(account_id_1);\n  EXPECT_TRUE(base::PathExists(small_wallpaper_path_1));\n\n  // Now login another user and set a default wallpaper for the user.\n  SimulateUserLogin(account_id_2);\n  controller_->SetDefaultWallpaper(account_id_2, true /*show_wallpaper=*/,\n                                   base::DoNothing());\n\n  // Simulate the removal of |kUser2|.\n  controller_->RemoveUserWallpaper(account_id_2);\n\n  // Verify that the other user's wallpaper is not affected.\n  EXPECT_TRUE(base::PathExists(small_wallpaper_path_1));\n}\n\nTEST_F(WallpaperControllerTest, IsActiveUserWallpaperControlledByPolicy) {\n  SetBypassDecode();\n  // Simulate the login screen. Verify that it returns false since there's no\n  // active user.\n  ClearLogin();\n  EXPECT_FALSE(controller_->IsActiveUserWallpaperControlledByPolicy());\n\n  SimulateUserLogin(account_id_1);\n  EXPECT_FALSE(controller_->IsActiveUserWallpaperControlledByPolicy());\n  // Set a policy wallpaper for the active user. Verify that the active user\n  // becomes policy controlled.\n  controller_->SetPolicyWallpaper(account_id_1, user_manager::USER_TYPE_REGULAR,\n                                  std::string() /*data=*/);\n  RunAllTasksUntilIdle();\n  EXPECT_TRUE(controller_->IsActiveUserWallpaperControlledByPolicy());\n\n  // Switch the active user. Verify the active user is not policy controlled.\n  SimulateUserLogin(account_id_2);\n  EXPECT_FALSE(controller_->IsActiveUserWallpaperControlledByPolicy());\n\n  // Logs out. Verify that it returns false since there's no active user.\n  ClearLogin();\n  EXPECT_FALSE(controller_->IsActiveUserWallpaperControlledByPolicy());\n}\n\nTEST_F(WallpaperControllerTest,\n       IsManagedGuestSessionWallpaperControlledByPolicy) {\n  SetBypassDecode();\n  // Simulate the login screen. Verify that it returns false since there's no\n  // active user.\n  ClearLogin();\n  EXPECT_FALSE(controller_->IsActiveUserWallpaperControlledByPolicy());\n\n  // Set a policy wallpaper for the managed guest session. Verify that the\n  // managed guest session becomes policy controlled.\n  controller_->SetPolicyWallpaper(account_id_1,\n                                  user_manager::USER_TYPE_PUBLIC_ACCOUNT,\n                                  std::string() /*data=*/);\n  SimulateUserLogin(account_id_1, user_manager::USER_TYPE_PUBLIC_ACCOUNT);\n  RunAllTasksUntilIdle();\n  EXPECT_TRUE(controller_->IsWallpaperControlledByPolicy(account_id_1));\n\n  // Verify the wallpaper policy is applied after logging in.\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  EXPECT_EQ(1, GetWallpaperCount());\n  ASSERT_EQ(controller_->GetWallpaperType(), WallpaperType::kPolicy);\n\n  // Switch the active user. Verify the active user is not policy controlled.\n  SimulateUserLogin(account_id_2);\n  EXPECT_FALSE(controller_->IsActiveUserWallpaperControlledByPolicy());\n\n  // Logs out. Verify that it returns false since there's no active user.\n  ClearLogin();\n  EXPECT_FALSE(controller_->IsActiveUserWallpaperControlledByPolicy());\n}\n\nTEST_F(WallpaperControllerTest, WallpaperBlur) {\n  TestWallpaperControllerObserver observer(controller_);\n\n  ASSERT_TRUE(controller_->IsBlurAllowedForLockState());\n  ASSERT_FALSE(controller_->IsWallpaperBlurredForLockState());\n\n  SetSessionState(SessionState::ACTIVE);\n  EXPECT_FALSE(controller_->IsWallpaperBlurredForLockState());\n  EXPECT_EQ(0, observer.blur_changed_count());\n\n  SetSessionState(SessionState::LOCKED);\n  EXPECT_TRUE(controller_->IsWallpaperBlurredForLockState());\n  EXPECT_EQ(1, observer.blur_changed_count());\n\n  SetSessionState(SessionState::LOGGED_IN_NOT_ACTIVE);\n  EXPECT_FALSE(controller_->IsWallpaperBlurredForLockState());\n  EXPECT_EQ(2, observer.blur_changed_count());\n\n  SetSessionState(SessionState::LOGIN_SECONDARY);\n  EXPECT_TRUE(controller_->IsWallpaperBlurredForLockState());\n  EXPECT_EQ(3, observer.blur_changed_count());\n\n  // Blur state does not change below.\n  SetSessionState(SessionState::LOGIN_PRIMARY);\n  EXPECT_TRUE(controller_->IsWallpaperBlurredForLockState());\n  EXPECT_EQ(3, observer.blur_changed_count());\n\n  SetSessionState(SessionState::OOBE);\n  EXPECT_TRUE(controller_->IsWallpaperBlurredForLockState());\n  EXPECT_EQ(3, observer.blur_changed_count());\n\n  SetSessionState(SessionState::UNKNOWN);\n  EXPECT_TRUE(controller_->IsWallpaperBlurredForLockState());\n  EXPECT_EQ(3, observer.blur_changed_count());\n}\n\nTEST_F(WallpaperControllerTest, WallpaperBlurDuringLockScreenTransition) {\n  ui::ScopedAnimationDurationScaleMode test_duration_mode(\n      ui::ScopedAnimationDurationScaleMode::NON_ZERO_DURATION);\n\n  gfx::ImageSkia image = CreateImage(600, 400, kWallpaperColor);\n  controller_->ShowWallpaperImage(\n      image, CreateWallpaperInfo(WALLPAPER_LAYOUT_CENTER),\n      /*preview_mode=*/false, /*always_on_top=*/false);\n\n  TestWallpaperControllerObserver observer(controller_);\n\n  ASSERT_TRUE(controller_->IsBlurAllowedForLockState());\n  ASSERT_FALSE(controller_->IsWallpaperBlurredForLockState());\n\n  ASSERT_EQ(2u, wallpaper_view()->layer()->parent()->children().size());\n  EXPECT_EQ(ui::LAYER_TEXTURED,\n            wallpaper_view()->layer()->parent()->children()[0]->type());\n  EXPECT_EQ(ui::LAYER_TEXTURED,\n            wallpaper_view()->layer()->parent()->children()[1]->type());\n\n  // Simulate lock and unlock sequence.\n  controller_->UpdateWallpaperBlurForLockState(true);\n  EXPECT_TRUE(controller_->IsWallpaperBlurredForLockState());\n  EXPECT_EQ(1, observer.blur_changed_count());\n\n  SetSessionState(SessionState::LOCKED);\n  EXPECT_TRUE(controller_->IsWallpaperBlurredForLockState());\n  ASSERT_EQ(3u, wallpaper_view()->layer()->parent()->children().size());\n  EXPECT_EQ(ui::LAYER_SOLID_COLOR,\n            wallpaper_view()->layer()->parent()->children()[0]->type());\n  EXPECT_EQ(ui::LAYER_TEXTURED,\n            wallpaper_view()->layer()->parent()->children()[1]->type());\n  EXPECT_EQ(ui::LAYER_TEXTURED,\n            wallpaper_view()->layer()->parent()->children()[2]->type());\n\n  // Change of state to ACTIVE triggers post lock animation and\n  // UpdateWallpaperBlur(false)\n  SetSessionState(SessionState::ACTIVE);\n  EXPECT_FALSE(controller_->IsWallpaperBlurredForLockState());\n  EXPECT_EQ(2, observer.blur_changed_count());\n  ASSERT_EQ(2u, wallpaper_view()->layer()->parent()->children().size());\n  EXPECT_EQ(ui::LAYER_TEXTURED,\n            wallpaper_view()->layer()->parent()->children()[0]->type());\n  EXPECT_EQ(ui::LAYER_TEXTURED,\n            wallpaper_view()->layer()->parent()->children()[1]->type());\n}\n\nTEST_F(WallpaperControllerTest, LockDuringOverview) {\n  gfx::ImageSkia image = CreateImage(600, 400, kWallpaperColor);\n  controller_->ShowWallpaperImage(\n      image, CreateWallpaperInfo(WALLPAPER_LAYOUT_CENTER),\n      /*preview_mode=*/false, /*always_on_top=*/false);\n  TestWallpaperControllerObserver observer(controller_);\n\n  EnterOverview();\n\n  EXPECT_FALSE(controller_->IsWallpaperBlurredForLockState());\n  EXPECT_EQ(0, observer.blur_changed_count());\n\n  // Simulate lock and unlock sequence.\n  SetSessionState(SessionState::LOCKED);\n\n  EXPECT_TRUE(controller_->IsWallpaperBlurredForLockState());\n\n  // Get wallpaper_view directly because it's not animating.\n  auto* wallpaper_view = Shell::Get()\n                             ->GetPrimaryRootWindowController()\n                             ->wallpaper_widget_controller()\n                             ->wallpaper_view();\n\n  // Make sure that wallpaper still have blur.\n  ASSERT_EQ(30, wallpaper_view->blur_sigma());\n}\n\nTEST_F(WallpaperControllerTest, DontLeakShieldView) {\n  SetSessionState(SessionState::LOCKED);\n  views::View* shield_view = wallpaper_view()->shield_view_for_testing();\n  ASSERT_TRUE(shield_view);\n  views::ViewTracker view_tracker(shield_view);\n  SetSessionState(SessionState::ACTIVE);\n  EXPECT_EQ(nullptr, wallpaper_view()->shield_view_for_testing());\n  EXPECT_EQ(nullptr, view_tracker.view());\n}\n\nTEST_F(WallpaperControllerTest, OnlyShowDevicePolicyWallpaperOnLoginScreen) {\n  SetBypassDecode();\n\n  // Verify the device policy wallpaper is shown on login screen.\n  SetSessionState(SessionState::LOGIN_PRIMARY);\n  controller_->SetDevicePolicyWallpaperPath(\n      base::FilePath(kDefaultSmallWallpaperName));\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_TRUE(IsDevicePolicyWallpaper());\n  // Verify the device policy wallpaper shouldn't be blurred.\n  ASSERT_FALSE(controller_->IsBlurAllowedForLockState());\n  ASSERT_FALSE(controller_->IsWallpaperBlurredForLockState());\n\n  // Verify the device policy wallpaper is replaced when session state is no\n  // longer LOGIN_PRIMARY.\n  SetSessionState(SessionState::LOGGED_IN_NOT_ACTIVE);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(2, GetWallpaperCount());\n  EXPECT_FALSE(IsDevicePolicyWallpaper());\n\n  // Verify the device policy wallpaper never shows up again when session\n  // state changes.\n  SetSessionState(SessionState::ACTIVE);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(2, GetWallpaperCount());\n  EXPECT_FALSE(IsDevicePolicyWallpaper());\n\n  SetSessionState(SessionState::LOCKED);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(2, GetWallpaperCount());\n  EXPECT_FALSE(IsDevicePolicyWallpaper());\n\n  SetSessionState(SessionState::LOGIN_SECONDARY);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(2, GetWallpaperCount());\n  EXPECT_FALSE(IsDevicePolicyWallpaper());\n}\n\nTEST_F(WallpaperControllerTest, ShouldShowInitialAnimationAfterBoot) {\n  CreateDefaultWallpapers();\n\n  // Simulate the login screen after system boot.\n  base::CommandLine::ForCurrentProcess()->AppendSwitch(\n      switches::kFirstExecAfterBoot);\n  base::CommandLine::ForCurrentProcess()->AppendSwitch(switches::kLoginManager);\n  ClearLogin();\n\n  // Show the first wallpaper. Verify that the slower animation should be used.\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  EXPECT_TRUE(controller_->ShouldShowInitialAnimation());\n  EXPECT_EQ(1, GetWallpaperCount());\n\n  // Show the second wallpaper. Verify that the slower animation should not be\n  // used. (Use a different user type to ensure a different wallpaper is shown,\n  // otherwise requests of loading the same wallpaper are ignored.)\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(kChildAccountId);\n  RunAllTasksUntilIdle();\n  EXPECT_FALSE(controller_->ShouldShowInitialAnimation());\n  EXPECT_EQ(1, GetWallpaperCount());\n\n  // Log in the user and show the wallpaper. Verify that the slower animation\n  // should not be used.\n  SimulateUserLogin(account_id_1);\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  EXPECT_FALSE(controller_->ShouldShowInitialAnimation());\n  EXPECT_EQ(1, GetWallpaperCount());\n}\n\nTEST_F(WallpaperControllerTest, ShouldNotShowInitialAnimationAfterSignOut) {\n  CreateDefaultWallpapers();\n\n  // Simulate the login screen after user sign-out. Verify that the slower\n  // animation should never be used.\n  base::CommandLine::ForCurrentProcess()->AppendSwitch(switches::kLoginManager);\n  CreateAndSaveWallpapers(account_id_1);\n  ClearLogin();\n\n  // Show the first wallpaper.\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  EXPECT_FALSE(controller_->ShouldShowInitialAnimation());\n  EXPECT_EQ(1, GetWallpaperCount());\n\n  // Show the second wallpaper.\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(kChildAccountId);\n  RunAllTasksUntilIdle();\n  EXPECT_FALSE(controller_->ShouldShowInitialAnimation());\n  EXPECT_EQ(1, GetWallpaperCount());\n\n  // Log in the user and show the wallpaper.\n  SimulateUserLogin(account_id_1);\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  EXPECT_FALSE(controller_->ShouldShowInitialAnimation());\n  EXPECT_EQ(1, GetWallpaperCount());\n}\n\nTEST_F(WallpaperControllerTest, ClosePreviewWallpaperOnOverviewStart) {\n  // Verify the user starts with a default wallpaper and the user wallpaper info\n  // is initialized with default values.\n  SimulateUserLogin(account_id_1);\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  WallpaperInfo user_wallpaper_info;\n  WallpaperInfo default_wallpaper_info(\n      std::string(), WALLPAPER_LAYOUT_CENTER_CROPPED, WallpaperType::kDefault,\n      base::Time::Now().LocalMidnight());\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n\n  // Simulate opening the wallpaper picker window.\n  std::unique_ptr<aura::Window> wallpaper_picker_window(\n      CreateTestWindow(gfx::Rect(0, 0, 100, 100)));\n  WindowState::Get(wallpaper_picker_window.get())->Activate();\n\n  // Set a custom wallpaper for the user and enable preview. Verify that the\n  // wallpaper is changed to the expected color.\n  const WallpaperLayout layout = WALLPAPER_LAYOUT_CENTER;\n  gfx::ImageSkia custom_wallpaper = CreateImage(640, 480, kWallpaperColor);\n  EXPECT_NE(kWallpaperColor, GetWallpaperColor());\n  ClearWallpaperCount();\n\n  TestWallpaperControllerObserver observer(controller_);\n  controller_->SetCustomWallpaper(account_id_1, file_name_1, layout,\n                                  custom_wallpaper, true /*preview_mode=*/);\n  RunAllTasksUntilIdle();\n  EXPECT_TRUE(observer.is_in_wallpaper_preview());\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(kWallpaperColor, GetWallpaperColor());\n  // Verify that the user wallpaper info remains unchanged during the preview.\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n\n  // Now enter overview mode. Verify the wallpaper changes back to the default,\n  // the user wallpaper info remains unchanged, and enters overview mode\n  // properly.\n  ClearWallpaperCount();\n  EnterOverview();\n  RunAllTasksUntilIdle();\n  EXPECT_FALSE(observer.is_in_wallpaper_preview());\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_NE(kWallpaperColor, GetWallpaperColor());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n  EXPECT_TRUE(Shell::Get()->overview_controller()->InOverviewSession());\n}\n\nTEST_F(WallpaperControllerTest, ClosePreviewWallpaperOnWindowCycleStart) {\n  // Verify the user starts with a default wallpaper and the user wallpaper info\n  // is initialized with default values.\n  SimulateUserLogin(account_id_1);\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  WallpaperInfo user_wallpaper_info;\n  WallpaperInfo default_wallpaper_info(\n      std::string(), WALLPAPER_LAYOUT_CENTER_CROPPED, WallpaperType::kDefault,\n      base::Time::Now().LocalMidnight());\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n\n  // Simulate opening the wallpaper picker window.\n  std::unique_ptr<aura::Window> wallpaper_picker_window(\n      CreateTestWindow(gfx::Rect(0, 0, 100, 100)));\n  WindowState::Get(wallpaper_picker_window.get())->Activate();\n\n  TestWallpaperControllerObserver observer(controller_);\n\n  // Set a custom wallpaper for the user and enable preview. Verify that the\n  // wallpaper is changed to the expected color.\n  const WallpaperLayout layout = WALLPAPER_LAYOUT_CENTER;\n  gfx::ImageSkia custom_wallpaper = CreateImage(640, 480, kWallpaperColor);\n  EXPECT_NE(kWallpaperColor, GetWallpaperColor());\n  ClearWallpaperCount();\n  controller_->SetCustomWallpaper(account_id_1, file_name_1, layout,\n                                  custom_wallpaper, true /*preview_mode=*/);\n  RunAllTasksUntilIdle();\n  EXPECT_TRUE(observer.is_in_wallpaper_preview());\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(kWallpaperColor, GetWallpaperColor());\n  // Verify that the user wallpaper info remains unchanged during the preview.\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n\n  // Now start window cycle. Verify the wallpaper changes back to the default,\n  // the user wallpaper info remains unchanged, and enters window cycle.\n  ClearWallpaperCount();\n  Shell::Get()->window_cycle_controller()->HandleCycleWindow(\n      WindowCycleController::WindowCyclingDirection::kForward);\n  RunAllTasksUntilIdle();\n  EXPECT_FALSE(observer.is_in_wallpaper_preview());\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_NE(kWallpaperColor, GetWallpaperColor());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n  EXPECT_TRUE(Shell::Get()->window_cycle_controller()->IsCycling());\n}\n\nTEST_F(WallpaperControllerTest,\n       ClosePreviewWallpaperOnActiveUserSessionChanged) {\n  // Verify the user starts with a default wallpaper and the user wallpaper info\n  // is initialized with default values.\n  SimulateUserLogin(account_id_1);\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  WallpaperInfo user_wallpaper_info;\n  WallpaperInfo default_wallpaper_info(\n      std::string(), WALLPAPER_LAYOUT_CENTER_CROPPED, WallpaperType::kDefault,\n      base::Time::Now().LocalMidnight());\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n\n  // Simulate opening the wallpaper picker window.\n  std::unique_ptr<aura::Window> wallpaper_picker_window(\n      CreateTestWindow(gfx::Rect(0, 0, 100, 100)));\n  WindowState::Get(wallpaper_picker_window.get())->Activate();\n\n  TestWallpaperControllerObserver observer(controller_);\n\n  // Set a custom wallpaper for the user and enable preview. Verify that the\n  // wallpaper is changed to the expected color.\n  const WallpaperLayout layout = WALLPAPER_LAYOUT_CENTER;\n  gfx::ImageSkia custom_wallpaper = CreateImage(640, 480, kWallpaperColor);\n  EXPECT_NE(kWallpaperColor, GetWallpaperColor());\n  ClearWallpaperCount();\n  controller_->SetCustomWallpaper(account_id_1, file_name_1, layout,\n                                  custom_wallpaper, true /*preview_mode=*/);\n  RunAllTasksUntilIdle();\n  EXPECT_TRUE(observer.is_in_wallpaper_preview());\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(kWallpaperColor, GetWallpaperColor());\n  // Verify that the user wallpaper info remains unchanged during the preview.\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n\n  // Now switch to another user. Verify the wallpaper changes back to the\n  // default and the user wallpaper remains unchanged.\n  ClearWallpaperCount();\n  SimulateUserLogin(account_id_2);\n  controller_->ShowUserWallpaper(account_id_2);\n  RunAllTasksUntilIdle();\n  EXPECT_FALSE(observer.is_in_wallpaper_preview());\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_NE(kWallpaperColor, GetWallpaperColor());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_2, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n}\n\nTEST_F(WallpaperControllerTest, ConfirmPreviewWallpaper) {\n  // Verify the user starts with a default wallpaper and the user wallpaper info\n  // is initialized with default values.\n  SimulateUserLogin(account_id_1);\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  WallpaperInfo user_wallpaper_info;\n  WallpaperInfo default_wallpaper_info(\n      std::string(), WALLPAPER_LAYOUT_CENTER_CROPPED, WallpaperType::kDefault,\n      base::Time::Now().LocalMidnight());\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n\n  // Simulate opening the wallpaper picker window.\n  std::unique_ptr<aura::Window> wallpaper_picker_window(\n      CreateTestWindow(gfx::Rect(0, 0, 100, 100)));\n  WindowState::Get(wallpaper_picker_window.get())->Activate();\n\n  // Set a custom wallpaper for the user and enable preview. Verify that the\n  // wallpaper is changed to the expected color.\n  const WallpaperLayout layout = WALLPAPER_LAYOUT_CENTER;\n  gfx::ImageSkia custom_wallpaper = CreateImage(640, 480, kWallpaperColor);\n  EXPECT_NE(kWallpaperColor, GetWallpaperColor());\n  ClearWallpaperCount();\n  controller_->SetCustomWallpaper(account_id_1, file_name_1, layout,\n                                  custom_wallpaper, true /*preview_mode=*/);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(kWallpaperColor, GetWallpaperColor());\n  // Verify that the user wallpaper info remains unchanged during the preview.\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n  histogram_tester().ExpectTotalCount(\"Ash.Wallpaper.Preview.Show\", 1);\n\n  // Now confirm the preview wallpaper, verify that there's no wallpaper change\n  // because the wallpaper is already shown.\n  ClearWallpaperCount();\n  controller_->ConfirmPreviewWallpaper();\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(0, GetWallpaperCount());\n  EXPECT_EQ(kWallpaperColor, GetWallpaperColor());\n\n  // Verify that the user wallpaper info is now updated to the custom wallpaper\n  // info.\n  WallpaperInfo custom_wallpaper_info(\n      base::FilePath(wallpaper_files_id_1).Append(file_name_1).value(), layout,\n      WallpaperType::kCustomized, base::Time::Now().LocalMidnight());\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, custom_wallpaper_info);\n\n  // Set an empty online wallpaper for the user, verify it fails.\n  ClearWallpaperCount();\n  std::unique_ptr<base::RunLoop> run_loop = std::make_unique<base::RunLoop>();\n  SetOnlineWallpaperFromImage(\n      account_id_1, kAssetId, gfx::ImageSkia(), kDummyUrl,\n      TestWallpaperControllerClient::kDummyCollectionId, layout,\n      /*save_file=*/false, /*preview_mode=*/true, /*from_user=*/true, kUnitId,\n      /*variants=*/std::vector<OnlineWallpaperVariant>(),\n      base::BindLambdaForTesting([&run_loop](bool success) {\n        EXPECT_FALSE(success);\n        run_loop->Quit();\n      }));\n  run_loop->Run();\n  EXPECT_EQ(0, GetWallpaperCount());\n\n  // Now set a valid online wallpaper for the user and enable preview. Verify\n  // that the wallpaper is changed to the expected color.\n  const SkColor online_wallpaper_color = SK_ColorCYAN;\n  gfx::ImageSkia online_wallpaper =\n      CreateImage(640, 480, online_wallpaper_color);\n  EXPECT_NE(online_wallpaper_color, GetWallpaperColor());\n  run_loop = std::make_unique<base::RunLoop>();\n  SetOnlineWallpaperFromImage(\n      account_id_1, kAssetId, online_wallpaper, kDummyUrl,\n      TestWallpaperControllerClient::kDummyCollectionId, layout,\n      /*save_file=*/false, /*preview_mode=*/true, /*from_user=*/true, kUnitId,\n      /*variants=*/\n      std::vector<OnlineWallpaperVariant>(),\n      base::BindLambdaForTesting([&run_loop](bool success) {\n        EXPECT_TRUE(success);\n        run_loop->Quit();\n      }));\n  run_loop->Run();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(online_wallpaper_color, GetWallpaperColor());\n  // Verify that the user wallpaper info remains unchanged during the preview.\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, custom_wallpaper_info);\n\n  // Now confirm the preview wallpaper, verify that there's no wallpaper change\n  // because the wallpaper is already shown.\n  ClearWallpaperCount();\n  controller_->ConfirmPreviewWallpaper();\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(0, GetWallpaperCount());\n  EXPECT_EQ(online_wallpaper_color, GetWallpaperColor());\n  // Verify that the user wallpaper info is now updated to the online wallpaper\n  // info.\n  WallpaperInfo online_wallpaper_info(OnlineWallpaperParams(\n      account_id_1, kAssetId, GURL(kDummyUrl),\n      TestWallpaperControllerClient::kDummyCollectionId, layout,\n      /*preview_mode=*/false,\n      /*from_user=*/true,\n      /*daily_refresh_enabled=*/false, kUnitId,\n      /*variants=*/\n      std::vector<OnlineWallpaperVariant>()));\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, online_wallpaper_info);\n}\n\nTEST_F(WallpaperControllerTest, CancelPreviewWallpaper) {\n  // Verify the user starts with a default wallpaper and the user wallpaper info\n  // is initialized with default values.\n  SimulateUserLogin(account_id_1);\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  WallpaperInfo user_wallpaper_info;\n  WallpaperInfo default_wallpaper_info(\n      std::string(), WALLPAPER_LAYOUT_CENTER_CROPPED, WallpaperType::kDefault,\n      base::Time::Now().LocalMidnight());\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n\n  // Simulate opening the wallpaper picker window.\n  std::unique_ptr<aura::Window> wallpaper_picker_window(\n      CreateTestWindow(gfx::Rect(0, 0, 100, 100)));\n  WindowState::Get(wallpaper_picker_window.get())->Activate();\n\n  // Set a custom wallpaper for the user and enable preview. Verify that the\n  // wallpaper is changed to the expected color.\n  const WallpaperLayout layout = WALLPAPER_LAYOUT_CENTER;\n  gfx::ImageSkia custom_wallpaper = CreateImage(640, 480, kWallpaperColor);\n  EXPECT_NE(kWallpaperColor, GetWallpaperColor());\n  ClearWallpaperCount();\n  controller_->SetCustomWallpaper(account_id_1, file_name_1, layout,\n                                  custom_wallpaper, true /*preview_mode=*/);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(kWallpaperColor, GetWallpaperColor());\n  // Verify that the user wallpaper info remains unchanged during the preview.\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n\n  // Now cancel the preview. Verify the wallpaper changes back to the default\n  // and the user wallpaper info remains unchanged.\n  ClearWallpaperCount();\n  controller_->CancelPreviewWallpaper();\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_NE(kWallpaperColor, GetWallpaperColor());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n\n  // Now set an online wallpaper for the user and enable preview. Verify that\n  // the wallpaper is changed to the expected color.\n  const SkColor online_wallpaper_color = SK_ColorCYAN;\n  gfx::ImageSkia online_wallpaper =\n      CreateImage(640, 480, online_wallpaper_color);\n  EXPECT_NE(online_wallpaper_color, GetWallpaperColor());\n  ClearWallpaperCount();\n  SetOnlineWallpaperFromImage(\n      account_id_1, kAssetId, online_wallpaper, kDummyUrl,\n      TestWallpaperControllerClient::kDummyCollectionId, layout,\n      /*save_file=*/false, /*preview_mode=*/true, /*from_user=*/true, kUnitId,\n      /*variants=*/std::vector<OnlineWallpaperVariant>(),\n      WallpaperController::SetWallpaperCallback());\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(online_wallpaper_color, GetWallpaperColor());\n  // Verify that the user wallpaper info remains unchanged during the preview.\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n\n  // Now cancel the preview. Verify the wallpaper changes back to the default\n  // and the user wallpaper info remains unchanged.\n  ClearWallpaperCount();\n  controller_->CancelPreviewWallpaper();\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_NE(online_wallpaper_color, GetWallpaperColor());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n}\n\nTEST_F(WallpaperControllerTest, WallpaperSyncedDuringPreview) {\n  // Verify the user starts with a default wallpaper and the user wallpaper info\n  // is initialized with default values.\n  SimulateUserLogin(account_id_1);\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  WallpaperInfo user_wallpaper_info;\n  WallpaperInfo default_wallpaper_info(\n      std::string(), WALLPAPER_LAYOUT_CENTER_CROPPED, WallpaperType::kDefault,\n      base::Time::Now().LocalMidnight());\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n\n  // Simulate opening the wallpaper picker window.\n  std::unique_ptr<aura::Window> wallpaper_picker_window(\n      CreateTestWindow(gfx::Rect(0, 0, 100, 100)));\n  WindowState::Get(wallpaper_picker_window.get())->Activate();\n\n  // Set a custom wallpaper for the user and enable preview. Verify that the\n  // wallpaper is changed to the expected color.\n  const WallpaperLayout layout = WALLPAPER_LAYOUT_CENTER;\n  gfx::ImageSkia custom_wallpaper = CreateImage(640, 480, kWallpaperColor);\n  EXPECT_NE(kWallpaperColor, GetWallpaperColor());\n  ClearWallpaperCount();\n  controller_->SetCustomWallpaper(account_id_1, file_name_1, layout,\n                                  custom_wallpaper, true /*preview_mode=*/);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(kWallpaperColor, GetWallpaperColor());\n  // Verify that the user wallpaper info remains unchanged during the preview.\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n\n  // Now set another custom wallpaper for the user and disable preview (this\n  // happens if a custom wallpaper set on another device is being synced).\n  // Verify there's no wallpaper change since preview mode shouldn't be\n  // interrupted.\n  const SkColor synced_custom_wallpaper_color = SK_ColorBLUE;\n  gfx::ImageSkia synced_custom_wallpaper =\n      CreateImage(640, 480, synced_custom_wallpaper_color);\n  ClearWallpaperCount();\n  controller_->SetCustomWallpaper(account_id_1, file_name_2, layout,\n                                  synced_custom_wallpaper,\n                                  false /*preview_mode=*/);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(0, GetWallpaperCount());\n  EXPECT_EQ(kWallpaperColor, GetWallpaperColor());\n  // However, the user wallpaper info should already be updated to the new info.\n  WallpaperInfo synced_custom_wallpaper_info(\n      base::FilePath(wallpaper_files_id_1).Append(file_name_2).value(), layout,\n      WallpaperType::kCustomized, base::Time::Now().LocalMidnight());\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, synced_custom_wallpaper_info);\n\n  // Now cancel the preview. Verify the synced custom wallpaper is shown instead\n  // of the initial default wallpaper, and the user wallpaper info is still\n  // correct.\n  ClearWallpaperCount();\n  controller_->CancelPreviewWallpaper();\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(synced_custom_wallpaper_color, GetWallpaperColor());\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, synced_custom_wallpaper_info);\n\n  // Repeat the above steps for online wallpapers: set a online wallpaper for\n  // the user and enable preview. Verify that the wallpaper is changed to the\n  // expected color.\n  gfx::ImageSkia online_wallpaper = CreateImage(640, 480, kWallpaperColor);\n  EXPECT_NE(kWallpaperColor, GetWallpaperColor());\n\n  ClearWallpaperCount();\n  SetOnlineWallpaperFromImage(\n      account_id_1, kAssetId, online_wallpaper, kDummyUrl,\n      TestWallpaperControllerClient::kDummyCollectionId, layout,\n      /*save_file=*/false, /*preview_mode=*/true, /*from_user=*/true, kUnitId,\n      /*variants=*/std::vector<OnlineWallpaperVariant>(),\n      WallpaperController::SetWallpaperCallback());\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(kWallpaperColor, GetWallpaperColor());\n  // Verify that the user wallpaper info remains unchanged during the preview.\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, synced_custom_wallpaper_info);\n\n  // Now set another online wallpaper for the user and disable preview. Verify\n  // there's no wallpaper change since preview mode shouldn't be interrupted.\n  const SkColor synced_online_wallpaper_color = SK_ColorCYAN;\n  gfx::ImageSkia synced_online_wallpaper =\n      CreateImage(640, 480, synced_online_wallpaper_color);\n  ClearWallpaperCount();\n  SetOnlineWallpaperFromImage(\n      account_id_1, kAssetId, synced_online_wallpaper, kDummyUrl2,\n      TestWallpaperControllerClient::kDummyCollectionId, layout,\n      /*save_file=*/false, /*preview_mode=*/false,\n      /*from_user=*/true, kUnitId,\n      /*variants=*/std::vector<OnlineWallpaperVariant>(),\n      WallpaperController::SetWallpaperCallback());\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(0, GetWallpaperCount());\n  EXPECT_EQ(kWallpaperColor, GetWallpaperColor());\n  // However, the user wallpaper info should already be updated to the new info.\n  WallpaperInfo synced_online_wallpaper_info =\n      WallpaperInfo(OnlineWallpaperParams(\n          account_id_1, kAssetId, GURL(kDummyUrl2),\n          TestWallpaperControllerClient::kDummyCollectionId, layout,\n          /*preview_mode=*/false,\n          /*from_user=*/true,\n          /*daily_refresh_enabled=*/false, kUnitId,\n          /*variants=*/\n          std::vector<OnlineWallpaperVariant>()));\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, synced_online_wallpaper_info);\n\n  // Now cancel the preview. Verify the synced online wallpaper is shown instead\n  // of the previous custom wallpaper, and the user wallpaper info is still\n  // correct.\n  ClearWallpaperCount();\n  controller_->CancelPreviewWallpaper();\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(synced_online_wallpaper_color, GetWallpaperColor());\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, synced_online_wallpaper_info);\n}\n\nTEST_F(WallpaperControllerTest, AddFirstWallpaperAnimationEndCallback) {\n  ui::ScopedAnimationDurationScaleMode test_duration_mode(\n      ui::ScopedAnimationDurationScaleMode::NON_ZERO_DURATION);\n  std::unique_ptr<aura::Window> test_window(\n      CreateTestWindow(gfx::Rect(0, 0, 100, 100)));\n\n  base::RunLoop test_loop;\n  controller_->AddFirstWallpaperAnimationEndCallback(test_loop.QuitClosure(),\n                                                     test_window.get());\n  // The callback is not run because the first wallpaper hasn't been set.\n  task_environment()->RunUntilIdle();\n  EXPECT_FALSE(test_loop.AnyQuitCalled());\n\n  // Set the first wallpaper.\n  controller_->ShowDefaultWallpaperForTesting();\n  controller_->AddFirstWallpaperAnimationEndCallback(test_loop.QuitClosure(),\n                                                     test_window.get());\n  task_environment()->RunUntilIdle();\n  // Neither callback is run because the animation of the first wallpaper\n  // hasn't finished yet.\n  EXPECT_FALSE(test_loop.AnyQuitCalled());\n\n  // Force the animation to complete. The two callbacks are both run.\n  RunDesktopControllerAnimation();\n  test_loop.Run();\n  EXPECT_TRUE(test_loop.AnyQuitCalled());\n\n  // The callback added after the first wallpaper animation is run right away.\n  bool is_third_callback_run = false;\n  controller_->AddFirstWallpaperAnimationEndCallback(\n      base::BindLambdaForTesting(\n          [&is_third_callback_run]() { is_third_callback_run = true; }),\n      test_window.get());\n  EXPECT_TRUE(is_third_callback_run);\n}\n\nTEST_F(WallpaperControllerTest, ShowOneShotWallpaper) {\n  gfx::ImageSkia custom_wallpaper = CreateImage(640, 480, kWallpaperColor);\n  WallpaperLayout layout = WALLPAPER_LAYOUT_CENTER;\n\n  SimulateUserLogin(account_id_1);\n  // First, set a custom wallpaper for |kUser1|. Verify the wallpaper is shown\n  // successfully and the user wallpaper info is updated.\n  ClearWallpaperCount();\n  controller_->SetCustomWallpaper(account_id_1, file_name_1, layout,\n                                  custom_wallpaper, false /*preview_mode=*/);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(kWallpaperColor, GetWallpaperColor());\n  EXPECT_EQ(WallpaperType::kCustomized, controller_->GetWallpaperType());\n  const WallpaperInfo expected_wallpaper_info(\n      base::FilePath(wallpaper_files_id_1).Append(file_name_1).value(), layout,\n      WallpaperType::kCustomized, base::Time::Now().LocalMidnight());\n  WallpaperInfo wallpaper_info;\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  EXPECT_EQ(expected_wallpaper_info, wallpaper_info);\n\n  // Show a one-shot wallpaper. Verify it is shown successfully.\n  ClearWallpaperCount();\n  constexpr SkColor kOneShotWallpaperColor = SK_ColorWHITE;\n  gfx::ImageSkia one_shot_wallpaper =\n      CreateImage(640, 480, kOneShotWallpaperColor);\n  controller_->ShowOneShotWallpaper(one_shot_wallpaper);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(kOneShotWallpaperColor, GetWallpaperColor());\n  EXPECT_EQ(WallpaperType::kOneShot, controller_->GetWallpaperType());\n  EXPECT_FALSE(controller_->IsBlurAllowedForLockState());\n  EXPECT_FALSE(controller_->ShouldApplyShield());\n\n  // Verify that we can reload wallpaer without losing it.\n  // This is important for screen rotation.\n  controller_->ReloadWallpaperForTesting(/*clear_cache=*/false);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(2, GetWallpaperCount());  // Reload increments count.\n  EXPECT_EQ(kOneShotWallpaperColor, GetWallpaperColor());\n  EXPECT_EQ(WallpaperType::kOneShot, controller_->GetWallpaperType());\n  EXPECT_FALSE(controller_->IsBlurAllowedForLockState());\n  EXPECT_FALSE(controller_->ShouldApplyShield());\n\n  // Verify the user wallpaper info is unaffected, and the one-shot wallpaper\n  // can be replaced by the user wallpaper.\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  EXPECT_EQ(expected_wallpaper_info, wallpaper_info);\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(kWallpaperColor, GetWallpaperColor());\n  EXPECT_EQ(WallpaperType::kCustomized, controller_->GetWallpaperType());\n}\n\nTEST_F(WallpaperControllerTest, OnFirstWallpaperShown) {\n  TestWallpaperControllerObserver observer(controller_);\n  EXPECT_EQ(0, GetWallpaperCount());\n  EXPECT_EQ(0, observer.first_shown_count());\n  // Show the first wallpaper, verify the observer is notified.\n  controller_->ShowWallpaperImage(CreateImage(640, 480, SK_ColorBLUE),\n                                  CreateWallpaperInfo(WALLPAPER_LAYOUT_STRETCH),\n                                  /*preview_mode=*/false,\n                                  /*always_on_top=*/false);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(SK_ColorBLUE, GetWallpaperColor());\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(1, observer.first_shown_count());\n  // Show the second wallpaper, verify the observer is not notified.\n  controller_->ShowWallpaperImage(CreateImage(640, 480, SK_ColorCYAN),\n                                  CreateWallpaperInfo(WALLPAPER_LAYOUT_STRETCH),\n                                  /*preview_mode=*/false,\n                                  /*always_on_top=*/false);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(SK_ColorCYAN, GetWallpaperColor());\n  EXPECT_EQ(2, GetWallpaperCount());\n  EXPECT_EQ(1, observer.first_shown_count());\n}\n\n// Although ephemeral users' custom wallpapers are not saved to disk, they\n// should be kept within the user session. Test for https://crbug.com/825237.\nTEST_F(WallpaperControllerTest, ShowWallpaperForEphemeralUser) {\n  // Clear the local pref so we can make sure nothing writes to it.\n  local_state()->ClearPref(prefs::kUserWallpaperInfo);\n\n  // Add an ephemeral user session and simulate login, like SimulateUserLogin.\n  UserSession session;\n  session.session_id = 0;\n  session.user_info.account_id = account_id_1;\n  session.user_info.is_ephemeral = true;\n  Shell::Get()->session_controller()->UpdateUserSession(std::move(session));\n  TestSessionControllerClient* const client = GetSessionControllerClient();\n  client->SwitchActiveUser(account_id_1);\n  client->SetSessionState(SessionState::ACTIVE);\n\n  // The user doesn't have wallpaper cache in the beginning.\n  gfx::ImageSkia cached_wallpaper;\n  EXPECT_FALSE(\n      controller_->GetWallpaperFromCache(account_id_1, &cached_wallpaper));\n  base::FilePath path;\n  EXPECT_FALSE(controller_->GetPathFromCache(account_id_1, &path));\n\n  ClearWallpaperCount();\n  controller_->SetCustomWallpaper(account_id_1, file_name_1,\n                                  WALLPAPER_LAYOUT_CENTER,\n                                  CreateImage(640, 480, kWallpaperColor),\n                                  /*preview_mode=*/false);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(WallpaperType::kCustomized, controller_->GetWallpaperType());\n  EXPECT_EQ(kWallpaperColor, GetWallpaperColor());\n  // Assert that we do not use local state for an ephemeral user.\n  auto* dict = local_state()->GetUserPrefValue(prefs::kUserWallpaperInfo);\n  ASSERT_FALSE(dict) << *dict;\n\n  // The custom wallpaper is cached.\n  EXPECT_TRUE(\n      controller_->GetWallpaperFromCache(account_id_1, &cached_wallpaper));\n  EXPECT_EQ(\n      kWallpaperColor,\n      cached_wallpaper.GetRepresentation(1.0f).GetBitmap().getColor(0, 0));\n  EXPECT_TRUE(controller_->GetPathFromCache(account_id_1, &path));\n\n  // Calling |ShowUserWallpaper| will continue showing the custom wallpaper\n  // instead of reverting to the default.\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(0, GetWallpaperCount());\n  EXPECT_EQ(WallpaperType::kCustomized, controller_->GetWallpaperType());\n  EXPECT_EQ(kWallpaperColor, GetWallpaperColor());\n}\n\nTEST_F(WallpaperControllerTest, AlwaysOnTopWallpaper) {\n  CreateDefaultWallpapers();\n  SetBypassDecode();\n\n  // Show a default wallpaper.\n  EXPECT_EQ(0, GetWallpaperCount());\n  controller_->ShowSigninWallpaper();\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  EXPECT_EQ(1, ChildCountForContainer(kWallpaperId));\n  EXPECT_EQ(0, ChildCountForContainer(kAlwaysOnTopWallpaperId));\n\n  // Show an always-on-top wallpaper.\n  const base::FilePath image_path =\n      base::CommandLine::ForCurrentProcess()->GetSwitchValuePath(\n          switches::kGuestWallpaperLarge);\n  controller_->ShowAlwaysOnTopWallpaper(image_path);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(2, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kOneShot);\n  EXPECT_EQ(0, ChildCountForContainer(kWallpaperId));\n  EXPECT_EQ(1, ChildCountForContainer(kAlwaysOnTopWallpaperId));\n\n  // Subsequent wallpaper requests are ignored when the current wallpaper is\n  // always-on-top.\n  controller_->ShowSigninWallpaper();\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(2, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kOneShot);\n  EXPECT_EQ(0, ChildCountForContainer(kWallpaperId));\n  EXPECT_EQ(1, ChildCountForContainer(kAlwaysOnTopWallpaperId));\n\n  // The wallpaper reverts to the default after the always-on-top wallpaper is\n  // removed.\n  controller_->RemoveAlwaysOnTopWallpaper();\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(3, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  EXPECT_EQ(1, ChildCountForContainer(kWallpaperId));\n  EXPECT_EQ(0, ChildCountForContainer(kAlwaysOnTopWallpaperId));\n\n  // Calling |RemoveAlwaysOnTopWallpaper| is a no-op when the current wallpaper\n  // is not always-on-top.\n  controller_->RemoveAlwaysOnTopWallpaper();\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(3, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  EXPECT_EQ(1, ChildCountForContainer(kWallpaperId));\n  EXPECT_EQ(0, ChildCountForContainer(kAlwaysOnTopWallpaperId));\n}\n\nnamespace {\n\nclass WallpaperControllerPrefTest : public AshTestBase {\n public:\n  WallpaperControllerPrefTest() {\n    base::Value::Dict property;\n    property.Set(\"rotation\", static_cast<int>(display::Display::ROTATE_90));\n    property.Set(\"width\", 800);\n    property.Set(\"height\", 600);\n\n    DictionaryPrefUpdate update(local_state(), prefs::kDisplayProperties);\n    update.Get()->SetKey(\"2200000000\", base::Value(std::move(property)));\n  }\n\n  ~WallpaperControllerPrefTest() override = default;\n\n  void SetUp() override { AshTestBase::SetUp(); }\n\n private:\n  base::test::ScopedFeatureList scoped_feature_list_;\n};\n\n}  // namespace\n\n// Make sure that the display and the wallpaper view are rotated correctly at\n// startup.\nTEST_F(WallpaperControllerPrefTest, InitWithPrefs) {\n  auto* wallpaper_view = Shell::GetPrimaryRootWindowController()\n                             ->wallpaper_widget_controller()\n                             ->wallpaper_view();\n  auto* root_window =\n      wallpaper_view->GetWidget()->GetNativeWindow()->GetRootWindow();\n\n  EXPECT_EQ(gfx::Size(600, 800), display::Screen::GetScreen()\n                                     ->GetDisplayNearestWindow(root_window)\n                                     .size());\n  EXPECT_EQ(root_window->bounds().size(), wallpaper_view->bounds().size());\n}\n\nTEST_F(WallpaperControllerTest, NoAnimationForNewRootWindowWhenLocked) {\n  ui::ScopedAnimationDurationScaleMode test_duration_mode(\n      ui::ScopedAnimationDurationScaleMode::NON_ZERO_DURATION);\n  SetSessionState(SessionState::LOCKED);\n  UpdateDisplay(\"800x600, 800x600\");\n  auto* secondary_root_window_controller =\n      Shell::Get()->GetAllRootWindowControllers()[1];\n  EXPECT_FALSE(secondary_root_window_controller->wallpaper_widget_controller()\n                   ->IsAnimating());\n  EXPECT_FALSE(secondary_root_window_controller->wallpaper_widget_controller()\n                   ->GetWidget()\n                   ->GetLayer()\n                   ->GetAnimator()\n                   ->is_animating());\n}\n\nTEST_F(WallpaperControllerTest, SetCustomWallpaper) {\n  gfx::ImageSkia image = CreateImage(640, 480, kWallpaperColor);\n  WallpaperLayout layout = WALLPAPER_LAYOUT_CENTER;\n\n  SimulateUserLogin(account_id_1);\n\n  // Set a custom wallpaper for |kUser1|. Verify the wallpaper is set\n  // successfully and wallpaper info is updated.\n  ClearWallpaperCount();\n  controller_->SetCustomWallpaper(account_id_1, file_name_1, layout, image,\n                                  false /*preview_mode=*/);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(kWallpaperColor, GetWallpaperColor());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kCustomized);\n  WallpaperInfo wallpaper_info;\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  WallpaperInfo expected_wallpaper_info(\n      base::FilePath(wallpaper_files_id_1).Append(file_name_1).value(), layout,\n      WallpaperType::kCustomized, base::Time::Now().LocalMidnight());\n  EXPECT_EQ(wallpaper_info, expected_wallpaper_info);\n  EXPECT_EQ(account_id_1, client_.get_save_wallpaper_to_drive_fs_account_id());\n\n  // Now set another custom wallpaper for |kUser1|. Verify that the on-screen\n  // wallpaper doesn't change since |kUser1| is not active, but wallpaper info\n  // is updated properly.\n  SimulateUserLogin(account_id_2);\n  const SkColor custom_wallpaper_color = SK_ColorCYAN;\n  image = CreateImage(640, 480, custom_wallpaper_color);\n  ClearWallpaperCount();\n  controller_->SetCustomWallpaper(account_id_1, file_name_1, layout, image,\n                                  false /*preview_mode=*/);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(0, GetWallpaperCount());\n  EXPECT_EQ(kWallpaperColor, GetWallpaperColor());\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  EXPECT_EQ(wallpaper_info, expected_wallpaper_info);\n\n  // Verify the updated wallpaper is shown after |kUser1| becomes active again.\n  SimulateUserLogin(account_id_1);\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(custom_wallpaper_color, GetWallpaperColor());\n}\n\nTEST_F(WallpaperControllerTest, OldOnlineInfoSynced_Discarded) {\n  // Create a dictionary that looks like the preference from crrev.com/a040384.\n  // DO NOT CHANGE as there are preferences like this in production.\n  base::Value::Dict wallpaper_info_dict;\n  wallpaper_info_dict.Set(\n      WallpaperPrefManager::kNewWallpaperDateNodeName,\n      base::NumberToString(\n          base::Time::Now().ToDeltaSinceWindowsEpoch().InMicroseconds()));\n  wallpaper_info_dict.Set(WallpaperPrefManager::kNewWallpaperLocationNodeName,\n                          \"location\");\n  wallpaper_info_dict.Set(\n      WallpaperPrefManager::kNewWallpaperUserFilePathNodeName,\n      \"user_file_path\");\n  wallpaper_info_dict.Set(WallpaperPrefManager::kNewWallpaperLayoutNodeName,\n                          WallpaperLayout::WALLPAPER_LAYOUT_CENTER);\n  wallpaper_info_dict.Set(WallpaperPrefManager::kNewWallpaperTypeNodeName,\n                          static_cast<int>(WallpaperType::kOnline));\n\n  {\n    DictionaryPrefUpdate wallpaper_update(GetProfilePrefService(account_id_1),\n                                          prefs::kSyncableWallpaperInfo);\n    wallpaper_update->SetKey(account_id_1.GetUserEmail(),\n                             base::Value(std::move(wallpaper_info_dict)));\n  }\n  SimulateUserLogin(account_id_1);\n  task_environment()->RunUntilIdle();\n\n  // Unmigrated synced wallpaper info are discarded.\n  WallpaperInfo actual;\n  EXPECT_FALSE(pref_manager_->GetUserWallpaperInfo(account_id_1, &actual));\n}\n\nTEST_F(WallpaperControllerTest, MigrateWallpaperInfo_Online) {\n  WallpaperInfo expected_info = InfoWithType(WallpaperType::kOnline);\n  pref_manager_->SetLocalWallpaperInfo(account_id_1, expected_info);\n  SimulateUserLogin(account_id_1);\n  WallpaperInfo info;\n  ASSERT_TRUE(pref_manager_->GetSyncedWallpaperInfo(account_id_1, &info));\n  EXPECT_EQ(expected_info, info);\n}\n\nTEST_F(WallpaperControllerTest, MigrateWallpaperInfoCustomized) {\n  WallpaperInfo expected_info = InfoWithType(WallpaperType::kCustomized);\n  pref_manager_->SetLocalWallpaperInfo(account_id_1, expected_info);\n  SimulateUserLogin(account_id_1);\n  WallpaperInfo info;\n  ASSERT_TRUE(pref_manager_->GetSyncedWallpaperInfo(account_id_1, &info));\n  EXPECT_EQ(expected_info, info);\n}\n\nTEST_F(WallpaperControllerTest, MigrateWallpaperInfoDaily) {\n  WallpaperInfo expected_info = WallpaperInfo(OnlineWallpaperParams(\n      account_id_1, kAssetId, GURL(kDummyUrl),\n      TestWallpaperControllerClient::kDummyCollectionId,\n      WALLPAPER_LAYOUT_CENTER, /*preview_mode=*/false, /*from_user=*/false,\n      /*daily_refresh_enabled=*/false, kUnitId,\n      std::vector<OnlineWallpaperVariant>()));\n  pref_manager_->SetLocalWallpaperInfo(account_id_1, expected_info);\n  SimulateUserLogin(account_id_1);\n  WallpaperInfo info;\n  ASSERT_TRUE(pref_manager_->GetSyncedWallpaperInfo(account_id_1, &info));\n  EXPECT_EQ(expected_info, info);\n  EXPECT_EQ(client_.migrate_collection_id_from_chrome_app_count(), 1u);\n}\n\nTEST_F(WallpaperControllerTest,\n       MigrateWallpaperInfoDoesntHappenWhenSyncedInfoAlreadyExists) {\n  SetBypassDecode();\n\n  WallpaperInfo local_info = WallpaperInfo(OnlineWallpaperParams(\n      account_id_1, kAssetId, GURL(kDummyUrl),\n      TestWallpaperControllerClient::kDummyCollectionId,\n      WALLPAPER_LAYOUT_CENTER, /*preview_mode=*/false, /*from_user=*/false,\n      /*daily_refresh_enabled=*/false, kUnitId,\n      std::vector<OnlineWallpaperVariant>()));\n  WallpaperInfo synced_info = WallpaperInfo(OnlineWallpaperParams(\n      account_id_1, kAssetId2, GURL(kDummyUrl2),\n      TestWallpaperControllerClient::kDummyCollectionId,\n      WALLPAPER_LAYOUT_CENTER, /*preview_mode=*/false, /*from_user=*/false,\n      /*daily_refresh_enabled=*/false, kUnitId,\n      std::vector<OnlineWallpaperVariant>()));\n  pref_manager_->SetLocalWallpaperInfo(account_id_1, local_info);\n  pref_manager_->SetSyncedWallpaperInfo(account_id_1, synced_info);\n  SimulateUserLogin(account_id_1);\n  WallpaperInfo info;\n  ASSERT_TRUE(pref_manager_->GetSyncedWallpaperInfo(account_id_1, &info));\n  // Synced info should be the same if local is the same age.\n  EXPECT_EQ(synced_info, info);\n}\n\nTEST_F(WallpaperControllerTest,\n       ActiveUserPrefServiceChangedSyncedInfoHandledLocally) {\n  CacheOnlineWallpaper(kDummyUrl);\n\n  WallpaperInfo synced_info = {kDummyUrl, WALLPAPER_LAYOUT_CENTER_CROPPED,\n                               WallpaperType::kOnline, base::Time::Now()};\n  synced_info.asset_id = kAssetId;\n  synced_info.collection_id = TestWallpaperControllerClient::kDummyCollectionId;\n  pref_manager_->SetSyncedWallpaperInfo(account_id_1, synced_info);\n\n  WallpaperInfo local_info = InfoWithType(WallpaperType::kThirdParty);\n  local_info.date = DayBeforeYesterdayish();\n  pref_manager_->SetLocalWallpaperInfo(account_id_1, local_info);\n\n  client_.ResetCounts();\n\n  controller_->OnActiveUserPrefServiceChanged(\n      GetProfilePrefService(account_id_1));\n  RunAllTasksUntilIdle();\n  WallpaperInfo actual_info;\n  EXPECT_TRUE(pref_manager_->GetUserWallpaperInfo(account_id_1, &actual_info));\n  EXPECT_EQ(WallpaperType::kOnline, actual_info.type);\n}\n\nTEST_F(WallpaperControllerTest, ActiveUserPrefServiceChanged_SyncDisabled) {\n  CacheOnlineWallpaper(kDummyUrl);\n  WallpaperInfo synced_info = {kDummyUrl, WALLPAPER_LAYOUT_CENTER_CROPPED,\n                               WallpaperType::kOnline, base::Time::Now()};\n  synced_info.asset_id = kAssetId;\n  synced_info.collection_id = TestWallpaperControllerClient::kDummyCollectionId;\n  pref_manager_->SetSyncedWallpaperInfo(account_id_1, synced_info);\n\n  WallpaperInfo local_info = InfoWithType(WallpaperType::kThirdParty);\n  local_info.date = DayBeforeYesterdayish();\n  pref_manager_->SetLocalWallpaperInfo(account_id_1, local_info);\n\n  client_.ResetCounts();\n\n  client_.set_wallpaper_sync_enabled(false);\n\n  controller_->OnActiveUserPrefServiceChanged(\n      GetProfilePrefService(account_id_1));\n  WallpaperInfo actual_info;\n  EXPECT_TRUE(pref_manager_->GetUserWallpaperInfo(account_id_1, &actual_info));\n  EXPECT_EQ(WallpaperType::kThirdParty, actual_info.type);\n}\n\nTEST_F(WallpaperControllerTest, HandleWallpaperInfoSyncedLocalIsPolicy) {\n  CacheOnlineWallpaper(kDummyUrl);\n  pref_manager_->SetLocalWallpaperInfo(account_id_1,\n                                       InfoWithType(WallpaperType::kPolicy));\n\n  SimulateUserLogin(account_id_1);\n  WallpaperInfo synced_info = {kDummyUrl, WALLPAPER_LAYOUT_CENTER_CROPPED,\n                               WallpaperType::kOnline, base::Time::Now()};\n  pref_manager_->SetSyncedWallpaperInfo(account_id_1, synced_info);\n  RunAllTasksUntilIdle();\n\n  WallpaperInfo actual_info;\n  EXPECT_TRUE(pref_manager_->GetUserWallpaperInfo(account_id_1, &actual_info));\n  EXPECT_NE(WallpaperType::kOnline, actual_info.type);\n}\n\nTEST_F(WallpaperControllerTest,\n       HandleWallpaperInfoSyncedLocalIsThirdPartyAndOlder) {\n  CacheOnlineWallpaper(kDummyUrl);\n\n  WallpaperInfo local_info = InfoWithType(WallpaperType::kThirdParty);\n  local_info.date = DayBeforeYesterdayish();\n  pref_manager_->SetLocalWallpaperInfo(account_id_1, local_info);\n\n  SimulateUserLogin(account_id_1);\n  WallpaperInfo synced_info = {kDummyUrl, WALLPAPER_LAYOUT_CENTER_CROPPED,\n                               WallpaperType::kOnline, base::Time::Now()};\n  synced_info.asset_id = kAssetId;\n  synced_info.collection_id = TestWallpaperControllerClient::kDummyCollectionId;\n  pref_manager_->SetSyncedWallpaperInfo(account_id_1, synced_info);\n  RunAllTasksUntilIdle();\n\n  WallpaperInfo actual_info;\n  EXPECT_TRUE(pref_manager_->GetUserWallpaperInfo(account_id_1, &actual_info));\n  EXPECT_EQ(WallpaperType::kOnline, actual_info.type);\n}\n\nTEST_F(WallpaperControllerTest,\n       HandleWallpaperInfoSyncedLocalIsThirdPartyAndNewer) {\n  CacheOnlineWallpaper(kDummyUrl);\n  pref_manager_->SetLocalWallpaperInfo(\n      account_id_1, InfoWithType(WallpaperType::kThirdParty));\n\n  WallpaperInfo synced_info = {kDummyUrl, WALLPAPER_LAYOUT_CENTER_CROPPED,\n                               WallpaperType::kOnline, DayBeforeYesterdayish()};\n  pref_manager_->SetSyncedWallpaperInfo(account_id_1, synced_info);\n  SimulateUserLogin(account_id_1);\n  pref_manager_->SetSyncedWallpaperInfo(account_id_1, synced_info);\n  RunAllTasksUntilIdle();\n\n  WallpaperInfo actual_info;\n  EXPECT_TRUE(pref_manager_->GetUserWallpaperInfo(account_id_1, &actual_info));\n  EXPECT_EQ(WallpaperType::kThirdParty, actual_info.type);\n}\n\nTEST_F(WallpaperControllerTest, HandleWallpaperInfoSyncedOnline) {\n  CacheOnlineWallpaper(kDummyUrl);\n\n  // Attempt to set an online wallpaper without providing the image data. Verify\n  // it succeeds this time because |SetOnlineWallpaperFromData| has saved the\n  // file.\n  ClearWallpaperCount();\n  WallpaperInfo info = WallpaperInfo(OnlineWallpaperParams(\n      account_id_1, kAssetId, GURL(kDummyUrl),\n      TestWallpaperControllerClient::kDummyCollectionId,\n      WALLPAPER_LAYOUT_CENTER, /*preview_mode=*/false, /*from_user=*/false,\n      /*daily_refresh_enabled=*/false, kUnitId,\n      std::vector<OnlineWallpaperVariant>()));\n  pref_manager_->SetSyncedWallpaperInfo(account_id_1, info);\n\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kOnline);\n}\n\nTEST_F(WallpaperControllerTest, HandleWallpaperInfoSyncedInactiveUser) {\n  CacheOnlineWallpaper(kDummyUrl);\n\n  // Make account_id_1 the inactive user.\n  SimulateUserLogin(account_id_2);\n\n  // Attempt to set an online wallpaper without providing the image data. Verify\n  // it succeeds this time because |SetOnlineWallpaperFromData| has saved the\n  // file.\n  ClearWallpaperCount();\n  pref_manager_->SetSyncedWallpaperInfo(account_id_1,\n                                        InfoWithType(WallpaperType::kOnline));\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(0, GetWallpaperCount());\n  EXPECT_NE(controller_->GetWallpaperType(), WallpaperType::kOnline);\n}\n\nTEST_F(WallpaperControllerTest, UpdateDailyRefreshWallpaper) {\n  std::string expected{\"fun_collection\"};\n  SimulateUserLogin(account_id_1);\n\n  WallpaperInfo info = {std::string(), WALLPAPER_LAYOUT_CENTER,\n                        WallpaperType::kDaily, DayBeforeYesterdayish()};\n  info.asset_id = kAssetId;\n  info.collection_id = expected;\n  pref_manager_->SetUserWallpaperInfo(account_id_1, info);\n\n  controller_->UpdateDailyRefreshWallpaperForTesting();\n  EXPECT_EQ(expected, client_.get_fetch_daily_refresh_wallpaper_param());\n}\n\n// Disabled due to flakes; see crbug/1320991.\nTEST_F(WallpaperControllerTest,\n       DISABLED_UpdateDailyRefreshWallpaperCalledOnLogin) {\n  SimulateUserLogin(account_id_1);\n\n  WallpaperInfo info = WallpaperInfo(OnlineWallpaperParams(\n      account_id_1, kAssetId, GURL(kDummyUrl),\n      TestWallpaperControllerClient::kDummyCollectionId,\n      WALLPAPER_LAYOUT_CENTER_CROPPED, /*preview_mode=*/false,\n      /*from_user=*/false,\n      /*daily_refresh_enabled=*/true, kUnitId,\n      /*variants=*/std::vector<OnlineWallpaperVariant>()));\n  info.date = DayBeforeYesterdayish();\n  pref_manager_->SetUserWallpaperInfo(account_id_1, info);\n\n  ClearLogin();\n  SimulateUserLogin(account_id_1);\n\n  // Info is set as over a day old so we expect one task to run in under an hour\n  // (due to fuzzing) then it will idle.\n  task_environment()->FastForwardBy(base::Hours(1));\n\n  EXPECT_EQ(TestWallpaperControllerClient::kDummyCollectionId,\n            client_.get_fetch_daily_refresh_wallpaper_param());\n}\n\nTEST_F(WallpaperControllerTest, UpdateDailyRefreshWallpaper_NotEnabled) {\n  SimulateUserLogin(account_id_1);\n  WallpaperInfo info = {std::string(), WALLPAPER_LAYOUT_CENTER,\n                        WallpaperType::kOnline, DayBeforeYesterdayish()};\n  info.collection_id = \"fun_collection\";\n  pref_manager_->SetUserWallpaperInfo(account_id_1, info);\n\n  controller_->UpdateDailyRefreshWallpaperForTesting();\n  EXPECT_EQ(std::string(), client_.get_fetch_daily_refresh_wallpaper_param());\n}\n\nTEST_F(WallpaperControllerTest, UpdateDailyRefreshWallpaper_NoCollectionId) {\n  SimulateUserLogin(account_id_1);\n  pref_manager_->SetUserWallpaperInfo(\n      account_id_1,\n      WallpaperInfo(std::string(), WALLPAPER_LAYOUT_CENTER,\n                    WallpaperType::kDaily, DayBeforeYesterdayish()));\n\n  controller_->UpdateDailyRefreshWallpaperForTesting();\n  EXPECT_EQ(std::string(), client_.get_fetch_daily_refresh_wallpaper_param());\n}\n\nTEST_F(WallpaperControllerTest,\n       UpdateDailyRefreshWallpaper_TimerStartsOnPrefServiceChange) {\n  using base::Time;\n\n  SimulateUserLogin(account_id_1);\n  WallpaperInfo info = {std::string(), WALLPAPER_LAYOUT_CENTER,\n                        WallpaperType::kDaily,\n                        base::Time::Now().LocalMidnight()};\n  info.collection_id = \"fun_collection\";\n  pref_manager_->SetUserWallpaperInfo(account_id_1, info);\n\n  controller_->OnActiveUserPrefServiceChanged(\n      GetProfilePrefService(account_id_1));\n\n  Time run_time =\n      controller_->GetUpdateWallpaperTimerForTesting().desired_run_time();\n  base::TimeDelta delta = run_time.ToDeltaSinceWindowsEpoch();\n\n  base::TimeDelta update_time =\n      Time::Now().LocalMidnight().ToDeltaSinceWindowsEpoch() + base::Days(1);\n\n  ASSERT_GE(delta, update_time - base::Minutes(1));\n  ASSERT_LE(delta, update_time + base::Hours(1) + base::Minutes(1));\n}\n\nTEST_F(WallpaperControllerTest,\n       UpdateDailyRefreshWallpaper_RetryTimerTriggersOnFailedFetchInfo) {\n  using base::Time;\n\n  client_.set_fetch_daily_refresh_info_fails(true);\n\n  SimulateUserLogin(account_id_1);\n\n  WallpaperInfo info = {std::string(), WALLPAPER_LAYOUT_CENTER,\n                        WallpaperType::kDaily, DayBeforeYesterdayish()};\n  info.collection_id = \"fun_collection\";\n  pref_manager_->SetUserWallpaperInfo(account_id_1, info);\n\n  controller_->UpdateDailyRefreshWallpaperForTesting();\n  Time run_time =\n      controller_->GetUpdateWallpaperTimerForTesting().desired_run_time();\n  base::TimeDelta delay = run_time - Time::Now();\n\n  base::TimeDelta one_hour = base::Hours(1);\n  // Lave a little wiggle room.\n  ASSERT_GE(delay, one_hour - base::Minutes(1));\n  ASSERT_LE(delay, one_hour + base::Minutes(1));\n}\n\nTEST_F(WallpaperControllerTest,\n       UpdateDailyRefreshWallpaper_RetryTimerTriggersOnFailedFetchData) {\n  using base::Time;\n\n  SimulateUserLogin(account_id_1);\n\n  WallpaperInfo info = {std::string(), WALLPAPER_LAYOUT_CENTER,\n                        WallpaperType::kDaily, DayBeforeYesterdayish()};\n  info.collection_id = \"fun_collection\";\n  pref_manager_->SetUserWallpaperInfo(account_id_1, info);\n\n  test_image_downloader_->set_should_fail(true);\n\n  controller_->UpdateDailyRefreshWallpaperForTesting();\n\n  RunAllTasksUntilIdle();\n\n  Time run_time =\n      controller_->GetUpdateWallpaperTimerForTesting().desired_run_time();\n  base::TimeDelta delay = run_time - Time::Now();\n\n  base::TimeDelta one_hour = base::Hours(1);\n  // Lave a little wiggle room.\n  ASSERT_GE(delay, one_hour - base::Minutes(1));\n  ASSERT_LE(delay, one_hour + base::Minutes(1));\n}\n\nTEST_F(WallpaperControllerTest, MigrateCustomWallpaper) {\n  gfx::ImageSkia image = CreateImage(640, 480, kWallpaperColor);\n  WallpaperLayout layout = WALLPAPER_LAYOUT_CENTER;\n\n  SimulateUserLogin(account_id_1);\n\n  controller_->SetCustomWallpaper(account_id_1, file_name_1, layout, image,\n                                  false /*preview_mode=*/);\n  RunAllTasksUntilIdle();\n  ClearLogin();\n\n  SimulateUserLogin(account_id_1);\n  EXPECT_EQ(account_id_1, client_.get_save_wallpaper_to_drive_fs_account_id());\n}\n\nTEST_F(WallpaperControllerTest, OnGoogleDriveMounted) {\n  WallpaperInfo local_info = InfoWithType(WallpaperType::kCustomized);\n  pref_manager_->SetLocalWallpaperInfo(account_id_1, local_info);\n\n  SimulateUserLogin(account_id_1);\n  controller_->SyncLocalAndRemotePrefs(account_id_1);\n  EXPECT_EQ(account_id_1, client_.get_save_wallpaper_to_drive_fs_account_id());\n}\n\nTEST_F(WallpaperControllerTest, OnGoogleDriveMounted_WallpaperIsntCustom) {\n  WallpaperInfo local_info = InfoWithType(WallpaperType::kOnline);\n  pref_manager_->SetLocalWallpaperInfo(account_id_1, local_info);\n\n  controller_->SyncLocalAndRemotePrefs(account_id_1);\n  EXPECT_TRUE(client_.get_save_wallpaper_to_drive_fs_account_id().empty());\n}\n\nTEST_F(WallpaperControllerTest, OnGoogleDriveMounted_AlreadySynced) {\n  WallpaperInfo local_info = InfoWithType(WallpaperType::kCustomized);\n  pref_manager_->SetLocalWallpaperInfo(account_id_1, local_info);\n\n  SimulateUserLogin(account_id_1);\n\n  gfx::ImageSkia image = CreateImage(640, 480, kWallpaperColor);\n  WallpaperLayout layout = WALLPAPER_LAYOUT_CENTER;\n\n  controller_->SetCustomWallpaper(account_id_1, file_name_1, layout, image,\n                                  false /*preview_mode=*/);\n  RunAllTasksUntilIdle();\n\n  client_.ResetCounts();\n\n  // Should not reupload image if it has already been synced.\n  controller_->SyncLocalAndRemotePrefs(account_id_1);\n  EXPECT_FALSE(client_.get_save_wallpaper_to_drive_fs_account_id().is_valid());\n}\n\nTEST_F(WallpaperControllerTest, OnGoogleDriveMounted_OldLocalInfo) {\n  WallpaperInfo local_info =\n      WallpaperInfo(\"a_url\", WALLPAPER_LAYOUT_CENTER_CROPPED,\n                    WallpaperType::kCustomized, DayBeforeYesterdayish());\n  pref_manager_->SetLocalWallpaperInfo(account_id_1, local_info);\n\n  WallpaperInfo synced_info = WallpaperInfo(\n      \"b_url\", WALLPAPER_LAYOUT_CENTER_CROPPED, WallpaperType::kCustomized,\n      base::Time::Now().LocalMidnight());\n  pref_manager_->SetSyncedWallpaperInfo(account_id_1, synced_info);\n  SimulateUserLogin(account_id_1);\n\n  controller_->SyncLocalAndRemotePrefs(account_id_1);\n  EXPECT_FALSE(client_.get_save_wallpaper_to_drive_fs_account_id().is_valid());\n  // This is called by WallpaperController::HandleCustomWallpaperSyncedIn.\n  EXPECT_EQ(client_.get_wallpaper_path_from_drive_fs_account_id(),\n            account_id_1);\n}\n\nTEST_F(WallpaperControllerTest, OnGoogleDriveMounted_NewLocalInfo) {\n  WallpaperInfo local_info = WallpaperInfo(\n      \"a_url\", WALLPAPER_LAYOUT_CENTER_CROPPED, WallpaperType::kCustomized,\n      base::Time::Now().LocalMidnight());\n  pref_manager_->SetLocalWallpaperInfo(account_id_1, local_info);\n\n  WallpaperInfo synced_info =\n      WallpaperInfo(\"b_url\", WALLPAPER_LAYOUT_CENTER_CROPPED,\n                    WallpaperType::kCustomized, DayBeforeYesterdayish());\n  pref_manager_->SetSyncedWallpaperInfo(account_id_1, synced_info);\n\n  SimulateUserLogin(account_id_1);\n\n  controller_->SyncLocalAndRemotePrefs(account_id_1);\n  EXPECT_EQ(account_id_1, client_.get_save_wallpaper_to_drive_fs_account_id());\n}\n\nTEST_F(WallpaperControllerTest, SetDailyRefreshCollectionId) {\n  pref_manager_->SetUserWallpaperInfo(\n      account_id_1,\n      WallpaperInfo(std::string(), WALLPAPER_LAYOUT_CENTER,\n                    WallpaperType::kOnline, DayBeforeYesterdayish()));\n\n  std::string collection_id = \"fun_collection\";\n  controller_->SetDailyRefreshCollectionId(account_id_1, collection_id);\n  WallpaperInfo expected = {std::string(), WALLPAPER_LAYOUT_CENTER,\n                            WallpaperType::kDaily, DayBeforeYesterdayish()};\n  expected.collection_id = collection_id;\n\n  WallpaperInfo actual;\n  pref_manager_->GetUserWallpaperInfo(account_id_1, &actual);\n  // Type should be `WallpaperType::kDaily` now, and collection_id should be\n  // updated.\n  EXPECT_EQ(expected, actual);\n  EXPECT_EQ(collection_id,\n            controller_->GetDailyRefreshCollectionId(account_id_1));\n}\n\nTEST_F(WallpaperControllerTest, SetDailyRefreshCollectionId_Empty) {\n  std::string collection_id = \"fun_collection\";\n  WallpaperInfo info = {std::string(), WALLPAPER_LAYOUT_CENTER,\n                        WallpaperType::kDaily, DayBeforeYesterdayish()};\n  info.collection_id = collection_id;\n  pref_manager_->SetUserWallpaperInfo(account_id_1, info);\n\n  controller_->SetDailyRefreshCollectionId(account_id_1, std::string());\n  WallpaperInfo expected = {std::string(), WALLPAPER_LAYOUT_CENTER,\n                            WallpaperType::kOnline, DayBeforeYesterdayish()};\n  expected.collection_id = collection_id;\n\n  WallpaperInfo actual;\n  pref_manager_->GetUserWallpaperInfo(account_id_1, &actual);\n  // Type should be `WallpaperType::kOnline` now, and collection_id should be\n  // `WallpaperType::EMPTY`.\n  EXPECT_EQ(expected, actual);\n  EXPECT_EQ(std::string(),\n            controller_->GetDailyRefreshCollectionId(account_id_1));\n}\n\n// WallpaperType should not change with an empty collection id if the previous\n// WallpaperType isn't |WallpaperType::kDaily|.\nTEST_F(WallpaperControllerTest,\n       SetDailyRefreshCollectionId_Empty_NotTypeDaily) {\n  pref_manager_->SetUserWallpaperInfo(\n      account_id_1,\n      WallpaperInfo(std::string(), WALLPAPER_LAYOUT_CENTER,\n                    WallpaperType::kCustomized, DayBeforeYesterdayish()));\n\n  controller_->SetDailyRefreshCollectionId(account_id_1, std::string());\n  WallpaperInfo expected =\n      WallpaperInfo(std::string(), WALLPAPER_LAYOUT_CENTER,\n                    WallpaperType::kCustomized, DayBeforeYesterdayish());\n\n  WallpaperInfo actual;\n  pref_manager_->GetUserWallpaperInfo(account_id_1, &actual);\n  EXPECT_EQ(expected, actual);\n  EXPECT_EQ(std::string(),\n            controller_->GetDailyRefreshCollectionId(account_id_1));\n}\n\nTEST_F(WallpaperControllerTest, UpdateWallpaperOnColorModeChanged) {\n  SimulateUserLogin(account_id_1);\n\n  auto run_loop = std::make_unique<base::RunLoop>();\n  ClearWallpaperCount();\n  std::vector<OnlineWallpaperVariant> variants;\n  variants.emplace_back(kAssetId, GURL(kDummyUrl),\n                        backdrop::Image::IMAGE_TYPE_DARK_MODE);\n  variants.emplace_back(kAssetId2, GURL(kDummyUrl2),\n                        backdrop::Image::IMAGE_TYPE_LIGHT_MODE);\n  const OnlineWallpaperParams& params =\n      OnlineWallpaperParams(account_id_1, kAssetId, GURL(kDummyUrl),\n                            TestWallpaperControllerClient::kDummyCollectionId,\n                            WALLPAPER_LAYOUT_CENTER_CROPPED,\n                            /*preview_mode=*/false, /*from_user=*/true,\n                            /*daily_refresh_enabled=*/false, kUnitId, variants);\n  controller_->SetOnlineWallpaper(\n      params, base::BindLambdaForTesting([&run_loop](bool success) {\n        EXPECT_TRUE(success);\n        run_loop->Quit();\n      }));\n  run_loop->Run();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kOnline);\n\n  pref_manager_->SetUserWallpaperInfo(account_id_1, WallpaperInfo(params));\n  Shell::Get()->session_controller()->GetActivePrefService()->SetBoolean(\n      prefs::kDarkModeEnabled, true);\n  controller_->OnColorModeChanged(true);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(2, GetWallpaperCount());\n\n  WallpaperInfo expected = WallpaperInfo(OnlineWallpaperParams(\n      account_id_1, kAssetId, GURL(kDummyUrl),\n      TestWallpaperControllerClient::kDummyCollectionId,\n      WALLPAPER_LAYOUT_CENTER_CROPPED, /*preview_mode=*/false,\n      /*from_user=*/true,\n      /*daily_refresh_enabled=*/false, kUnitId, variants));\n  WallpaperInfo actual;\n  EXPECT_TRUE(pref_manager_->GetUserWallpaperInfo(account_id_1, &actual));\n  EXPECT_EQ(expected, actual);\n}\n\nTEST_F(WallpaperControllerTest,\n       UpdateDailyWallpaperVariantOnColorModeChanged_RefreshTimerDoesntReset) {\n  using base::Time;\n\n  SimulateUserLogin(account_id_1);\n  // Resets the count as user will start with a default image after login.\n  ClearWallpaperCount();\n\n  std::vector<OnlineWallpaperVariant> variants;\n  variants.emplace_back(kAssetId, GURL(kDummyUrl),\n                        backdrop::Image::IMAGE_TYPE_DARK_MODE);\n  variants.emplace_back(kAssetId2, GURL(kDummyUrl2),\n                        backdrop::Image::IMAGE_TYPE_LIGHT_MODE);\n  const OnlineWallpaperParams& params =\n      OnlineWallpaperParams(account_id_1, kAssetId, GURL(kDummyUrl),\n                            TestWallpaperControllerClient::kDummyCollectionId,\n                            WALLPAPER_LAYOUT_CENTER_CROPPED,\n                            /*preview_mode=*/false, /*from_user=*/true,\n                            /*daily_refresh_enabled=*/true, kUnitId, variants);\n  const WallpaperInfo info = WallpaperInfo(params);\n  pref_manager_->SetUserWallpaperInfo(account_id_1, info);\n\n  // Set a new daily wallpaper.\n  controller_->UpdateDailyRefreshWallpaperForTesting();\n  RunAllTasksUntilIdle();\n\n  Time run_time =\n      controller_->GetUpdateWallpaperTimerForTesting().desired_run_time();\n  base::TimeDelta delay = run_time - Time::Now();\n  base::TimeDelta one_day = base::Days(1);\n  // Leave a little wiggle room, as well as account for the hour fuzzing that\n  // we do.\n  EXPECT_GE(delay, one_day - base::Minutes(1));\n  EXPECT_LE(delay, one_day + base::Minutes(61));\n\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDaily);\n\n  // Fast forward by one hour and attempt a system's color mode change.\n  task_environment()->FastForwardBy(base::Hours(1));\n  Shell::Get()->dark_light_mode_controller()->ToggleColorMode();\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(2, GetWallpaperCount());\n  // Expect the refresh timer doesn't reset.\n  EXPECT_EQ(\n      run_time,\n      controller_->GetUpdateWallpaperTimerForTesting().desired_run_time());\n\n  WallpaperInfo actual;\n  EXPECT_TRUE(pref_manager_->GetUserWallpaperInfo(account_id_1, &actual));\n  EXPECT_EQ(info, actual);\n}\n\nTEST_F(WallpaperControllerTest,\n       UpdateWallpaperInfoWithOnlineWallpaperVariants) {\n  SimulateUserLogin(account_id_1);\n\n  // auto run_loop = std::make_unique<base::RunLoop>();\n  std::vector<OnlineWallpaperVariant> variants;\n  variants.emplace_back(kAssetId, GURL(kDummyUrl),\n                        backdrop::Image::IMAGE_TYPE_LIGHT_MODE);\n  variants.emplace_back(kAssetId2, GURL(kDummyUrl2),\n                        backdrop::Image::IMAGE_TYPE_DARK_MODE);\n  const OnlineWallpaperParams& params =\n      OnlineWallpaperParams(account_id_1, kAssetId, GURL(kDummyUrl),\n                            TestWallpaperControllerClient::kDummyCollectionId,\n                            WALLPAPER_LAYOUT_CENTER_CROPPED,\n                            /*preview_mode=*/false, /*from_user=*/true,\n                            /*daily_refresh_enabled=*/false, kUnitId, variants);\n\n  pref_manager_->SetUserWallpaperInfo(account_id_1, WallpaperInfo(params));\n  WallpaperInfo expected = WallpaperInfo(params);\n  WallpaperInfo actual;\n  pref_manager_->GetUserWallpaperInfo(account_id_1, &actual);\n  EXPECT_EQ(expected, actual);\n}\n\nTEST_F(WallpaperControllerTest, SetOnlineWallpaperIfExists) {\n  SetBypassDecode();\n  gfx::ImageSkia image = CreateImage(640, 480, kWallpaperColor);\n  WallpaperLayout layout = WALLPAPER_LAYOUT_CENTER_CROPPED;\n  std::vector<OnlineWallpaperVariant> variants;\n  variants.emplace_back(kAssetId, GURL(kDummyUrl),\n                        backdrop::Image::IMAGE_TYPE_UNKNOWN);\n  SimulateUserLogin(account_id_1);\n\n  // Verify that calling |SetOnlineWallpaperIfExists| without providing image\n  // data fails.\n  std::unique_ptr<base::RunLoop> run_loop = std::make_unique<base::RunLoop>();\n  ClearWallpaperCount();\n  const OnlineWallpaperParams& params = OnlineWallpaperParams(\n      account_id_1, kAssetId, GURL(kDummyUrl),\n      TestWallpaperControllerClient::kDummyCollectionId, layout,\n      /*preview_mode=*/false, /*from_user=*/true,\n      /*daily_refresh_enabled=*/false, kUnitId, variants);\n  controller_->SetOnlineWallpaperIfExists(\n      params, base::BindLambdaForTesting([&run_loop](bool file_exists) {\n        EXPECT_FALSE(file_exists);\n        run_loop->Quit();\n      }));\n  run_loop->Run();\n  EXPECT_EQ(0, GetWallpaperCount());\n\n  // Set an online wallpaper with image data. Verify that the wallpaper is set\n  // successfully.\n  ClearWallpaperCount();\n  controller_->SetOnlineWallpaperFromData(\n      params,\n      /*image_data=*/std::string(),\n      WallpaperController::SetWallpaperCallback());\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kOnline);\n  // Verify that the user wallpaper info is updated.\n  WallpaperInfo wallpaper_info;\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  WallpaperInfo expected_wallpaper_info = WallpaperInfo(params);\n  EXPECT_EQ(wallpaper_info, expected_wallpaper_info);\n\n  // Change the on-screen wallpaper to a different one. (Otherwise the\n  // subsequent calls will be no-op since we intentionally prevent reloading the\n  // same wallpaper.)\n  ClearWallpaperCount();\n  controller_->SetCustomWallpaper(account_id_1, file_name_1, layout,\n                                  CreateImage(640, 480, kWallpaperColor),\n                                  /*preview_mode=*/false);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kCustomized);\n\n  // Attempt to set an online wallpaper via |SetOnlineWallpaperIfExists| without\n  // providing the image data. Verify it succeeds this time because\n  // |SetOnlineWallpaperFromData| has saved the file.\n  ClearWallpaperCount();\n  run_loop = std::make_unique<base::RunLoop>();\n  controller_->SetOnlineWallpaperIfExists(\n      OnlineWallpaperParams(account_id_1, kAssetId, GURL(kDummyUrl),\n                            TestWallpaperControllerClient::kDummyCollectionId,\n                            layout,\n                            /*preview_mode=*/false, /*from_user=*/true,\n                            /*daily_refresh_enabled=*/false, kUnitId, variants),\n      base::BindLambdaForTesting([&run_loop](bool file_exists) {\n        EXPECT_TRUE(file_exists);\n        run_loop->Quit();\n      }));\n  run_loop->Run();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kOnline);\n}\n\nTEST_F(WallpaperControllerTest,\n       HandleWallpaperInfoSyncedForDarkLightWallpapers_NotSynced) {\n  SimulateUserLogin(account_id_1);\n  CacheOnlineWallpaper(kDummyUrl);\n  ClearWallpaperCount();\n\n  std::vector<OnlineWallpaperVariant> variants;\n  variants.emplace_back(kAssetId, GURL(kDummyUrl),\n                        backdrop::Image::IMAGE_TYPE_LIGHT_MODE);\n  variants.emplace_back(kAssetId2, GURL(kDummyUrl2),\n                        backdrop::Image::IMAGE_TYPE_DARK_MODE);\n  const OnlineWallpaperParams& params =\n      OnlineWallpaperParams(account_id_1, kAssetId, GURL(kDummyUrl),\n                            TestWallpaperControllerClient::kDummyCollectionId,\n                            WALLPAPER_LAYOUT_CENTER_CROPPED,\n                            /*preview_mode=*/false, /*from_user=*/true,\n                            /*daily_refresh_enabled=*/false, kUnitId, variants);\n  // Force local info to not have a unit_id.\n  WallpaperInfo local_info = WallpaperInfo(params);\n  local_info.unit_id = absl::nullopt;\n  pref_manager_->SetLocalWallpaperInfo(account_id_1, local_info);\n\n  const OnlineWallpaperParams& params2 =\n      OnlineWallpaperParams(account_id_1, kAssetId2, GURL(kDummyUrl2),\n                            TestWallpaperControllerClient::kDummyCollectionId,\n                            WALLPAPER_LAYOUT_CENTER_CROPPED,\n                            /*preview_mode=*/false, /*from_user=*/true,\n                            /*daily_refresh_enabled=*/false, kUnitId, variants);\n  // synced info tracks dark variant.\n  const WallpaperInfo& synced_info = WallpaperInfo(params2);\n  pref_manager_->SetSyncedWallpaperInfo(account_id_1, synced_info);\n  RunAllTasksUntilIdle();\n\n  WallpaperInfo actual_info;\n  EXPECT_TRUE(pref_manager_->GetUserWallpaperInfo(account_id_1, &actual_info));\n  EXPECT_EQ(synced_info, actual_info);\n  // Verify the wallpaper is set.\n  EXPECT_EQ(1, GetWallpaperCount());\n}\n\nTEST_F(WallpaperControllerTest,\n       HandleWallpaperInfoSyncedForDarkLightWallpapers_AlreadySynced) {\n  SimulateUserLogin(account_id_1);\n  CacheOnlineWallpaper(kDummyUrl);\n  ClearWallpaperCount();\n\n  std::vector<OnlineWallpaperVariant> variants;\n  variants.emplace_back(kAssetId, GURL(kDummyUrl),\n                        backdrop::Image::IMAGE_TYPE_LIGHT_MODE);\n  variants.emplace_back(kAssetId2, GURL(kDummyUrl2),\n                        backdrop::Image::IMAGE_TYPE_DARK_MODE);\n  const OnlineWallpaperParams& params =\n      OnlineWallpaperParams(account_id_1, kAssetId, GURL(kDummyUrl),\n                            TestWallpaperControllerClient::kDummyCollectionId,\n                            WALLPAPER_LAYOUT_CENTER_CROPPED,\n                            /*preview_mode=*/false, /*from_user=*/true,\n                            /*daily_refresh_enabled=*/false, kUnitId, variants);\n  // local info tracks light variant.\n  const WallpaperInfo& local_info = WallpaperInfo(params);\n  pref_manager_->SetLocalWallpaperInfo(account_id_1, local_info);\n\n  const OnlineWallpaperParams& params2 =\n      OnlineWallpaperParams(account_id_1, kAssetId2, GURL(kDummyUrl2),\n                            TestWallpaperControllerClient::kDummyCollectionId,\n                            WALLPAPER_LAYOUT_CENTER_CROPPED,\n                            /*preview_mode=*/false, /*from_user=*/true,\n                            /*daily_refresh_enabled=*/false, kUnitId, variants);\n  // synced info tracks dark variant.\n  const WallpaperInfo& synced_info = WallpaperInfo(params2);\n  pref_manager_->SetSyncedWallpaperInfo(account_id_1, synced_info);\n  RunAllTasksUntilIdle();\n\n  WallpaperInfo actual_info;\n  EXPECT_TRUE(pref_manager_->GetUserWallpaperInfo(account_id_1, &actual_info));\n  EXPECT_EQ(local_info, synced_info);\n  EXPECT_EQ(local_info, actual_info);\n  // Verify the wallpaper is not set again.\n  EXPECT_EQ(0, GetWallpaperCount());\n}\n\nTEST_F(WallpaperControllerTest, WallpaperCustomization_Used) {\n  // Reset to login screen.\n  GetSessionControllerClient()->RequestSignOut();\n\n  // Emulate login screen behavior.\n  controller_->ShowSigninWallpaper();\n  // Let the task queue run so that we run `ShowWallpaperImage()`.\n  task_environment()->RunUntilIdle();\n\n  std::pair<const base::FilePath, const base::FilePath> paths =\n      CreateCustomizationWallpapers();\n  ASSERT_FALSE(paths.first.empty());\n  ASSERT_FALSE(paths.second.empty());\n\n  SetBypassDecode();\n  controller_->SetCustomizedDefaultWallpaperPaths(paths.first, paths.second);\n  task_environment()->RunUntilIdle();\n\n  // Verify that the customized wallpaper is in use.\n  EXPECT_THAT(GetCurrentWallpaperInfo().location,\n              testing::EndsWith(kCustomizationSmallWallpaperName));\n}\n\nTEST_F(WallpaperControllerTest, WallpaperCustomization_UnusedForNonDefault) {\n  SetBypassDecode();\n  SimulateUserLogin(account_id_1);\n\n  // Set wallpaper to something a user may have chose.\n  controller_->SetOnlineWallpaperFromData(\n      OnlineWallpaperParams(account_id_1, kAssetId, GURL(kDummyUrl),\n                            /*collection_id=*/std::string(),\n                            WALLPAPER_LAYOUT_CENTER,\n                            /*preview_mode=*/false, /*from_user=*/false,\n                            /*daily_refresh_enabled=*/false, kUnitId,\n                            /*variants=*/std::vector<OnlineWallpaperVariant>()),\n      /*image_data=*/std::string(),\n      WallpaperController::SetWallpaperCallback());\n  // Let the task queue run so that we run `ShowWallpaperImage()`.\n  task_environment()->RunUntilIdle();\n\n  // Simulate wallpaper customization retrieval completing after login.\n  std::pair<const base::FilePath, const base::FilePath> paths =\n      CreateCustomizationWallpapers();\n  ASSERT_FALSE(paths.first.empty());\n  ASSERT_FALSE(paths.second.empty());\n\n  controller_->SetCustomizedDefaultWallpaperPaths(paths.first, paths.second);\n  task_environment()->RunUntilIdle();\n\n  // Verify that we still use the online wallpaper. i.e. did not switch to\n  // default.\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kOnline);\n}\n\nclass WallpaperControllerGooglePhotosWallpaperTest\n    : public WallpaperControllerTest,\n      public testing::WithParamInterface<bool> {\n public:\n  WallpaperControllerGooglePhotosWallpaperTest() {\n    if (GooglePhotosEnabled()) {\n      scoped_feature_list_.InitWithFeatures(\n          {ash::features::kWallpaperGooglePhotosIntegration}, {});\n    } else {\n      scoped_feature_list_.InitWithFeatures(\n          {}, {ash::features::kWallpaperGooglePhotosIntegration});\n    }\n  }\n\n  WallpaperControllerGooglePhotosWallpaperTest(\n      const WallpaperControllerGooglePhotosWallpaperTest&) = delete;\n  WallpaperControllerGooglePhotosWallpaperTest& operator=(\n      const WallpaperControllerGooglePhotosWallpaperTest&) = delete;\n\n  ~WallpaperControllerGooglePhotosWallpaperTest() override = default;\n\n  bool GooglePhotosEnabled() const { return GetParam(); }\n\n  void WaitForWallpaperCount(int count) {\n    base::RunLoop run_loop;\n    base::RepeatingTimer repeating_timer;\n    repeating_timer.Start(FROM_HERE, base::Milliseconds(10),\n                          base::BindLambdaForTesting([&]() {\n                            if (GetWallpaperCount() >= count) {\n                              repeating_timer.Stop();\n                              run_loop.Quit();\n                            }\n                          }));\n    run_loop.Run();\n  }\n\n private:\n  base::test::ScopedFeatureList scoped_feature_list_;\n};\n\nINSTANTIATE_TEST_SUITE_P(All,\n                         WallpaperControllerGooglePhotosWallpaperTest,\n                         testing::Bool());\n\nTEST_P(WallpaperControllerGooglePhotosWallpaperTest, SetGooglePhotosWallpaper) {\n  bool feature_enabled = GooglePhotosEnabled();\n  SimulateUserLogin(account_id_1);\n\n  // First set the wallpaper to an Online one so we can tell for sure if setting\n  // a Google Photos wallpaper has failed.\n  base::test::TestFuture<bool> online_future;\n  controller_->SetOnlineWallpaper(\n      {account_id_1,\n       kAssetId,\n       GURL(kDummyUrl),\n       TestWallpaperControllerClient::kDummyCollectionId,\n       WALLPAPER_LAYOUT_CENTER_CROPPED,\n       /*preview_mode=*/false,\n       /*from_user=*/true,\n       /*daily_refresh_enabled=*/false,\n       kUnitId,\n       {}},\n      online_future.GetCallback());\n  ASSERT_TRUE(online_future.Wait());\n  ASSERT_EQ(1, GetWallpaperCount());\n  ASSERT_EQ(controller_->GetWallpaperType(), WallpaperType::kOnline);\n\n  // Now attempt setting a Google Photos wallpaper.\n  ClearWallpaperCount();\n  int expected_wallpaper_count = 0;\n  ASSERT_EQ(expected_wallpaper_count, GetWallpaperCount());\n  GooglePhotosWallpaperParams params(account_id_1, kFakeGooglePhotosPhotoId,\n                                     /*daily_refresh_enabled=*/false,\n                                     WallpaperLayout::WALLPAPER_LAYOUT_STRETCH,\n                                     /*preview_mode=*/false, \"dedup_key\");\n\n  controller_->SetGooglePhotosWallpaper(params, base::DoNothing());\n  if (feature_enabled)\n    ++expected_wallpaper_count;\n\n  WaitForWallpaperCount(expected_wallpaper_count);\n\n  EXPECT_EQ(feature_enabled, controller_->GetWallpaperType() ==\n                                 WallpaperType::kOnceGooglePhotos);\n\n  WallpaperInfo wallpaper_info;\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  WallpaperInfo expected_wallpaper_info(params);\n  EXPECT_EQ(feature_enabled, wallpaper_info == expected_wallpaper_info);\n}\n\nTEST_P(WallpaperControllerGooglePhotosWallpaperTest,\n       SetGooglePhotosWallpaperFails) {\n  SimulateUserLogin(account_id_1);\n\n  // First set the wallpaper to an Online one so we can tell for sure if setting\n  // a Google Photos wallpaper has failed.\n  base::test::TestFuture<bool> online_future;\n  OnlineWallpaperParams online_params(\n      {account_id_1,\n       kAssetId,\n       GURL(kDummyUrl),\n       TestWallpaperControllerClient::kDummyCollectionId,\n       WALLPAPER_LAYOUT_CENTER_CROPPED,\n       /*preview_mode=*/false,\n       /*from_user=*/true,\n       /*daily_refresh_enabled=*/false,\n       kUnitId,\n       {}});\n  controller_->SetOnlineWallpaper(online_params, online_future.GetCallback());\n  ASSERT_TRUE(online_future.Wait());\n  ASSERT_EQ(1, GetWallpaperCount());\n  ASSERT_EQ(controller_->GetWallpaperType(), WallpaperType::kOnline);\n\n  // Attempt to set a Google Photos wallpaper with the client set to fail to\n  // fetch the Google Photos photo data.\n  client_.set_fetch_google_photos_photo_fails(true);\n  ClearWallpaperCount();\n  ASSERT_EQ(0, GetWallpaperCount());\n  base::test::TestFuture<bool> google_photos_future;\n  controller_->SetGooglePhotosWallpaper(\n      {account_id_1, kFakeGooglePhotosPhotoId, false,\n       WallpaperLayout::WALLPAPER_LAYOUT_STRETCH, false, \"dedup_key\"},\n      google_photos_future.GetCallback());\n  EXPECT_FALSE(google_photos_future.Get());\n  EXPECT_NE(controller_->GetWallpaperType(), WallpaperType::kOnceGooglePhotos);\n\n  WallpaperInfo wallpaper_info;\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  WallpaperInfo expected_wallpaper_info(online_params);\n  EXPECT_EQ(wallpaper_info, expected_wallpaper_info);\n}\n\nTEST_P(WallpaperControllerGooglePhotosWallpaperTest,\n       RetryTimerTriggersOnFailedFetchPhotoForStalenessCheck) {\n  using base::Time;\n\n  SimulateUserLogin(account_id_1);\n\n  GooglePhotosWallpaperParams params(account_id_1, kFakeGooglePhotosPhotoId,\n                                     /*daily_refresh_enabled=*/false,\n                                     WallpaperLayout::WALLPAPER_LAYOUT_STRETCH,\n                                     /*preview_mode=*/false,\n                                     /*dedup_key=*/absl::nullopt);\n  controller_->SetGooglePhotosWallpaper(params, base::DoNothing());\n  task_environment()->RunUntilIdle();\n\n  Time run_time =\n      controller_->GetUpdateWallpaperTimerForTesting().desired_run_time();\n  base::TimeDelta delay = run_time - Time::Now();\n\n  // If the feature is disabled, setting a GooglePhotos wallpaper is a nop.\n  if (GooglePhotosEnabled()) {\n    base::TimeDelta one_day = base::Days(1);\n    // Leave a little wiggle room, as well as account for the hour fuzzing that\n    // we do.\n    EXPECT_GE(delay, one_day - base::Minutes(1));\n    EXPECT_LE(delay, one_day + base::Minutes(61));\n  } else {\n    EXPECT_FALSE(controller_->GetUpdateWallpaperTimerForTesting().IsRunning());\n  }\n\n  client_.set_fetch_google_photos_photo_fails(true);\n\n  // Trigger Google Photos wallpaper cache check.\n  controller_->OnActiveUserSessionChanged(account_id_1);\n\n  run_time =\n      controller_->GetUpdateWallpaperTimerForTesting().desired_run_time();\n  delay = run_time - Time::Now();\n\n  base::TimeDelta one_hour = base::Hours(1);\n\n  // The cache check does not happen when the feature is disabled, since the\n  // local `WallpaperInfo` is rejected.\n  if (GooglePhotosEnabled()) {\n    // Leave a little wiggle room.\n    EXPECT_GE(delay, one_hour - base::Minutes(1));\n    EXPECT_LE(delay, one_hour + base::Minutes(1));\n  }\n}\n\nTEST_P(WallpaperControllerGooglePhotosWallpaperTest,\n       ResetToDefaultForDeletedPhotoOnStalenessCheck) {\n  SimulateUserLogin(account_id_1);\n\n  WallpaperInfo info = {kFakeGooglePhotosPhotoId, WALLPAPER_LAYOUT_CENTER,\n                        WallpaperType::kOnceGooglePhotos,\n                        DayBeforeYesterdayish()};\n  pref_manager_->SetUserWallpaperInfo(account_id_1, info);\n\n  client_.set_google_photo_has_been_deleted(true);\n  // Trigger Google Photos wallpaper cache check.\n  controller_->OnActiveUserSessionChanged(account_id_1);\n  if (GooglePhotosEnabled())\n    WaitForWallpaperCount(1);\n\n  EXPECT_EQ(GooglePhotosEnabled(),\n            controller_->GetWallpaperType() == WallpaperType::kDefault);\n}\n\nTEST_P(WallpaperControllerGooglePhotosWallpaperTest,\n       GooglePhotosAreCachedOnDisk) {\n  SimulateUserLogin(account_id_1);\n\n  base::test::TestFuture<bool> google_photos_future;\n\n  controller_->SetGooglePhotosWallpaper(\n      {account_id_1, kFakeGooglePhotosPhotoId, /*daily_refresh_enabled=*/false,\n       WALLPAPER_LAYOUT_STRETCH,\n       /*preview_mode=*/false, \"dedup_key\"},\n      google_photos_future.GetCallback());\n  EXPECT_EQ(GooglePhotosEnabled(), google_photos_future.Get());\n  RunAllTasksUntilIdle();\n\n  base::FilePath saved_wallpaper = online_wallpaper_dir_.GetPath()\n                                       .Append(\"google_photos/\")\n                                       .Append(account_id_1.GetAccountIdKey())\n                                       .Append(kFakeGooglePhotosPhotoId);\n  ASSERT_EQ(GooglePhotosEnabled(), base::PathExists(saved_wallpaper));\n}\n\nTEST_P(WallpaperControllerGooglePhotosWallpaperTest,\n       GooglePhotosAreCachedInMemory) {\n  SimulateUserLogin(account_id_1);\n\n  base::FilePath path;\n  EXPECT_FALSE(controller_->GetPathFromCache(account_id_1, &path));\n  gfx::ImageSkia cached_wallpaper;\n  EXPECT_FALSE(\n      controller_->GetWallpaperFromCache(account_id_1, &cached_wallpaper));\n\n  base::test::TestFuture<bool> google_photos_future;\n  controller_->SetGooglePhotosWallpaper(\n      {account_id_1, kFakeGooglePhotosPhotoId, /*daily_refresh_enabled=*/false,\n       WALLPAPER_LAYOUT_STRETCH,\n       /*preview_mode=*/false, \"dedup_key\"},\n      google_photos_future.GetCallback());\n  EXPECT_EQ(GooglePhotosEnabled(), google_photos_future.Get());\n  RunAllTasksUntilIdle();\n\n  // We store an empty path for Google Photos wallpapers in the in-memory cache\n  // because storing the real path correctly would require updating the cache\n  // after the asynchronous save operation, and we have no use for it anyway.\n  EXPECT_EQ(GooglePhotosEnabled(),\n            controller_->GetPathFromCache(account_id_1, &path));\n  EXPECT_TRUE(path.empty());\n  EXPECT_EQ(GooglePhotosEnabled(), controller_->GetWallpaperFromCache(\n                                       account_id_1, &cached_wallpaper));\n}\n\nTEST_P(WallpaperControllerGooglePhotosWallpaperTest,\n       GooglePhotosAreReadFromCache) {\n  SimulateUserLogin(account_id_1);\n\n  base::test::TestFuture<bool> google_photos_future;\n\n  GooglePhotosWallpaperParams params({account_id_1, kFakeGooglePhotosPhotoId,\n                                      /*daily_refresh_enabled=*/false,\n                                      WALLPAPER_LAYOUT_STRETCH,\n                                      /*preview_mode=*/false, \"dedup_key\"});\n  controller_->SetGooglePhotosWallpaper(params,\n                                        google_photos_future.GetCallback());\n  EXPECT_EQ(GooglePhotosEnabled(), google_photos_future.Get());\n  RunAllTasksUntilIdle();\n\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  // When Google Photos is disabled, the wallpaper will not be in disk cache,\n  // so it will attempt to read from disk, fail to find it, and then reset to\n  // the default wallpaper.\n  const size_t expected_decodes = GooglePhotosEnabled() ? 0 : 1;\n  const WallpaperType expected_type = GooglePhotosEnabled()\n                                          ? WallpaperType::kOnceGooglePhotos\n                                          : WallpaperType::kDefault;\n\n  EXPECT_EQ(expected_decodes, GetDecodeFilePaths().size());\n  EXPECT_EQ(expected_type, controller_->GetWallpaperType());\n}\n\nTEST_P(WallpaperControllerGooglePhotosWallpaperTest, ConfirmPreviewWallpaper) {\n  // Verify the user starts with a default wallpaper and the user wallpaper info\n  // is initialized with default values.\n  SimulateUserLogin(account_id_1);\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(GetWallpaperCount(), 1);\n  WallpaperInfo user_wallpaper_info;\n  WallpaperInfo default_wallpaper_info(\n      std::string(), WALLPAPER_LAYOUT_CENTER_CROPPED, WallpaperType::kDefault,\n      base::Time::Now().LocalMidnight());\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n\n  // Simulate opening the wallpaper picker window.\n  std::unique_ptr<aura::Window> wallpaper_picker_window(\n      CreateTestWindow(gfx::Rect(0, 0, 100, 100)));\n  WindowState::Get(wallpaper_picker_window.get())->Activate();\n\n  // Set a Google Photos wallpaper for the user and enable preview. Verify that\n  // the wallpaper is a Google Photos image if the feature is enabled.\n  const WallpaperLayout layout = WALLPAPER_LAYOUT_STRETCH;\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  ClearWallpaperCount();\n  std::string photo_id = \"foobar\";\n  base::test::TestFuture<bool> google_photos_future;\n  controller_->SetGooglePhotosWallpaper(\n      {account_id_1, photo_id, /*daily_refresh_enabled=*/false, layout,\n       /*preview_mode=*/true, \"dedup_key\"},\n      google_photos_future.GetCallback());\n  EXPECT_EQ(google_photos_future.Get(), GooglePhotosEnabled());\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(GetWallpaperCount(), GooglePhotosEnabled() ? 1 : 0);\n  EXPECT_EQ(controller_->GetWallpaperType(),\n            GooglePhotosEnabled() ? WallpaperType::kOnceGooglePhotos\n                                  : WallpaperType::kDefault);\n\n  // Verify that the user wallpaper info remains unchanged during the preview.\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n  histogram_tester().ExpectTotalCount(\"Ash.Wallpaper.Preview.Show\",\n                                      GooglePhotosEnabled() ? 1 : 0);\n\n  if (GooglePhotosEnabled()) {\n    // Now confirm the preview wallpaper, verify that there's no wallpaper\n    // change because the wallpaper is already shown.\n    ClearWallpaperCount();\n    controller_->ConfirmPreviewWallpaper();\n    RunAllTasksUntilIdle();\n    EXPECT_EQ(GetWallpaperCount(), 0);\n    EXPECT_EQ(controller_->GetWallpaperType(),\n              WallpaperType::kOnceGooglePhotos);\n\n    // Verify that the user wallpaper info is now updated to the Google Photos\n    // wallpaper info.\n    WallpaperInfo google_photos_wallpaper_info(\n        photo_id, layout, WallpaperType::kOnceGooglePhotos,\n        base::Time::Now().LocalMidnight());\n    EXPECT_TRUE(pref_manager_->GetUserWallpaperInfo(account_id_1,\n                                                    &user_wallpaper_info));\n    EXPECT_EQ(user_wallpaper_info, google_photos_wallpaper_info);\n  }\n}\n\nTEST_P(WallpaperControllerGooglePhotosWallpaperTest, CancelPreviewWallpaper) {\n  // Verify the user starts with a default wallpaper and the user wallpaper info\n  // is initialized with default values.\n  SimulateUserLogin(account_id_1);\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(GetWallpaperCount(), 1);\n  WallpaperInfo user_wallpaper_info;\n  WallpaperInfo default_wallpaper_info(\n      std::string(), WALLPAPER_LAYOUT_CENTER_CROPPED, WallpaperType::kDefault,\n      base::Time::Now().LocalMidnight());\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n\n  // Simulate opening the wallpaper picker window.\n  std::unique_ptr<aura::Window> wallpaper_picker_window(\n      CreateTestWindow(gfx::Rect(0, 0, 100, 100)));\n  WindowState::Get(wallpaper_picker_window.get())->Activate();\n\n  // Set a Google Photos wallpaper for the user and enable preview. Verify that\n  // the wallpaper is a Google Photos image if the feature is enabled.\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  ClearWallpaperCount();\n  std::string photo_id = \"foobar\";\n  base::test::TestFuture<bool> google_photos_future;\n  controller_->SetGooglePhotosWallpaper(\n      {account_id_1, photo_id, /*daily_refresh_enabled=*/false,\n       WALLPAPER_LAYOUT_STRETCH, /*preview_mode=*/true, \"dedup_key\"},\n      google_photos_future.GetCallback());\n  EXPECT_EQ(google_photos_future.Get(), GooglePhotosEnabled());\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(GetWallpaperCount(), GooglePhotosEnabled() ? 1 : 0);\n  EXPECT_EQ(controller_->GetWallpaperType(),\n            GooglePhotosEnabled() ? WallpaperType::kOnceGooglePhotos\n                                  : WallpaperType::kDefault);\n\n  // Verify that the user wallpaper info remains unchanged during the preview.\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n  histogram_tester().ExpectTotalCount(\"Ash.Wallpaper.Preview.Show\",\n                                      GooglePhotosEnabled() ? 1 : 0);\n\n  if (GooglePhotosEnabled()) {\n    // Now cancel the preview. Verify the wallpaper changes back to the default\n    // and the user wallpaper info remains unchanged.\n    ClearWallpaperCount();\n    controller_->CancelPreviewWallpaper();\n    RunAllTasksUntilIdle();\n    EXPECT_EQ(GetWallpaperCount(), 1);\n    EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n    EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n  }\n}\n\nTEST_P(WallpaperControllerGooglePhotosWallpaperTest,\n       WallpaperSyncedDuringPreview) {\n  // Verify the user starts with a default wallpaper and the user wallpaper info\n  // is initialized with default values.\n  SimulateUserLogin(account_id_1);\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(GetWallpaperCount(), 1);\n  WallpaperInfo user_wallpaper_info;\n  WallpaperInfo default_wallpaper_info(\n      std::string(), WALLPAPER_LAYOUT_CENTER_CROPPED, WallpaperType::kDefault,\n      base::Time::Now().LocalMidnight());\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n\n  // Simulate opening the wallpaper picker window.\n  std::unique_ptr<aura::Window> wallpaper_picker_window(\n      CreateTestWindow(gfx::Rect(0, 0, 100, 100)));\n  WindowState::Get(wallpaper_picker_window.get())->Activate();\n\n  // Set a Google Photos wallpaper for the user and enable preview. Verify that\n  // the wallpaper is a Google Photos image if the feature is enabled.\n  const WallpaperLayout layout = WALLPAPER_LAYOUT_STRETCH;\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  ClearWallpaperCount();\n  std::string photo_id = \"foobar\";\n  base::test::TestFuture<bool> google_photos_future;\n  controller_->SetGooglePhotosWallpaper(\n      {account_id_1, photo_id, /*daily_refresh_enabled=*/false, layout,\n       /*preview_mode=*/true, \"dedup_key\"},\n      google_photos_future.GetCallback());\n  EXPECT_EQ(google_photos_future.Get(), GooglePhotosEnabled());\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(GetWallpaperCount(), GooglePhotosEnabled() ? 1 : 0);\n  EXPECT_EQ(controller_->GetWallpaperType(),\n            GooglePhotosEnabled() ? WallpaperType::kOnceGooglePhotos\n                                  : WallpaperType::kDefault);\n\n  // Verify that the user wallpaper info remains unchanged during the preview.\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n  histogram_tester().ExpectTotalCount(\"Ash.Wallpaper.Preview.Show\",\n                                      GooglePhotosEnabled() ? 1 : 0);\n\n  // Now set a custom wallpaper for the user and disable preview (this happens\n  // if a custom wallpaper set on another device is being synced). Verify\n  // there's no wallpaper change since preview mode shouldn't be interrupted.\n  if (GooglePhotosEnabled()) {\n    gfx::ImageSkia synced_custom_wallpaper =\n        CreateImage(640, 480, kWallpaperColor);\n    ClearWallpaperCount();\n    controller_->SetCustomWallpaper(account_id_1, file_name_1, layout,\n                                    synced_custom_wallpaper,\n                                    /*preview_mode=*/false);\n    RunAllTasksUntilIdle();\n    EXPECT_EQ(GetWallpaperCount(), 0);\n    EXPECT_EQ(controller_->GetWallpaperType(),\n              WallpaperType::kOnceGooglePhotos);\n\n    // However, the user wallpaper info should already be updated to the new\n    // info.\n    WallpaperInfo synced_custom_wallpaper_info(\n        base::FilePath(wallpaper_files_id_1).Append(file_name_1).value(),\n        layout, WallpaperType::kCustomized, base::Time::Now().LocalMidnight());\n    EXPECT_TRUE(pref_manager_->GetUserWallpaperInfo(account_id_1,\n                                                    &user_wallpaper_info));\n    EXPECT_EQ(user_wallpaper_info, synced_custom_wallpaper_info);\n\n    // Now cancel the preview. Verify the synced custom wallpaper is shown\n    // instead of the initial default wallpaper, and the user wallpaper info is\n    // still correct.\n    ClearWallpaperCount();\n    controller_->CancelPreviewWallpaper();\n    RunAllTasksUntilIdle();\n    EXPECT_EQ(GetWallpaperCount(), 1);\n    EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kCustomized);\n    EXPECT_TRUE(pref_manager_->GetUserWallpaperInfo(account_id_1,\n                                                    &user_wallpaper_info));\n    EXPECT_EQ(user_wallpaper_info, synced_custom_wallpaper_info);\n  }\n}\n\nTEST_P(WallpaperControllerGooglePhotosWallpaperTest,\n       UpdateGooglePhotosDailyRefreshWallpaper) {\n  // The `TestWallpaperControllerClient` sends back the reversed\n  // `collection_id` when asked to fetch a daily photo.\n  std::string expected_photo_id = kFakeGooglePhotosAlbumId;\n  std::reverse(expected_photo_id.begin(), expected_photo_id.end());\n\n  SimulateUserLogin(account_id_1);\n\n  GooglePhotosWallpaperParams params(\n      account_id_1, kFakeGooglePhotosAlbumId,\n      /*daily_refresh_enabled=*/true, WALLPAPER_LAYOUT_CENTER_CROPPED,\n      /*preview_mode=*/false, /*dedup_key=*/absl::nullopt);\n  WallpaperInfo info(params);\n  pref_manager_->SetUserWallpaperInfo(account_id_1, info);\n\n  controller_->UpdateDailyRefreshWallpaperForTesting();\n  RunAllTasksUntilIdle();\n\n  WallpaperInfo expected_info;\n  bool success =\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &expected_info);\n  EXPECT_EQ(success, GooglePhotosEnabled());\n  if (success) {\n    EXPECT_EQ(expected_photo_id, expected_info.location);\n    EXPECT_EQ(kFakeGooglePhotosAlbumId, expected_info.collection_id);\n  }\n}\n\nTEST_P(WallpaperControllerGooglePhotosWallpaperTest,\n       DailyRefreshTimerStartsForDailyGooglePhotos) {\n  SimulateUserLogin(account_id_1);\n\n  GooglePhotosWallpaperParams params(\n      account_id_1, kFakeGooglePhotosAlbumId,\n      /*daily_refresh_enabled=*/true, WALLPAPER_LAYOUT_CENTER_CROPPED,\n      /*preview_mode=*/false, /*dedup_key=*/absl::nullopt);\n  WallpaperInfo info(params);\n  pref_manager_->SetUserWallpaperInfo(account_id_1, info);\n\n  controller_->UpdateDailyRefreshWallpaperForTesting();\n  RunAllTasksUntilIdle();\n  auto& timer = controller_->GetUpdateWallpaperTimerForTesting();\n  base::TimeDelta run_time =\n      timer.desired_run_time().ToDeltaSinceWindowsEpoch();\n\n  base::TimeDelta update_time =\n      (base::Time::Now() + base::Days(1)).ToDeltaSinceWindowsEpoch();\n\n  if (GooglePhotosEnabled()) {\n    EXPECT_GE(run_time, update_time - base::Minutes(1));\n    EXPECT_LE(run_time, update_time + base::Minutes(61));\n  } else {\n    EXPECT_FALSE(timer.IsRunning());\n  }\n}\n\nTEST_P(WallpaperControllerGooglePhotosWallpaperTest,\n       DailyRefreshRetryTimerStartsOnFailedFetch) {\n  SimulateUserLogin(account_id_1);\n\n  GooglePhotosWallpaperParams params(\n      account_id_1, kFakeGooglePhotosAlbumId,\n      /*daily_refresh_enabled=*/true, WALLPAPER_LAYOUT_CENTER_CROPPED,\n      /*preview_mode=*/false, /*dedup_key=*/absl::nullopt);\n  WallpaperInfo info(params);\n  pref_manager_->SetUserWallpaperInfo(account_id_1, info);\n\n  client_.set_fetch_google_photos_photo_fails(true);\n  controller_->UpdateDailyRefreshWallpaperForTesting();\n  RunAllTasksUntilIdle();\n\n  base::TimeDelta run_time = controller_->GetUpdateWallpaperTimerForTesting()\n                                 .desired_run_time()\n                                 .ToDeltaSinceWindowsEpoch();\n\n  base::TimeDelta update_time =\n      (base::Time::Now() + base::Hours(1)).ToDeltaSinceWindowsEpoch();\n\n  if (GooglePhotosEnabled()) {\n    EXPECT_GE(run_time, update_time - base::Minutes(1));\n    EXPECT_LE(run_time, update_time + base::Minutes(1));\n  } else {\n    EXPECT_FALSE(controller_->GetUpdateWallpaperTimerForTesting().IsRunning());\n  }\n}\n\nTEST_P(WallpaperControllerGooglePhotosWallpaperTest,\n       EmptyDailyGooglePhotosAlbumsDoNothing) {\n  SimulateUserLogin(account_id_1);\n\n  GooglePhotosWallpaperParams daily_google_photos_params(\n      account_id_1, kFakeGooglePhotosAlbumId, /*daily_refresh_enabled=*/true,\n      WALLPAPER_LAYOUT_CENTER_CROPPED, /*preview_mode=*/false,\n      /*dedup_key=*/absl::nullopt);\n  OnlineWallpaperParams online_params(\n      account_id_1, kAssetId, GURL(kDummyUrl),\n      TestWallpaperControllerClient::kDummyCollectionId,\n      WALLPAPER_LAYOUT_CENTER_CROPPED,\n      /*preview_mode=*/false, /*from_user=*/true,\n      /*daily_refresh_enabled=*/false, kUnitId,\n      /*variants=*/std::vector<OnlineWallpaperVariant>());\n\n  WallpaperInfo online_info(online_params);\n  pref_manager_->SetUserWallpaperInfo(account_id_1, online_info);\n\n  client_.set_fetch_google_photos_photo_fails(true);\n  controller_->SetGooglePhotosWallpaper(daily_google_photos_params,\n                                        base::DoNothing());\n  RunAllTasksUntilIdle();\n\n  WallpaperInfo current_info;\n  pref_manager_->GetUserWallpaperInfo(account_id_1, &current_info);\n\n  EXPECT_EQ(online_info, current_info);\n}\n\nTEST_P(WallpaperControllerGooglePhotosWallpaperTest,\n       ResetToDefaultForDeletedDailyGooglePhotosAlbums) {\n  SimulateUserLogin(account_id_1);\n\n  base::test::TestFuture<bool> google_photos_future;\n  controller_->SetGooglePhotosWallpaper(\n      {account_id_1, kFakeGooglePhotosAlbumId, /*daily_refresh_enabled=*/true,\n       WallpaperLayout::WALLPAPER_LAYOUT_CENTER_CROPPED,\n       /*preview_mode=*/false, /*dedup_key=*/absl::nullopt},\n      google_photos_future.GetCallback());\n  EXPECT_EQ(GooglePhotosEnabled(), google_photos_future.Get());\n  RunAllTasksUntilIdle();\n\n  WallpaperInfo current_info;\n  pref_manager_->GetUserWallpaperInfo(account_id_1, &current_info);\n\n  EXPECT_EQ(GooglePhotosEnabled(),\n            WallpaperType::kDailyGooglePhotos == current_info.type);\n\n  // This makes the test fetch in `client_` return a null photo, but a\n  // successful call, which is the sign for a deleted or empty album.\n  client_.set_google_photo_has_been_deleted(true);\n\n  controller_->UpdateDailyRefreshWallpaperForTesting();\n  RunAllTasksUntilIdle();\n\n  pref_manager_->GetUserWallpaperInfo(account_id_1, &current_info);\n\n  EXPECT_EQ(GooglePhotosEnabled(),\n            WallpaperType::kDefault == current_info.type);\n}\n\nTEST_P(WallpaperControllerGooglePhotosWallpaperTest,\n       DailyGooglePhotosAreCached) {\n  SimulateUserLogin(account_id_1);\n  // The `TestWallpaperControllerClient` sends back the reversed\n  // `collection_id` when asked to fetch a daily photo.\n  std::string expected_photo_id = kFakeGooglePhotosAlbumId;\n  std::reverse(expected_photo_id.begin(), expected_photo_id.end());\n\n  base::test::TestFuture<bool> google_photos_future;\n  controller_->SetGooglePhotosWallpaper(\n      {account_id_1, kFakeGooglePhotosAlbumId, /*daily_refresh_enabled=*/true,\n       WallpaperLayout::WALLPAPER_LAYOUT_CENTER_CROPPED,\n       /*preview_mode=*/false, /*dedup_key=*/absl::nullopt},\n      google_photos_future.GetCallback());\n  EXPECT_EQ(GooglePhotosEnabled(), google_photos_future.Get());\n  RunAllTasksUntilIdle();\n\n  base::FilePath saved_wallpaper = online_wallpaper_dir_.GetPath()\n                                       .Append(\"google_photos/\")\n                                       .Append(account_id_1.GetAccountIdKey())\n                                       .Append(expected_photo_id);\n  ASSERT_EQ(GooglePhotosEnabled(), base::PathExists(saved_wallpaper));\n}\n\nTEST_P(WallpaperControllerGooglePhotosWallpaperTest,\n       ResetToDefaultWhenLoadingInvalidWallpaper) {\n  SimulateUserLogin(account_id_1);\n\n  const WallpaperType type = GooglePhotosEnabled()\n                                 ? WallpaperType::kCount\n                                 : WallpaperType::kOnceGooglePhotos;\n\n  WallpaperInfo info = {kFakeGooglePhotosPhotoId, WALLPAPER_LAYOUT_CENTER, type,\n                        base::Time::Now()};\n  pref_manager_->SetUserWallpaperInfo(account_id_1, info);\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n}\n\n}  // namespace ash\n"
  },
  "written_data": {
    "ash/wallpaper/wallpaper_controller_unittest.cc": "// Copyright 2012 The Chromium Authors\n// Use of this source code is governed by a BSD-style license that can be\n// found in the LICENSE file.\n\n#include \"ash/wallpaper/wallpaper_controller_impl.h\"\n\n#include <cmath>\n#include <cstdlib>\n#include <memory>\n#include <vector>\n\n#include \"ash/constants/ash_features.h\"\n#include \"ash/constants/ash_pref_names.h\"\n#include \"ash/constants/ash_switches.h\"\n#include \"ash/public/cpp/shell_window_ids.h\"\n#include \"ash/public/cpp/test/shell_test_api.h\"\n#include \"ash/public/cpp/test/test_image_downloader.h\"\n#include \"ash/public/cpp/wallpaper/online_wallpaper_params.h\"\n#include \"ash/public/cpp/wallpaper/online_wallpaper_variant.h\"\n#include \"ash/public/cpp/wallpaper/wallpaper_controller_client.h\"\n#include \"ash/public/cpp/wallpaper/wallpaper_controller_observer.h\"\n#include \"ash/public/cpp/wallpaper/wallpaper_types.h\"\n#include \"ash/root_window_controller.h\"\n#include \"ash/session/session_controller_impl.h\"\n#include \"ash/session/test_session_controller_client.h\"\n#include \"ash/shell.h\"\n#include \"ash/style/dark_light_mode_controller_impl.h\"\n#include \"ash/test/ash_test_base.h\"\n#include \"ash/wallpaper/test_wallpaper_controller_client.h\"\n#include \"ash/wallpaper/wallpaper_pref_manager.h\"\n#include \"ash/wallpaper/wallpaper_utils/wallpaper_resizer.h\"\n#include \"ash/wallpaper/wallpaper_view.h\"\n#include \"ash/wallpaper/wallpaper_widget_controller.h\"\n#include \"ash/webui/personalization_app/proto/backdrop_wallpaper.pb.h\"\n#include \"ash/wm/overview/overview_controller.h\"\n#include \"ash/wm/window_cycle/window_cycle_controller.h\"\n#include \"ash/wm/window_state.h\"\n#include \"base/callback_helpers.h\"\n#include \"base/command_line.h\"\n#include \"base/files/file_util.h\"\n#include \"base/files/scoped_temp_dir.h\"\n#include \"base/metrics/metrics_hashes.h\"\n#include \"base/run_loop.h\"\n#include \"base/strings/stringprintf.h\"\n#include \"base/task/current_thread.h\"\n#include \"base/task/task_observer.h\"\n#include \"base/task/thread_pool/thread_pool_instance.h\"\n#include \"base/test/bind.h\"\n#include \"base/test/metrics/histogram_tester.h\"\n#include \"base/test/scoped_feature_list.h\"\n#include \"base/test/task_environment.h\"\n#include \"base/test/test_future.h\"\n#include \"base/threading/thread_restrictions.h\"\n#include \"base/time/time_override.h\"\n#include \"chromeos/constants/chromeos_features.h\"\n#include \"components/prefs/scoped_user_pref_update.h\"\n#include \"components/user_manager/user_names.h\"\n#include \"components/user_manager/user_type.h\"\n#include \"services/data_decoder/public/cpp/test_support/in_process_data_decoder.h\"\n#include \"testing/gmock/include/gmock/gmock-matchers.h\"\n#include \"third_party/skia/include/core/SkBitmap.h\"\n#include \"third_party/skia/include/core/SkColor.h\"\n#include \"ui/aura/window.h\"\n#include \"ui/compositor/layer.h\"\n#include \"ui/compositor/layer_tree_owner.h\"\n#include \"ui/compositor/scoped_animation_duration_scale_mode.h\"\n#include \"ui/compositor/test/layer_animator_test_controller.h\"\n#include \"ui/display/display.h\"\n#include \"ui/display/screen.h\"\n#include \"ui/gfx/canvas.h\"\n#include \"ui/gfx/codec/jpeg_codec.h\"\n#include \"ui/gfx/color_analysis.h\"\n#include \"ui/views/view_tracker.h\"\n#include \"ui/views/widget/widget.h\"\n\nusing session_manager::SessionState;\n\nnamespace ash {\nnamespace {\n\n// Containers IDs used for tests.\nconstexpr int kWallpaperId = kShellWindowId_WallpaperContainer;\nconstexpr int kLockScreenWallpaperId =\n    kShellWindowId_LockScreenWallpaperContainer;\nconstexpr int kAlwaysOnTopWallpaperId =\n    kShellWindowId_AlwaysOnTopWallpaperContainer;\n\nconstexpr char kDefaultSmallWallpaperName[] = \"small.jpg\";\nconstexpr char kDefaultLargeWallpaperName[] = \"large.jpg\";\nconstexpr char kGuestSmallWallpaperName[] = \"guest_small.jpg\";\nconstexpr char kGuestLargeWallpaperName[] = \"guest_large.jpg\";\nconstexpr char kChildSmallWallpaperName[] = \"child_small.jpg\";\nconstexpr char kChildLargeWallpaperName[] = \"child_large.jpg\";\n\nconstexpr char kCustomizationSmallWallpaperName[] = \"small_customization.jpeg\";\nconstexpr char kCustomizationLargeWallpaperName[] = \"large_customization.jpeg\";\n\n// Colors used to distinguish between wallpapers with large and small\n// resolution.\nconstexpr SkColor kLargeCustomWallpaperColor = SK_ColorDKGRAY;\nconstexpr SkColor kSmallCustomWallpaperColor = SK_ColorLTGRAY;\n\n// A color that can be passed to |CreateImage|. Specifically chosen to not\n// conflict with any of the custom wallpaper colors.\nconstexpr SkColor kWallpaperColor = SK_ColorMAGENTA;\n\nstd::string GetDummyFileId(const AccountId& account_id) {\n  return account_id.GetUserEmail() + \"-hash\";\n}\n\nstd::string GetDummyFileName(const AccountId& account_id) {\n  return account_id.GetUserEmail() + \"-file\";\n}\n\nconstexpr char kUser1[] = \"[email protected]\";\nconst AccountId account_id_1 = AccountId::FromUserEmailGaiaId(kUser1, kUser1);\nconst std::string wallpaper_files_id_1 = GetDummyFileId(account_id_1);\nconst std::string file_name_1 = GetDummyFileName(account_id_1);\n\nconstexpr char kUser2[] = \"[email protected]\";\nconst AccountId account_id_2 = AccountId::FromUserEmailGaiaId(kUser2, kUser2);\nconst std::string wallpaper_files_id_2 = GetDummyFileId(account_id_2);\nconst std::string file_name_2 = GetDummyFileName(account_id_2);\n\nconstexpr char kChildEmail[] = \"[email protected]\";\n\nconst std::string kDummyUrl = \"https://best_wallpaper/1\";\nconst std::string kDummyUrl2 = \"https://best_wallpaper/2\";\n\nconst uint64_t kAssetId = 1;\nconst uint64_t kAssetId2 = 2;\nconst uint64_t kUnitId = 1;\nconst uint64_t kUnitId2 = 2;\n\nconst std::string kFakeGooglePhotosAlbumId = \"fake_album\";\nconst std::string kFakeGooglePhotosPhotoId = \"fake_photo\";\n\n// Creates an image of size |size|.\ngfx::ImageSkia CreateImage(int width, int height, SkColor color) {\n  SkBitmap bitmap;\n  bitmap.allocN32Pixels(width, height);\n  bitmap.eraseColor(color);\n  gfx::ImageSkia image = gfx::ImageSkia::CreateFrom1xBitmap(bitmap);\n  return image;\n}\n\n// Returns number of child windows in a shell window container.\nint ChildCountForContainer(int container_id) {\n  aura::Window* root = Shell::Get()->GetPrimaryRootWindow();\n  aura::Window* container = root->GetChildById(container_id);\n  return static_cast<int>(container->children().size());\n}\n\n// Steps a layer animation until it is completed. Animations must be enabled.\nvoid RunAnimationForLayer(ui::Layer* layer) {\n  // Animations must be enabled for stepping to work.\n  ASSERT_NE(ui::ScopedAnimationDurationScaleMode::duration_multiplier(),\n            ui::ScopedAnimationDurationScaleMode::ZERO_DURATION);\n\n  ui::LayerAnimatorTestController controller(layer->GetAnimator());\n  // Multiple steps are required to complete complex animations.\n  // TODO(vollick): This should not be necessary. crbug.com/154017\n  while (controller.animator()->is_animating()) {\n    controller.StartThreadedAnimationsIfNeeded();\n    base::TimeTicks step_time = controller.animator()->last_step_time();\n    layer->GetAnimator()->Step(step_time + base::Milliseconds(1000));\n  }\n}\n\n// Writes a JPEG image of the specified size and color to |path|. Returns true\n// on success.\nbool WriteJPEGFile(const base::FilePath& path,\n                   int width,\n                   int height,\n                   SkColor color) {\n  base::ScopedAllowBlockingForTesting allow_blocking;\n  SkBitmap bitmap;\n  bitmap.allocN32Pixels(width, height);\n  bitmap.eraseColor(color);\n  std::vector<unsigned char> output;\n  if (!gfx::JPEGCodec::Encode(bitmap, 80 /*quality*/, &output)) {\n    LOG(ERROR) << \"Unable to encode \" << width << \"x\" << height << \" bitmap\";\n    return false;\n  }\n\n  size_t bytes_written = base::WriteFile(\n      path, reinterpret_cast<const char*>(&output[0]), output.size());\n  if (bytes_written != output.size()) {\n    LOG(ERROR) << \"Wrote \" << bytes_written << \" byte(s) instead of \"\n               << output.size() << \" to \" << path.value();\n    return false;\n  }\n  return true;\n}\n\n// Returns custom wallpaper path. Creates the directory if it doesn't exist.\nbase::FilePath GetCustomWallpaperPath(const char* sub_dir,\n                                      const std::string& wallpaper_files_id,\n                                      const std::string& file_name) {\n  base::ScopedAllowBlockingForTesting allow_blocking;\n  base::FilePath wallpaper_path =\n      WallpaperControllerImpl::GetCustomWallpaperPath(\n          sub_dir, wallpaper_files_id, file_name);\n  if (!base::DirectoryExists(wallpaper_path.DirName()))\n    base::CreateDirectory(wallpaper_path.DirName());\n\n  return wallpaper_path;\n}\n\nvoid WaitUntilCustomWallpapersDeleted(const AccountId& account_id) {\n  const std::string wallpaper_file_id = GetDummyFileId(account_id);\n\n  base::FilePath small_wallpaper_dir =\n      WallpaperControllerImpl::GetCustomWallpaperDir(\n          WallpaperControllerImpl::kSmallWallpaperSubDir)\n          .Append(wallpaper_file_id);\n  base::FilePath large_wallpaper_dir =\n      WallpaperControllerImpl::GetCustomWallpaperDir(\n          WallpaperControllerImpl::kLargeWallpaperSubDir)\n          .Append(wallpaper_file_id);\n  base::FilePath original_wallpaper_dir =\n      WallpaperControllerImpl::GetCustomWallpaperDir(\n          WallpaperControllerImpl::kOriginalWallpaperSubDir)\n          .Append(wallpaper_file_id);\n\n  while (base::PathExists(small_wallpaper_dir) ||\n         base::PathExists(large_wallpaper_dir) ||\n         base::PathExists(original_wallpaper_dir)) {\n  }\n}\n\n// Monitors if any task is processed by the message loop.\nclass TaskObserver : public base::TaskObserver {\n public:\n  TaskObserver() : processed_(false) {}\n\n  TaskObserver(const TaskObserver&) = delete;\n  TaskObserver& operator=(const TaskObserver&) = delete;\n\n  ~TaskObserver() override = default;\n\n  // TaskObserver:\n  void WillProcessTask(const base::PendingTask& /* pending_task */,\n                       bool /* was_blocked_or_low_priority */) override {}\n  void DidProcessTask(const base::PendingTask& pending_task) override {\n    processed_ = true;\n  }\n\n  // Returns true if any task was processed.\n  bool processed() const { return processed_; }\n\n private:\n  bool processed_;\n};\n\n// See content::RunAllTasksUntilIdle().\nvoid RunAllTasksUntilIdle() {\n  while (true) {\n    TaskObserver task_observer;\n    base::CurrentThread::Get()->AddTaskObserver(&task_observer);\n    // May spin message loop.\n    base::ThreadPoolInstance::Get()->FlushForTesting();\n\n    base::RunLoop().RunUntilIdle();\n    base::CurrentThread::Get()->RemoveTaskObserver(&task_observer);\n\n    if (!task_observer.processed())\n      break;\n  }\n}\n\nPrefService* GetProfilePrefService(const AccountId& account_id) {\n  return Shell::Get()->session_controller()->GetUserPrefServiceForUser(\n      account_id);\n}\n\nWallpaperInfo InfoWithType(WallpaperType type) {\n  WallpaperInfo info(std::string(), WALLPAPER_LAYOUT_CENTER_CROPPED, type,\n                     base::Time::Now());\n  if (type == WallpaperType::kDaily || type == WallpaperType::kOnline) {\n    // Daily and Online types require asset id and collection id.\n    info.asset_id = 1234;\n    info.collection_id = \"placeholder collection\";\n    info.location = \"https://example.com/example.jpeg\";\n  }\n  if (type == WallpaperType::kOnceGooglePhotos)\n    info.dedup_key = \"dedup_key\";\n  return info;\n}\n\nbase::Time DayBeforeYesterdayish() {\n  base::TimeDelta today_delta =\n      base::Time::Now().LocalMidnight().ToDeltaSinceWindowsEpoch();\n  base::TimeDelta yesterday_delta = today_delta - base::Days(2);\n  return base::Time::FromDeltaSinceWindowsEpoch(yesterday_delta);\n}\n\n// A test implementation of the WallpaperControllerObserver interface.\nclass TestWallpaperControllerObserver : public WallpaperControllerObserver {\n public:\n  explicit TestWallpaperControllerObserver(WallpaperController* controller)\n      : controller_(controller) {\n    controller_->AddObserver(this);\n  }\n\n  TestWallpaperControllerObserver(const TestWallpaperControllerObserver&) =\n      delete;\n  TestWallpaperControllerObserver& operator=(\n      const TestWallpaperControllerObserver&) = delete;\n\n  ~TestWallpaperControllerObserver() override {\n    controller_->RemoveObserver(this);\n  }\n\n  // WallpaperControllerObserver\n  void OnWallpaperChanged() override { ++wallpaper_changed_count_; }\n  void OnWallpaperColorsChanged() override { ++colors_changed_count_; }\n  void OnWallpaperBlurChanged() override { ++blur_changed_count_; }\n  void OnFirstWallpaperShown() override { ++first_shown_count_; }\n  void OnWallpaperPreviewStarted() override {\n    DCHECK(!is_in_wallpaper_preview_);\n    is_in_wallpaper_preview_ = true;\n  }\n  void OnWallpaperPreviewEnded() override {\n    DCHECK(is_in_wallpaper_preview_);\n    is_in_wallpaper_preview_ = false;\n  }\n\n  int colors_changed_count() const { return colors_changed_count_; }\n  int blur_changed_count() const { return blur_changed_count_; }\n  int first_shown_count() const { return first_shown_count_; }\n  int wallpaper_changed_count() const { return wallpaper_changed_count_; }\n  bool is_in_wallpaper_preview() const { return is_in_wallpaper_preview_; }\n\n private:\n  WallpaperController* controller_;\n  int colors_changed_count_ = 0;\n  int blur_changed_count_ = 0;\n  int first_shown_count_ = 0;\n  int wallpaper_changed_count_ = 0;\n  bool is_in_wallpaper_preview_ = false;\n};\n\n}  // namespace\n\nclass WallpaperControllerTest : public AshTestBase {\n public:\n  WallpaperControllerTest()\n      : AshTestBase(base::test::TaskEnvironment::TimeSource::MOCK_TIME) {}\n\n  WallpaperControllerTest(const WallpaperControllerTest&) = delete;\n  WallpaperControllerTest& operator=(const WallpaperControllerTest&) = delete;\n\n  void SetUp() override {\n    auto pref_manager = WallpaperPrefManager::Create(local_state());\n    pref_manager_ = pref_manager.get();\n    // Override the pref manager that will be used to construct the\n    // WallpaperController.\n    WallpaperControllerImpl::SetWallpaperPrefManagerForTesting(\n        std::move(pref_manager));\n\n    AshTestBase::SetUp();\n\n    TestSessionControllerClient* const client = GetSessionControllerClient();\n    client->ProvidePrefServiceForUser(account_id_1);\n    client->ProvidePrefServiceForUser(account_id_2);\n    client->ProvidePrefServiceForUser(\n        AccountId::FromUserEmail(user_manager::kGuestUserName));\n    client->ProvidePrefServiceForUser(kChildAccountId);\n\n    // This is almost certainly not what was originally intended for these\n    // tests, but they have never actually exercised properly decoded\n    // wallpapers, as they've never actually been connected to a Data Decoder.\n    // We simulate a \"crashing\" ImageDcoder to get the behavior the tests were\n    // written around, but at some point they should probably be fixed.\n    in_process_data_decoder_.service().SimulateImageDecoderCrashForTesting(\n        true);\n\n    test_image_downloader_ = std::make_unique<TestImageDownloader>();\n\n    controller_ = Shell::Get()->wallpaper_controller();\n    controller_->set_wallpaper_reload_no_delay_for_test();\n\n    ASSERT_TRUE(user_data_dir_.CreateUniqueTempDir());\n    ASSERT_TRUE(online_wallpaper_dir_.CreateUniqueTempDir());\n    ASSERT_TRUE(custom_wallpaper_dir_.CreateUniqueTempDir());\n    base::FilePath policy_wallpaper;\n    controller_->Init(user_data_dir_.GetPath(), online_wallpaper_dir_.GetPath(),\n                      custom_wallpaper_dir_.GetPath(), policy_wallpaper);\n    client_.ResetCounts();\n    controller_->SetClient(&client_);\n    client_.set_fake_files_id_for_account_id(account_id_1,\n                                             wallpaper_files_id_1);\n    client_.set_fake_files_id_for_account_id(account_id_2,\n                                             wallpaper_files_id_2);\n  }\n\n  void TearDown() override {\n    // Although pref services outlive wallpaper controller in the os, in ash\n    // tests, they are destroyed in tear down (See |AshTestHelper|). We don't\n    // want this timer to run a task after tear down, since it relies on a pref\n    // service being around.\n    controller_->GetUpdateWallpaperTimerForTesting().Stop();\n\n    AshTestBase::TearDown();\n  }\n\n  WallpaperView* wallpaper_view() {\n    return Shell::Get()\n        ->GetPrimaryRootWindowController()\n        ->wallpaper_widget_controller()\n        ->wallpaper_view();\n  }\n\n protected:\n  // Helper function that tests the wallpaper is always fitted to the native\n  // display resolution when the layout is WALLPAPER_LAYOUT_CENTER.\n  void WallpaperFitToNativeResolution(WallpaperView* view,\n                                      float device_scale_factor,\n                                      int image_width,\n                                      int image_height,\n                                      SkColor color) {\n    gfx::Size size = view->bounds().size();\n    gfx::Canvas canvas(size, device_scale_factor, true);\n    view->OnPaint(&canvas);\n\n    SkBitmap bitmap = canvas.GetBitmap();\n    int bitmap_width = bitmap.width();\n    int bitmap_height = bitmap.height();\n    for (int i = 0; i < bitmap_width; i++) {\n      for (int j = 0; j < bitmap_height; j++) {\n        if (i >= (bitmap_width - image_width) / 2 &&\n            i < (bitmap_width + image_width) / 2 &&\n            j >= (bitmap_height - image_height) / 2 &&\n            j < (bitmap_height + image_height) / 2) {\n          EXPECT_EQ(color, bitmap.getColor(i, j));\n        } else {\n          EXPECT_EQ(SK_ColorBLACK, bitmap.getColor(i, j));\n        }\n      }\n    }\n  }\n\n  // Runs AnimatingWallpaperWidgetController's animation to completion.\n  void RunDesktopControllerAnimation() {\n    WallpaperWidgetController* controller =\n        Shell::Get()\n            ->GetPrimaryRootWindowController()\n            ->wallpaper_widget_controller();\n    ASSERT_TRUE(controller);\n\n    ui::LayerTreeOwner* owner = controller->old_layer_tree_owner_for_testing();\n    if (!owner)\n      return;\n\n    ASSERT_NO_FATAL_FAILURE(RunAnimationForLayer(owner->root()));\n  }\n\n  // Convenience function to ensure ShouldCalculateColors() returns true.\n  void EnableShelfColoring() {\n    const gfx::ImageSkia kImage = CreateImage(10, 10, kWallpaperColor);\n    controller_->ShowWallpaperImage(\n        kImage, CreateWallpaperInfo(WALLPAPER_LAYOUT_STRETCH),\n        /*preview_mode=*/false, /*always_on_top=*/false);\n    SetSessionState(SessionState::ACTIVE);\n\n    EXPECT_TRUE(ShouldCalculateColors());\n  }\n\n  // Convenience function to set the SessionState.\n  void SetSessionState(SessionState session_state) {\n    GetSessionControllerClient()->SetSessionState(session_state);\n  }\n\n  // Helper function to create a |WallpaperInfo| struct with dummy values\n  // given the desired layout.\n  WallpaperInfo CreateWallpaperInfo(WallpaperLayout layout) {\n    return WallpaperInfo(std::string(), layout, WallpaperType::kDefault,\n                         base::Time::Now().LocalMidnight());\n  }\n\n  // Saves wallpaper images in the appropriate location for |account_id| and\n  // returns the relative path of the file.\n  base::FilePath PrecacheWallpapers(const AccountId& account_id) {\n    std::string wallpaper_files_id = GetDummyFileId(account_id);\n\n    std::string file_name = GetDummyFileName(account_id);\n    base::FilePath small_wallpaper_path =\n        GetCustomWallpaperPath(WallpaperControllerImpl::kSmallWallpaperSubDir,\n                               wallpaper_files_id, file_name);\n    base::FilePath large_wallpaper_path =\n        GetCustomWallpaperPath(WallpaperControllerImpl::kLargeWallpaperSubDir,\n                               wallpaper_files_id, file_name);\n\n    // Saves the small/large resolution wallpapers to small/large custom\n    // wallpaper paths.\n    CHECK(WriteJPEGFile(small_wallpaper_path, kSmallWallpaperMaxWidth,\n                        kSmallWallpaperMaxHeight, kSmallCustomWallpaperColor));\n    CHECK(WriteJPEGFile(large_wallpaper_path, kLargeWallpaperMaxWidth,\n                        kLargeWallpaperMaxHeight, kLargeCustomWallpaperColor));\n\n    return base::FilePath(wallpaper_files_id).Append(file_name);\n  }\n\n  // Saves images with different resolution to corresponding paths and saves\n  // wallpaper info to local state, so that subsequent calls of |ShowWallpaper|\n  // can retrieve the images and info.\n  void CreateAndSaveWallpapers(const AccountId& account_id) {\n    base::FilePath relative_path = PrecacheWallpapers(account_id);\n    // Saves wallpaper info to local state for user.\n    WallpaperInfo info = {\n        relative_path.value(), WALLPAPER_LAYOUT_CENTER_CROPPED,\n        WallpaperType::kCustomized, base::Time::Now().LocalMidnight()};\n    ASSERT_TRUE(pref_manager_->SetUserWallpaperInfo(account_id, info));\n  }\n\n  // Simulates setting a custom wallpaper by directly setting the wallpaper\n  // info.\n  void SimulateSettingCustomWallpaper(const AccountId& account_id) {\n    ASSERT_TRUE(pref_manager_->SetUserWallpaperInfo(\n        account_id,\n        WallpaperInfo(\"dummy_file_location\", WALLPAPER_LAYOUT_CENTER,\n                      WallpaperType::kCustomized,\n                      base::Time::Now().LocalMidnight())));\n  }\n\n  // Initializes default wallpaper paths \"*default_*file\" and writes JPEG\n  // wallpaper images to them. Only needs to be called (once) by tests that\n  // want to test loading of default wallpapers.\n  void CreateDefaultWallpapers() {\n    base::ScopedAllowBlockingForTesting allow_blocking;\n    ASSERT_TRUE(default_wallpaper_dir_.CreateUniqueTempDir());\n    const base::FilePath default_wallpaper_path =\n        default_wallpaper_dir_.GetPath();\n\n    base::CommandLine* command_line = base::CommandLine::ForCurrentProcess();\n    const base::FilePath small_file =\n        default_wallpaper_path.Append(kDefaultSmallWallpaperName);\n    command_line->AppendSwitchASCII(switches::kDefaultWallpaperSmall,\n                                    small_file.value());\n    const base::FilePath large_file =\n        default_wallpaper_path.Append(kDefaultLargeWallpaperName);\n    command_line->AppendSwitchASCII(switches::kDefaultWallpaperLarge,\n                                    large_file.value());\n\n    const base::FilePath guest_small_file =\n        default_wallpaper_path.Append(kGuestSmallWallpaperName);\n    command_line->AppendSwitchASCII(switches::kGuestWallpaperSmall,\n                                    guest_small_file.value());\n    const base::FilePath guest_large_file =\n        default_wallpaper_path.Append(kGuestLargeWallpaperName);\n    command_line->AppendSwitchASCII(switches::kGuestWallpaperLarge,\n                                    guest_large_file.value());\n\n    const base::FilePath child_small_file =\n        default_wallpaper_path.Append(kChildSmallWallpaperName);\n    command_line->AppendSwitchASCII(switches::kChildWallpaperSmall,\n                                    child_small_file.value());\n    const base::FilePath child_large_file =\n        default_wallpaper_path.Append(kChildLargeWallpaperName);\n    command_line->AppendSwitchASCII(switches::kChildWallpaperLarge,\n                                    child_large_file.value());\n\n    const int kWallpaperSize = 2;\n    ASSERT_TRUE(WriteJPEGFile(small_file, kWallpaperSize, kWallpaperSize,\n                              kWallpaperColor));\n    ASSERT_TRUE(WriteJPEGFile(large_file, kWallpaperSize, kWallpaperSize,\n                              kWallpaperColor));\n\n    ASSERT_TRUE(WriteJPEGFile(guest_small_file, kWallpaperSize, kWallpaperSize,\n                              kWallpaperColor));\n    ASSERT_TRUE(WriteJPEGFile(guest_large_file, kWallpaperSize, kWallpaperSize,\n                              kWallpaperColor));\n\n    ASSERT_TRUE(WriteJPEGFile(child_small_file, kWallpaperSize, kWallpaperSize,\n                              kWallpaperColor));\n    ASSERT_TRUE(WriteJPEGFile(child_large_file, kWallpaperSize, kWallpaperSize,\n                              kWallpaperColor));\n  }\n\n  // Returns the paths of a small and large jpeg for use with customized default\n  // wallpapers.\n  [[nodiscard]] std::pair<const base::FilePath, const base::FilePath>\n  CreateCustomizationWallpapers() {\n    base::ScopedAllowBlockingForTesting allow_blocking;\n    CHECK(customization_wallpaper_dir_.CreateUniqueTempDir());\n\n    base::FilePath root = customization_wallpaper_dir_.GetPath();\n\n    const base::FilePath small_file =\n        root.Append(kCustomizationSmallWallpaperName);\n    const base::FilePath large_file =\n        root.Append(kCustomizationLargeWallpaperName);\n\n    CHECK(WriteJPEGFile(small_file, 800, 800, SK_ColorGREEN));\n    CHECK(WriteJPEGFile(large_file, 2000, 2000, SK_ColorBLUE));\n\n    return {small_file, large_file};\n  }\n\n  // A helper to test the behavior of setting online wallpaper after the image\n  // is decoded. This is needed because image decoding is not supported in unit\n  // tests.\n  void SetOnlineWallpaperFromImage(\n      const AccountId& account_id,\n      uint64_t asset_id,\n      const gfx::ImageSkia& image,\n      const std::string& url,\n      const std::string& collection_id,\n      WallpaperLayout layout,\n      bool save_file,\n      bool preview_mode,\n      bool from_user,\n      uint64_t unit_id,\n      const std::vector<OnlineWallpaperVariant>& variants,\n      WallpaperController::SetWallpaperCallback callback) {\n    const OnlineWallpaperParams params = {\n        account_id, asset_id,     GURL(url), collection_id,\n        layout,     preview_mode, from_user, /*daily_refresh_enabled=*/false,\n        unit_id,    variants};\n    controller_->OnOnlineWallpaperDecoded(params, save_file,\n                                          std::move(callback), image);\n  }\n\n  // Returns color of the current wallpaper. Note: this function assumes the\n  // wallpaper has a solid color.\n  SkColor GetWallpaperColor() {\n    const gfx::ImageSkiaRep& representation =\n        controller_->GetWallpaper().GetRepresentation(1.0f);\n    return representation.GetBitmap().getColor(0, 0);\n  }\n\n  // Wrapper for private ShouldCalculateColors().\n  bool ShouldCalculateColors() { return controller_->ShouldCalculateColors(); }\n\n  // Wrapper for private IsDevicePolicyWallpaper().\n  bool IsDevicePolicyWallpaper() {\n    return controller_->IsDevicePolicyWallpaper();\n  }\n\n  int GetWallpaperCount() { return controller_->wallpaper_count_for_testing_; }\n\n  const std::vector<base::FilePath>& GetDecodeFilePaths() {\n    return controller_->decode_requests_for_testing_;\n  }\n\n  // Returns the `WallpaperInfo` associated with the current\n  // `WallpaperResizer`. Usually, this is the same as\n  // `GetActiveUserWallpaperInfo()` except when the user is not logged in.\n  const WallpaperInfo GetCurrentWallpaperInfo() {\n    WallpaperResizer* wallpaper = controller_->current_wallpaper_.get();\n    if (!wallpaper)\n      return WallpaperInfo();\n\n    return wallpaper->wallpaper_info();\n  }\n\n  void SetBypassDecode() { controller_->set_bypass_decode_for_testing(); }\n\n  void ClearWallpaperCount() { controller_->wallpaper_count_for_testing_ = 0; }\n\n  void ClearDecodeFilePaths() {\n    controller_->decode_requests_for_testing_.clear();\n  }\n\n  void ClearWallpaper() { controller_->current_wallpaper_.reset(); }\n\n  int GetWallpaperContainerId() {\n    return controller_->GetWallpaperContainerId(controller_->locked_);\n  }\n\n  const base::HistogramTester& histogram_tester() const {\n    return histogram_tester_;\n  }\n\n  void CacheOnlineWallpaper(std::string path) {\n    // Set an Online Wallpaper from Data, so syncing in doesn't need to download\n    // an Online Wallpaper.\n    SetBypassDecode();\n    SimulateUserLogin(account_id_1);\n    ClearWallpaperCount();\n    controller_->SetOnlineWallpaperFromData(\n        OnlineWallpaperParams(\n            account_id_1, kAssetId, GURL(path),\n            /*collection_id=*/std::string(), WALLPAPER_LAYOUT_CENTER_CROPPED,\n            /*preview_mode=*/false, /*from_user=*/false,\n            /*daily_refresh_enabled=*/false, kUnitId,\n            /*variants=*/std::vector<OnlineWallpaperVariant>()),\n        /*image_data=*/std::string(),\n        WallpaperController::SetWallpaperCallback());\n    RunAllTasksUntilIdle();\n\n    // Change the on-screen wallpaper to a different one. (Otherwise the\n    // subsequent calls will be no-op since we intentionally prevent reloading\n    // the same wallpaper.)\n    ClearWallpaperCount();\n    controller_->SetCustomWallpaper(\n        account_id_1, file_name_1, WALLPAPER_LAYOUT_CENTER_CROPPED,\n        CreateImage(640, 480, kWallpaperColor), false /*preview_mode=*/);\n    RunAllTasksUntilIdle();\n  }\n\n  WallpaperControllerImpl* controller_;\n  WallpaperPrefManager* pref_manager_ = nullptr;  // owned by controller\n\n  base::ScopedTempDir user_data_dir_;\n  base::ScopedTempDir online_wallpaper_dir_;\n  base::ScopedTempDir custom_wallpaper_dir_;\n  base::ScopedTempDir default_wallpaper_dir_;\n  base::ScopedTempDir customization_wallpaper_dir_;\n  base::HistogramTester histogram_tester_;\n\n  TestWallpaperControllerClient client_;\n  std::unique_ptr<TestImageDownloader> test_image_downloader_;\n\n  const AccountId kChildAccountId =\n      AccountId::FromUserEmailGaiaId(kChildEmail, kChildEmail);\n\n private:\n  data_decoder::test::InProcessDataDecoder in_process_data_decoder_;\n};\n\nTEST_F(WallpaperControllerTest, Client) {\n  base::FilePath empty_path;\n  controller_->Init(empty_path, empty_path, empty_path, empty_path);\n\n  EXPECT_EQ(0u, client_.open_count());\n  EXPECT_TRUE(controller_->CanOpenWallpaperPicker());\n  controller_->OpenWallpaperPickerIfAllowed();\n  EXPECT_EQ(1u, client_.open_count());\n}\n\nTEST_F(WallpaperControllerTest, BasicReparenting) {\n  WallpaperControllerImpl* controller = Shell::Get()->wallpaper_controller();\n  controller->CreateEmptyWallpaperForTesting();\n\n  // Wallpaper view/window exists in the wallpaper container and nothing is in\n  // the lock screen wallpaper container.\n  EXPECT_EQ(1, ChildCountForContainer(kWallpaperId));\n  EXPECT_EQ(0, ChildCountForContainer(kLockScreenWallpaperId));\n\n  controller->OnSessionStateChanged(session_manager::SessionState::LOCKED);\n\n  // One window is moved from desktop to lock container.\n  EXPECT_EQ(0, ChildCountForContainer(kWallpaperId));\n  EXPECT_EQ(1, ChildCountForContainer(kLockScreenWallpaperId));\n\n  controller->OnSessionStateChanged(session_manager::SessionState::ACTIVE);\n\n  // One window is moved from lock to desktop container.\n  EXPECT_EQ(1, ChildCountForContainer(kWallpaperId));\n  EXPECT_EQ(0, ChildCountForContainer(kLockScreenWallpaperId));\n}\n\nTEST_F(WallpaperControllerTest, SwitchWallpapersWhenNewWallpaperAnimationEnds) {\n  // We cannot short-circuit animations for this test.\n  ui::ScopedAnimationDurationScaleMode test_duration_mode(\n      ui::ScopedAnimationDurationScaleMode::NON_ZERO_DURATION);\n\n  // Create the wallpaper and its view.\n  WallpaperControllerImpl* controller = Shell::Get()->wallpaper_controller();\n  controller->CreateEmptyWallpaperForTesting();\n\n  // The new wallpaper is ready to animate.\n  WallpaperWidgetController* widget_controller =\n      Shell::Get()\n          ->GetPrimaryRootWindowController()\n          ->wallpaper_widget_controller();\n  EXPECT_TRUE(widget_controller->IsAnimating());\n\n  // Force the animation to play to completion.\n  RunDesktopControllerAnimation();\n  EXPECT_FALSE(widget_controller->IsAnimating());\n}\n\n// Test for crbug.com/149043 \"Unlock screen, no launcher appears\". Ensure we\n// move all wallpaper views if there are more than one.\nTEST_F(WallpaperControllerTest, WallpaperMovementDuringUnlock) {\n  // We cannot short-circuit animations for this test.\n  ui::ScopedAnimationDurationScaleMode test_duration_mode(\n      ui::ScopedAnimationDurationScaleMode::NON_ZERO_DURATION);\n\n  // Reset wallpaper state, see ControllerOwnership above.\n  WallpaperControllerImpl* controller = Shell::Get()->wallpaper_controller();\n  controller->CreateEmptyWallpaperForTesting();\n\n  // Run wallpaper show animation to completion.\n  RunDesktopControllerAnimation();\n\n  // User locks the screen, which moves the wallpaper forward.\n  controller->OnSessionStateChanged(session_manager::SessionState::LOCKED);\n\n  // Suspend/resume cycle causes wallpaper to refresh, loading a new wallpaper\n  // that will animate in on top of the old one.\n  controller->CreateEmptyWallpaperForTesting();\n\n  // In this state we have a wallpaper views stored in\n  // LockScreenWallpaperContainer.\n  WallpaperWidgetController* widget_controller =\n      Shell::Get()\n          ->GetPrimaryRootWindowController()\n          ->wallpaper_widget_controller();\n  EXPECT_TRUE(widget_controller->IsAnimating());\n  EXPECT_EQ(0, ChildCountForContainer(kWallpaperId));\n  EXPECT_EQ(1, ChildCountForContainer(kLockScreenWallpaperId));\n  // There must be three layers, shield, original and old layers.\n  ASSERT_EQ(3u, wallpaper_view()->layer()->parent()->children().size());\n\n  // Before the wallpaper's animation completes, user unlocks the screen, which\n  // moves the wallpaper to the back.\n  controller->OnSessionStateChanged(session_manager::SessionState::ACTIVE);\n\n  // Ensure that widget has moved.\n  EXPECT_EQ(1, ChildCountForContainer(kWallpaperId));\n  // There must be two layers, original and old layers while animating.\n  ASSERT_EQ(2u, wallpaper_view()->layer()->parent()->children().size());\n  EXPECT_EQ(0, ChildCountForContainer(kLockScreenWallpaperId));\n\n  // Finish the new wallpaper animation.\n  RunDesktopControllerAnimation();\n\n  // Now there is one wallpaper and layer.\n  EXPECT_EQ(1, ChildCountForContainer(kWallpaperId));\n  ASSERT_EQ(1u, wallpaper_view()->layer()->parent()->children().size());\n  EXPECT_EQ(0, ChildCountForContainer(kLockScreenWallpaperId));\n}\n\n// Test for crbug.com/156542. Animating wallpaper should immediately finish\n// animation and replace current wallpaper before next animation starts.\nTEST_F(WallpaperControllerTest, ChangeWallpaperQuick) {\n  // We cannot short-circuit animations for this test.\n  ui::ScopedAnimationDurationScaleMode test_duration_mode(\n      ui::ScopedAnimationDurationScaleMode::NON_ZERO_DURATION);\n\n  // Reset wallpaper state, see ControllerOwnership above.\n  WallpaperControllerImpl* controller = Shell::Get()->wallpaper_controller();\n  controller->CreateEmptyWallpaperForTesting();\n\n  // Run wallpaper show animation to completion.\n  RunDesktopControllerAnimation();\n\n  // Change to a new wallpaper.\n  controller->CreateEmptyWallpaperForTesting();\n\n  WallpaperWidgetController* widget_controller =\n      Shell::Get()\n          ->GetPrimaryRootWindowController()\n          ->wallpaper_widget_controller();\n  EXPECT_TRUE(widget_controller->IsAnimating());\n\n  // Change to another wallpaper before animation finished.\n  controller->CreateEmptyWallpaperForTesting();\n\n  // Run wallpaper show animation to completion.\n  RunDesktopControllerAnimation();\n\n  EXPECT_FALSE(widget_controller->IsAnimating());\n}\n\nTEST_F(WallpaperControllerTest, ResizeCustomWallpaper) {\n  UpdateDisplay(\"320x200\");\n\n  gfx::ImageSkia image = CreateImage(640, 480, kWallpaperColor);\n\n  // Set the image as custom wallpaper, wait for the resize to finish, and check\n  // that the resized image is the expected size.\n  controller_->ShowWallpaperImage(\n      image, CreateWallpaperInfo(WALLPAPER_LAYOUT_STRETCH),\n      /*preview_mode=*/false, /*always_on_top=*/false);\n  EXPECT_TRUE(image.BackedBySameObjectAs(controller_->GetWallpaper()));\n  RunAllTasksUntilIdle();\n  gfx::ImageSkia resized_image = controller_->GetWallpaper();\n  EXPECT_FALSE(image.BackedBySameObjectAs(resized_image));\n  EXPECT_EQ(gfx::Size(320, 200).ToString(), resized_image.size().ToString());\n\n  // Load the original wallpaper again and check that we're still using the\n  // previously-resized image instead of doing another resize\n  // (http://crbug.com/321402).\n  controller_->ShowWallpaperImage(\n      image, CreateWallpaperInfo(WALLPAPER_LAYOUT_STRETCH),\n      /*preview_mode=*/false, /*always_on_top=*/false);\n  RunAllTasksUntilIdle();\n  EXPECT_TRUE(resized_image.BackedBySameObjectAs(controller_->GetWallpaper()));\n}\n\nTEST_F(WallpaperControllerTest, GetMaxDisplaySize) {\n  // Device scale factor shouldn't affect the native size.\n  UpdateDisplay(\"1000x300*2\");\n  EXPECT_EQ(\"1000x300\",\n            WallpaperControllerImpl::GetMaxDisplaySizeInNative().ToString());\n\n  // Rotated display should return the rotated size.\n  UpdateDisplay(\"1000x300*2/r\");\n  EXPECT_EQ(\"300x1000\",\n            WallpaperControllerImpl::GetMaxDisplaySizeInNative().ToString());\n\n  // UI Scaling shouldn't affect the native size.\n  UpdateDisplay(\"1000x300*[email protected]\");\n  EXPECT_EQ(\"1000x300\",\n            WallpaperControllerImpl::GetMaxDisplaySizeInNative().ToString());\n\n  // First display has maximum size.\n  UpdateDisplay(\"400x300,200x100\");\n  EXPECT_EQ(\"400x300\",\n            WallpaperControllerImpl::GetMaxDisplaySizeInNative().ToString());\n\n  // Second display has maximum size.\n  UpdateDisplay(\"400x300,500x600\");\n  EXPECT_EQ(\"500x600\",\n            WallpaperControllerImpl::GetMaxDisplaySizeInNative().ToString());\n\n  // Maximum width and height belongs to different displays.\n  UpdateDisplay(\"400x300,100x500\");\n  EXPECT_EQ(\"400x500\",\n            WallpaperControllerImpl::GetMaxDisplaySizeInNative().ToString());\n}\n\n// Test that the wallpaper is always fitted to the native display resolution\n// when the layout is WALLPAPER_LAYOUT_CENTER to prevent blurry images.\nTEST_F(WallpaperControllerTest, DontScaleWallpaperWithCenterLayout) {\n  // We cannot short-circuit animations for this test.\n  ui::ScopedAnimationDurationScaleMode test_duration_mode(\n      ui::ScopedAnimationDurationScaleMode::NON_ZERO_DURATION);\n\n  const gfx::Size high_resolution(3600, 2400);\n  const gfx::Size low_resolution(360, 240);\n  const float high_dsf = 2.0f;\n  const float low_dsf = 1.0f;\n\n  gfx::ImageSkia image_high_res = CreateImage(\n      high_resolution.width(), high_resolution.height(), kWallpaperColor);\n  gfx::ImageSkia image_low_res = CreateImage(\n      low_resolution.width(), low_resolution.height(), kWallpaperColor);\n\n  UpdateDisplay(\"1200x600*2\");\n  {\n    SCOPED_TRACE(base::StringPrintf(\"1200x600*2 high resolution\"));\n    controller_->ShowWallpaperImage(\n        image_high_res, CreateWallpaperInfo(WALLPAPER_LAYOUT_CENTER),\n        /*preview_mode=*/false, /*always_on_top=*/false);\n    WallpaperFitToNativeResolution(wallpaper_view(), high_dsf,\n                                   high_resolution.width(),\n                                   high_resolution.height(), kWallpaperColor);\n  }\n  {\n    SCOPED_TRACE(base::StringPrintf(\"1200x600*2 low resolution\"));\n    controller_->ShowWallpaperImage(\n        image_low_res, CreateWallpaperInfo(WALLPAPER_LAYOUT_CENTER),\n        /*preview_mode=*/false, /*always_on_top=*/false);\n    WallpaperFitToNativeResolution(wallpaper_view(), high_dsf,\n                                   low_resolution.width(),\n                                   low_resolution.height(), kWallpaperColor);\n  }\n\n  UpdateDisplay(\"1200x600\");\n  {\n    SCOPED_TRACE(base::StringPrintf(\"1200x600 high resolution\"));\n    controller_->ShowWallpaperImage(\n        image_high_res, CreateWallpaperInfo(WALLPAPER_LAYOUT_CENTER),\n        /*preview_mode=*/false, /*always_on_top=*/false);\n    WallpaperFitToNativeResolution(wallpaper_view(), low_dsf,\n                                   high_resolution.width(),\n                                   high_resolution.height(), kWallpaperColor);\n  }\n  {\n    SCOPED_TRACE(base::StringPrintf(\"1200x600 low resolution\"));\n    controller_->ShowWallpaperImage(\n        image_low_res, CreateWallpaperInfo(WALLPAPER_LAYOUT_CENTER),\n        /*preview_mode=*/false, /*always_on_top=*/false);\n    WallpaperFitToNativeResolution(wallpaper_view(), low_dsf,\n                                   low_resolution.width(),\n                                   low_resolution.height(), kWallpaperColor);\n  }\n\n  UpdateDisplay(\"1200x600/[email protected]\");  // 1.5 ui scale\n  {\n    SCOPED_TRACE(base::StringPrintf(\"1200x600/[email protected] high resolution\"));\n    controller_->ShowWallpaperImage(\n        image_high_res, CreateWallpaperInfo(WALLPAPER_LAYOUT_CENTER),\n        /*preview_mode=*/false, /*always_on_top=*/false);\n    WallpaperFitToNativeResolution(wallpaper_view(), low_dsf,\n                                   high_resolution.width(),\n                                   high_resolution.height(), kWallpaperColor);\n  }\n  {\n    SCOPED_TRACE(base::StringPrintf(\"1200x600/[email protected] low resolution\"));\n    controller_->ShowWallpaperImage(\n        image_low_res, CreateWallpaperInfo(WALLPAPER_LAYOUT_CENTER),\n        /*preview_mode=*/false, /*always_on_top=*/false);\n    WallpaperFitToNativeResolution(wallpaper_view(), low_dsf,\n                                   low_resolution.width(),\n                                   low_resolution.height(), kWallpaperColor);\n  }\n}\n\nTEST_F(WallpaperControllerTest, ShouldCalculateColorsBasedOnImage) {\n  EnableShelfColoring();\n  EXPECT_TRUE(ShouldCalculateColors());\n\n  controller_->CreateEmptyWallpaperForTesting();\n  EXPECT_FALSE(ShouldCalculateColors());\n}\n\nTEST_F(WallpaperControllerTest, ShouldCalculateColorsBasedOnSessionState) {\n  EnableShelfColoring();\n\n  SetSessionState(SessionState::UNKNOWN);\n  EXPECT_FALSE(ShouldCalculateColors());\n\n  SetSessionState(SessionState::OOBE);\n  EXPECT_FALSE(ShouldCalculateColors());\n\n  SetSessionState(SessionState::LOGIN_PRIMARY);\n  EXPECT_FALSE(ShouldCalculateColors());\n\n  SetSessionState(SessionState::LOGGED_IN_NOT_ACTIVE);\n  EXPECT_FALSE(ShouldCalculateColors());\n\n  SetSessionState(SessionState::ACTIVE);\n  EXPECT_TRUE(ShouldCalculateColors());\n\n  SetSessionState(SessionState::LOCKED);\n  EXPECT_FALSE(ShouldCalculateColors());\n\n  SetSessionState(SessionState::LOGIN_SECONDARY);\n  EXPECT_FALSE(ShouldCalculateColors());\n}\n\nTEST_F(WallpaperControllerTest, EnableShelfColoringNotifiesObservers) {\n  TestWallpaperControllerObserver observer(controller_);\n  EXPECT_EQ(0, observer.colors_changed_count());\n\n  // Enable shelf coloring will set a customized wallpaper image and change\n  // session state to ACTIVE, which will trigger wallpaper colors calculation.\n  EnableShelfColoring();\n  base::RunLoop().RunUntilIdle();\n  EXPECT_EQ(1, observer.colors_changed_count());\n}\n\nTEST_F(WallpaperControllerTest, ProminentColor_CachedColorsAvailableAtLogin) {\n  SetBypassDecode();\n  // Cache some wallpapers and store that in the local prefs. Otherwise, we\n  // can't cache colors.\n  base::FilePath relative_path = PrecacheWallpapers(account_id_1);\n  WallpaperInfo info = InfoWithType(WallpaperType::kCustomized);\n  info.location = relative_path.value();\n  ASSERT_TRUE(pref_manager_->SetLocalWallpaperInfo(account_id_1, info));\n\n  // Store colors in local prefs simulating cache behavior.\n  const std::vector<SkColor> prominent_colors = {SK_ColorGREEN, SK_ColorRED,\n                                                 SK_ColorBLUE,  SK_ColorWHITE,\n                                                 SK_ColorWHITE, SK_ColorWHITE};\n  pref_manager_->CacheProminentColors(account_id_1, prominent_colors);\n  const SkColor k_means_color = SK_ColorLTGRAY;\n  pref_manager_->CacheKMeanColor(account_id_1, k_means_color);\n\n  // Reset to login screen.\n  GetSessionControllerClient()->RequestSignOut();\n\n  TestWallpaperControllerObserver observer(controller_);\n  ASSERT_EQ(0, observer.colors_changed_count());\n\n  // Show user wallpaper in login screen. We are *not* logged in yet.\n  controller_->ShowUserWallpaper(account_id_1,\n                                 user_manager::UserType::USER_TYPE_REGULAR);\n  task_environment()->RunUntilIdle();\n\n  // Showing a user wallpaper should cause the cached colors to be fetched and\n  // reported.\n  EXPECT_EQ(1, observer.colors_changed_count());\n\n  // DARK_VIBRANT happens to be prominent color 0.\n  EXPECT_EQ(SK_ColorGREEN, controller_->GetProminentColor(\n                               {color_utils::LumaRange::DARK,\n                                color_utils::SaturationRange::VIBRANT}));\n  EXPECT_EQ(k_means_color, controller_->GetKMeanColor());\n}\n\nTEST_F(WallpaperControllerTest, ProminentColor_ClearedBetweenUsers) {\n  SetBypassDecode();\n  // Setup prominent colors for account 1.\n  base::FilePath relative_path = PrecacheWallpapers(account_id_1);\n  WallpaperInfo info = InfoWithType(WallpaperType::kCustomized);\n  info.location = relative_path.value();\n  ASSERT_TRUE(pref_manager_->SetLocalWallpaperInfo(account_id_1, info));\n\n  const std::vector<SkColor> prominent_colors = {SK_ColorGREEN, SK_ColorRED,\n                                                 SK_ColorBLUE,  SK_ColorWHITE,\n                                                 SK_ColorWHITE, SK_ColorWHITE};\n  pref_manager_->CacheProminentColors(account_id_1, prominent_colors);\n  const SkColor k_means_color = SK_ColorLTGRAY;\n  pref_manager_->CacheKMeanColor(account_id_1, k_means_color);\n\n  // Set a wallpaper for account 2.\n  WallpaperInfo info2 = InfoWithType(WallpaperType::kDefault);\n  ASSERT_TRUE(pref_manager_->SetLocalWallpaperInfo(account_id_2, info2));\n\n  // Reset to login screen.\n  GetSessionControllerClient()->RequestSignOut();\n\n  TestWallpaperControllerObserver observer(controller_);\n\n  // Show wallpaper for account 1.\n  controller_->ShowUserWallpaper(account_id_1,\n                                 user_manager::UserType::USER_TYPE_REGULAR);\n  task_environment()->RunUntilIdle();\n\n  // Verify that we can retrieve the prominent color.\n  EXPECT_EQ(SK_ColorGREEN, controller_->GetProminentColor(\n                               {color_utils::LumaRange::DARK,\n                                color_utils::SaturationRange::VIBRANT}));\n\n  // Show wallpaper for account 2.\n  controller_->ShowUserWallpaper(account_id_2,\n                                 user_manager::UserType::USER_TYPE_REGULAR);\n  task_environment()->RunUntilIdle();\n  // Since account 2 has not cached colors, the prominent color should be\n  // invalid.\n  EXPECT_EQ(\n      kInvalidWallpaperColor,\n      controller_->GetProminentColor({color_utils::LumaRange::DARK,\n                                      color_utils::SaturationRange::VIBRANT}));\n  EXPECT_EQ(2, observer.colors_changed_count());\n}\n\nTEST_F(WallpaperControllerTest, SetOnlineWallpaperFromDataSavesFile) {\n  SetBypassDecode();\n  gfx::ImageSkia image = CreateImage(640, 480, kWallpaperColor);\n  SimulateUserLogin(account_id_1);\n\n  // Verify that there's no offline wallpaper available in the beginning.\n  std::unique_ptr<base::RunLoop> run_loop = std::make_unique<base::RunLoop>();\n  controller_->GetOfflineWallpaperList(base::BindLambdaForTesting(\n      [&run_loop](const std::vector<std::string>& url_list) {\n        EXPECT_TRUE(url_list.empty());\n        run_loop->Quit();\n      }));\n  run_loop->Run();\n\n  // Set an online wallpaper with image data.\n  ClearWallpaperCount();\n  controller_->SetOnlineWallpaperFromData(\n      OnlineWallpaperParams(account_id_1, kAssetId, GURL(kDummyUrl),\n                            /*collection_id=*/std::string(),\n                            WALLPAPER_LAYOUT_CENTER_CROPPED,\n                            /*preview_mode=*/false, /*from_user=*/false,\n                            /*daily_refresh_enabled=*/false, kUnitId,\n                            /*variants=*/std::vector<OnlineWallpaperVariant>()),\n      /*image_data=*/std::string(),\n      WallpaperController::SetWallpaperCallback());\n  RunAllTasksUntilIdle();\n\n  // Verify that the wallpaper with |url| is available offline, and the returned\n  // file name should not contain the small wallpaper suffix.\n  run_loop = std::make_unique<base::RunLoop>();\n  controller_->GetOfflineWallpaperList(base::BindLambdaForTesting(\n      [&run_loop](const std::vector<std::string>& url_list) {\n        EXPECT_EQ(1U, url_list.size());\n        EXPECT_EQ(GURL(kDummyUrl).ExtractFileName(), url_list[0]);\n        run_loop->Quit();\n      }));\n  run_loop->Run();\n}\n\nTEST_F(WallpaperControllerTest,\n       UpdatePrimaryUserWallpaperWhileSecondUserActive) {\n  SetBypassDecode();\n  WallpaperInfo wallpaper_info;\n\n  SimulateUserLogin(account_id_1);\n\n  // Set an online wallpaper with image data. Verify that the wallpaper is set\n  // successfully.\n  const OnlineWallpaperParams& params = OnlineWallpaperParams(\n      account_id_1, kAssetId, GURL(kDummyUrl),\n      /*collection_id=*/std::string(), WALLPAPER_LAYOUT_CENTER_CROPPED,\n      /*preview_mode=*/false, /*from_user=*/false,\n      /*daily_refresh_enabled=*/false, kUnitId,\n      /*variants=*/std::vector<OnlineWallpaperVariant>());\n  controller_->SetOnlineWallpaperFromData(\n      params,\n      /*image_data=*/std::string(),\n      WallpaperController::SetWallpaperCallback());\n  RunAllTasksUntilIdle();\n  // Verify that the user wallpaper info is updated.\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  WallpaperInfo expected_wallpaper_info(params);\n  EXPECT_EQ(wallpaper_info, expected_wallpaper_info);\n\n  // Log in |kUser2|, and set another online wallpaper for |kUser1|. Verify that\n  // the on-screen wallpaper doesn't change since |kUser1| is not active, but\n  // wallpaper info is updated properly.\n  SimulateUserLogin(account_id_2);\n  ClearWallpaperCount();\n  const OnlineWallpaperParams& new_params = OnlineWallpaperParams(\n      account_id_1, kAssetId2, GURL(kDummyUrl2),\n      /*collection_id=*/std::string(), WALLPAPER_LAYOUT_CENTER_CROPPED,\n      /*preview_mode=*/false, /*from_user=*/false,\n      /*daily_refresh_enabled=*/false, kUnitId2,\n      /*variants=*/std::vector<OnlineWallpaperVariant>());\n  controller_->SetOnlineWallpaperFromData(\n      new_params,\n      /*image_data=*/std::string(),\n      WallpaperController::SetWallpaperCallback());\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(0, GetWallpaperCount());\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  WallpaperInfo expected_wallpaper_info_2(new_params);\n  EXPECT_EQ(wallpaper_info, expected_wallpaper_info_2);\n}\n\nTEST_F(WallpaperControllerTest, SetOnlineWallpaper) {\n  SetBypassDecode();\n\n  gfx::ImageSkia image = CreateImage(640, 480, kWallpaperColor);\n  WallpaperLayout layout = WALLPAPER_LAYOUT_CENTER_CROPPED;\n  SimulateUserLogin(account_id_1);\n\n  // Verify that calling |SetOnlineWallpaper| will download the image data if it\n  // does not exist. Verify that the wallpaper is set successfully.\n  auto run_loop = std::make_unique<base::RunLoop>();\n  ClearWallpaperCount();\n  const OnlineWallpaperParams& params = OnlineWallpaperParams(\n      account_id_1, kAssetId, GURL(kDummyUrl),\n      TestWallpaperControllerClient::kDummyCollectionId, layout,\n      /*preview_mode=*/false, /*from_user=*/true,\n      /*daily_refresh_enabled=*/false, kUnitId,\n      /*variants=*/std::vector<OnlineWallpaperVariant>());\n  controller_->SetOnlineWallpaper(\n      params, base::BindLambdaForTesting([&run_loop](bool success) {\n        EXPECT_TRUE(success);\n        run_loop->Quit();\n      }));\n  run_loop->Run();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kOnline);\n  // Verify that the user wallpaper info is updated.\n  WallpaperInfo wallpaper_info;\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  WallpaperInfo expected_wallpaper_info(params);\n  EXPECT_EQ(wallpaper_info, expected_wallpaper_info);\n  // Verify that wallpaper & collection metrics are logged.\n  histogram_tester().ExpectBucketCount(\"Ash.Wallpaper.Image\", kUnitId, 1);\n  histogram_tester().ExpectBucketCount(\n      \"Ash.Wallpaper.Collection\",\n      static_cast<int>(base::PersistentHash(\n          TestWallpaperControllerClient::kDummyCollectionId)),\n      1);\n  histogram_tester().ExpectBucketCount(\"Ash.Wallpaper.Type\",\n                                       WallpaperType::kOnline, 1);\n\n  // Verify that the wallpaper with |url| is available offline, and the returned\n  // file name should not contain the small wallpaper suffix.\n  run_loop = std::make_unique<base::RunLoop>();\n  controller_->GetOfflineWallpaperList(base::BindLambdaForTesting(\n      [&run_loop](const std::vector<std::string>& url_list) {\n        EXPECT_EQ(1U, url_list.size());\n        EXPECT_EQ(GURL(kDummyUrl).ExtractFileName(), url_list[0]);\n        run_loop->Quit();\n      }));\n  run_loop->Run();\n}\n\nTEST_F(WallpaperControllerTest, SetAndRemovePolicyWallpaper) {\n  SetBypassDecode();\n  // Simulate the login screen.\n  ClearLogin();\n\n  // The user starts with no wallpaper info and is not controlled by policy.\n  WallpaperInfo wallpaper_info;\n  EXPECT_FALSE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  EXPECT_FALSE(controller_->IsWallpaperControlledByPolicy(account_id_1));\n  // A default wallpaper is shown for the user.\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  EXPECT_EQ(1, GetWallpaperCount());\n  ASSERT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n\n  // Set a policy wallpaper. Verify that the user becomes policy controlled and\n  // the wallpaper info is updated.\n  ClearWallpaperCount();\n  controller_->SetPolicyWallpaper(account_id_1, user_manager::USER_TYPE_REGULAR,\n                                  std::string() /*data=*/);\n  RunAllTasksUntilIdle();\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  WallpaperInfo policy_wallpaper_info(base::FilePath(wallpaper_files_id_1)\n                                          .Append(\"policy-controlled.jpeg\")\n                                          .value(),\n                                      WALLPAPER_LAYOUT_CENTER_CROPPED,\n                                      WallpaperType::kPolicy,\n                                      base::Time::Now().LocalMidnight());\n  EXPECT_EQ(wallpaper_info, policy_wallpaper_info);\n  EXPECT_TRUE(controller_->IsWallpaperControlledByPolicy(account_id_1));\n  // Verify the wallpaper is not updated since the user hasn't logged in.\n  EXPECT_EQ(0, GetWallpaperCount());\n\n  // Log in the user. Verify the policy wallpaper is now being shown.\n  SimulateUserLogin(account_id_1);\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  EXPECT_EQ(1, GetWallpaperCount());\n  ASSERT_EQ(controller_->GetWallpaperType(), WallpaperType::kPolicy);\n\n  // Clear the wallpaper and log out the user. Verify the policy wallpaper is\n  // shown in the login screen.\n  ClearWallpaper();\n  ClearLogin();\n  controller_->ClearPrefChangeObserverForTesting();\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kPolicy);\n  EXPECT_TRUE(controller_->IsWallpaperControlledByPolicy(account_id_1));\n  // Remove the policy wallpaper. Verify the wallpaper info is reset to default\n  // and the user is no longer policy controlled.\n  ClearWallpaperCount();\n  controller_->RemovePolicyWallpaper(account_id_1);\n  WaitUntilCustomWallpapersDeleted(account_id_1);\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  WallpaperInfo default_wallpaper_info(\n      std::string(), WALLPAPER_LAYOUT_CENTER_CROPPED, WallpaperType::kDefault,\n      base::Time::Now().LocalMidnight());\n  EXPECT_EQ(wallpaper_info, default_wallpaper_info);\n  EXPECT_FALSE(controller_->IsWallpaperControlledByPolicy(account_id_1));\n  // Verify the wallpaper is not updated since the user hasn't logged in (to\n  // avoid abrupt wallpaper change in login screen).\n  EXPECT_EQ(0, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kPolicy);\n\n  // Log in the user. Verify the default wallpaper is now being shown.\n  SimulateUserLogin(account_id_1);\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n}\n\n// Simulates the scenario where the wallpaper are not yet resized and only the\n// original size image is available.\nTEST_F(WallpaperControllerTest, ShowUserWallpaper_OriginalFallback) {\n  SetBypassDecode();\n  CreateDefaultWallpapers();\n\n  // Simulate the login screen.\n  ClearLogin();\n\n  // Set a wallpaper.\n  CreateAndSaveWallpapers(account_id_1);\n  RunAllTasksUntilIdle();\n\n  // Verify the wallpaper was set.\n  WallpaperInfo wallpaper_info;\n  ASSERT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  ASSERT_EQ(WallpaperType::kCustomized, wallpaper_info.type);\n  ASSERT_EQ(\"[email protected]/[email protected]\", wallpaper_info.location);\n\n  // Move the wallpaper file to the original folder.\n  base::FilePath saved_wallpaper = custom_wallpaper_dir_.GetPath().Append(\n      \"small/[email protected]/[email protected]\");\n  ASSERT_TRUE(base::PathExists(saved_wallpaper));\n  base::CreateDirectory(\n      WallpaperControllerImpl::GetCustomWallpaperDir(\"original\")\n          .Append(\"[email protected]\"));\n  ASSERT_TRUE(base::PathExists(\n      WallpaperControllerImpl::GetCustomWallpaperDir(\"original\")));\n  ASSERT_TRUE(\n      base::Move(saved_wallpaper,\n                 WallpaperControllerImpl::GetCustomWallpaperDir(\"original\")\n                     .Append(wallpaper_info.location)));\n  ASSERT_FALSE(base::PathExists(saved_wallpaper));\n  ClearDecodeFilePaths();\n\n  // Show wallpaper\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n\n  // Verify the wallpaper was found in the original folder.\n  EXPECT_FALSE(GetDecodeFilePaths().empty());\n  EXPECT_THAT(\n      GetDecodeFilePaths().back().value(),\n      testing::EndsWith(\"original/[email protected]/[email protected]\"));\n}\n\n// Simulates a missing wallpaper due (possibly) an outdated preference. In this\n// situation, we fallback to the default.\nTEST_F(WallpaperControllerTest, ShowUserWallpaper_MissingFile) {\n  CreateDefaultWallpapers();\n\n  // Simulate the login screen.\n  ClearLogin();\n\n  // Set a wallpaper.\n  CreateAndSaveWallpapers(account_id_1);\n  RunAllTasksUntilIdle();\n\n  // Verify the wallpaper was set.\n  WallpaperInfo wallpaper_info;\n  ASSERT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  ASSERT_EQ(WallpaperType::kCustomized, wallpaper_info.type);\n  ASSERT_EQ(\"[email protected]/[email protected]\", wallpaper_info.location);\n\n  // Delete wallpaper file.\n  EXPECT_TRUE(base::DeleteFile(\n      user_data_dir_.GetPath().Append(wallpaper_info.location)));\n  ClearDecodeFilePaths();\n\n  // Show wallpaper\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n\n  // Verify the default wallpaper was used because the stored wallpaper was\n  // missing.\n  EXPECT_FALSE(GetDecodeFilePaths().empty());\n  EXPECT_THAT(GetDecodeFilePaths().back().value(),\n              testing::EndsWith(kDefaultSmallWallpaperName));\n}\n\nTEST_F(WallpaperControllerTest, RemovePolicyWallpaperNoOp) {\n  auto verify_custom_wallpaper_info = [&]() {\n    EXPECT_EQ(WallpaperType::kCustomized, controller_->GetWallpaperType());\n    EXPECT_EQ(kWallpaperColor, GetWallpaperColor());\n\n    WallpaperInfo wallpaper_info;\n    EXPECT_TRUE(\n        pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n    WallpaperInfo expected_wallpaper_info(\n        base::FilePath(wallpaper_files_id_1).Append(file_name_1).value(),\n        WALLPAPER_LAYOUT_CENTER, WallpaperType::kCustomized,\n        base::Time::Now().LocalMidnight());\n    EXPECT_EQ(expected_wallpaper_info, wallpaper_info);\n  };\n\n  // Set a custom wallpaper. Verify the user is not policy controlled and the\n  // wallpaper info is correct.\n  SimulateUserLogin(account_id_1);\n  ClearWallpaperCount();\n  controller_->SetCustomWallpaper(\n      account_id_1, file_name_1, WALLPAPER_LAYOUT_CENTER,\n      CreateImage(640, 480, kWallpaperColor), false /*preview_mode=*/);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_FALSE(controller_->IsWallpaperControlledByPolicy(account_id_1));\n  verify_custom_wallpaper_info();\n\n  // Verify RemovePolicyWallpaper() is a no-op when the user doesn't have a\n  // policy wallpaper.\n  controller_->RemovePolicyWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  verify_custom_wallpaper_info();\n}\n\nTEST_F(WallpaperControllerTest, SetThirdPartyWallpaper) {\n  SetBypassDecode();\n  SimulateUserLogin(account_id_1);\n\n  // Verify the user starts with no wallpaper info.\n  WallpaperInfo wallpaper_info;\n  EXPECT_FALSE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n\n  // Set a third-party wallpaper for |kUser1|.\n  const WallpaperLayout layout = WALLPAPER_LAYOUT_CENTER;\n  gfx::ImageSkia third_party_wallpaper = CreateImage(640, 480, kWallpaperColor);\n  ClearWallpaperCount();\n  EXPECT_TRUE(controller_->SetThirdPartyWallpaper(\n      account_id_1, file_name_1, layout, third_party_wallpaper));\n  RunAllTasksUntilIdle();\n  // Verify the wallpaper is shown.\n  EXPECT_EQ(1, GetWallpaperCount());\n  // Verify the user wallpaper info is updated.\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  WallpaperInfo expected_wallpaper_info(\n      base::FilePath(wallpaper_files_id_1).Append(file_name_1).value(), layout,\n      WallpaperType::kCustomized, base::Time::Now().LocalMidnight());\n  EXPECT_EQ(wallpaper_info, expected_wallpaper_info);\n  EXPECT_EQ(account_id_1, client_.get_save_wallpaper_to_drive_fs_account_id());\n\n  // Switch active user to |kUser2|, but set another third-party wallpaper for\n  // |kUser1|; the operation should not be allowed, because |kUser1| is not the\n  // active user.\n  SimulateUserLogin(account_id_2);\n  ClearWallpaperCount();\n  EXPECT_FALSE(controller_->SetThirdPartyWallpaper(\n      account_id_1, file_name_2, layout, third_party_wallpaper));\n  // Verify the wallpaper is not shown.\n  EXPECT_EQ(0, GetWallpaperCount());\n  // Verify the wallpaper info for |kUser1| is updated, because setting\n  // wallpaper is still allowed for non-active users.\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  WallpaperInfo expected_wallpaper_info_2(\n      base::FilePath(wallpaper_files_id_1).Append(file_name_2).value(), layout,\n      WallpaperType::kCustomized, base::Time::Now().LocalMidnight());\n  EXPECT_EQ(wallpaper_info, expected_wallpaper_info_2);\n\n  // Set a policy wallpaper for |kUser2|. Verify that |kUser2| becomes policy\n  // controlled.\n  controller_->SetPolicyWallpaper(account_id_2, user_manager::USER_TYPE_REGULAR,\n                                  std::string() /*data=*/);\n  RunAllTasksUntilIdle();\n  EXPECT_TRUE(controller_->IsWallpaperControlledByPolicy(account_id_2));\n  EXPECT_TRUE(controller_->IsActiveUserWallpaperControlledByPolicy());\n\n  // Setting a third-party wallpaper for |kUser2| should not be allowed, because\n  // third-party wallpapers cannot be set for policy controlled users.\n  ClearWallpaperCount();\n  EXPECT_FALSE(controller_->SetThirdPartyWallpaper(\n      account_id_2, file_name_1, layout, third_party_wallpaper));\n  // Verify the wallpaper is not shown.\n  EXPECT_EQ(0, GetWallpaperCount());\n  // Verify |kUser2| is still policy controlled and has the policy wallpaper\n  // info.\n  EXPECT_TRUE(controller_->IsWallpaperControlledByPolicy(account_id_2));\n  EXPECT_TRUE(controller_->IsActiveUserWallpaperControlledByPolicy());\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_2, &wallpaper_info));\n  WallpaperInfo policy_wallpaper_info(base::FilePath(wallpaper_files_id_2)\n                                          .Append(\"policy-controlled.jpeg\")\n                                          .value(),\n                                      WALLPAPER_LAYOUT_CENTER_CROPPED,\n                                      WallpaperType::kPolicy,\n                                      base::Time::Now().LocalMidnight());\n  EXPECT_EQ(wallpaper_info, policy_wallpaper_info);\n}\n\nTEST_F(WallpaperControllerTest, SetDefaultWallpaperForRegularAccount) {\n  CreateDefaultWallpapers();\n  SimulateUserLogin(account_id_1);\n\n  // First, simulate setting a user custom wallpaper.\n  SimulateSettingCustomWallpaper(account_id_1);\n  WallpaperInfo wallpaper_info;\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  WallpaperInfo default_wallpaper_info(\n      std::string(), WALLPAPER_LAYOUT_CENTER_CROPPED, WallpaperType::kDefault,\n      base::Time::Now().LocalMidnight());\n  EXPECT_NE(wallpaper_info.type, default_wallpaper_info.type);\n\n  // Verify |SetDefaultWallpaper| removes the previously set custom wallpaper\n  // info, and the large default wallpaper is set successfully with the correct\n  // file path.\n  UpdateDisplay(\"1600x1200\");\n  RunAllTasksUntilIdle();\n  ClearWallpaperCount();\n  ClearDecodeFilePaths();\n  controller_->SetDefaultWallpaper(account_id_1, true /*show_wallpaper=*/,\n                                   base::DoNothing());\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  ASSERT_EQ(1u, GetDecodeFilePaths().size());\n  EXPECT_EQ(default_wallpaper_dir_.GetPath().Append(kDefaultLargeWallpaperName),\n            GetDecodeFilePaths()[0]);\n\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  // The user wallpaper info has been reset to the default value.\n  EXPECT_EQ(wallpaper_info, default_wallpaper_info);\n\n  SimulateSettingCustomWallpaper(account_id_1);\n  // Verify |SetDefaultWallpaper| removes the previously set custom wallpaper\n  // info, and the small default wallpaper is set successfully with the correct\n  // file path.\n  UpdateDisplay(\"800x600\");\n  RunAllTasksUntilIdle();\n  ClearWallpaperCount();\n  ClearDecodeFilePaths();\n  controller_->SetDefaultWallpaper(account_id_1, true /*show_wallpaper=*/,\n                                   base::DoNothing());\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  ASSERT_EQ(1u, GetDecodeFilePaths().size());\n  EXPECT_EQ(default_wallpaper_dir_.GetPath().Append(kDefaultSmallWallpaperName),\n            GetDecodeFilePaths()[0]);\n\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  // The user wallpaper info has been reset to the default value.\n  EXPECT_EQ(wallpaper_info, default_wallpaper_info);\n\n  SimulateSettingCustomWallpaper(account_id_1);\n  // Verify that when screen is rotated, |SetDefaultWallpaper| removes the\n  // previously set custom wallpaper info, and the small default wallpaper is\n  // set successfully with the correct file path.\n  UpdateDisplay(\"800x600/r\");\n  RunAllTasksUntilIdle();\n  ClearWallpaperCount();\n  ClearDecodeFilePaths();\n  controller_->SetDefaultWallpaper(account_id_1, true /*show_wallpaper=*/,\n                                   base::DoNothing());\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  ASSERT_EQ(1u, GetDecodeFilePaths().size());\n  EXPECT_EQ(default_wallpaper_dir_.GetPath().Append(kDefaultSmallWallpaperName),\n            GetDecodeFilePaths()[0]);\n\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  // The user wallpaper info has been reset to the default value.\n  EXPECT_EQ(wallpaper_info, default_wallpaper_info);\n}\n\nTEST_F(WallpaperControllerTest, SetDefaultWallpaperForChildAccount) {\n  CreateDefaultWallpapers();\n\n  SimulateUserLogin(kChildAccountId, user_manager::USER_TYPE_CHILD);\n\n  // Verify the large child wallpaper is set successfully with the correct file\n  // path.\n  UpdateDisplay(\"1600x1200\");\n  RunAllTasksUntilIdle();\n  ClearWallpaperCount();\n  ClearDecodeFilePaths();\n  controller_->SetDefaultWallpaper(kChildAccountId, true /*show_wallpaper=*/,\n                                   base::DoNothing());\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  ASSERT_EQ(1u, GetDecodeFilePaths().size());\n  EXPECT_EQ(default_wallpaper_dir_.GetPath().Append(kChildLargeWallpaperName),\n            GetDecodeFilePaths()[0]);\n\n  // Verify the small child wallpaper is set successfully with the correct file\n  // path.\n  UpdateDisplay(\"800x600\");\n  RunAllTasksUntilIdle();\n  ClearWallpaperCount();\n  ClearDecodeFilePaths();\n  controller_->SetDefaultWallpaper(kChildAccountId, true /*show_wallpaper=*/,\n                                   base::DoNothing());\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  ASSERT_EQ(1u, GetDecodeFilePaths().size());\n  EXPECT_EQ(default_wallpaper_dir_.GetPath().Append(kChildSmallWallpaperName),\n            GetDecodeFilePaths()[0]);\n}\n\n// Verify that the |ShowWallpaperImage| will be called with the default image\n// for the guest session only even if there's a policy that has been set for\n// another user which invokes |SetPolicyWallpaper|.\nTEST_F(WallpaperControllerTest,\n       SetDefaultWallpaperForGuestSessionUnaffectedByWallpaperPolicy) {\n  SetBypassDecode();\n  // Simulate the login screen.\n  ClearLogin();\n  CreateDefaultWallpapers();\n  ClearWallpaperCount();\n\n  // First, simulate settings for a guest user which will show the default\n  // wallpaper image by invoking |ShowWallpaperImage|.\n  SimulateGuestLogin();\n\n  UpdateDisplay(\"1600x1200\");\n  RunAllTasksUntilIdle();\n  ClearWallpaperCount();\n  ClearDecodeFilePaths();\n\n  const AccountId guest_id =\n      AccountId::FromUserEmail(user_manager::kGuestUserName);\n  SimulateUserLogin(guest_id, user_manager::USER_TYPE_GUEST);\n  controller_->SetDefaultWallpaper(guest_id, /*show_wallpaper=*/true,\n                                   base::DoNothing());\n\n  WallpaperInfo wallpaper_info;\n  WallpaperInfo default_wallpaper_info(\n      std::string(), WALLPAPER_LAYOUT_CENTER_CROPPED, WallpaperType::kDefault,\n      base::Time::Now().LocalMidnight());\n  // Verify that the current displayed wallpaper is the default one inside the\n  // guest session.\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  EXPECT_TRUE(pref_manager_->GetUserWallpaperInfo(guest_id, &wallpaper_info));\n  EXPECT_EQ(wallpaper_info, default_wallpaper_info);\n  ASSERT_EQ(1u, GetDecodeFilePaths().size());\n  EXPECT_EQ(default_wallpaper_dir_.GetPath().Append(kGuestLargeWallpaperName),\n            GetDecodeFilePaths()[0]);\n\n  // Second, set a user policy for which is being set for another\n  // user and verifying that the policy has been applied successfully.\n  WallpaperInfo policy_wallpaper_info;\n  controller_->SetPolicyWallpaper(account_id_1, user_manager::USER_TYPE_REGULAR,\n                                  /*data=*/std::string());\n  EXPECT_TRUE(pref_manager_->GetUserWallpaperInfo(account_id_1,\n                                                  &policy_wallpaper_info));\n  WallpaperInfo expected_policy_wallpaper_info(\n      base::FilePath(wallpaper_files_id_1)\n          .Append(\"policy-controlled.jpeg\")\n          .value(),\n      WALLPAPER_LAYOUT_CENTER_CROPPED, WallpaperType::kPolicy,\n      base::Time::Now().LocalMidnight());\n  EXPECT_EQ(policy_wallpaper_info, expected_policy_wallpaper_info);\n  EXPECT_TRUE(controller_->IsWallpaperControlledByPolicy(account_id_1));\n\n  // Finally, verifying that the guest session hasn't been affected by the new\n  // policy and |ShowWallpaperImage| hasn't been invoked another time.\n\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  EXPECT_TRUE(pref_manager_->GetUserWallpaperInfo(guest_id, &wallpaper_info));\n  EXPECT_EQ(wallpaper_info, default_wallpaper_info);\n  ASSERT_EQ(1u, GetDecodeFilePaths().size());\n  EXPECT_EQ(default_wallpaper_dir_.GetPath().Append(kGuestLargeWallpaperName),\n            GetDecodeFilePaths()[0]);\n}\n\nTEST_F(WallpaperControllerTest, SetDefaultWallpaperForGuestSession) {\n  CreateDefaultWallpapers();\n\n  // First, simulate setting a custom wallpaper for a regular user.\n  SimulateUserLogin(account_id_1);\n  SimulateSettingCustomWallpaper(account_id_1);\n  WallpaperInfo wallpaper_info;\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  WallpaperInfo default_wallpaper_info(\n      std::string(), WALLPAPER_LAYOUT_CENTER_CROPPED, WallpaperType::kDefault,\n      base::Time::Now().LocalMidnight());\n  EXPECT_NE(wallpaper_info.type, default_wallpaper_info.type);\n\n  const AccountId guest_id =\n      AccountId::FromUserEmail(user_manager::kGuestUserName);\n  SimulateUserLogin(guest_id, user_manager::USER_TYPE_GUEST);\n\n  // Verify that during a guest session, |SetDefaultWallpaper| removes the user\n  // custom wallpaper info, but a guest specific wallpaper should be set,\n  // instead of the regular default wallpaper.\n  UpdateDisplay(\"1600x1200\");\n  RunAllTasksUntilIdle();\n  ClearWallpaperCount();\n  ClearDecodeFilePaths();\n  controller_->SetDefaultWallpaper(guest_id, true /*show_wallpaper=*/,\n                                   base::DoNothing());\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  EXPECT_TRUE(pref_manager_->GetUserWallpaperInfo(guest_id, &wallpaper_info));\n  EXPECT_EQ(wallpaper_info, default_wallpaper_info);\n  ASSERT_EQ(1u, GetDecodeFilePaths().size());\n  EXPECT_EQ(default_wallpaper_dir_.GetPath().Append(kGuestLargeWallpaperName),\n            GetDecodeFilePaths()[0]);\n\n  UpdateDisplay(\"800x600\");\n  RunAllTasksUntilIdle();\n  ClearWallpaperCount();\n  ClearDecodeFilePaths();\n  controller_->SetDefaultWallpaper(guest_id, true /*show_wallpaper=*/,\n                                   base::DoNothing());\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  ASSERT_EQ(1u, GetDecodeFilePaths().size());\n  EXPECT_EQ(default_wallpaper_dir_.GetPath().Append(kGuestSmallWallpaperName),\n            GetDecodeFilePaths()[0]);\n}\n\nTEST_F(WallpaperControllerTest, SetDefaultWallpaperCallbackTiming) {\n  SetBypassDecode();\n  SimulateUserLogin(account_id_1);\n\n  // First, simulate setting a user custom wallpaper.\n  SimulateSettingCustomWallpaper(account_id_1);\n  WallpaperInfo wallpaper_info;\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  EXPECT_NE(wallpaper_info.type, WallpaperType::kDefault);\n\n  TestWallpaperControllerObserver observer(controller_);\n\n  // Set default wallpaper and wait for success callback.\n  base::RunLoop loop;\n  controller_->SetDefaultWallpaper(\n      account_id_1, /*show_wallpaper=*/true,\n      base::BindLambdaForTesting([&loop, &observer](bool success) {\n        ASSERT_TRUE(success);\n        // Success callback should run before wallpaper observer is notified of\n        // change.\n        ASSERT_EQ(0, observer.wallpaper_changed_count());\n        loop.Quit();\n      }));\n  loop.Run();\n  // Wallpaper observer should have been notified of wallpaper change.\n  EXPECT_EQ(1, observer.wallpaper_changed_count());\n}\n\nTEST_F(WallpaperControllerTest, IgnoreWallpaperRequestInKioskMode) {\n  gfx::ImageSkia image = CreateImage(640, 480, kWallpaperColor);\n  SimulateUserLogin(\"kiosk\", user_manager::USER_TYPE_KIOSK_APP);\n\n  // Verify that |SetCustomWallpaper| doesn't set wallpaper in kiosk mode, and\n  // |account_id_1|'s wallpaper info is not updated.\n  ClearWallpaperCount();\n  controller_->SetCustomWallpaper(account_id_1, file_name_1,\n                                  WALLPAPER_LAYOUT_CENTER, image,\n                                  false /*preview_mode=*/);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(0, GetWallpaperCount());\n  WallpaperInfo wallpaper_info;\n  EXPECT_FALSE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n\n  // Verify that |SetOnlineWallpaperFromData| doesn't set wallpaper in kiosk\n  // mode, and |account_id_1|'s wallpaper info is not updated.\n  std::unique_ptr<base::RunLoop> run_loop = std::make_unique<base::RunLoop>();\n  ClearWallpaperCount();\n  controller_->SetOnlineWallpaperFromData(\n      OnlineWallpaperParams(account_id_1, kAssetId, GURL(kDummyUrl),\n                            /*collection_id=*/std::string(),\n                            WALLPAPER_LAYOUT_CENTER,\n                            /*preview_mode=*/false, /*from_user=*/false,\n                            /*daily_refresh_enabled=*/false, kUnitId,\n                            /*variants=*/std::vector<OnlineWallpaperVariant>()),\n      /*image_data=*/std::string(),\n      base::BindLambdaForTesting([&run_loop](bool success) {\n        EXPECT_FALSE(success);\n        run_loop->Quit();\n      }));\n  run_loop->Run();\n  EXPECT_EQ(0, GetWallpaperCount());\n  EXPECT_FALSE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n\n  // Verify that |SetDefaultWallpaper| doesn't set wallpaper in kiosk mode, and\n  // |account_id_1|'s wallpaper info is not updated.\n  ClearWallpaperCount();\n  controller_->SetDefaultWallpaper(account_id_1, true /*show_wallpaper=*/,\n                                   base::DoNothing());\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(0, GetWallpaperCount());\n  EXPECT_FALSE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n}\n\n// Disable the wallpaper setting for public session since it is ephemeral.\nTEST_F(WallpaperControllerTest, NotShowWallpaperSettingInPublicSession) {\n  SimulateUserLogin(\"public_session\", user_manager::USER_TYPE_PUBLIC_ACCOUNT);\n  EXPECT_FALSE(controller_->ShouldShowWallpaperSetting());\n}\n\nTEST_F(WallpaperControllerTest, IgnoreWallpaperRequestWhenPolicyIsEnforced) {\n  SetBypassDecode();\n  gfx::ImageSkia image = CreateImage(640, 480, kWallpaperColor);\n  SimulateUserLogin(account_id_1);\n\n  // Set a policy wallpaper for the user. Verify the user is policy controlled.\n  controller_->SetPolicyWallpaper(account_id_1, user_manager::USER_TYPE_REGULAR,\n                                  std::string() /*data=*/);\n  RunAllTasksUntilIdle();\n  EXPECT_TRUE(controller_->IsWallpaperControlledByPolicy(account_id_1));\n\n  WallpaperInfo wallpaper_info;\n  WallpaperInfo policy_wallpaper_info(base::FilePath(wallpaper_files_id_1)\n                                          .Append(\"policy-controlled.jpeg\")\n                                          .value(),\n                                      WALLPAPER_LAYOUT_CENTER_CROPPED,\n                                      WallpaperType::kPolicy,\n                                      base::Time::Now().LocalMidnight());\n\n  {\n    // Verify that |SetCustomWallpaper| doesn't set wallpaper when policy is\n    // enforced, and the user wallpaper info is not updated.\n    ClearWallpaperCount();\n    controller_->SetCustomWallpaper(account_id_1, file_name_1,\n                                    WALLPAPER_LAYOUT_CENTER, image,\n                                    false /*preview_mode=*/);\n    RunAllTasksUntilIdle();\n    EXPECT_EQ(0, GetWallpaperCount());\n    EXPECT_TRUE(\n        pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n    EXPECT_EQ(wallpaper_info, policy_wallpaper_info);\n  }\n\n  {\n    // Verify that |SetCustomWallpaper| with callback doesn't set wallpaper when\n    // policy is enforced, and the user wallpaper info is not updated.\n    std::unique_ptr<base::RunLoop> run_loop = std::make_unique<base::RunLoop>();\n    ClearWallpaperCount();\n    controller_->SetCustomWallpaper(\n        account_id_1, base::FilePath(file_name_1), WALLPAPER_LAYOUT_CENTER,\n        /*preview_mode=*/false,\n        base::BindLambdaForTesting([&run_loop](bool success) {\n          EXPECT_FALSE(success);\n          run_loop->Quit();\n        }));\n    run_loop->Run();\n    EXPECT_EQ(0, GetWallpaperCount());\n    EXPECT_TRUE(\n        pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n    EXPECT_EQ(wallpaper_info, policy_wallpaper_info);\n  }\n\n  {\n    // Verify that |SetOnlineWallpaperFromData| doesn't set wallpaper when\n    // policy is enforced, and the user wallpaper info is not updated.\n    std::unique_ptr<base::RunLoop> run_loop = std::make_unique<base::RunLoop>();\n    ClearWallpaperCount();\n    controller_->SetOnlineWallpaperFromData(\n        OnlineWallpaperParams(\n            account_id_1, kAssetId, GURL(kDummyUrl),\n            /*collection_id=*/std::string(), WALLPAPER_LAYOUT_CENTER_CROPPED,\n            /*preview_mode=*/false, /*from_user=*/false,\n            /*daily_refresh_enabled=*/false, kUnitId,\n            /*variants=*/std::vector<OnlineWallpaperVariant>()),\n        /*image_data=*/std::string(),\n        base::BindLambdaForTesting([&run_loop](bool success) {\n          EXPECT_FALSE(success);\n          run_loop->Quit();\n        }));\n    run_loop->Run();\n    EXPECT_EQ(0, GetWallpaperCount());\n    EXPECT_TRUE(\n        pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n    EXPECT_EQ(wallpaper_info, policy_wallpaper_info);\n  }\n\n  {\n    // Verify that |SetOnlineWallpaper| doesn't set wallpaper when policy is\n    // enforced, and the user wallpaper info is not updated.\n    std::unique_ptr<base::RunLoop> run_loop = std::make_unique<base::RunLoop>();\n    ClearWallpaperCount();\n    controller_->SetOnlineWallpaper(\n        OnlineWallpaperParams(\n            account_id_1, kAssetId, GURL(kDummyUrl),\n            /*collection_id=*/std::string(), WALLPAPER_LAYOUT_CENTER_CROPPED,\n            /*preview_mode=*/false, /*from_user=*/false,\n            /*daily_refresh_enabled=*/false, kUnitId,\n            /*variants=*/std::vector<OnlineWallpaperVariant>()),\n        base::BindLambdaForTesting([&run_loop](bool success) {\n          EXPECT_FALSE(success);\n          run_loop->Quit();\n        }));\n    run_loop->Run();\n    EXPECT_EQ(0, GetWallpaperCount());\n    EXPECT_TRUE(\n        pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n    EXPECT_EQ(wallpaper_info, policy_wallpaper_info);\n  }\n\n  {\n    // Verify that |SetDefaultWallpaper| doesn't set wallpaper when policy is\n    // enforced, and the user wallpaper info is not updated.\n    ClearWallpaperCount();\n    controller_->SetDefaultWallpaper(account_id_1, true /*show_wallpaper=*/,\n                                     base::DoNothing());\n    RunAllTasksUntilIdle();\n    EXPECT_EQ(0, GetWallpaperCount());\n    EXPECT_TRUE(\n        pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n    EXPECT_EQ(wallpaper_info, policy_wallpaper_info);\n  }\n}\n\nTEST_F(WallpaperControllerTest, VerifyWallpaperCache) {\n  SetBypassDecode();\n  gfx::ImageSkia image = CreateImage(640, 480, kWallpaperColor);\n  SimulateUserLogin(account_id_1);\n\n  // |kUser1| doesn't have wallpaper cache in the beginning.\n  gfx::ImageSkia cached_wallpaper;\n  EXPECT_FALSE(\n      controller_->GetWallpaperFromCache(account_id_1, &cached_wallpaper));\n  base::FilePath path;\n  EXPECT_FALSE(controller_->GetPathFromCache(account_id_1, &path));\n\n  // Verify |SetOnlineWallpaperFromData| updates wallpaper cache for |user1|.\n  controller_->SetOnlineWallpaperFromData(\n      OnlineWallpaperParams(account_id_1, kAssetId, GURL(kDummyUrl),\n                            /*collection_id=*/std::string(),\n                            WALLPAPER_LAYOUT_CENTER,\n                            /*preview_mode=*/false, /*from_user=*/false,\n                            /*daily_refresh_enabled=*/false, kUnitId,\n                            /*variants=*/std::vector<OnlineWallpaperVariant>()),\n      /*image_data=*/std::string(),\n      WallpaperController::SetWallpaperCallback());\n  RunAllTasksUntilIdle();\n  EXPECT_TRUE(\n      controller_->GetWallpaperFromCache(account_id_1, &cached_wallpaper));\n  EXPECT_TRUE(controller_->GetPathFromCache(account_id_1, &path));\n\n  // After |kUser2| is logged in, |user1|'s wallpaper cache should still be kept\n  // (crbug.com/339576). Note the active user is still |user1|.\n  TestSessionControllerClient* session = GetSessionControllerClient();\n  session->AddUserSession(kUser2);\n  EXPECT_TRUE(\n      controller_->GetWallpaperFromCache(account_id_1, &cached_wallpaper));\n  EXPECT_TRUE(controller_->GetPathFromCache(account_id_1, &path));\n\n  // Verify |SetDefaultWallpaper| clears wallpaper cache.\n  controller_->SetDefaultWallpaper(account_id_1, true /*show_wallpaper=*/,\n                                   base::DoNothing());\n  EXPECT_FALSE(\n      controller_->GetWallpaperFromCache(account_id_1, &cached_wallpaper));\n  EXPECT_FALSE(controller_->GetPathFromCache(account_id_1, &path));\n\n  // Verify |SetCustomWallpaper| updates wallpaper cache for |user1|.\n  controller_->SetCustomWallpaper(account_id_1, file_name_1,\n                                  WALLPAPER_LAYOUT_CENTER, image,\n                                  false /*preview_mode=*/);\n  RunAllTasksUntilIdle();\n  EXPECT_TRUE(\n      controller_->GetWallpaperFromCache(account_id_1, &cached_wallpaper));\n  EXPECT_TRUE(controller_->GetPathFromCache(account_id_1, &path));\n\n  // Verify |RemoveUserWallpaper| clears wallpaper cache.\n  controller_->RemoveUserWallpaper(account_id_1);\n  EXPECT_FALSE(\n      controller_->GetWallpaperFromCache(account_id_1, &cached_wallpaper));\n  EXPECT_FALSE(controller_->GetPathFromCache(account_id_1, &path));\n}\n\n// Tests that the appropriate wallpaper (large vs. small) is shown depending\n// on the desktop resolution.\nTEST_F(WallpaperControllerTest, ShowCustomWallpaperWithCorrectResolution) {\n  CreateDefaultWallpapers();\n  const base::FilePath small_custom_wallpaper_path =\n      GetCustomWallpaperPath(WallpaperControllerImpl::kSmallWallpaperSubDir,\n                             wallpaper_files_id_1, file_name_1);\n  const base::FilePath large_custom_wallpaper_path =\n      GetCustomWallpaperPath(WallpaperControllerImpl::kLargeWallpaperSubDir,\n                             wallpaper_files_id_1, file_name_1);\n  const base::FilePath small_default_wallpaper_path =\n      default_wallpaper_dir_.GetPath().Append(kDefaultSmallWallpaperName);\n  const base::FilePath large_default_wallpaper_path =\n      default_wallpaper_dir_.GetPath().Append(kDefaultLargeWallpaperName);\n\n  CreateAndSaveWallpapers(account_id_1);\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  // Display is initialized to 800x600. The small resolution custom wallpaper is\n  // expected. A second decode request with small resolution default wallpaper\n  // is also expected. (Because unit tests don't support actual wallpaper\n  // decoding, it falls back to the default wallpaper.)\n  EXPECT_EQ(1, GetWallpaperCount());\n  ASSERT_EQ(2u, GetDecodeFilePaths().size());\n  EXPECT_EQ(small_custom_wallpaper_path, GetDecodeFilePaths()[0]);\n  EXPECT_EQ(small_default_wallpaper_path, GetDecodeFilePaths()[1]);\n\n  // Hook up another 800x600 display. This shouldn't trigger a reload.\n  ClearWallpaperCount();\n  ClearDecodeFilePaths();\n  UpdateDisplay(\"800x600,800x600\");\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(0, GetWallpaperCount());\n  EXPECT_EQ(0u, GetDecodeFilePaths().size());\n\n  // Detach the secondary display.\n  UpdateDisplay(\"800x600\");\n  RunAllTasksUntilIdle();\n  // Hook up a 2000x2000 display. The large resolution custom wallpaper should\n  // be loaded.\n  ClearWallpaperCount();\n  ClearDecodeFilePaths();\n  UpdateDisplay(\"800x600,3000x2000\");\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  ASSERT_EQ(2u, GetDecodeFilePaths().size());\n  EXPECT_EQ(large_custom_wallpaper_path, GetDecodeFilePaths()[0]);\n  EXPECT_EQ(large_default_wallpaper_path, GetDecodeFilePaths()[1]);\n\n  // Detach the secondary display.\n  UpdateDisplay(\"800x600\");\n  RunAllTasksUntilIdle();\n  // Hook up the 3000x2000 display again. The large resolution default wallpaper\n  // should persist. Test for crbug/165788.\n  ClearWallpaperCount();\n  ClearDecodeFilePaths();\n  UpdateDisplay(\"800x600,3000x2000\");\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  ASSERT_EQ(2u, GetDecodeFilePaths().size());\n  EXPECT_EQ(large_custom_wallpaper_path, GetDecodeFilePaths()[0]);\n  EXPECT_EQ(large_default_wallpaper_path, GetDecodeFilePaths()[1]);\n}\n\n// After the display is rotated, the sign in wallpaper should be kept. Test for\n// crbug.com/794725.\nTEST_F(WallpaperControllerTest, SigninWallpaperIsKeptAfterRotation) {\n  CreateDefaultWallpapers();\n\n  UpdateDisplay(\"800x600\");\n  RunAllTasksUntilIdle();\n  controller_->ShowSigninWallpaper();\n  RunAllTasksUntilIdle();\n  // Display is initialized to 800x600. The small resolution default wallpaper\n  // is expected.\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  ASSERT_EQ(1u, GetDecodeFilePaths().size());\n  EXPECT_EQ(default_wallpaper_dir_.GetPath().Append(kDefaultSmallWallpaperName),\n            GetDecodeFilePaths()[0]);\n\n  ClearWallpaperCount();\n  ClearDecodeFilePaths();\n  // After rotating the display, the small resolution default wallpaper should\n  // still be expected, instead of a custom wallpaper.\n  UpdateDisplay(\"800x600/r\");\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  ASSERT_EQ(1u, GetDecodeFilePaths().size());\n  EXPECT_EQ(default_wallpaper_dir_.GetPath().Append(kDefaultSmallWallpaperName),\n            GetDecodeFilePaths()[0]);\n}\n\n// Display size change should trigger wallpaper reload.\nTEST_F(WallpaperControllerTest, ReloadWallpaper) {\n  CreateAndSaveWallpapers(account_id_1);\n\n  // Show a user wallpaper.\n  UpdateDisplay(\"800x600\");\n  RunAllTasksUntilIdle();\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  // Rotating the display should trigger a wallpaper reload.\n  ClearWallpaperCount();\n  UpdateDisplay(\"800x600/r\");\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  // Calling |ShowUserWallpaper| again with the same account id and display\n  // size should not trigger wallpaper reload (crbug.com/158383).\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(0, GetWallpaperCount());\n\n  // Start wallpaper preview.\n  SimulateUserLogin(account_id_1);\n  std::unique_ptr<aura::Window> wallpaper_picker_window(\n      CreateTestWindow(gfx::Rect(0, 0, 100, 100)));\n  WindowState::Get(wallpaper_picker_window.get())->Activate();\n  ClearWallpaperCount();\n  controller_->SetCustomWallpaper(\n      account_id_1, file_name_1, WALLPAPER_LAYOUT_CENTER,\n      CreateImage(640, 480, kWallpaperColor), true /*preview_mode=*/);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  // Rotating the display should trigger a wallpaper reload.\n  ClearWallpaperCount();\n  UpdateDisplay(\"800x600\");\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  ClearWallpaperCount();\n  controller_->CancelPreviewWallpaper();\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n\n  // Show an always-on-top wallpaper.\n  const base::FilePath image_path =\n      base::CommandLine::ForCurrentProcess()->GetSwitchValuePath(\n          switches::kGuestWallpaperLarge);\n  CreateDefaultWallpapers();\n  SetBypassDecode();\n  ClearWallpaperCount();\n  controller_->ShowAlwaysOnTopWallpaper(image_path);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  // Rotating the display should trigger a wallpaper reload.\n  ClearWallpaperCount();\n  UpdateDisplay(\"800x600/r\");\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n}\n\nTEST_F(WallpaperControllerTest, UpdateCurrentWallpaperLayout) {\n  SetBypassDecode();\n  gfx::ImageSkia image = CreateImage(640, 480, kSmallCustomWallpaperColor);\n  WallpaperLayout layout = WALLPAPER_LAYOUT_STRETCH;\n  WallpaperLayout new_layout = WALLPAPER_LAYOUT_CENTER;\n  SimulateUserLogin(account_id_1);\n\n  // Set a custom wallpaper for the user. Verify that it's set successfully\n  // and the wallpaper info is updated.\n  ClearWallpaperCount();\n  controller_->SetCustomWallpaper(account_id_1, file_name_1, layout, image,\n                                  false /*preview_mode=*/);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperLayout(), layout);\n  WallpaperInfo wallpaper_info;\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  WallpaperInfo expected_custom_wallpaper_info(\n      base::FilePath(wallpaper_files_id_1).Append(file_name_1).value(), layout,\n      WallpaperType::kCustomized, base::Time::Now().LocalMidnight());\n  EXPECT_EQ(wallpaper_info, expected_custom_wallpaper_info);\n\n  // Now change to a different layout. Verify that the layout is updated for\n  // both the current wallpaper and the saved wallpaper info.\n  ClearWallpaperCount();\n  controller_->UpdateCurrentWallpaperLayout(account_id_1, new_layout);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperLayout(), new_layout);\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  expected_custom_wallpaper_info.layout = new_layout;\n  EXPECT_EQ(wallpaper_info, expected_custom_wallpaper_info);\n\n  {\n    base::test::ScopedFeatureList scoped_feature_list;\n    scoped_feature_list.InitWithFeatures(\n        {ash::features::kWallpaperGooglePhotosIntegration}, {});\n\n    // Now set a Google Photos wallpaper. Verify that it's set successfully and\n    // the wallpaper info is updated.\n    ClearWallpaperCount();\n    controller_->SetGooglePhotosWallpaper(\n        GooglePhotosWallpaperParams(account_id_1, \"id\",\n                                    /*daily_refresh_enabled=*/false, layout,\n                                    /*preview_mode=*/false, \"dedup_key\"),\n        base::DoNothing());\n    RunAllTasksUntilIdle();\n    EXPECT_EQ(1, GetWallpaperCount());\n    EXPECT_EQ(controller_->GetWallpaperType(),\n              WallpaperType::kOnceGooglePhotos);\n    EXPECT_EQ(controller_->GetWallpaperLayout(), layout);\n    EXPECT_TRUE(\n        pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n    EXPECT_EQ(wallpaper_info,\n              WallpaperInfo(GooglePhotosWallpaperParams(\n                  account_id_1, \"id\", /*daily_refresh_enabled=*/false, layout,\n                  /*preview_mode=*/false, \"dedup_key\")));\n\n    // Now change to a different layout. Verify that the layout is updated for\n    // both the current wallpaper and the saved wallpaper info.\n    ClearWallpaperCount();\n    controller_->UpdateCurrentWallpaperLayout(account_id_1, new_layout);\n    RunAllTasksUntilIdle();\n    EXPECT_EQ(1, GetWallpaperCount());\n    EXPECT_EQ(controller_->GetWallpaperLayout(), new_layout);\n    EXPECT_TRUE(\n        pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n    EXPECT_EQ(wallpaper_info,\n              WallpaperInfo(GooglePhotosWallpaperParams(\n                  account_id_1, \"id\", /*daily_refresh_enabled=*/false,\n                  new_layout, /*preview_mode=*/false, \"dedup_key\")));\n  }\n\n  // Now set an online wallpaper. Verify that it's set successfully and the\n  // wallpaper info is updated.\n  image = CreateImage(640, 480, kWallpaperColor);\n  ClearWallpaperCount();\n  const OnlineWallpaperParams& params =\n      OnlineWallpaperParams(account_id_1, kAssetId, GURL(kDummyUrl),\n                            /*collection_id=*/std::string(), layout,\n                            /*preview_mode=*/false, /*from_user=*/false,\n                            /*daily_refresh_enabled=*/false, kUnitId,\n                            /*variants=*/std::vector<OnlineWallpaperVariant>());\n  controller_->SetOnlineWallpaperFromData(\n      params,\n      /*image_data=*/std::string(),\n      WallpaperController::SetWallpaperCallback());\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kOnline);\n  EXPECT_EQ(controller_->GetWallpaperLayout(), layout);\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  WallpaperInfo expected_online_wallpaper_info(params);\n  EXPECT_EQ(wallpaper_info, expected_online_wallpaper_info);\n\n  // Now change the layout of the online wallpaper. Verify that it's a no-op.\n  ClearWallpaperCount();\n  controller_->UpdateCurrentWallpaperLayout(account_id_1, new_layout);\n  RunAllTasksUntilIdle();\n  // The wallpaper is not updated.\n  EXPECT_EQ(0, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperLayout(), layout);\n  // The saved wallpaper info is not updated.\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  EXPECT_EQ(wallpaper_info, expected_online_wallpaper_info);\n}\n\n// Tests that if a user who has a custom wallpaper is removed from the device,\n// only the directory that contains the user's custom wallpapers gets removed.\n// The other user's custom wallpaper is not affected.\nTEST_F(WallpaperControllerTest, RemoveUserWithCustomWallpaper) {\n  SimulateUserLogin(account_id_1);\n  base::FilePath small_wallpaper_path_1 =\n      GetCustomWallpaperPath(WallpaperControllerImpl::kSmallWallpaperSubDir,\n                             wallpaper_files_id_1, file_name_1);\n\n  // Set a custom wallpaper for |kUser1| and verify the wallpaper exists.\n  CreateAndSaveWallpapers(account_id_1);\n  EXPECT_TRUE(base::PathExists(small_wallpaper_path_1));\n\n  // Now login another user and set a custom wallpaper for the user.\n  SimulateUserLogin(account_id_2);\n  base::FilePath small_wallpaper_path_2 = GetCustomWallpaperPath(\n      WallpaperControllerImpl::kSmallWallpaperSubDir, wallpaper_files_id_2,\n      GetDummyFileName(account_id_2));\n  CreateAndSaveWallpapers(account_id_2);\n  EXPECT_TRUE(base::PathExists(small_wallpaper_path_2));\n\n  // Simulate the removal of |kUser2|.\n  controller_->RemoveUserWallpaper(account_id_2);\n  // Wait until all files under the user's custom wallpaper directory are\n  // removed.\n  WaitUntilCustomWallpapersDeleted(account_id_2);\n  EXPECT_FALSE(base::PathExists(small_wallpaper_path_2));\n\n  // Verify that the other user's wallpaper is not affected.\n  EXPECT_TRUE(base::PathExists(small_wallpaper_path_1));\n}\n\n// Tests that if a user who has a default wallpaper is removed from the device,\n// the other user's custom wallpaper is not affected.\nTEST_F(WallpaperControllerTest, RemoveUserWithDefaultWallpaper) {\n  SimulateUserLogin(account_id_1);\n  base::FilePath small_wallpaper_path_1 =\n      GetCustomWallpaperPath(WallpaperControllerImpl::kSmallWallpaperSubDir,\n                             wallpaper_files_id_1, file_name_1);\n  // Set a custom wallpaper for |kUser1| and verify the wallpaper exists.\n  CreateAndSaveWallpapers(account_id_1);\n  EXPECT_TRUE(base::PathExists(small_wallpaper_path_1));\n\n  // Now login another user and set a default wallpaper for the user.\n  SimulateUserLogin(account_id_2);\n  controller_->SetDefaultWallpaper(account_id_2, true /*show_wallpaper=*/,\n                                   base::DoNothing());\n\n  // Simulate the removal of |kUser2|.\n  controller_->RemoveUserWallpaper(account_id_2);\n\n  // Verify that the other user's wallpaper is not affected.\n  EXPECT_TRUE(base::PathExists(small_wallpaper_path_1));\n}\n\nTEST_F(WallpaperControllerTest, IsActiveUserWallpaperControlledByPolicy) {\n  SetBypassDecode();\n  // Simulate the login screen. Verify that it returns false since there's no\n  // active user.\n  ClearLogin();\n  EXPECT_FALSE(controller_->IsActiveUserWallpaperControlledByPolicy());\n\n  SimulateUserLogin(account_id_1);\n  EXPECT_FALSE(controller_->IsActiveUserWallpaperControlledByPolicy());\n  // Set a policy wallpaper for the active user. Verify that the active user\n  // becomes policy controlled.\n  controller_->SetPolicyWallpaper(account_id_1, user_manager::USER_TYPE_REGULAR,\n                                  std::string() /*data=*/);\n  RunAllTasksUntilIdle();\n  EXPECT_TRUE(controller_->IsActiveUserWallpaperControlledByPolicy());\n\n  // Switch the active user. Verify the active user is not policy controlled.\n  SimulateUserLogin(account_id_2);\n  EXPECT_FALSE(controller_->IsActiveUserWallpaperControlledByPolicy());\n\n  // Logs out. Verify that it returns false since there's no active user.\n  ClearLogin();\n  EXPECT_FALSE(controller_->IsActiveUserWallpaperControlledByPolicy());\n}\n\nTEST_F(WallpaperControllerTest,\n       IsManagedGuestSessionWallpaperControlledByPolicy) {\n  SetBypassDecode();\n  // Simulate the login screen. Verify that it returns false since there's no\n  // active user.\n  ClearLogin();\n  EXPECT_FALSE(controller_->IsActiveUserWallpaperControlledByPolicy());\n\n  // Set a policy wallpaper for the managed guest session. Verify that the\n  // managed guest session becomes policy controlled.\n  controller_->SetPolicyWallpaper(account_id_1,\n                                  user_manager::USER_TYPE_PUBLIC_ACCOUNT,\n                                  std::string() /*data=*/);\n  SimulateUserLogin(account_id_1, user_manager::USER_TYPE_PUBLIC_ACCOUNT);\n  RunAllTasksUntilIdle();\n  EXPECT_TRUE(controller_->IsWallpaperControlledByPolicy(account_id_1));\n\n  // Verify the wallpaper policy is applied after logging in.\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  EXPECT_EQ(1, GetWallpaperCount());\n  ASSERT_EQ(controller_->GetWallpaperType(), WallpaperType::kPolicy);\n\n  // Switch the active user. Verify the active user is not policy controlled.\n  SimulateUserLogin(account_id_2);\n  EXPECT_FALSE(controller_->IsActiveUserWallpaperControlledByPolicy());\n\n  // Logs out. Verify that it returns false since there's no active user.\n  ClearLogin();\n  EXPECT_FALSE(controller_->IsActiveUserWallpaperControlledByPolicy());\n}\n\nTEST_F(WallpaperControllerTest, WallpaperBlur) {\n  TestWallpaperControllerObserver observer(controller_);\n\n  ASSERT_TRUE(controller_->IsBlurAllowedForLockState());\n  ASSERT_FALSE(controller_->IsWallpaperBlurredForLockState());\n\n  SetSessionState(SessionState::ACTIVE);\n  EXPECT_FALSE(controller_->IsWallpaperBlurredForLockState());\n  EXPECT_EQ(0, observer.blur_changed_count());\n\n  SetSessionState(SessionState::LOCKED);\n  EXPECT_TRUE(controller_->IsWallpaperBlurredForLockState());\n  EXPECT_EQ(1, observer.blur_changed_count());\n\n  SetSessionState(SessionState::LOGGED_IN_NOT_ACTIVE);\n  EXPECT_FALSE(controller_->IsWallpaperBlurredForLockState());\n  EXPECT_EQ(2, observer.blur_changed_count());\n\n  SetSessionState(SessionState::LOGIN_SECONDARY);\n  EXPECT_TRUE(controller_->IsWallpaperBlurredForLockState());\n  EXPECT_EQ(3, observer.blur_changed_count());\n\n  // Blur state does not change below.\n  SetSessionState(SessionState::LOGIN_PRIMARY);\n  EXPECT_TRUE(controller_->IsWallpaperBlurredForLockState());\n  EXPECT_EQ(3, observer.blur_changed_count());\n\n  SetSessionState(SessionState::OOBE);\n  EXPECT_TRUE(controller_->IsWallpaperBlurredForLockState());\n  EXPECT_EQ(3, observer.blur_changed_count());\n\n  SetSessionState(SessionState::UNKNOWN);\n  EXPECT_TRUE(controller_->IsWallpaperBlurredForLockState());\n  EXPECT_EQ(3, observer.blur_changed_count());\n}\n\nTEST_F(WallpaperControllerTest, WallpaperBlurDuringLockScreenTransition) {\n  ui::ScopedAnimationDurationScaleMode test_duration_mode(\n      ui::ScopedAnimationDurationScaleMode::NON_ZERO_DURATION);\n\n  gfx::ImageSkia image = CreateImage(600, 400, kWallpaperColor);\n  controller_->ShowWallpaperImage(\n      image, CreateWallpaperInfo(WALLPAPER_LAYOUT_CENTER),\n      /*preview_mode=*/false, /*always_on_top=*/false);\n\n  TestWallpaperControllerObserver observer(controller_);\n\n  ASSERT_TRUE(controller_->IsBlurAllowedForLockState());\n  ASSERT_FALSE(controller_->IsWallpaperBlurredForLockState());\n\n  ASSERT_EQ(2u, wallpaper_view()->layer()->parent()->children().size());\n  EXPECT_EQ(ui::LAYER_TEXTURED,\n            wallpaper_view()->layer()->parent()->children()[0]->type());\n  EXPECT_EQ(ui::LAYER_TEXTURED,\n            wallpaper_view()->layer()->parent()->children()[1]->type());\n\n  // Simulate lock and unlock sequence.\n  controller_->UpdateWallpaperBlurForLockState(true);\n  EXPECT_TRUE(controller_->IsWallpaperBlurredForLockState());\n  EXPECT_EQ(1, observer.blur_changed_count());\n\n  SetSessionState(SessionState::LOCKED);\n  EXPECT_TRUE(controller_->IsWallpaperBlurredForLockState());\n  ASSERT_EQ(3u, wallpaper_view()->layer()->parent()->children().size());\n  EXPECT_EQ(ui::LAYER_SOLID_COLOR,\n            wallpaper_view()->layer()->parent()->children()[0]->type());\n  EXPECT_EQ(ui::LAYER_TEXTURED,\n            wallpaper_view()->layer()->parent()->children()[1]->type());\n  EXPECT_EQ(ui::LAYER_TEXTURED,\n            wallpaper_view()->layer()->parent()->children()[2]->type());\n\n  // Change of state to ACTIVE triggers post lock animation and\n  // UpdateWallpaperBlur(false)\n  SetSessionState(SessionState::ACTIVE);\n  EXPECT_FALSE(controller_->IsWallpaperBlurredForLockState());\n  EXPECT_EQ(2, observer.blur_changed_count());\n  ASSERT_EQ(2u, wallpaper_view()->layer()->parent()->children().size());\n  EXPECT_EQ(ui::LAYER_TEXTURED,\n            wallpaper_view()->layer()->parent()->children()[0]->type());\n  EXPECT_EQ(ui::LAYER_TEXTURED,\n            wallpaper_view()->layer()->parent()->children()[1]->type());\n}\n\nTEST_F(WallpaperControllerTest, LockDuringOverview) {\n  gfx::ImageSkia image = CreateImage(600, 400, kWallpaperColor);\n  controller_->ShowWallpaperImage(\n      image, CreateWallpaperInfo(WALLPAPER_LAYOUT_CENTER),\n      /*preview_mode=*/false, /*always_on_top=*/false);\n  TestWallpaperControllerObserver observer(controller_);\n\n  EnterOverview();\n\n  EXPECT_FALSE(controller_->IsWallpaperBlurredForLockState());\n  EXPECT_EQ(0, observer.blur_changed_count());\n\n  // Simulate lock and unlock sequence.\n  SetSessionState(SessionState::LOCKED);\n\n  EXPECT_TRUE(controller_->IsWallpaperBlurredForLockState());\n\n  // Get wallpaper_view directly because it's not animating.\n  auto* wallpaper_view = Shell::Get()\n                             ->GetPrimaryRootWindowController()\n                             ->wallpaper_widget_controller()\n                             ->wallpaper_view();\n\n  // Make sure that wallpaper still have blur.\n  ASSERT_EQ(30, wallpaper_view->blur_sigma());\n}\n\nTEST_F(WallpaperControllerTest, DontLeakShieldView) {\n  SetSessionState(SessionState::LOCKED);\n  views::View* shield_view = wallpaper_view()->shield_view_for_testing();\n  ASSERT_TRUE(shield_view);\n  views::ViewTracker view_tracker(shield_view);\n  SetSessionState(SessionState::ACTIVE);\n  EXPECT_EQ(nullptr, wallpaper_view()->shield_view_for_testing());\n  EXPECT_EQ(nullptr, view_tracker.view());\n}\n\nTEST_F(WallpaperControllerTest, OnlyShowDevicePolicyWallpaperOnLoginScreen) {\n  SetBypassDecode();\n\n  // Verify the device policy wallpaper is shown on login screen.\n  SetSessionState(SessionState::LOGIN_PRIMARY);\n  controller_->SetDevicePolicyWallpaperPath(\n      base::FilePath(kDefaultSmallWallpaperName));\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_TRUE(IsDevicePolicyWallpaper());\n  // Verify the device policy wallpaper shouldn't be blurred.\n  ASSERT_FALSE(controller_->IsBlurAllowedForLockState());\n  ASSERT_FALSE(controller_->IsWallpaperBlurredForLockState());\n\n  // Verify the device policy wallpaper is replaced when session state is no\n  // longer LOGIN_PRIMARY.\n  SetSessionState(SessionState::LOGGED_IN_NOT_ACTIVE);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(2, GetWallpaperCount());\n  EXPECT_FALSE(IsDevicePolicyWallpaper());\n\n  // Verify the device policy wallpaper never shows up again when session\n  // state changes.\n  SetSessionState(SessionState::ACTIVE);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(2, GetWallpaperCount());\n  EXPECT_FALSE(IsDevicePolicyWallpaper());\n\n  SetSessionState(SessionState::LOCKED);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(2, GetWallpaperCount());\n  EXPECT_FALSE(IsDevicePolicyWallpaper());\n\n  SetSessionState(SessionState::LOGIN_SECONDARY);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(2, GetWallpaperCount());\n  EXPECT_FALSE(IsDevicePolicyWallpaper());\n}\n\nTEST_F(WallpaperControllerTest, ShouldShowInitialAnimationAfterBoot) {\n  CreateDefaultWallpapers();\n\n  // Simulate the login screen after system boot.\n  base::CommandLine::ForCurrentProcess()->AppendSwitch(\n      switches::kFirstExecAfterBoot);\n  base::CommandLine::ForCurrentProcess()->AppendSwitch(switches::kLoginManager);\n  ClearLogin();\n\n  // Show the first wallpaper. Verify that the slower animation should be used.\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  EXPECT_TRUE(controller_->ShouldShowInitialAnimation());\n  EXPECT_EQ(1, GetWallpaperCount());\n\n  // Show the second wallpaper. Verify that the slower animation should not be\n  // used. (Use a different user type to ensure a different wallpaper is shown,\n  // otherwise requests of loading the same wallpaper are ignored.)\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(kChildAccountId);\n  RunAllTasksUntilIdle();\n  EXPECT_FALSE(controller_->ShouldShowInitialAnimation());\n  EXPECT_EQ(1, GetWallpaperCount());\n\n  // Log in the user and show the wallpaper. Verify that the slower animation\n  // should not be used.\n  SimulateUserLogin(account_id_1);\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  EXPECT_FALSE(controller_->ShouldShowInitialAnimation());\n  EXPECT_EQ(1, GetWallpaperCount());\n}\n\nTEST_F(WallpaperControllerTest, ShouldNotShowInitialAnimationAfterSignOut) {\n  CreateDefaultWallpapers();\n\n  // Simulate the login screen after user sign-out. Verify that the slower\n  // animation should never be used.\n  base::CommandLine::ForCurrentProcess()->AppendSwitch(switches::kLoginManager);\n  CreateAndSaveWallpapers(account_id_1);\n  ClearLogin();\n\n  // Show the first wallpaper.\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  EXPECT_FALSE(controller_->ShouldShowInitialAnimation());\n  EXPECT_EQ(1, GetWallpaperCount());\n\n  // Show the second wallpaper.\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(kChildAccountId);\n  RunAllTasksUntilIdle();\n  EXPECT_FALSE(controller_->ShouldShowInitialAnimation());\n  EXPECT_EQ(1, GetWallpaperCount());\n\n  // Log in the user and show the wallpaper.\n  SimulateUserLogin(account_id_1);\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  EXPECT_FALSE(controller_->ShouldShowInitialAnimation());\n  EXPECT_EQ(1, GetWallpaperCount());\n}\n\nTEST_F(WallpaperControllerTest, ClosePreviewWallpaperOnOverviewStart) {\n  // Verify the user starts with a default wallpaper and the user wallpaper info\n  // is initialized with default values.\n  SimulateUserLogin(account_id_1);\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  WallpaperInfo user_wallpaper_info;\n  WallpaperInfo default_wallpaper_info(\n      std::string(), WALLPAPER_LAYOUT_CENTER_CROPPED, WallpaperType::kDefault,\n      base::Time::Now().LocalMidnight());\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n\n  // Simulate opening the wallpaper picker window.\n  std::unique_ptr<aura::Window> wallpaper_picker_window(\n      CreateTestWindow(gfx::Rect(0, 0, 100, 100)));\n  WindowState::Get(wallpaper_picker_window.get())->Activate();\n\n  // Set a custom wallpaper for the user and enable preview. Verify that the\n  // wallpaper is changed to the expected color.\n  const WallpaperLayout layout = WALLPAPER_LAYOUT_CENTER;\n  gfx::ImageSkia custom_wallpaper = CreateImage(640, 480, kWallpaperColor);\n  EXPECT_NE(kWallpaperColor, GetWallpaperColor());\n  ClearWallpaperCount();\n\n  TestWallpaperControllerObserver observer(controller_);\n  controller_->SetCustomWallpaper(account_id_1, file_name_1, layout,\n                                  custom_wallpaper, true /*preview_mode=*/);\n  RunAllTasksUntilIdle();\n  EXPECT_TRUE(observer.is_in_wallpaper_preview());\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(kWallpaperColor, GetWallpaperColor());\n  // Verify that the user wallpaper info remains unchanged during the preview.\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n\n  // Now enter overview mode. Verify the wallpaper changes back to the default,\n  // the user wallpaper info remains unchanged, and enters overview mode\n  // properly.\n  ClearWallpaperCount();\n  EnterOverview();\n  RunAllTasksUntilIdle();\n  EXPECT_FALSE(observer.is_in_wallpaper_preview());\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_NE(kWallpaperColor, GetWallpaperColor());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n  EXPECT_TRUE(Shell::Get()->overview_controller()->InOverviewSession());\n}\n\nTEST_F(WallpaperControllerTest, ClosePreviewWallpaperOnWindowCycleStart) {\n  // Verify the user starts with a default wallpaper and the user wallpaper info\n  // is initialized with default values.\n  SimulateUserLogin(account_id_1);\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  WallpaperInfo user_wallpaper_info;\n  WallpaperInfo default_wallpaper_info(\n      std::string(), WALLPAPER_LAYOUT_CENTER_CROPPED, WallpaperType::kDefault,\n      base::Time::Now().LocalMidnight());\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n\n  // Simulate opening the wallpaper picker window.\n  std::unique_ptr<aura::Window> wallpaper_picker_window(\n      CreateTestWindow(gfx::Rect(0, 0, 100, 100)));\n  WindowState::Get(wallpaper_picker_window.get())->Activate();\n\n  TestWallpaperControllerObserver observer(controller_);\n\n  // Set a custom wallpaper for the user and enable preview. Verify that the\n  // wallpaper is changed to the expected color.\n  const WallpaperLayout layout = WALLPAPER_LAYOUT_CENTER;\n  gfx::ImageSkia custom_wallpaper = CreateImage(640, 480, kWallpaperColor);\n  EXPECT_NE(kWallpaperColor, GetWallpaperColor());\n  ClearWallpaperCount();\n  controller_->SetCustomWallpaper(account_id_1, file_name_1, layout,\n                                  custom_wallpaper, true /*preview_mode=*/);\n  RunAllTasksUntilIdle();\n  EXPECT_TRUE(observer.is_in_wallpaper_preview());\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(kWallpaperColor, GetWallpaperColor());\n  // Verify that the user wallpaper info remains unchanged during the preview.\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n\n  // Now start window cycle. Verify the wallpaper changes back to the default,\n  // the user wallpaper info remains unchanged, and enters window cycle.\n  ClearWallpaperCount();\n  Shell::Get()->window_cycle_controller()->HandleCycleWindow(\n      WindowCycleController::WindowCyclingDirection::kForward);\n  RunAllTasksUntilIdle();\n  EXPECT_FALSE(observer.is_in_wallpaper_preview());\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_NE(kWallpaperColor, GetWallpaperColor());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n  EXPECT_TRUE(Shell::Get()->window_cycle_controller()->IsCycling());\n}\n\nTEST_F(WallpaperControllerTest,\n       ClosePreviewWallpaperOnActiveUserSessionChanged) {\n  // Verify the user starts with a default wallpaper and the user wallpaper info\n  // is initialized with default values.\n  SimulateUserLogin(account_id_1);\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  WallpaperInfo user_wallpaper_info;\n  WallpaperInfo default_wallpaper_info(\n      std::string(), WALLPAPER_LAYOUT_CENTER_CROPPED, WallpaperType::kDefault,\n      base::Time::Now().LocalMidnight());\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n\n  // Simulate opening the wallpaper picker window.\n  std::unique_ptr<aura::Window> wallpaper_picker_window(\n      CreateTestWindow(gfx::Rect(0, 0, 100, 100)));\n  WindowState::Get(wallpaper_picker_window.get())->Activate();\n\n  TestWallpaperControllerObserver observer(controller_);\n\n  // Set a custom wallpaper for the user and enable preview. Verify that the\n  // wallpaper is changed to the expected color.\n  const WallpaperLayout layout = WALLPAPER_LAYOUT_CENTER;\n  gfx::ImageSkia custom_wallpaper = CreateImage(640, 480, kWallpaperColor);\n  EXPECT_NE(kWallpaperColor, GetWallpaperColor());\n  ClearWallpaperCount();\n  controller_->SetCustomWallpaper(account_id_1, file_name_1, layout,\n                                  custom_wallpaper, true /*preview_mode=*/);\n  RunAllTasksUntilIdle();\n  EXPECT_TRUE(observer.is_in_wallpaper_preview());\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(kWallpaperColor, GetWallpaperColor());\n  // Verify that the user wallpaper info remains unchanged during the preview.\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n\n  // Now switch to another user. Verify the wallpaper changes back to the\n  // default and the user wallpaper remains unchanged.\n  ClearWallpaperCount();\n  SimulateUserLogin(account_id_2);\n  controller_->ShowUserWallpaper(account_id_2);\n  RunAllTasksUntilIdle();\n  EXPECT_FALSE(observer.is_in_wallpaper_preview());\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_NE(kWallpaperColor, GetWallpaperColor());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_2, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n}\n\nTEST_F(WallpaperControllerTest, ConfirmPreviewWallpaper) {\n  // Verify the user starts with a default wallpaper and the user wallpaper info\n  // is initialized with default values.\n  SimulateUserLogin(account_id_1);\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  WallpaperInfo user_wallpaper_info;\n  WallpaperInfo default_wallpaper_info(\n      std::string(), WALLPAPER_LAYOUT_CENTER_CROPPED, WallpaperType::kDefault,\n      base::Time::Now().LocalMidnight());\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n\n  // Simulate opening the wallpaper picker window.\n  std::unique_ptr<aura::Window> wallpaper_picker_window(\n      CreateTestWindow(gfx::Rect(0, 0, 100, 100)));\n  WindowState::Get(wallpaper_picker_window.get())->Activate();\n\n  // Set a custom wallpaper for the user and enable preview. Verify that the\n  // wallpaper is changed to the expected color.\n  const WallpaperLayout layout = WALLPAPER_LAYOUT_CENTER;\n  gfx::ImageSkia custom_wallpaper = CreateImage(640, 480, kWallpaperColor);\n  EXPECT_NE(kWallpaperColor, GetWallpaperColor());\n  ClearWallpaperCount();\n  controller_->SetCustomWallpaper(account_id_1, file_name_1, layout,\n                                  custom_wallpaper, true /*preview_mode=*/);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(kWallpaperColor, GetWallpaperColor());\n  // Verify that the user wallpaper info remains unchanged during the preview.\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n  histogram_tester().ExpectTotalCount(\"Ash.Wallpaper.Preview.Show\", 1);\n\n  // Now confirm the preview wallpaper, verify that there's no wallpaper change\n  // because the wallpaper is already shown.\n  ClearWallpaperCount();\n  controller_->ConfirmPreviewWallpaper();\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(0, GetWallpaperCount());\n  EXPECT_EQ(kWallpaperColor, GetWallpaperColor());\n\n  // Verify that the user wallpaper info is now updated to the custom wallpaper\n  // info.\n  WallpaperInfo custom_wallpaper_info(\n      base::FilePath(wallpaper_files_id_1).Append(file_name_1).value(), layout,\n      WallpaperType::kCustomized, base::Time::Now().LocalMidnight());\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, custom_wallpaper_info);\n\n  // Set an empty online wallpaper for the user, verify it fails.\n  ClearWallpaperCount();\n  std::unique_ptr<base::RunLoop> run_loop = std::make_unique<base::RunLoop>();\n  SetOnlineWallpaperFromImage(\n      account_id_1, kAssetId, gfx::ImageSkia(), kDummyUrl,\n      TestWallpaperControllerClient::kDummyCollectionId, layout,\n      /*save_file=*/false, /*preview_mode=*/true, /*from_user=*/true, kUnitId,\n      /*variants=*/std::vector<OnlineWallpaperVariant>(),\n      base::BindLambdaForTesting([&run_loop](bool success) {\n        EXPECT_FALSE(success);\n        run_loop->Quit();\n      }));\n  run_loop->Run();\n  EXPECT_EQ(0, GetWallpaperCount());\n\n  // Now set a valid online wallpaper for the user and enable preview. Verify\n  // that the wallpaper is changed to the expected color.\n  const SkColor online_wallpaper_color = SK_ColorCYAN;\n  gfx::ImageSkia online_wallpaper =\n      CreateImage(640, 480, online_wallpaper_color);\n  EXPECT_NE(online_wallpaper_color, GetWallpaperColor());\n  run_loop = std::make_unique<base::RunLoop>();\n  SetOnlineWallpaperFromImage(\n      account_id_1, kAssetId, online_wallpaper, kDummyUrl,\n      TestWallpaperControllerClient::kDummyCollectionId, layout,\n      /*save_file=*/false, /*preview_mode=*/true, /*from_user=*/true, kUnitId,\n      /*variants=*/\n      std::vector<OnlineWallpaperVariant>(),\n      base::BindLambdaForTesting([&run_loop](bool success) {\n        EXPECT_TRUE(success);\n        run_loop->Quit();\n      }));\n  run_loop->Run();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(online_wallpaper_color, GetWallpaperColor());\n  // Verify that the user wallpaper info remains unchanged during the preview.\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, custom_wallpaper_info);\n\n  // Now confirm the preview wallpaper, verify that there's no wallpaper change\n  // because the wallpaper is already shown.\n  ClearWallpaperCount();\n  controller_->ConfirmPreviewWallpaper();\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(0, GetWallpaperCount());\n  EXPECT_EQ(online_wallpaper_color, GetWallpaperColor());\n  // Verify that the user wallpaper info is now updated to the online wallpaper\n  // info.\n  WallpaperInfo online_wallpaper_info(OnlineWallpaperParams(\n      account_id_1, kAssetId, GURL(kDummyUrl),\n      TestWallpaperControllerClient::kDummyCollectionId, layout,\n      /*preview_mode=*/false,\n      /*from_user=*/true,\n      /*daily_refresh_enabled=*/false, kUnitId,\n      /*variants=*/\n      std::vector<OnlineWallpaperVariant>()));\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, online_wallpaper_info);\n}\n\nTEST_F(WallpaperControllerTest, CancelPreviewWallpaper) {\n  // Verify the user starts with a default wallpaper and the user wallpaper info\n  // is initialized with default values.\n  SimulateUserLogin(account_id_1);\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  WallpaperInfo user_wallpaper_info;\n  WallpaperInfo default_wallpaper_info(\n      std::string(), WALLPAPER_LAYOUT_CENTER_CROPPED, WallpaperType::kDefault,\n      base::Time::Now().LocalMidnight());\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n\n  // Simulate opening the wallpaper picker window.\n  std::unique_ptr<aura::Window> wallpaper_picker_window(\n      CreateTestWindow(gfx::Rect(0, 0, 100, 100)));\n  WindowState::Get(wallpaper_picker_window.get())->Activate();\n\n  // Set a custom wallpaper for the user and enable preview. Verify that the\n  // wallpaper is changed to the expected color.\n  const WallpaperLayout layout = WALLPAPER_LAYOUT_CENTER;\n  gfx::ImageSkia custom_wallpaper = CreateImage(640, 480, kWallpaperColor);\n  EXPECT_NE(kWallpaperColor, GetWallpaperColor());\n  ClearWallpaperCount();\n  controller_->SetCustomWallpaper(account_id_1, file_name_1, layout,\n                                  custom_wallpaper, true /*preview_mode=*/);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(kWallpaperColor, GetWallpaperColor());\n  // Verify that the user wallpaper info remains unchanged during the preview.\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n\n  // Now cancel the preview. Verify the wallpaper changes back to the default\n  // and the user wallpaper info remains unchanged.\n  ClearWallpaperCount();\n  controller_->CancelPreviewWallpaper();\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_NE(kWallpaperColor, GetWallpaperColor());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n\n  // Now set an online wallpaper for the user and enable preview. Verify that\n  // the wallpaper is changed to the expected color.\n  const SkColor online_wallpaper_color = SK_ColorCYAN;\n  gfx::ImageSkia online_wallpaper =\n      CreateImage(640, 480, online_wallpaper_color);\n  EXPECT_NE(online_wallpaper_color, GetWallpaperColor());\n  ClearWallpaperCount();\n  SetOnlineWallpaperFromImage(\n      account_id_1, kAssetId, online_wallpaper, kDummyUrl,\n      TestWallpaperControllerClient::kDummyCollectionId, layout,\n      /*save_file=*/false, /*preview_mode=*/true, /*from_user=*/true, kUnitId,\n      /*variants=*/std::vector<OnlineWallpaperVariant>(),\n      WallpaperController::SetWallpaperCallback());\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(online_wallpaper_color, GetWallpaperColor());\n  // Verify that the user wallpaper info remains unchanged during the preview.\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n\n  // Now cancel the preview. Verify the wallpaper changes back to the default\n  // and the user wallpaper info remains unchanged.\n  ClearWallpaperCount();\n  controller_->CancelPreviewWallpaper();\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_NE(online_wallpaper_color, GetWallpaperColor());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n}\n\nTEST_F(WallpaperControllerTest, WallpaperSyncedDuringPreview) {\n  // Verify the user starts with a default wallpaper and the user wallpaper info\n  // is initialized with default values.\n  SimulateUserLogin(account_id_1);\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  WallpaperInfo user_wallpaper_info;\n  WallpaperInfo default_wallpaper_info(\n      std::string(), WALLPAPER_LAYOUT_CENTER_CROPPED, WallpaperType::kDefault,\n      base::Time::Now().LocalMidnight());\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n\n  // Simulate opening the wallpaper picker window.\n  std::unique_ptr<aura::Window> wallpaper_picker_window(\n      CreateTestWindow(gfx::Rect(0, 0, 100, 100)));\n  WindowState::Get(wallpaper_picker_window.get())->Activate();\n\n  // Set a custom wallpaper for the user and enable preview. Verify that the\n  // wallpaper is changed to the expected color.\n  const WallpaperLayout layout = WALLPAPER_LAYOUT_CENTER;\n  gfx::ImageSkia custom_wallpaper = CreateImage(640, 480, kWallpaperColor);\n  EXPECT_NE(kWallpaperColor, GetWallpaperColor());\n  ClearWallpaperCount();\n  controller_->SetCustomWallpaper(account_id_1, file_name_1, layout,\n                                  custom_wallpaper, true /*preview_mode=*/);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(kWallpaperColor, GetWallpaperColor());\n  // Verify that the user wallpaper info remains unchanged during the preview.\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n\n  // Now set another custom wallpaper for the user and disable preview (this\n  // happens if a custom wallpaper set on another device is being synced).\n  // Verify there's no wallpaper change since preview mode shouldn't be\n  // interrupted.\n  const SkColor synced_custom_wallpaper_color = SK_ColorBLUE;\n  gfx::ImageSkia synced_custom_wallpaper =\n      CreateImage(640, 480, synced_custom_wallpaper_color);\n  ClearWallpaperCount();\n  controller_->SetCustomWallpaper(account_id_1, file_name_2, layout,\n                                  synced_custom_wallpaper,\n                                  false /*preview_mode=*/);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(0, GetWallpaperCount());\n  EXPECT_EQ(kWallpaperColor, GetWallpaperColor());\n  // However, the user wallpaper info should already be updated to the new info.\n  WallpaperInfo synced_custom_wallpaper_info(\n      base::FilePath(wallpaper_files_id_1).Append(file_name_2).value(), layout,\n      WallpaperType::kCustomized, base::Time::Now().LocalMidnight());\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, synced_custom_wallpaper_info);\n\n  // Now cancel the preview. Verify the synced custom wallpaper is shown instead\n  // of the initial default wallpaper, and the user wallpaper info is still\n  // correct.\n  ClearWallpaperCount();\n  controller_->CancelPreviewWallpaper();\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(synced_custom_wallpaper_color, GetWallpaperColor());\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, synced_custom_wallpaper_info);\n\n  // Repeat the above steps for online wallpapers: set a online wallpaper for\n  // the user and enable preview. Verify that the wallpaper is changed to the\n  // expected color.\n  gfx::ImageSkia online_wallpaper = CreateImage(640, 480, kWallpaperColor);\n  EXPECT_NE(kWallpaperColor, GetWallpaperColor());\n\n  ClearWallpaperCount();\n  SetOnlineWallpaperFromImage(\n      account_id_1, kAssetId, online_wallpaper, kDummyUrl,\n      TestWallpaperControllerClient::kDummyCollectionId, layout,\n      /*save_file=*/false, /*preview_mode=*/true, /*from_user=*/true, kUnitId,\n      /*variants=*/std::vector<OnlineWallpaperVariant>(),\n      WallpaperController::SetWallpaperCallback());\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(kWallpaperColor, GetWallpaperColor());\n  // Verify that the user wallpaper info remains unchanged during the preview.\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, synced_custom_wallpaper_info);\n\n  // Now set another online wallpaper for the user and disable preview. Verify\n  // there's no wallpaper change since preview mode shouldn't be interrupted.\n  const SkColor synced_online_wallpaper_color = SK_ColorCYAN;\n  gfx::ImageSkia synced_online_wallpaper =\n      CreateImage(640, 480, synced_online_wallpaper_color);\n  ClearWallpaperCount();\n  SetOnlineWallpaperFromImage(\n      account_id_1, kAssetId, synced_online_wallpaper, kDummyUrl2,\n      TestWallpaperControllerClient::kDummyCollectionId, layout,\n      /*save_file=*/false, /*preview_mode=*/false,\n      /*from_user=*/true, kUnitId,\n      /*variants=*/std::vector<OnlineWallpaperVariant>(),\n      WallpaperController::SetWallpaperCallback());\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(0, GetWallpaperCount());\n  EXPECT_EQ(kWallpaperColor, GetWallpaperColor());\n  // However, the user wallpaper info should already be updated to the new info.\n  WallpaperInfo synced_online_wallpaper_info =\n      WallpaperInfo(OnlineWallpaperParams(\n          account_id_1, kAssetId, GURL(kDummyUrl2),\n          TestWallpaperControllerClient::kDummyCollectionId, layout,\n          /*preview_mode=*/false,\n          /*from_user=*/true,\n          /*daily_refresh_enabled=*/false, kUnitId,\n          /*variants=*/\n          std::vector<OnlineWallpaperVariant>()));\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, synced_online_wallpaper_info);\n\n  // Now cancel the preview. Verify the synced online wallpaper is shown instead\n  // of the previous custom wallpaper, and the user wallpaper info is still\n  // correct.\n  ClearWallpaperCount();\n  controller_->CancelPreviewWallpaper();\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(synced_online_wallpaper_color, GetWallpaperColor());\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, synced_online_wallpaper_info);\n}\n\nTEST_F(WallpaperControllerTest, AddFirstWallpaperAnimationEndCallback) {\n  ui::ScopedAnimationDurationScaleMode test_duration_mode(\n      ui::ScopedAnimationDurationScaleMode::NON_ZERO_DURATION);\n  std::unique_ptr<aura::Window> test_window(\n      CreateTestWindow(gfx::Rect(0, 0, 100, 100)));\n\n  base::RunLoop test_loop;\n  controller_->AddFirstWallpaperAnimationEndCallback(test_loop.QuitClosure(),\n                                                     test_window.get());\n  // The callback is not run because the first wallpaper hasn't been set.\n  task_environment()->RunUntilIdle();\n  EXPECT_FALSE(test_loop.AnyQuitCalled());\n\n  // Set the first wallpaper.\n  controller_->ShowDefaultWallpaperForTesting();\n  controller_->AddFirstWallpaperAnimationEndCallback(test_loop.QuitClosure(),\n                                                     test_window.get());\n  task_environment()->RunUntilIdle();\n  // Neither callback is run because the animation of the first wallpaper\n  // hasn't finished yet.\n  EXPECT_FALSE(test_loop.AnyQuitCalled());\n\n  // Force the animation to complete. The two callbacks are both run.\n  RunDesktopControllerAnimation();\n  test_loop.Run();\n  EXPECT_TRUE(test_loop.AnyQuitCalled());\n\n  // The callback added after the first wallpaper animation is run right away.\n  bool is_third_callback_run = false;\n  controller_->AddFirstWallpaperAnimationEndCallback(\n      base::BindLambdaForTesting(\n          [&is_third_callback_run]() { is_third_callback_run = true; }),\n      test_window.get());\n  EXPECT_TRUE(is_third_callback_run);\n}\n\nTEST_F(WallpaperControllerTest, ShowOneShotWallpaper) {\n  gfx::ImageSkia custom_wallpaper = CreateImage(640, 480, kWallpaperColor);\n  WallpaperLayout layout = WALLPAPER_LAYOUT_CENTER;\n\n  SimulateUserLogin(account_id_1);\n  // First, set a custom wallpaper for |kUser1|. Verify the wallpaper is shown\n  // successfully and the user wallpaper info is updated.\n  ClearWallpaperCount();\n  controller_->SetCustomWallpaper(account_id_1, file_name_1, layout,\n                                  custom_wallpaper, false /*preview_mode=*/);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(kWallpaperColor, GetWallpaperColor());\n  EXPECT_EQ(WallpaperType::kCustomized, controller_->GetWallpaperType());\n  const WallpaperInfo expected_wallpaper_info(\n      base::FilePath(wallpaper_files_id_1).Append(file_name_1).value(), layout,\n      WallpaperType::kCustomized, base::Time::Now().LocalMidnight());\n  WallpaperInfo wallpaper_info;\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  EXPECT_EQ(expected_wallpaper_info, wallpaper_info);\n\n  // Show a one-shot wallpaper. Verify it is shown successfully.\n  ClearWallpaperCount();\n  constexpr SkColor kOneShotWallpaperColor = SK_ColorWHITE;\n  gfx::ImageSkia one_shot_wallpaper =\n      CreateImage(640, 480, kOneShotWallpaperColor);\n  controller_->ShowOneShotWallpaper(one_shot_wallpaper);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(kOneShotWallpaperColor, GetWallpaperColor());\n  EXPECT_EQ(WallpaperType::kOneShot, controller_->GetWallpaperType());\n  EXPECT_FALSE(controller_->IsBlurAllowedForLockState());\n  EXPECT_FALSE(controller_->ShouldApplyShield());\n\n  // Verify that we can reload wallpaer without losing it.\n  // This is important for screen rotation.\n  controller_->ReloadWallpaperForTesting(/*clear_cache=*/false);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(2, GetWallpaperCount());  // Reload increments count.\n  EXPECT_EQ(kOneShotWallpaperColor, GetWallpaperColor());\n  EXPECT_EQ(WallpaperType::kOneShot, controller_->GetWallpaperType());\n  EXPECT_FALSE(controller_->IsBlurAllowedForLockState());\n  EXPECT_FALSE(controller_->ShouldApplyShield());\n\n  // Verify the user wallpaper info is unaffected, and the one-shot wallpaper\n  // can be replaced by the user wallpaper.\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  EXPECT_EQ(expected_wallpaper_info, wallpaper_info);\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(kWallpaperColor, GetWallpaperColor());\n  EXPECT_EQ(WallpaperType::kCustomized, controller_->GetWallpaperType());\n}\n\nTEST_F(WallpaperControllerTest, OnFirstWallpaperShown) {\n  TestWallpaperControllerObserver observer(controller_);\n  EXPECT_EQ(0, GetWallpaperCount());\n  EXPECT_EQ(0, observer.first_shown_count());\n  // Show the first wallpaper, verify the observer is notified.\n  controller_->ShowWallpaperImage(CreateImage(640, 480, SK_ColorBLUE),\n                                  CreateWallpaperInfo(WALLPAPER_LAYOUT_STRETCH),\n                                  /*preview_mode=*/false,\n                                  /*always_on_top=*/false);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(SK_ColorBLUE, GetWallpaperColor());\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(1, observer.first_shown_count());\n  // Show the second wallpaper, verify the observer is not notified.\n  controller_->ShowWallpaperImage(CreateImage(640, 480, SK_ColorCYAN),\n                                  CreateWallpaperInfo(WALLPAPER_LAYOUT_STRETCH),\n                                  /*preview_mode=*/false,\n                                  /*always_on_top=*/false);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(SK_ColorCYAN, GetWallpaperColor());\n  EXPECT_EQ(2, GetWallpaperCount());\n  EXPECT_EQ(1, observer.first_shown_count());\n}\n\n// Although ephemeral users' custom wallpapers are not saved to disk, they\n// should be kept within the user session. Test for https://crbug.com/825237.\nTEST_F(WallpaperControllerTest, ShowWallpaperForEphemeralUser) {\n  // Clear the local pref so we can make sure nothing writes to it.\n  local_state()->ClearPref(prefs::kUserWallpaperInfo);\n\n  // Add an ephemeral user session and simulate login, like SimulateUserLogin.\n  UserSession session;\n  session.session_id = 0;\n  session.user_info.account_id = account_id_1;\n  session.user_info.is_ephemeral = true;\n  Shell::Get()->session_controller()->UpdateUserSession(std::move(session));\n  TestSessionControllerClient* const client = GetSessionControllerClient();\n  client->SwitchActiveUser(account_id_1);\n  client->SetSessionState(SessionState::ACTIVE);\n\n  // The user doesn't have wallpaper cache in the beginning.\n  gfx::ImageSkia cached_wallpaper;\n  EXPECT_FALSE(\n      controller_->GetWallpaperFromCache(account_id_1, &cached_wallpaper));\n  base::FilePath path;\n  EXPECT_FALSE(controller_->GetPathFromCache(account_id_1, &path));\n\n  ClearWallpaperCount();\n  controller_->SetCustomWallpaper(account_id_1, file_name_1,\n                                  WALLPAPER_LAYOUT_CENTER,\n                                  CreateImage(640, 480, kWallpaperColor),\n                                  /*preview_mode=*/false);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(WallpaperType::kCustomized, controller_->GetWallpaperType());\n  EXPECT_EQ(kWallpaperColor, GetWallpaperColor());\n  // Assert that we do not use local state for an ephemeral user.\n  auto* dict = local_state()->GetUserPrefValue(prefs::kUserWallpaperInfo);\n  ASSERT_FALSE(dict) << *dict;\n\n  // The custom wallpaper is cached.\n  EXPECT_TRUE(\n      controller_->GetWallpaperFromCache(account_id_1, &cached_wallpaper));\n  EXPECT_EQ(\n      kWallpaperColor,\n      cached_wallpaper.GetRepresentation(1.0f).GetBitmap().getColor(0, 0));\n  EXPECT_TRUE(controller_->GetPathFromCache(account_id_1, &path));\n\n  // Calling |ShowUserWallpaper| will continue showing the custom wallpaper\n  // instead of reverting to the default.\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(0, GetWallpaperCount());\n  EXPECT_EQ(WallpaperType::kCustomized, controller_->GetWallpaperType());\n  EXPECT_EQ(kWallpaperColor, GetWallpaperColor());\n}\n\nTEST_F(WallpaperControllerTest, AlwaysOnTopWallpaper) {\n  CreateDefaultWallpapers();\n  SetBypassDecode();\n\n  // Show a default wallpaper.\n  EXPECT_EQ(0, GetWallpaperCount());\n  controller_->ShowSigninWallpaper();\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  EXPECT_EQ(1, ChildCountForContainer(kWallpaperId));\n  EXPECT_EQ(0, ChildCountForContainer(kAlwaysOnTopWallpaperId));\n\n  // Show an always-on-top wallpaper.\n  const base::FilePath image_path =\n      base::CommandLine::ForCurrentProcess()->GetSwitchValuePath(\n          switches::kGuestWallpaperLarge);\n  controller_->ShowAlwaysOnTopWallpaper(image_path);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(2, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kOneShot);\n  EXPECT_EQ(0, ChildCountForContainer(kWallpaperId));\n  EXPECT_EQ(1, ChildCountForContainer(kAlwaysOnTopWallpaperId));\n\n  // Subsequent wallpaper requests are ignored when the current wallpaper is\n  // always-on-top.\n  controller_->ShowSigninWallpaper();\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(2, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kOneShot);\n  EXPECT_EQ(0, ChildCountForContainer(kWallpaperId));\n  EXPECT_EQ(1, ChildCountForContainer(kAlwaysOnTopWallpaperId));\n\n  // The wallpaper reverts to the default after the always-on-top wallpaper is\n  // removed.\n  controller_->RemoveAlwaysOnTopWallpaper();\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(3, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  EXPECT_EQ(1, ChildCountForContainer(kWallpaperId));\n  EXPECT_EQ(0, ChildCountForContainer(kAlwaysOnTopWallpaperId));\n\n  // Calling |RemoveAlwaysOnTopWallpaper| is a no-op when the current wallpaper\n  // is not always-on-top.\n  controller_->RemoveAlwaysOnTopWallpaper();\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(3, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  EXPECT_EQ(1, ChildCountForContainer(kWallpaperId));\n  EXPECT_EQ(0, ChildCountForContainer(kAlwaysOnTopWallpaperId));\n}\n\nnamespace {\n\nclass WallpaperControllerPrefTest : public AshTestBase {\n public:\n  WallpaperControllerPrefTest() {\n    base::Value::Dict property;\n    property.Set(\"rotation\", static_cast<int>(display::Display::ROTATE_90));\n    property.Set(\"width\", 800);\n    property.Set(\"height\", 600);\n\n    DictionaryPrefUpdate update(local_state(), prefs::kDisplayProperties);\n    update.Get()->SetKey(\"2200000000\", base::Value(std::move(property)));\n  }\n\n  ~WallpaperControllerPrefTest() override = default;\n\n  void SetUp() override { AshTestBase::SetUp(); }\n\n private:\n  base::test::ScopedFeatureList scoped_feature_list_;\n};\n\n}  // namespace\n\n// Make sure that the display and the wallpaper view are rotated correctly at\n// startup.\nTEST_F(WallpaperControllerPrefTest, InitWithPrefs) {\n  auto* wallpaper_view = Shell::GetPrimaryRootWindowController()\n                             ->wallpaper_widget_controller()\n                             ->wallpaper_view();\n  auto* root_window =\n      wallpaper_view->GetWidget()->GetNativeWindow()->GetRootWindow();\n\n  EXPECT_EQ(gfx::Size(600, 800), display::Screen::GetScreen()\n                                     ->GetDisplayNearestWindow(root_window)\n                                     .size());\n  EXPECT_EQ(root_window->bounds().size(), wallpaper_view->bounds().size());\n}\n\nTEST_F(WallpaperControllerTest, NoAnimationForNewRootWindowWhenLocked) {\n  ui::ScopedAnimationDurationScaleMode test_duration_mode(\n      ui::ScopedAnimationDurationScaleMode::NON_ZERO_DURATION);\n  SetSessionState(SessionState::LOCKED);\n  UpdateDisplay(\"800x600, 800x600\");\n  auto* secondary_root_window_controller =\n      Shell::Get()->GetAllRootWindowControllers()[1];\n  EXPECT_FALSE(secondary_root_window_controller->wallpaper_widget_controller()\n                   ->IsAnimating());\n  EXPECT_FALSE(secondary_root_window_controller->wallpaper_widget_controller()\n                   ->GetWidget()\n                   ->GetLayer()\n                   ->GetAnimator()\n                   ->is_animating());\n}\n\nTEST_F(WallpaperControllerTest, SetCustomWallpaper) {\n  gfx::ImageSkia image = CreateImage(640, 480, kWallpaperColor);\n  WallpaperLayout layout = WALLPAPER_LAYOUT_CENTER;\n\n  SimulateUserLogin(account_id_1);\n\n  // Set a custom wallpaper for |kUser1|. Verify the wallpaper is set\n  // successfully and wallpaper info is updated.\n  ClearWallpaperCount();\n  controller_->SetCustomWallpaper(account_id_1, file_name_1, layout, image,\n                                  false /*preview_mode=*/);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(kWallpaperColor, GetWallpaperColor());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kCustomized);\n  WallpaperInfo wallpaper_info;\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  WallpaperInfo expected_wallpaper_info(\n      base::FilePath(wallpaper_files_id_1).Append(file_name_1).value(), layout,\n      WallpaperType::kCustomized, base::Time::Now().LocalMidnight());\n  EXPECT_EQ(wallpaper_info, expected_wallpaper_info);\n  EXPECT_EQ(account_id_1, client_.get_save_wallpaper_to_drive_fs_account_id());\n\n  // Now set another custom wallpaper for |kUser1|. Verify that the on-screen\n  // wallpaper doesn't change since |kUser1| is not active, but wallpaper info\n  // is updated properly.\n  SimulateUserLogin(account_id_2);\n  const SkColor custom_wallpaper_color = SK_ColorCYAN;\n  image = CreateImage(640, 480, custom_wallpaper_color);\n  ClearWallpaperCount();\n  controller_->SetCustomWallpaper(account_id_1, file_name_1, layout, image,\n                                  false /*preview_mode=*/);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(0, GetWallpaperCount());\n  EXPECT_EQ(kWallpaperColor, GetWallpaperColor());\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  EXPECT_EQ(wallpaper_info, expected_wallpaper_info);\n\n  // Verify the updated wallpaper is shown after |kUser1| becomes active again.\n  SimulateUserLogin(account_id_1);\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(custom_wallpaper_color, GetWallpaperColor());\n}\n\nTEST_F(WallpaperControllerTest, OldOnlineInfoSynced_Discarded) {\n  // Create a dictionary that looks like the preference from crrev.com/a040384.\n  // DO NOT CHANGE as there are preferences like this in production.\n  base::Value::Dict wallpaper_info_dict;\n  wallpaper_info_dict.Set(\n      WallpaperPrefManager::kNewWallpaperDateNodeName,\n      base::NumberToString(\n          base::Time::Now().ToDeltaSinceWindowsEpoch().InMicroseconds()));\n  wallpaper_info_dict.Set(WallpaperPrefManager::kNewWallpaperLocationNodeName,\n                          \"location\");\n  wallpaper_info_dict.Set(\n      WallpaperPrefManager::kNewWallpaperUserFilePathNodeName,\n      \"user_file_path\");\n  wallpaper_info_dict.Set(WallpaperPrefManager::kNewWallpaperLayoutNodeName,\n                          WallpaperLayout::WALLPAPER_LAYOUT_CENTER);\n  wallpaper_info_dict.Set(WallpaperPrefManager::kNewWallpaperTypeNodeName,\n                          static_cast<int>(WallpaperType::kOnline));\n\n  {\n    DictionaryPrefUpdate wallpaper_update(GetProfilePrefService(account_id_1),\n                                          prefs::kSyncableWallpaperInfo);\n    wallpaper_update->SetKey(account_id_1.GetUserEmail(),\n                             base::Value(std::move(wallpaper_info_dict)));\n  }\n  SimulateUserLogin(account_id_1);\n  task_environment()->RunUntilIdle();\n\n  // Unmigrated synced wallpaper info are discarded.\n  WallpaperInfo actual;\n  EXPECT_FALSE(pref_manager_->GetUserWallpaperInfo(account_id_1, &actual));\n}\n\nTEST_F(WallpaperControllerTest, MigrateWallpaperInfo_Online) {\n  WallpaperInfo expected_info = InfoWithType(WallpaperType::kOnline);\n  pref_manager_->SetLocalWallpaperInfo(account_id_1, expected_info);\n  SimulateUserLogin(account_id_1);\n  WallpaperInfo info;\n  ASSERT_TRUE(pref_manager_->GetSyncedWallpaperInfo(account_id_1, &info));\n  EXPECT_EQ(expected_info, info);\n}\n\nTEST_F(WallpaperControllerTest, MigrateWallpaperInfoCustomized) {\n  WallpaperInfo expected_info = InfoWithType(WallpaperType::kCustomized);\n  pref_manager_->SetLocalWallpaperInfo(account_id_1, expected_info);\n  SimulateUserLogin(account_id_1);\n  WallpaperInfo info;\n  ASSERT_TRUE(pref_manager_->GetSyncedWallpaperInfo(account_id_1, &info));\n  EXPECT_EQ(expected_info, info);\n}\n\nTEST_F(WallpaperControllerTest, MigrateWallpaperInfoDaily) {\n  WallpaperInfo expected_info = WallpaperInfo(OnlineWallpaperParams(\n      account_id_1, kAssetId, GURL(kDummyUrl),\n      TestWallpaperControllerClient::kDummyCollectionId,\n      WALLPAPER_LAYOUT_CENTER, /*preview_mode=*/false, /*from_user=*/false,\n      /*daily_refresh_enabled=*/false, kUnitId,\n      std::vector<OnlineWallpaperVariant>()));\n  pref_manager_->SetLocalWallpaperInfo(account_id_1, expected_info);\n  SimulateUserLogin(account_id_1);\n  WallpaperInfo info;\n  ASSERT_TRUE(pref_manager_->GetSyncedWallpaperInfo(account_id_1, &info));\n  EXPECT_EQ(expected_info, info);\n  EXPECT_EQ(client_.migrate_collection_id_from_chrome_app_count(), 1u);\n}\n\nTEST_F(WallpaperControllerTest,\n       MigrateWallpaperInfoDoesntHappenWhenSyncedInfoAlreadyExists) {\n  SetBypassDecode();\n\n  WallpaperInfo local_info = WallpaperInfo(OnlineWallpaperParams(\n      account_id_1, kAssetId, GURL(kDummyUrl),\n      TestWallpaperControllerClient::kDummyCollectionId,\n      WALLPAPER_LAYOUT_CENTER, /*preview_mode=*/false, /*from_user=*/false,\n      /*daily_refresh_enabled=*/false, kUnitId,\n      std::vector<OnlineWallpaperVariant>()));\n  WallpaperInfo synced_info = WallpaperInfo(OnlineWallpaperParams(\n      account_id_1, kAssetId2, GURL(kDummyUrl2),\n      TestWallpaperControllerClient::kDummyCollectionId,\n      WALLPAPER_LAYOUT_CENTER, /*preview_mode=*/false, /*from_user=*/false,\n      /*daily_refresh_enabled=*/false, kUnitId,\n      std::vector<OnlineWallpaperVariant>()));\n  pref_manager_->SetLocalWallpaperInfo(account_id_1, local_info);\n  pref_manager_->SetSyncedWallpaperInfo(account_id_1, synced_info);\n  SimulateUserLogin(account_id_1);\n  WallpaperInfo info;\n  ASSERT_TRUE(pref_manager_->GetSyncedWallpaperInfo(account_id_1, &info));\n  // Synced info should be the same if local is the same age.\n  EXPECT_EQ(synced_info, info);\n}\n\nTEST_F(WallpaperControllerTest,\n       ActiveUserPrefServiceChangedSyncedInfoHandledLocally) {\n  CacheOnlineWallpaper(kDummyUrl);\n\n  WallpaperInfo synced_info = {kDummyUrl, WALLPAPER_LAYOUT_CENTER_CROPPED,\n                               WallpaperType::kOnline, base::Time::Now()};\n  synced_info.asset_id = kAssetId;\n  synced_info.collection_id = TestWallpaperControllerClient::kDummyCollectionId;\n  pref_manager_->SetSyncedWallpaperInfo(account_id_1, synced_info);\n\n  WallpaperInfo local_info = InfoWithType(WallpaperType::kThirdParty);\n  local_info.date = DayBeforeYesterdayish();\n  pref_manager_->SetLocalWallpaperInfo(account_id_1, local_info);\n\n  client_.ResetCounts();\n\n  controller_->OnActiveUserPrefServiceChanged(\n      GetProfilePrefService(account_id_1));\n  RunAllTasksUntilIdle();\n  WallpaperInfo actual_info;\n  EXPECT_TRUE(pref_manager_->GetUserWallpaperInfo(account_id_1, &actual_info));\n  EXPECT_EQ(WallpaperType::kOnline, actual_info.type);\n}\n\nTEST_F(WallpaperControllerTest, ActiveUserPrefServiceChanged_SyncDisabled) {\n  CacheOnlineWallpaper(kDummyUrl);\n  WallpaperInfo synced_info = {kDummyUrl, WALLPAPER_LAYOUT_CENTER_CROPPED,\n                               WallpaperType::kOnline, base::Time::Now()};\n  synced_info.asset_id = kAssetId;\n  synced_info.collection_id = TestWallpaperControllerClient::kDummyCollectionId;\n  pref_manager_->SetSyncedWallpaperInfo(account_id_1, synced_info);\n\n  WallpaperInfo local_info = InfoWithType(WallpaperType::kThirdParty);\n  local_info.date = DayBeforeYesterdayish();\n  pref_manager_->SetLocalWallpaperInfo(account_id_1, local_info);\n\n  client_.ResetCounts();\n\n  client_.set_wallpaper_sync_enabled(false);\n\n  controller_->OnActiveUserPrefServiceChanged(\n      GetProfilePrefService(account_id_1));\n  WallpaperInfo actual_info;\n  EXPECT_TRUE(pref_manager_->GetUserWallpaperInfo(account_id_1, &actual_info));\n  EXPECT_EQ(WallpaperType::kThirdParty, actual_info.type);\n}\n\nTEST_F(WallpaperControllerTest, HandleWallpaperInfoSyncedLocalIsPolicy) {\n  CacheOnlineWallpaper(kDummyUrl);\n  pref_manager_->SetLocalWallpaperInfo(account_id_1,\n                                       InfoWithType(WallpaperType::kPolicy));\n\n  SimulateUserLogin(account_id_1);\n  WallpaperInfo synced_info = {kDummyUrl, WALLPAPER_LAYOUT_CENTER_CROPPED,\n                               WallpaperType::kOnline, base::Time::Now()};\n  pref_manager_->SetSyncedWallpaperInfo(account_id_1, synced_info);\n  RunAllTasksUntilIdle();\n\n  WallpaperInfo actual_info;\n  EXPECT_TRUE(pref_manager_->GetUserWallpaperInfo(account_id_1, &actual_info));\n  EXPECT_NE(WallpaperType::kOnline, actual_info.type);\n}\n\nTEST_F(WallpaperControllerTest,\n       HandleWallpaperInfoSyncedLocalIsThirdPartyAndOlder) {\n  CacheOnlineWallpaper(kDummyUrl);\n\n  WallpaperInfo local_info = InfoWithType(WallpaperType::kThirdParty);\n  local_info.date = DayBeforeYesterdayish();\n  pref_manager_->SetLocalWallpaperInfo(account_id_1, local_info);\n\n  SimulateUserLogin(account_id_1);\n  WallpaperInfo synced_info = {kDummyUrl, WALLPAPER_LAYOUT_CENTER_CROPPED,\n                               WallpaperType::kOnline, base::Time::Now()};\n  synced_info.asset_id = kAssetId;\n  synced_info.collection_id = TestWallpaperControllerClient::kDummyCollectionId;\n  pref_manager_->SetSyncedWallpaperInfo(account_id_1, synced_info);\n  RunAllTasksUntilIdle();\n\n  WallpaperInfo actual_info;\n  EXPECT_TRUE(pref_manager_->GetUserWallpaperInfo(account_id_1, &actual_info));\n  EXPECT_EQ(WallpaperType::kOnline, actual_info.type);\n}\n\nTEST_F(WallpaperControllerTest,\n       HandleWallpaperInfoSyncedLocalIsThirdPartyAndNewer) {\n  CacheOnlineWallpaper(kDummyUrl);\n  pref_manager_->SetLocalWallpaperInfo(\n      account_id_1, InfoWithType(WallpaperType::kThirdParty));\n\n  WallpaperInfo synced_info = {kDummyUrl, WALLPAPER_LAYOUT_CENTER_CROPPED,\n                               WallpaperType::kOnline, DayBeforeYesterdayish()};\n  pref_manager_->SetSyncedWallpaperInfo(account_id_1, synced_info);\n  SimulateUserLogin(account_id_1);\n  pref_manager_->SetSyncedWallpaperInfo(account_id_1, synced_info);\n  RunAllTasksUntilIdle();\n\n  WallpaperInfo actual_info;\n  EXPECT_TRUE(pref_manager_->GetUserWallpaperInfo(account_id_1, &actual_info));\n  EXPECT_EQ(WallpaperType::kThirdParty, actual_info.type);\n}\n\nTEST_F(WallpaperControllerTest, HandleWallpaperInfoSyncedOnline) {\n  CacheOnlineWallpaper(kDummyUrl);\n\n  // Attempt to set an online wallpaper without providing the image data. Verify\n  // it succeeds this time because |SetOnlineWallpaperFromData| has saved the\n  // file.\n  ClearWallpaperCount();\n  WallpaperInfo info = WallpaperInfo(OnlineWallpaperParams(\n      account_id_1, kAssetId, GURL(kDummyUrl),\n      TestWallpaperControllerClient::kDummyCollectionId,\n      WALLPAPER_LAYOUT_CENTER, /*preview_mode=*/false, /*from_user=*/false,\n      /*daily_refresh_enabled=*/false, kUnitId,\n      std::vector<OnlineWallpaperVariant>()));\n  pref_manager_->SetSyncedWallpaperInfo(account_id_1, info);\n\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kOnline);\n}\n\nTEST_F(WallpaperControllerTest, HandleWallpaperInfoSyncedInactiveUser) {\n  CacheOnlineWallpaper(kDummyUrl);\n\n  // Make account_id_1 the inactive user.\n  SimulateUserLogin(account_id_2);\n\n  // Attempt to set an online wallpaper without providing the image data. Verify\n  // it succeeds this time because |SetOnlineWallpaperFromData| has saved the\n  // file.\n  ClearWallpaperCount();\n  pref_manager_->SetSyncedWallpaperInfo(account_id_1,\n                                        InfoWithType(WallpaperType::kOnline));\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(0, GetWallpaperCount());\n  EXPECT_NE(controller_->GetWallpaperType(), WallpaperType::kOnline);\n}\n\nTEST_F(WallpaperControllerTest, UpdateDailyRefreshWallpaper) {\n  std::string expected{\"fun_collection\"};\n  SimulateUserLogin(account_id_1);\n\n  WallpaperInfo info = {std::string(), WALLPAPER_LAYOUT_CENTER,\n                        WallpaperType::kDaily, DayBeforeYesterdayish()};\n  info.asset_id = kAssetId;\n  info.collection_id = expected;\n  pref_manager_->SetUserWallpaperInfo(account_id_1, info);\n\n  controller_->UpdateDailyRefreshWallpaperForTesting();\n  EXPECT_EQ(expected, client_.get_fetch_daily_refresh_wallpaper_param());\n}\n\n// Disabled due to flakes; see crbug/1320991.\nTEST_F(WallpaperControllerTest,\n       DISABLED_UpdateDailyRefreshWallpaperCalledOnLogin) {\n  SimulateUserLogin(account_id_1);\n\n  WallpaperInfo info = WallpaperInfo(OnlineWallpaperParams(\n      account_id_1, kAssetId, GURL(kDummyUrl),\n      TestWallpaperControllerClient::kDummyCollectionId,\n      WALLPAPER_LAYOUT_CENTER_CROPPED, /*preview_mode=*/false,\n      /*from_user=*/false,\n      /*daily_refresh_enabled=*/true, kUnitId,\n      /*variants=*/std::vector<OnlineWallpaperVariant>()));\n  info.date = DayBeforeYesterdayish();\n  pref_manager_->SetUserWallpaperInfo(account_id_1, info);\n\n  ClearLogin();\n  SimulateUserLogin(account_id_1);\n\n  // Info is set as over a day old so we expect one task to run in under an hour\n  // (due to fuzzing) then it will idle.\n  task_environment()->FastForwardBy(base::Hours(1));\n\n  EXPECT_EQ(TestWallpaperControllerClient::kDummyCollectionId,\n            client_.get_fetch_daily_refresh_wallpaper_param());\n}\n\nTEST_F(WallpaperControllerTest, UpdateDailyRefreshWallpaper_NotEnabled) {\n  SimulateUserLogin(account_id_1);\n  WallpaperInfo info = {std::string(), WALLPAPER_LAYOUT_CENTER,\n                        WallpaperType::kOnline, DayBeforeYesterdayish()};\n  info.collection_id = \"fun_collection\";\n  pref_manager_->SetUserWallpaperInfo(account_id_1, info);\n\n  controller_->UpdateDailyRefreshWallpaperForTesting();\n  EXPECT_EQ(std::string(), client_.get_fetch_daily_refresh_wallpaper_param());\n}\n\nTEST_F(WallpaperControllerTest, UpdateDailyRefreshWallpaper_NoCollectionId) {\n  SimulateUserLogin(account_id_1);\n  pref_manager_->SetUserWallpaperInfo(\n      account_id_1,\n      WallpaperInfo(std::string(), WALLPAPER_LAYOUT_CENTER,\n                    WallpaperType::kDaily, DayBeforeYesterdayish()));\n\n  controller_->UpdateDailyRefreshWallpaperForTesting();\n  EXPECT_EQ(std::string(), client_.get_fetch_daily_refresh_wallpaper_param());\n}\n\nTEST_F(WallpaperControllerTest,\n       UpdateDailyRefreshWallpaper_TimerStartsOnPrefServiceChange) {\n  using base::Time;\n\n  SimulateUserLogin(account_id_1);\n  WallpaperInfo info = {std::string(), WALLPAPER_LAYOUT_CENTER,\n                        WallpaperType::kDaily,\n                        base::Time::Now().LocalMidnight()};\n  info.collection_id = \"fun_collection\";\n  pref_manager_->SetUserWallpaperInfo(account_id_1, info);\n\n  controller_->OnActiveUserPrefServiceChanged(\n      GetProfilePrefService(account_id_1));\n\n  Time run_time =\n      controller_->GetUpdateWallpaperTimerForTesting().desired_run_time();\n  base::TimeDelta delta = run_time.ToDeltaSinceWindowsEpoch();\n\n  base::TimeDelta update_time =\n      Time::Now().LocalMidnight().ToDeltaSinceWindowsEpoch() + base::Days(1);\n\n  ASSERT_GE(delta, update_time - base::Minutes(1));\n  ASSERT_LE(delta, update_time + base::Hours(1) + base::Minutes(1));\n}\n\nTEST_F(WallpaperControllerTest,\n       UpdateDailyRefreshWallpaper_RetryTimerTriggersOnFailedFetchInfo) {\n  using base::Time;\n\n  client_.set_fetch_daily_refresh_info_fails(true);\n\n  SimulateUserLogin(account_id_1);\n\n  WallpaperInfo info = {std::string(), WALLPAPER_LAYOUT_CENTER,\n                        WallpaperType::kDaily, DayBeforeYesterdayish()};\n  info.collection_id = \"fun_collection\";\n  pref_manager_->SetUserWallpaperInfo(account_id_1, info);\n\n  controller_->UpdateDailyRefreshWallpaperForTesting();\n  Time run_time =\n      controller_->GetUpdateWallpaperTimerForTesting().desired_run_time();\n  base::TimeDelta delay = run_time - Time::Now();\n\n  base::TimeDelta one_hour = base::Hours(1);\n  // Lave a little wiggle room.\n  ASSERT_GE(delay, one_hour - base::Minutes(1));\n  ASSERT_LE(delay, one_hour + base::Minutes(1));\n}\n\nTEST_F(WallpaperControllerTest,\n       UpdateDailyRefreshWallpaper_RetryTimerTriggersOnFailedFetchData) {\n  using base::Time;\n\n  SimulateUserLogin(account_id_1);\n\n  WallpaperInfo info = {std::string(), WALLPAPER_LAYOUT_CENTER,\n                        WallpaperType::kDaily, DayBeforeYesterdayish()};\n  info.collection_id = \"fun_collection\";\n  pref_manager_->SetUserWallpaperInfo(account_id_1, info);\n\n  test_image_downloader_->set_should_fail(true);\n\n  controller_->UpdateDailyRefreshWallpaperForTesting();\n\n  RunAllTasksUntilIdle();\n\n  Time run_time =\n      controller_->GetUpdateWallpaperTimerForTesting().desired_run_time();\n  base::TimeDelta delay = run_time - Time::Now();\n\n  base::TimeDelta one_hour = base::Hours(1);\n  // Lave a little wiggle room.\n  ASSERT_GE(delay, one_hour - base::Minutes(1));\n  ASSERT_LE(delay, one_hour + base::Minutes(1));\n}\n\nTEST_F(WallpaperControllerTest, MigrateCustomWallpaper) {\n  gfx::ImageSkia image = CreateImage(640, 480, kWallpaperColor);\n  WallpaperLayout layout = WALLPAPER_LAYOUT_CENTER;\n\n  SimulateUserLogin(account_id_1);\n\n  controller_->SetCustomWallpaper(account_id_1, file_name_1, layout, image,\n                                  false /*preview_mode=*/);\n  RunAllTasksUntilIdle();\n  ClearLogin();\n\n  SimulateUserLogin(account_id_1);\n  EXPECT_EQ(account_id_1, client_.get_save_wallpaper_to_drive_fs_account_id());\n}\n\nTEST_F(WallpaperControllerTest, OnGoogleDriveMounted) {\n  WallpaperInfo local_info = InfoWithType(WallpaperType::kCustomized);\n  pref_manager_->SetLocalWallpaperInfo(account_id_1, local_info);\n\n  SimulateUserLogin(account_id_1);\n  controller_->SyncLocalAndRemotePrefs(account_id_1);\n  EXPECT_EQ(account_id_1, client_.get_save_wallpaper_to_drive_fs_account_id());\n}\n\nTEST_F(WallpaperControllerTest, OnGoogleDriveMounted_WallpaperIsntCustom) {\n  WallpaperInfo local_info = InfoWithType(WallpaperType::kOnline);\n  pref_manager_->SetLocalWallpaperInfo(account_id_1, local_info);\n\n  controller_->SyncLocalAndRemotePrefs(account_id_1);\n  EXPECT_TRUE(client_.get_save_wallpaper_to_drive_fs_account_id().empty());\n}\n\nTEST_F(WallpaperControllerTest, OnGoogleDriveMounted_AlreadySynced) {\n  WallpaperInfo local_info = InfoWithType(WallpaperType::kCustomized);\n  pref_manager_->SetLocalWallpaperInfo(account_id_1, local_info);\n\n  SimulateUserLogin(account_id_1);\n\n  gfx::ImageSkia image = CreateImage(640, 480, kWallpaperColor);\n  WallpaperLayout layout = WALLPAPER_LAYOUT_CENTER;\n\n  controller_->SetCustomWallpaper(account_id_1, file_name_1, layout, image,\n                                  false /*preview_mode=*/);\n  RunAllTasksUntilIdle();\n\n  client_.ResetCounts();\n\n  // Should not reupload image if it has already been synced.\n  controller_->SyncLocalAndRemotePrefs(account_id_1);\n  EXPECT_FALSE(client_.get_save_wallpaper_to_drive_fs_account_id().is_valid());\n}\n\nTEST_F(WallpaperControllerTest, OnGoogleDriveMounted_OldLocalInfo) {\n  WallpaperInfo local_info =\n      WallpaperInfo(\"a_url\", WALLPAPER_LAYOUT_CENTER_CROPPED,\n                    WallpaperType::kCustomized, DayBeforeYesterdayish());\n  pref_manager_->SetLocalWallpaperInfo(account_id_1, local_info);\n\n  WallpaperInfo synced_info = WallpaperInfo(\n      \"b_url\", WALLPAPER_LAYOUT_CENTER_CROPPED, WallpaperType::kCustomized,\n      base::Time::Now().LocalMidnight());\n  pref_manager_->SetSyncedWallpaperInfo(account_id_1, synced_info);\n  SimulateUserLogin(account_id_1);\n\n  controller_->SyncLocalAndRemotePrefs(account_id_1);\n  EXPECT_FALSE(client_.get_save_wallpaper_to_drive_fs_account_id().is_valid());\n  // This is called by WallpaperController::HandleCustomWallpaperSyncedIn.\n  EXPECT_EQ(client_.get_wallpaper_path_from_drive_fs_account_id(),\n            account_id_1);\n}\n\nTEST_F(WallpaperControllerTest, OnGoogleDriveMounted_NewLocalInfo) {\n  WallpaperInfo local_info = WallpaperInfo(\n      \"a_url\", WALLPAPER_LAYOUT_CENTER_CROPPED, WallpaperType::kCustomized,\n      base::Time::Now().LocalMidnight());\n  pref_manager_->SetLocalWallpaperInfo(account_id_1, local_info);\n\n  WallpaperInfo synced_info =\n      WallpaperInfo(\"b_url\", WALLPAPER_LAYOUT_CENTER_CROPPED,\n                    WallpaperType::kCustomized, DayBeforeYesterdayish());\n  pref_manager_->SetSyncedWallpaperInfo(account_id_1, synced_info);\n\n  SimulateUserLogin(account_id_1);\n\n  controller_->SyncLocalAndRemotePrefs(account_id_1);\n  EXPECT_EQ(account_id_1, client_.get_save_wallpaper_to_drive_fs_account_id());\n}\n\nTEST_F(WallpaperControllerTest, SetDailyRefreshCollectionId) {\n  pref_manager_->SetUserWallpaperInfo(\n      account_id_1,\n      WallpaperInfo(std::string(), WALLPAPER_LAYOUT_CENTER,\n                    WallpaperType::kOnline, DayBeforeYesterdayish()));\n\n  std::string collection_id = \"fun_collection\";\n  controller_->SetDailyRefreshCollectionId(account_id_1, collection_id);\n  WallpaperInfo expected = {std::string(), WALLPAPER_LAYOUT_CENTER,\n                            WallpaperType::kDaily, DayBeforeYesterdayish()};\n  expected.collection_id = collection_id;\n\n  WallpaperInfo actual;\n  pref_manager_->GetUserWallpaperInfo(account_id_1, &actual);\n  // Type should be `WallpaperType::kDaily` now, and collection_id should be\n  // updated.\n  EXPECT_EQ(expected, actual);\n  EXPECT_EQ(collection_id,\n            controller_->GetDailyRefreshCollectionId(account_id_1));\n}\n\nTEST_F(WallpaperControllerTest, SetDailyRefreshCollectionId_Empty) {\n  std::string collection_id = \"fun_collection\";\n  WallpaperInfo info = {std::string(), WALLPAPER_LAYOUT_CENTER,\n                        WallpaperType::kDaily, DayBeforeYesterdayish()};\n  info.collection_id = collection_id;\n  pref_manager_->SetUserWallpaperInfo(account_id_1, info);\n\n  controller_->SetDailyRefreshCollectionId(account_id_1, std::string());\n  WallpaperInfo expected = {std::string(), WALLPAPER_LAYOUT_CENTER,\n                            WallpaperType::kOnline, DayBeforeYesterdayish()};\n  expected.collection_id = collection_id;\n\n  WallpaperInfo actual;\n  pref_manager_->GetUserWallpaperInfo(account_id_1, &actual);\n  // Type should be `WallpaperType::kOnline` now, and collection_id should be\n  // `WallpaperType::EMPTY`.\n  EXPECT_EQ(expected, actual);\n  EXPECT_EQ(std::string(),\n            controller_->GetDailyRefreshCollectionId(account_id_1));\n}\n\n// WallpaperType should not change with an empty collection id if the previous\n// WallpaperType isn't |WallpaperType::kDaily|.\nTEST_F(WallpaperControllerTest,\n       SetDailyRefreshCollectionId_Empty_NotTypeDaily) {\n  pref_manager_->SetUserWallpaperInfo(\n      account_id_1,\n      WallpaperInfo(std::string(), WALLPAPER_LAYOUT_CENTER,\n                    WallpaperType::kCustomized, DayBeforeYesterdayish()));\n\n  controller_->SetDailyRefreshCollectionId(account_id_1, std::string());\n  WallpaperInfo expected =\n      WallpaperInfo(std::string(), WALLPAPER_LAYOUT_CENTER,\n                    WallpaperType::kCustomized, DayBeforeYesterdayish());\n\n  WallpaperInfo actual;\n  pref_manager_->GetUserWallpaperInfo(account_id_1, &actual);\n  EXPECT_EQ(expected, actual);\n  EXPECT_EQ(std::string(),\n            controller_->GetDailyRefreshCollectionId(account_id_1));\n}\n\nTEST_F(WallpaperControllerTest, UpdateWallpaperOnColorModeChanged) {\n  SimulateUserLogin(account_id_1);\n\n  auto run_loop = std::make_unique<base::RunLoop>();\n  ClearWallpaperCount();\n  std::vector<OnlineWallpaperVariant> variants;\n  variants.emplace_back(kAssetId, GURL(kDummyUrl),\n                        backdrop::Image::IMAGE_TYPE_DARK_MODE);\n  variants.emplace_back(kAssetId2, GURL(kDummyUrl2),\n                        backdrop::Image::IMAGE_TYPE_LIGHT_MODE);\n  const OnlineWallpaperParams& params =\n      OnlineWallpaperParams(account_id_1, kAssetId, GURL(kDummyUrl),\n                            TestWallpaperControllerClient::kDummyCollectionId,\n                            WALLPAPER_LAYOUT_CENTER_CROPPED,\n                            /*preview_mode=*/false, /*from_user=*/true,\n                            /*daily_refresh_enabled=*/false, kUnitId, variants);\n  controller_->SetOnlineWallpaper(\n      params, base::BindLambdaForTesting([&run_loop](bool success) {\n        EXPECT_TRUE(success);\n        run_loop->Quit();\n      }));\n  run_loop->Run();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kOnline);\n\n  pref_manager_->SetUserWallpaperInfo(account_id_1, WallpaperInfo(params));\n  Shell::Get()->session_controller()->GetActivePrefService()->SetBoolean(\n      prefs::kDarkModeEnabled, true);\n  controller_->OnColorModeChanged(true);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(2, GetWallpaperCount());\n\n  WallpaperInfo expected = WallpaperInfo(OnlineWallpaperParams(\n      account_id_1, kAssetId, GURL(kDummyUrl),\n      TestWallpaperControllerClient::kDummyCollectionId,\n      WALLPAPER_LAYOUT_CENTER_CROPPED, /*preview_mode=*/false,\n      /*from_user=*/true,\n      /*daily_refresh_enabled=*/false, kUnitId, variants));\n  WallpaperInfo actual;\n  EXPECT_TRUE(pref_manager_->GetUserWallpaperInfo(account_id_1, &actual));\n  EXPECT_EQ(expected, actual);\n}\n\nTEST_F(\n    WallpaperControllerTest,\n    // TODO(crbug.com/9191919): Re-enable this test\n    DISABLED_UpdateDailyWallpaperVariantOnColorModeChanged_RefreshTimerDoesntReset) {\n  using base::Time;\n\n  SimulateUserLogin(account_id_1);\n  // Resets the count as user will start with a default image after login.\n  ClearWallpaperCount();\n\n  std::vector<OnlineWallpaperVariant> variants;\n  variants.emplace_back(kAssetId, GURL(kDummyUrl),\n                        backdrop::Image::IMAGE_TYPE_DARK_MODE);\n  variants.emplace_back(kAssetId2, GURL(kDummyUrl2),\n                        backdrop::Image::IMAGE_TYPE_LIGHT_MODE);\n  const OnlineWallpaperParams& params =\n      OnlineWallpaperParams(account_id_1, kAssetId, GURL(kDummyUrl),\n                            TestWallpaperControllerClient::kDummyCollectionId,\n                            WALLPAPER_LAYOUT_CENTER_CROPPED,\n                            /*preview_mode=*/false, /*from_user=*/true,\n                            /*daily_refresh_enabled=*/true, kUnitId, variants);\n  const WallpaperInfo info = WallpaperInfo(params);\n  pref_manager_->SetUserWallpaperInfo(account_id_1, info);\n\n  // Set a new daily wallpaper.\n  controller_->UpdateDailyRefreshWallpaperForTesting();\n  RunAllTasksUntilIdle();\n\n  Time run_time =\n      controller_->GetUpdateWallpaperTimerForTesting().desired_run_time();\n  base::TimeDelta delay = run_time - Time::Now();\n  base::TimeDelta one_day = base::Days(1);\n  // Leave a little wiggle room, as well as account for the hour fuzzing that\n  // we do.\n  EXPECT_GE(delay, one_day - base::Minutes(1));\n  EXPECT_LE(delay, one_day + base::Minutes(61));\n\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDaily);\n\n  // Fast forward by one hour and attempt a system's color mode change.\n  task_environment()->FastForwardBy(base::Hours(1));\n  Shell::Get()->dark_light_mode_controller()->ToggleColorMode();\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(2, GetWallpaperCount());\n  // Expect the refresh timer doesn't reset.\n  EXPECT_EQ(\n      run_time,\n      controller_->GetUpdateWallpaperTimerForTesting().desired_run_time());\n\n  WallpaperInfo actual;\n  EXPECT_TRUE(pref_manager_->GetUserWallpaperInfo(account_id_1, &actual));\n  EXPECT_EQ(info, actual);\n}\n\nTEST_F(WallpaperControllerTest,\n       UpdateWallpaperInfoWithOnlineWallpaperVariants) {\n  SimulateUserLogin(account_id_1);\n\n  // auto run_loop = std::make_unique<base::RunLoop>();\n  std::vector<OnlineWallpaperVariant> variants;\n  variants.emplace_back(kAssetId, GURL(kDummyUrl),\n                        backdrop::Image::IMAGE_TYPE_LIGHT_MODE);\n  variants.emplace_back(kAssetId2, GURL(kDummyUrl2),\n                        backdrop::Image::IMAGE_TYPE_DARK_MODE);\n  const OnlineWallpaperParams& params =\n      OnlineWallpaperParams(account_id_1, kAssetId, GURL(kDummyUrl),\n                            TestWallpaperControllerClient::kDummyCollectionId,\n                            WALLPAPER_LAYOUT_CENTER_CROPPED,\n                            /*preview_mode=*/false, /*from_user=*/true,\n                            /*daily_refresh_enabled=*/false, kUnitId, variants);\n\n  pref_manager_->SetUserWallpaperInfo(account_id_1, WallpaperInfo(params));\n  WallpaperInfo expected = WallpaperInfo(params);\n  WallpaperInfo actual;\n  pref_manager_->GetUserWallpaperInfo(account_id_1, &actual);\n  EXPECT_EQ(expected, actual);\n}\n\nTEST_F(WallpaperControllerTest, SetOnlineWallpaperIfExists) {\n  SetBypassDecode();\n  gfx::ImageSkia image = CreateImage(640, 480, kWallpaperColor);\n  WallpaperLayout layout = WALLPAPER_LAYOUT_CENTER_CROPPED;\n  std::vector<OnlineWallpaperVariant> variants;\n  variants.emplace_back(kAssetId, GURL(kDummyUrl),\n                        backdrop::Image::IMAGE_TYPE_UNKNOWN);\n  SimulateUserLogin(account_id_1);\n\n  // Verify that calling |SetOnlineWallpaperIfExists| without providing image\n  // data fails.\n  std::unique_ptr<base::RunLoop> run_loop = std::make_unique<base::RunLoop>();\n  ClearWallpaperCount();\n  const OnlineWallpaperParams& params = OnlineWallpaperParams(\n      account_id_1, kAssetId, GURL(kDummyUrl),\n      TestWallpaperControllerClient::kDummyCollectionId, layout,\n      /*preview_mode=*/false, /*from_user=*/true,\n      /*daily_refresh_enabled=*/false, kUnitId, variants);\n  controller_->SetOnlineWallpaperIfExists(\n      params, base::BindLambdaForTesting([&run_loop](bool file_exists) {\n        EXPECT_FALSE(file_exists);\n        run_loop->Quit();\n      }));\n  run_loop->Run();\n  EXPECT_EQ(0, GetWallpaperCount());\n\n  // Set an online wallpaper with image data. Verify that the wallpaper is set\n  // successfully.\n  ClearWallpaperCount();\n  controller_->SetOnlineWallpaperFromData(\n      params,\n      /*image_data=*/std::string(),\n      WallpaperController::SetWallpaperCallback());\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kOnline);\n  // Verify that the user wallpaper info is updated.\n  WallpaperInfo wallpaper_info;\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  WallpaperInfo expected_wallpaper_info = WallpaperInfo(params);\n  EXPECT_EQ(wallpaper_info, expected_wallpaper_info);\n\n  // Change the on-screen wallpaper to a different one. (Otherwise the\n  // subsequent calls will be no-op since we intentionally prevent reloading the\n  // same wallpaper.)\n  ClearWallpaperCount();\n  controller_->SetCustomWallpaper(account_id_1, file_name_1, layout,\n                                  CreateImage(640, 480, kWallpaperColor),\n                                  /*preview_mode=*/false);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kCustomized);\n\n  // Attempt to set an online wallpaper via |SetOnlineWallpaperIfExists| without\n  // providing the image data. Verify it succeeds this time because\n  // |SetOnlineWallpaperFromData| has saved the file.\n  ClearWallpaperCount();\n  run_loop = std::make_unique<base::RunLoop>();\n  controller_->SetOnlineWallpaperIfExists(\n      OnlineWallpaperParams(account_id_1, kAssetId, GURL(kDummyUrl),\n                            TestWallpaperControllerClient::kDummyCollectionId,\n                            layout,\n                            /*preview_mode=*/false, /*from_user=*/true,\n                            /*daily_refresh_enabled=*/false, kUnitId, variants),\n      base::BindLambdaForTesting([&run_loop](bool file_exists) {\n        EXPECT_TRUE(file_exists);\n        run_loop->Quit();\n      }));\n  run_loop->Run();\n  EXPECT_EQ(1, GetWallpaperCount());\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kOnline);\n}\n\nTEST_F(WallpaperControllerTest,\n       HandleWallpaperInfoSyncedForDarkLightWallpapers_NotSynced) {\n  SimulateUserLogin(account_id_1);\n  CacheOnlineWallpaper(kDummyUrl);\n  ClearWallpaperCount();\n\n  std::vector<OnlineWallpaperVariant> variants;\n  variants.emplace_back(kAssetId, GURL(kDummyUrl),\n                        backdrop::Image::IMAGE_TYPE_LIGHT_MODE);\n  variants.emplace_back(kAssetId2, GURL(kDummyUrl2),\n                        backdrop::Image::IMAGE_TYPE_DARK_MODE);\n  const OnlineWallpaperParams& params =\n      OnlineWallpaperParams(account_id_1, kAssetId, GURL(kDummyUrl),\n                            TestWallpaperControllerClient::kDummyCollectionId,\n                            WALLPAPER_LAYOUT_CENTER_CROPPED,\n                            /*preview_mode=*/false, /*from_user=*/true,\n                            /*daily_refresh_enabled=*/false, kUnitId, variants);\n  // Force local info to not have a unit_id.\n  WallpaperInfo local_info = WallpaperInfo(params);\n  local_info.unit_id = absl::nullopt;\n  pref_manager_->SetLocalWallpaperInfo(account_id_1, local_info);\n\n  const OnlineWallpaperParams& params2 =\n      OnlineWallpaperParams(account_id_1, kAssetId2, GURL(kDummyUrl2),\n                            TestWallpaperControllerClient::kDummyCollectionId,\n                            WALLPAPER_LAYOUT_CENTER_CROPPED,\n                            /*preview_mode=*/false, /*from_user=*/true,\n                            /*daily_refresh_enabled=*/false, kUnitId, variants);\n  // synced info tracks dark variant.\n  const WallpaperInfo& synced_info = WallpaperInfo(params2);\n  pref_manager_->SetSyncedWallpaperInfo(account_id_1, synced_info);\n  RunAllTasksUntilIdle();\n\n  WallpaperInfo actual_info;\n  EXPECT_TRUE(pref_manager_->GetUserWallpaperInfo(account_id_1, &actual_info));\n  EXPECT_EQ(synced_info, actual_info);\n  // Verify the wallpaper is set.\n  EXPECT_EQ(1, GetWallpaperCount());\n}\n\nTEST_F(WallpaperControllerTest,\n       HandleWallpaperInfoSyncedForDarkLightWallpapers_AlreadySynced) {\n  SimulateUserLogin(account_id_1);\n  CacheOnlineWallpaper(kDummyUrl);\n  ClearWallpaperCount();\n\n  std::vector<OnlineWallpaperVariant> variants;\n  variants.emplace_back(kAssetId, GURL(kDummyUrl),\n                        backdrop::Image::IMAGE_TYPE_LIGHT_MODE);\n  variants.emplace_back(kAssetId2, GURL(kDummyUrl2),\n                        backdrop::Image::IMAGE_TYPE_DARK_MODE);\n  const OnlineWallpaperParams& params =\n      OnlineWallpaperParams(account_id_1, kAssetId, GURL(kDummyUrl),\n                            TestWallpaperControllerClient::kDummyCollectionId,\n                            WALLPAPER_LAYOUT_CENTER_CROPPED,\n                            /*preview_mode=*/false, /*from_user=*/true,\n                            /*daily_refresh_enabled=*/false, kUnitId, variants);\n  // local info tracks light variant.\n  const WallpaperInfo& local_info = WallpaperInfo(params);\n  pref_manager_->SetLocalWallpaperInfo(account_id_1, local_info);\n\n  const OnlineWallpaperParams& params2 =\n      OnlineWallpaperParams(account_id_1, kAssetId2, GURL(kDummyUrl2),\n                            TestWallpaperControllerClient::kDummyCollectionId,\n                            WALLPAPER_LAYOUT_CENTER_CROPPED,\n                            /*preview_mode=*/false, /*from_user=*/true,\n                            /*daily_refresh_enabled=*/false, kUnitId, variants);\n  // synced info tracks dark variant.\n  const WallpaperInfo& synced_info = WallpaperInfo(params2);\n  pref_manager_->SetSyncedWallpaperInfo(account_id_1, synced_info);\n  RunAllTasksUntilIdle();\n\n  WallpaperInfo actual_info;\n  EXPECT_TRUE(pref_manager_->GetUserWallpaperInfo(account_id_1, &actual_info));\n  EXPECT_EQ(local_info, synced_info);\n  EXPECT_EQ(local_info, actual_info);\n  // Verify the wallpaper is not set again.\n  EXPECT_EQ(0, GetWallpaperCount());\n}\n\nTEST_F(WallpaperControllerTest, WallpaperCustomization_Used) {\n  // Reset to login screen.\n  GetSessionControllerClient()->RequestSignOut();\n\n  // Emulate login screen behavior.\n  controller_->ShowSigninWallpaper();\n  // Let the task queue run so that we run `ShowWallpaperImage()`.\n  task_environment()->RunUntilIdle();\n\n  std::pair<const base::FilePath, const base::FilePath> paths =\n      CreateCustomizationWallpapers();\n  ASSERT_FALSE(paths.first.empty());\n  ASSERT_FALSE(paths.second.empty());\n\n  SetBypassDecode();\n  controller_->SetCustomizedDefaultWallpaperPaths(paths.first, paths.second);\n  task_environment()->RunUntilIdle();\n\n  // Verify that the customized wallpaper is in use.\n  EXPECT_THAT(GetCurrentWallpaperInfo().location,\n              testing::EndsWith(kCustomizationSmallWallpaperName));\n}\n\nTEST_F(WallpaperControllerTest, WallpaperCustomization_UnusedForNonDefault) {\n  SetBypassDecode();\n  SimulateUserLogin(account_id_1);\n\n  // Set wallpaper to something a user may have chose.\n  controller_->SetOnlineWallpaperFromData(\n      OnlineWallpaperParams(account_id_1, kAssetId, GURL(kDummyUrl),\n                            /*collection_id=*/std::string(),\n                            WALLPAPER_LAYOUT_CENTER,\n                            /*preview_mode=*/false, /*from_user=*/false,\n                            /*daily_refresh_enabled=*/false, kUnitId,\n                            /*variants=*/std::vector<OnlineWallpaperVariant>()),\n      /*image_data=*/std::string(),\n      WallpaperController::SetWallpaperCallback());\n  // Let the task queue run so that we run `ShowWallpaperImage()`.\n  task_environment()->RunUntilIdle();\n\n  // Simulate wallpaper customization retrieval completing after login.\n  std::pair<const base::FilePath, const base::FilePath> paths =\n      CreateCustomizationWallpapers();\n  ASSERT_FALSE(paths.first.empty());\n  ASSERT_FALSE(paths.second.empty());\n\n  controller_->SetCustomizedDefaultWallpaperPaths(paths.first, paths.second);\n  task_environment()->RunUntilIdle();\n\n  // Verify that we still use the online wallpaper. i.e. did not switch to\n  // default.\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kOnline);\n}\n\nclass WallpaperControllerGooglePhotosWallpaperTest\n    : public WallpaperControllerTest,\n      public testing::WithParamInterface<bool> {\n public:\n  WallpaperControllerGooglePhotosWallpaperTest() {\n    if (GooglePhotosEnabled()) {\n      scoped_feature_list_.InitWithFeatures(\n          {ash::features::kWallpaperGooglePhotosIntegration}, {});\n    } else {\n      scoped_feature_list_.InitWithFeatures(\n          {}, {ash::features::kWallpaperGooglePhotosIntegration});\n    }\n  }\n\n  WallpaperControllerGooglePhotosWallpaperTest(\n      const WallpaperControllerGooglePhotosWallpaperTest&) = delete;\n  WallpaperControllerGooglePhotosWallpaperTest& operator=(\n      const WallpaperControllerGooglePhotosWallpaperTest&) = delete;\n\n  ~WallpaperControllerGooglePhotosWallpaperTest() override = default;\n\n  bool GooglePhotosEnabled() const { return GetParam(); }\n\n  void WaitForWallpaperCount(int count) {\n    base::RunLoop run_loop;\n    base::RepeatingTimer repeating_timer;\n    repeating_timer.Start(FROM_HERE, base::Milliseconds(10),\n                          base::BindLambdaForTesting([&]() {\n                            if (GetWallpaperCount() >= count) {\n                              repeating_timer.Stop();\n                              run_loop.Quit();\n                            }\n                          }));\n    run_loop.Run();\n  }\n\n private:\n  base::test::ScopedFeatureList scoped_feature_list_;\n};\n\nINSTANTIATE_TEST_SUITE_P(All,\n                         WallpaperControllerGooglePhotosWallpaperTest,\n                         testing::Bool());\n\nTEST_P(WallpaperControllerGooglePhotosWallpaperTest, SetGooglePhotosWallpaper) {\n  bool feature_enabled = GooglePhotosEnabled();\n  SimulateUserLogin(account_id_1);\n\n  // First set the wallpaper to an Online one so we can tell for sure if setting\n  // a Google Photos wallpaper has failed.\n  base::test::TestFuture<bool> online_future;\n  controller_->SetOnlineWallpaper(\n      {account_id_1,\n       kAssetId,\n       GURL(kDummyUrl),\n       TestWallpaperControllerClient::kDummyCollectionId,\n       WALLPAPER_LAYOUT_CENTER_CROPPED,\n       /*preview_mode=*/false,\n       /*from_user=*/true,\n       /*daily_refresh_enabled=*/false,\n       kUnitId,\n       {}},\n      online_future.GetCallback());\n  ASSERT_TRUE(online_future.Wait());\n  ASSERT_EQ(1, GetWallpaperCount());\n  ASSERT_EQ(controller_->GetWallpaperType(), WallpaperType::kOnline);\n\n  // Now attempt setting a Google Photos wallpaper.\n  ClearWallpaperCount();\n  int expected_wallpaper_count = 0;\n  ASSERT_EQ(expected_wallpaper_count, GetWallpaperCount());\n  GooglePhotosWallpaperParams params(account_id_1, kFakeGooglePhotosPhotoId,\n                                     /*daily_refresh_enabled=*/false,\n                                     WallpaperLayout::WALLPAPER_LAYOUT_STRETCH,\n                                     /*preview_mode=*/false, \"dedup_key\");\n\n  controller_->SetGooglePhotosWallpaper(params, base::DoNothing());\n  if (feature_enabled)\n    ++expected_wallpaper_count;\n\n  WaitForWallpaperCount(expected_wallpaper_count);\n\n  EXPECT_EQ(feature_enabled, controller_->GetWallpaperType() ==\n                                 WallpaperType::kOnceGooglePhotos);\n\n  WallpaperInfo wallpaper_info;\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  WallpaperInfo expected_wallpaper_info(params);\n  EXPECT_EQ(feature_enabled, wallpaper_info == expected_wallpaper_info);\n}\n\nTEST_P(WallpaperControllerGooglePhotosWallpaperTest,\n       SetGooglePhotosWallpaperFails) {\n  SimulateUserLogin(account_id_1);\n\n  // First set the wallpaper to an Online one so we can tell for sure if setting\n  // a Google Photos wallpaper has failed.\n  base::test::TestFuture<bool> online_future;\n  OnlineWallpaperParams online_params(\n      {account_id_1,\n       kAssetId,\n       GURL(kDummyUrl),\n       TestWallpaperControllerClient::kDummyCollectionId,\n       WALLPAPER_LAYOUT_CENTER_CROPPED,\n       /*preview_mode=*/false,\n       /*from_user=*/true,\n       /*daily_refresh_enabled=*/false,\n       kUnitId,\n       {}});\n  controller_->SetOnlineWallpaper(online_params, online_future.GetCallback());\n  ASSERT_TRUE(online_future.Wait());\n  ASSERT_EQ(1, GetWallpaperCount());\n  ASSERT_EQ(controller_->GetWallpaperType(), WallpaperType::kOnline);\n\n  // Attempt to set a Google Photos wallpaper with the client set to fail to\n  // fetch the Google Photos photo data.\n  client_.set_fetch_google_photos_photo_fails(true);\n  ClearWallpaperCount();\n  ASSERT_EQ(0, GetWallpaperCount());\n  base::test::TestFuture<bool> google_photos_future;\n  controller_->SetGooglePhotosWallpaper(\n      {account_id_1, kFakeGooglePhotosPhotoId, false,\n       WallpaperLayout::WALLPAPER_LAYOUT_STRETCH, false, \"dedup_key\"},\n      google_photos_future.GetCallback());\n  EXPECT_FALSE(google_photos_future.Get());\n  EXPECT_NE(controller_->GetWallpaperType(), WallpaperType::kOnceGooglePhotos);\n\n  WallpaperInfo wallpaper_info;\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &wallpaper_info));\n  WallpaperInfo expected_wallpaper_info(online_params);\n  EXPECT_EQ(wallpaper_info, expected_wallpaper_info);\n}\n\nTEST_P(WallpaperControllerGooglePhotosWallpaperTest,\n       RetryTimerTriggersOnFailedFetchPhotoForStalenessCheck) {\n  using base::Time;\n\n  SimulateUserLogin(account_id_1);\n\n  GooglePhotosWallpaperParams params(account_id_1, kFakeGooglePhotosPhotoId,\n                                     /*daily_refresh_enabled=*/false,\n                                     WallpaperLayout::WALLPAPER_LAYOUT_STRETCH,\n                                     /*preview_mode=*/false,\n                                     /*dedup_key=*/absl::nullopt);\n  controller_->SetGooglePhotosWallpaper(params, base::DoNothing());\n  task_environment()->RunUntilIdle();\n\n  Time run_time =\n      controller_->GetUpdateWallpaperTimerForTesting().desired_run_time();\n  base::TimeDelta delay = run_time - Time::Now();\n\n  // If the feature is disabled, setting a GooglePhotos wallpaper is a nop.\n  if (GooglePhotosEnabled()) {\n    base::TimeDelta one_day = base::Days(1);\n    // Leave a little wiggle room, as well as account for the hour fuzzing that\n    // we do.\n    EXPECT_GE(delay, one_day - base::Minutes(1));\n    EXPECT_LE(delay, one_day + base::Minutes(61));\n  } else {\n    EXPECT_FALSE(controller_->GetUpdateWallpaperTimerForTesting().IsRunning());\n  }\n\n  client_.set_fetch_google_photos_photo_fails(true);\n\n  // Trigger Google Photos wallpaper cache check.\n  controller_->OnActiveUserSessionChanged(account_id_1);\n\n  run_time =\n      controller_->GetUpdateWallpaperTimerForTesting().desired_run_time();\n  delay = run_time - Time::Now();\n\n  base::TimeDelta one_hour = base::Hours(1);\n\n  // The cache check does not happen when the feature is disabled, since the\n  // local `WallpaperInfo` is rejected.\n  if (GooglePhotosEnabled()) {\n    // Leave a little wiggle room.\n    EXPECT_GE(delay, one_hour - base::Minutes(1));\n    EXPECT_LE(delay, one_hour + base::Minutes(1));\n  }\n}\n\nTEST_P(WallpaperControllerGooglePhotosWallpaperTest,\n       ResetToDefaultForDeletedPhotoOnStalenessCheck) {\n  SimulateUserLogin(account_id_1);\n\n  WallpaperInfo info = {kFakeGooglePhotosPhotoId, WALLPAPER_LAYOUT_CENTER,\n                        WallpaperType::kOnceGooglePhotos,\n                        DayBeforeYesterdayish()};\n  pref_manager_->SetUserWallpaperInfo(account_id_1, info);\n\n  client_.set_google_photo_has_been_deleted(true);\n  // Trigger Google Photos wallpaper cache check.\n  controller_->OnActiveUserSessionChanged(account_id_1);\n  if (GooglePhotosEnabled())\n    WaitForWallpaperCount(1);\n\n  EXPECT_EQ(GooglePhotosEnabled(),\n            controller_->GetWallpaperType() == WallpaperType::kDefault);\n}\n\nTEST_P(WallpaperControllerGooglePhotosWallpaperTest,\n       GooglePhotosAreCachedOnDisk) {\n  SimulateUserLogin(account_id_1);\n\n  base::test::TestFuture<bool> google_photos_future;\n\n  controller_->SetGooglePhotosWallpaper(\n      {account_id_1, kFakeGooglePhotosPhotoId, /*daily_refresh_enabled=*/false,\n       WALLPAPER_LAYOUT_STRETCH,\n       /*preview_mode=*/false, \"dedup_key\"},\n      google_photos_future.GetCallback());\n  EXPECT_EQ(GooglePhotosEnabled(), google_photos_future.Get());\n  RunAllTasksUntilIdle();\n\n  base::FilePath saved_wallpaper = online_wallpaper_dir_.GetPath()\n                                       .Append(\"google_photos/\")\n                                       .Append(account_id_1.GetAccountIdKey())\n                                       .Append(kFakeGooglePhotosPhotoId);\n  ASSERT_EQ(GooglePhotosEnabled(), base::PathExists(saved_wallpaper));\n}\n\nTEST_P(WallpaperControllerGooglePhotosWallpaperTest,\n       GooglePhotosAreCachedInMemory) {\n  SimulateUserLogin(account_id_1);\n\n  base::FilePath path;\n  EXPECT_FALSE(controller_->GetPathFromCache(account_id_1, &path));\n  gfx::ImageSkia cached_wallpaper;\n  EXPECT_FALSE(\n      controller_->GetWallpaperFromCache(account_id_1, &cached_wallpaper));\n\n  base::test::TestFuture<bool> google_photos_future;\n  controller_->SetGooglePhotosWallpaper(\n      {account_id_1, kFakeGooglePhotosPhotoId, /*daily_refresh_enabled=*/false,\n       WALLPAPER_LAYOUT_STRETCH,\n       /*preview_mode=*/false, \"dedup_key\"},\n      google_photos_future.GetCallback());\n  EXPECT_EQ(GooglePhotosEnabled(), google_photos_future.Get());\n  RunAllTasksUntilIdle();\n\n  // We store an empty path for Google Photos wallpapers in the in-memory cache\n  // because storing the real path correctly would require updating the cache\n  // after the asynchronous save operation, and we have no use for it anyway.\n  EXPECT_EQ(GooglePhotosEnabled(),\n            controller_->GetPathFromCache(account_id_1, &path));\n  EXPECT_TRUE(path.empty());\n  EXPECT_EQ(GooglePhotosEnabled(), controller_->GetWallpaperFromCache(\n                                       account_id_1, &cached_wallpaper));\n}\n\nTEST_P(WallpaperControllerGooglePhotosWallpaperTest,\n       GooglePhotosAreReadFromCache) {\n  SimulateUserLogin(account_id_1);\n\n  base::test::TestFuture<bool> google_photos_future;\n\n  GooglePhotosWallpaperParams params({account_id_1, kFakeGooglePhotosPhotoId,\n                                      /*daily_refresh_enabled=*/false,\n                                      WALLPAPER_LAYOUT_STRETCH,\n                                      /*preview_mode=*/false, \"dedup_key\"});\n  controller_->SetGooglePhotosWallpaper(params,\n                                        google_photos_future.GetCallback());\n  EXPECT_EQ(GooglePhotosEnabled(), google_photos_future.Get());\n  RunAllTasksUntilIdle();\n\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  // When Google Photos is disabled, the wallpaper will not be in disk cache,\n  // so it will attempt to read from disk, fail to find it, and then reset to\n  // the default wallpaper.\n  const size_t expected_decodes = GooglePhotosEnabled() ? 0 : 1;\n  const WallpaperType expected_type = GooglePhotosEnabled()\n                                          ? WallpaperType::kOnceGooglePhotos\n                                          : WallpaperType::kDefault;\n\n  EXPECT_EQ(expected_decodes, GetDecodeFilePaths().size());\n  EXPECT_EQ(expected_type, controller_->GetWallpaperType());\n}\n\nTEST_P(WallpaperControllerGooglePhotosWallpaperTest, ConfirmPreviewWallpaper) {\n  // Verify the user starts with a default wallpaper and the user wallpaper info\n  // is initialized with default values.\n  SimulateUserLogin(account_id_1);\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(GetWallpaperCount(), 1);\n  WallpaperInfo user_wallpaper_info;\n  WallpaperInfo default_wallpaper_info(\n      std::string(), WALLPAPER_LAYOUT_CENTER_CROPPED, WallpaperType::kDefault,\n      base::Time::Now().LocalMidnight());\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n\n  // Simulate opening the wallpaper picker window.\n  std::unique_ptr<aura::Window> wallpaper_picker_window(\n      CreateTestWindow(gfx::Rect(0, 0, 100, 100)));\n  WindowState::Get(wallpaper_picker_window.get())->Activate();\n\n  // Set a Google Photos wallpaper for the user and enable preview. Verify that\n  // the wallpaper is a Google Photos image if the feature is enabled.\n  const WallpaperLayout layout = WALLPAPER_LAYOUT_STRETCH;\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  ClearWallpaperCount();\n  std::string photo_id = \"foobar\";\n  base::test::TestFuture<bool> google_photos_future;\n  controller_->SetGooglePhotosWallpaper(\n      {account_id_1, photo_id, /*daily_refresh_enabled=*/false, layout,\n       /*preview_mode=*/true, \"dedup_key\"},\n      google_photos_future.GetCallback());\n  EXPECT_EQ(google_photos_future.Get(), GooglePhotosEnabled());\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(GetWallpaperCount(), GooglePhotosEnabled() ? 1 : 0);\n  EXPECT_EQ(controller_->GetWallpaperType(),\n            GooglePhotosEnabled() ? WallpaperType::kOnceGooglePhotos\n                                  : WallpaperType::kDefault);\n\n  // Verify that the user wallpaper info remains unchanged during the preview.\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n  histogram_tester().ExpectTotalCount(\"Ash.Wallpaper.Preview.Show\",\n                                      GooglePhotosEnabled() ? 1 : 0);\n\n  if (GooglePhotosEnabled()) {\n    // Now confirm the preview wallpaper, verify that there's no wallpaper\n    // change because the wallpaper is already shown.\n    ClearWallpaperCount();\n    controller_->ConfirmPreviewWallpaper();\n    RunAllTasksUntilIdle();\n    EXPECT_EQ(GetWallpaperCount(), 0);\n    EXPECT_EQ(controller_->GetWallpaperType(),\n              WallpaperType::kOnceGooglePhotos);\n\n    // Verify that the user wallpaper info is now updated to the Google Photos\n    // wallpaper info.\n    WallpaperInfo google_photos_wallpaper_info(\n        photo_id, layout, WallpaperType::kOnceGooglePhotos,\n        base::Time::Now().LocalMidnight());\n    EXPECT_TRUE(pref_manager_->GetUserWallpaperInfo(account_id_1,\n                                                    &user_wallpaper_info));\n    EXPECT_EQ(user_wallpaper_info, google_photos_wallpaper_info);\n  }\n}\n\nTEST_P(WallpaperControllerGooglePhotosWallpaperTest, CancelPreviewWallpaper) {\n  // Verify the user starts with a default wallpaper and the user wallpaper info\n  // is initialized with default values.\n  SimulateUserLogin(account_id_1);\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(GetWallpaperCount(), 1);\n  WallpaperInfo user_wallpaper_info;\n  WallpaperInfo default_wallpaper_info(\n      std::string(), WALLPAPER_LAYOUT_CENTER_CROPPED, WallpaperType::kDefault,\n      base::Time::Now().LocalMidnight());\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n\n  // Simulate opening the wallpaper picker window.\n  std::unique_ptr<aura::Window> wallpaper_picker_window(\n      CreateTestWindow(gfx::Rect(0, 0, 100, 100)));\n  WindowState::Get(wallpaper_picker_window.get())->Activate();\n\n  // Set a Google Photos wallpaper for the user and enable preview. Verify that\n  // the wallpaper is a Google Photos image if the feature is enabled.\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  ClearWallpaperCount();\n  std::string photo_id = \"foobar\";\n  base::test::TestFuture<bool> google_photos_future;\n  controller_->SetGooglePhotosWallpaper(\n      {account_id_1, photo_id, /*daily_refresh_enabled=*/false,\n       WALLPAPER_LAYOUT_STRETCH, /*preview_mode=*/true, \"dedup_key\"},\n      google_photos_future.GetCallback());\n  EXPECT_EQ(google_photos_future.Get(), GooglePhotosEnabled());\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(GetWallpaperCount(), GooglePhotosEnabled() ? 1 : 0);\n  EXPECT_EQ(controller_->GetWallpaperType(),\n            GooglePhotosEnabled() ? WallpaperType::kOnceGooglePhotos\n                                  : WallpaperType::kDefault);\n\n  // Verify that the user wallpaper info remains unchanged during the preview.\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n  histogram_tester().ExpectTotalCount(\"Ash.Wallpaper.Preview.Show\",\n                                      GooglePhotosEnabled() ? 1 : 0);\n\n  if (GooglePhotosEnabled()) {\n    // Now cancel the preview. Verify the wallpaper changes back to the default\n    // and the user wallpaper info remains unchanged.\n    ClearWallpaperCount();\n    controller_->CancelPreviewWallpaper();\n    RunAllTasksUntilIdle();\n    EXPECT_EQ(GetWallpaperCount(), 1);\n    EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n    EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n  }\n}\n\nTEST_P(WallpaperControllerGooglePhotosWallpaperTest,\n       WallpaperSyncedDuringPreview) {\n  // Verify the user starts with a default wallpaper and the user wallpaper info\n  // is initialized with default values.\n  SimulateUserLogin(account_id_1);\n  ClearWallpaperCount();\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(GetWallpaperCount(), 1);\n  WallpaperInfo user_wallpaper_info;\n  WallpaperInfo default_wallpaper_info(\n      std::string(), WALLPAPER_LAYOUT_CENTER_CROPPED, WallpaperType::kDefault,\n      base::Time::Now().LocalMidnight());\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n\n  // Simulate opening the wallpaper picker window.\n  std::unique_ptr<aura::Window> wallpaper_picker_window(\n      CreateTestWindow(gfx::Rect(0, 0, 100, 100)));\n  WindowState::Get(wallpaper_picker_window.get())->Activate();\n\n  // Set a Google Photos wallpaper for the user and enable preview. Verify that\n  // the wallpaper is a Google Photos image if the feature is enabled.\n  const WallpaperLayout layout = WALLPAPER_LAYOUT_STRETCH;\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n  ClearWallpaperCount();\n  std::string photo_id = \"foobar\";\n  base::test::TestFuture<bool> google_photos_future;\n  controller_->SetGooglePhotosWallpaper(\n      {account_id_1, photo_id, /*daily_refresh_enabled=*/false, layout,\n       /*preview_mode=*/true, \"dedup_key\"},\n      google_photos_future.GetCallback());\n  EXPECT_EQ(google_photos_future.Get(), GooglePhotosEnabled());\n  RunAllTasksUntilIdle();\n  EXPECT_EQ(GetWallpaperCount(), GooglePhotosEnabled() ? 1 : 0);\n  EXPECT_EQ(controller_->GetWallpaperType(),\n            GooglePhotosEnabled() ? WallpaperType::kOnceGooglePhotos\n                                  : WallpaperType::kDefault);\n\n  // Verify that the user wallpaper info remains unchanged during the preview.\n  EXPECT_TRUE(\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &user_wallpaper_info));\n  EXPECT_EQ(user_wallpaper_info, default_wallpaper_info);\n  histogram_tester().ExpectTotalCount(\"Ash.Wallpaper.Preview.Show\",\n                                      GooglePhotosEnabled() ? 1 : 0);\n\n  // Now set a custom wallpaper for the user and disable preview (this happens\n  // if a custom wallpaper set on another device is being synced). Verify\n  // there's no wallpaper change since preview mode shouldn't be interrupted.\n  if (GooglePhotosEnabled()) {\n    gfx::ImageSkia synced_custom_wallpaper =\n        CreateImage(640, 480, kWallpaperColor);\n    ClearWallpaperCount();\n    controller_->SetCustomWallpaper(account_id_1, file_name_1, layout,\n                                    synced_custom_wallpaper,\n                                    /*preview_mode=*/false);\n    RunAllTasksUntilIdle();\n    EXPECT_EQ(GetWallpaperCount(), 0);\n    EXPECT_EQ(controller_->GetWallpaperType(),\n              WallpaperType::kOnceGooglePhotos);\n\n    // However, the user wallpaper info should already be updated to the new\n    // info.\n    WallpaperInfo synced_custom_wallpaper_info(\n        base::FilePath(wallpaper_files_id_1).Append(file_name_1).value(),\n        layout, WallpaperType::kCustomized, base::Time::Now().LocalMidnight());\n    EXPECT_TRUE(pref_manager_->GetUserWallpaperInfo(account_id_1,\n                                                    &user_wallpaper_info));\n    EXPECT_EQ(user_wallpaper_info, synced_custom_wallpaper_info);\n\n    // Now cancel the preview. Verify the synced custom wallpaper is shown\n    // instead of the initial default wallpaper, and the user wallpaper info is\n    // still correct.\n    ClearWallpaperCount();\n    controller_->CancelPreviewWallpaper();\n    RunAllTasksUntilIdle();\n    EXPECT_EQ(GetWallpaperCount(), 1);\n    EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kCustomized);\n    EXPECT_TRUE(pref_manager_->GetUserWallpaperInfo(account_id_1,\n                                                    &user_wallpaper_info));\n    EXPECT_EQ(user_wallpaper_info, synced_custom_wallpaper_info);\n  }\n}\n\nTEST_P(WallpaperControllerGooglePhotosWallpaperTest,\n       UpdateGooglePhotosDailyRefreshWallpaper) {\n  // The `TestWallpaperControllerClient` sends back the reversed\n  // `collection_id` when asked to fetch a daily photo.\n  std::string expected_photo_id = kFakeGooglePhotosAlbumId;\n  std::reverse(expected_photo_id.begin(), expected_photo_id.end());\n\n  SimulateUserLogin(account_id_1);\n\n  GooglePhotosWallpaperParams params(\n      account_id_1, kFakeGooglePhotosAlbumId,\n      /*daily_refresh_enabled=*/true, WALLPAPER_LAYOUT_CENTER_CROPPED,\n      /*preview_mode=*/false, /*dedup_key=*/absl::nullopt);\n  WallpaperInfo info(params);\n  pref_manager_->SetUserWallpaperInfo(account_id_1, info);\n\n  controller_->UpdateDailyRefreshWallpaperForTesting();\n  RunAllTasksUntilIdle();\n\n  WallpaperInfo expected_info;\n  bool success =\n      pref_manager_->GetUserWallpaperInfo(account_id_1, &expected_info);\n  EXPECT_EQ(success, GooglePhotosEnabled());\n  if (success) {\n    EXPECT_EQ(expected_photo_id, expected_info.location);\n    EXPECT_EQ(kFakeGooglePhotosAlbumId, expected_info.collection_id);\n  }\n}\n\nTEST_P(WallpaperControllerGooglePhotosWallpaperTest,\n       DailyRefreshTimerStartsForDailyGooglePhotos) {\n  SimulateUserLogin(account_id_1);\n\n  GooglePhotosWallpaperParams params(\n      account_id_1, kFakeGooglePhotosAlbumId,\n      /*daily_refresh_enabled=*/true, WALLPAPER_LAYOUT_CENTER_CROPPED,\n      /*preview_mode=*/false, /*dedup_key=*/absl::nullopt);\n  WallpaperInfo info(params);\n  pref_manager_->SetUserWallpaperInfo(account_id_1, info);\n\n  controller_->UpdateDailyRefreshWallpaperForTesting();\n  RunAllTasksUntilIdle();\n  auto& timer = controller_->GetUpdateWallpaperTimerForTesting();\n  base::TimeDelta run_time =\n      timer.desired_run_time().ToDeltaSinceWindowsEpoch();\n\n  base::TimeDelta update_time =\n      (base::Time::Now() + base::Days(1)).ToDeltaSinceWindowsEpoch();\n\n  if (GooglePhotosEnabled()) {\n    EXPECT_GE(run_time, update_time - base::Minutes(1));\n    EXPECT_LE(run_time, update_time + base::Minutes(61));\n  } else {\n    EXPECT_FALSE(timer.IsRunning());\n  }\n}\n\nTEST_P(WallpaperControllerGooglePhotosWallpaperTest,\n       DailyRefreshRetryTimerStartsOnFailedFetch) {\n  SimulateUserLogin(account_id_1);\n\n  GooglePhotosWallpaperParams params(\n      account_id_1, kFakeGooglePhotosAlbumId,\n      /*daily_refresh_enabled=*/true, WALLPAPER_LAYOUT_CENTER_CROPPED,\n      /*preview_mode=*/false, /*dedup_key=*/absl::nullopt);\n  WallpaperInfo info(params);\n  pref_manager_->SetUserWallpaperInfo(account_id_1, info);\n\n  client_.set_fetch_google_photos_photo_fails(true);\n  controller_->UpdateDailyRefreshWallpaperForTesting();\n  RunAllTasksUntilIdle();\n\n  base::TimeDelta run_time = controller_->GetUpdateWallpaperTimerForTesting()\n                                 .desired_run_time()\n                                 .ToDeltaSinceWindowsEpoch();\n\n  base::TimeDelta update_time =\n      (base::Time::Now() + base::Hours(1)).ToDeltaSinceWindowsEpoch();\n\n  if (GooglePhotosEnabled()) {\n    EXPECT_GE(run_time, update_time - base::Minutes(1));\n    EXPECT_LE(run_time, update_time + base::Minutes(1));\n  } else {\n    EXPECT_FALSE(controller_->GetUpdateWallpaperTimerForTesting().IsRunning());\n  }\n}\n\nTEST_P(WallpaperControllerGooglePhotosWallpaperTest,\n       EmptyDailyGooglePhotosAlbumsDoNothing) {\n  SimulateUserLogin(account_id_1);\n\n  GooglePhotosWallpaperParams daily_google_photos_params(\n      account_id_1, kFakeGooglePhotosAlbumId, /*daily_refresh_enabled=*/true,\n      WALLPAPER_LAYOUT_CENTER_CROPPED, /*preview_mode=*/false,\n      /*dedup_key=*/absl::nullopt);\n  OnlineWallpaperParams online_params(\n      account_id_1, kAssetId, GURL(kDummyUrl),\n      TestWallpaperControllerClient::kDummyCollectionId,\n      WALLPAPER_LAYOUT_CENTER_CROPPED,\n      /*preview_mode=*/false, /*from_user=*/true,\n      /*daily_refresh_enabled=*/false, kUnitId,\n      /*variants=*/std::vector<OnlineWallpaperVariant>());\n\n  WallpaperInfo online_info(online_params);\n  pref_manager_->SetUserWallpaperInfo(account_id_1, online_info);\n\n  client_.set_fetch_google_photos_photo_fails(true);\n  controller_->SetGooglePhotosWallpaper(daily_google_photos_params,\n                                        base::DoNothing());\n  RunAllTasksUntilIdle();\n\n  WallpaperInfo current_info;\n  pref_manager_->GetUserWallpaperInfo(account_id_1, &current_info);\n\n  EXPECT_EQ(online_info, current_info);\n}\n\nTEST_P(WallpaperControllerGooglePhotosWallpaperTest,\n       ResetToDefaultForDeletedDailyGooglePhotosAlbums) {\n  SimulateUserLogin(account_id_1);\n\n  base::test::TestFuture<bool> google_photos_future;\n  controller_->SetGooglePhotosWallpaper(\n      {account_id_1, kFakeGooglePhotosAlbumId, /*daily_refresh_enabled=*/true,\n       WallpaperLayout::WALLPAPER_LAYOUT_CENTER_CROPPED,\n       /*preview_mode=*/false, /*dedup_key=*/absl::nullopt},\n      google_photos_future.GetCallback());\n  EXPECT_EQ(GooglePhotosEnabled(), google_photos_future.Get());\n  RunAllTasksUntilIdle();\n\n  WallpaperInfo current_info;\n  pref_manager_->GetUserWallpaperInfo(account_id_1, &current_info);\n\n  EXPECT_EQ(GooglePhotosEnabled(),\n            WallpaperType::kDailyGooglePhotos == current_info.type);\n\n  // This makes the test fetch in `client_` return a null photo, but a\n  // successful call, which is the sign for a deleted or empty album.\n  client_.set_google_photo_has_been_deleted(true);\n\n  controller_->UpdateDailyRefreshWallpaperForTesting();\n  RunAllTasksUntilIdle();\n\n  pref_manager_->GetUserWallpaperInfo(account_id_1, &current_info);\n\n  EXPECT_EQ(GooglePhotosEnabled(),\n            WallpaperType::kDefault == current_info.type);\n}\n\nTEST_P(WallpaperControllerGooglePhotosWallpaperTest,\n       DailyGooglePhotosAreCached) {\n  SimulateUserLogin(account_id_1);\n  // The `TestWallpaperControllerClient` sends back the reversed\n  // `collection_id` when asked to fetch a daily photo.\n  std::string expected_photo_id = kFakeGooglePhotosAlbumId;\n  std::reverse(expected_photo_id.begin(), expected_photo_id.end());\n\n  base::test::TestFuture<bool> google_photos_future;\n  controller_->SetGooglePhotosWallpaper(\n      {account_id_1, kFakeGooglePhotosAlbumId, /*daily_refresh_enabled=*/true,\n       WallpaperLayout::WALLPAPER_LAYOUT_CENTER_CROPPED,\n       /*preview_mode=*/false, /*dedup_key=*/absl::nullopt},\n      google_photos_future.GetCallback());\n  EXPECT_EQ(GooglePhotosEnabled(), google_photos_future.Get());\n  RunAllTasksUntilIdle();\n\n  base::FilePath saved_wallpaper = online_wallpaper_dir_.GetPath()\n                                       .Append(\"google_photos/\")\n                                       .Append(account_id_1.GetAccountIdKey())\n                                       .Append(expected_photo_id);\n  ASSERT_EQ(GooglePhotosEnabled(), base::PathExists(saved_wallpaper));\n}\n\nTEST_P(WallpaperControllerGooglePhotosWallpaperTest,\n       ResetToDefaultWhenLoadingInvalidWallpaper) {\n  SimulateUserLogin(account_id_1);\n\n  const WallpaperType type = GooglePhotosEnabled()\n                                 ? WallpaperType::kCount\n                                 : WallpaperType::kOnceGooglePhotos;\n\n  WallpaperInfo info = {kFakeGooglePhotosPhotoId, WALLPAPER_LAYOUT_CENTER, type,\n                        base::Time::Now()};\n  pref_manager_->SetUserWallpaperInfo(account_id_1, info);\n  controller_->ShowUserWallpaper(account_id_1);\n  RunAllTasksUntilIdle();\n\n  EXPECT_EQ(controller_->GetWallpaperType(), WallpaperType::kDefault);\n}\n\n}  // namespace ash\n"
  }
}