chromium/chrome/browser/ash/crostini/crostini_test_helper.h

// Copyright 2018 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#ifndef CHROME_BROWSER_ASH_CROSTINI_CROSTINI_TEST_HELPER_H_
#define CHROME_BROWSER_ASH_CROSTINI_CROSTINI_TEST_HELPER_H_

#include <map>
#include <string>

#include "base/memory/raw_ptr.h"
#include "base/test/scoped_feature_list.h"
#include "chrome/browser/ash/crostini/crostini_util.h"
#include "chrome/browser/ash/login/users/fake_chrome_user_manager.h"
#include "chromeos/ash/components/dbus/vm_applications/apps.pb.h"
#include "components/user_manager/scoped_user_manager.h"

class TestingProfile;

namespace crostini {

// This class is used to help test Crostini app integration by providing a
// simple interface to add, update, and remove apps from the registry.
class CrostiniTestHelper {
 public:
  // For convenience, instantiating this allows Crostini, and enables it
  // unless enable_crostini is false. The destructor resets these.
  explicit CrostiniTestHelper(TestingProfile* profile,
                              bool enable_crostini = true);
  ~CrostiniTestHelper();

  // Creates the apps named "dummy1" and "dummy2" in the default container.
  void SetupDummyApps();
  // Returns the |i|th app from the current list of apps.
  vm_tools::apps::App GetApp(int i);
  // Adds an app in the default container. Replaces an existing app with the
  // same desktop file id if one exists.
  void AddApp(const vm_tools::apps::App& app);
  // Removes the |i|th app from the current list of apps.
  void RemoveApp(int i);
  // Updates the Keywords field in an app
  void UpdateAppKeywords(
      vm_tools::apps::App& app,
      const std::map<std::string, std::set<std::string>>& keywords);

  // When the App Service is enabled, the timing of when Profile-related and
  // Profile-creation-triggered initialization occurs means that the App
  // Service has to be re-initialized with Crostini's testing fakes. This
  // method does that re-initialization.
  void ReInitializeAppServiceIntegration();

  // Set/unset the the CrostiniEnabled pref
  static void EnableCrostini(TestingProfile* profile);
  static void DisableCrostini(TestingProfile* profile);

  // Returns the app id that the registry would use for the given desktop file.
  static std::string GenerateAppId(
      const std::string& desktop_file_id,
      const std::string& vm_name = kCrostiniDefaultVmName,
      const std::string& container_name = kCrostiniDefaultContainerName);

  // Returns an App with the desktop file id, default name, and no_display
  // as provided.
  static vm_tools::apps::App BasicApp(const std::string& desktop_file_id,
                                      const std::string& name = "",
                                      bool no_display = false);

  // Returns an ApplicationList with a single desktop file.
  static vm_tools::apps::ApplicationList BasicAppList(
      const std::string& desktop_file_id,
      const std::string& vm_name = kCrostiniDefaultVmName,
      const std::string& container_name = kCrostiniDefaultContainerName);

 private:
  void UpdateRegistry();

  user_manager::TypedScopedUserManager<ash::FakeChromeUserManager>
      fake_user_manager_;
  raw_ptr<TestingProfile> profile_;
  vm_tools::apps::ApplicationList current_apps_;

  // This are used to allow Crostini.
  base::test::ScopedFeatureList scoped_feature_list_;
};

}  // namespace crostini

#endif  // CHROME_BROWSER_ASH_CROSTINI_CROSTINI_TEST_HELPER_H_