[go: nahoru, domu]

blob: 3f758d7ebbe4f1d487f02adfbe1b2ade2427663b [file] [log] [blame]
// Copyright 2022 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef FUCHSIA_WEB_RUNNERS_CAST_TEST_CAST_RUNNER_LAUNCHER_H_
#define FUCHSIA_WEB_RUNNERS_CAST_TEST_CAST_RUNNER_LAUNCHER_H_
#include <lib/sys/component/cpp/testing/realm_builder.h>
#include <lib/sys/cpp/service_directory.h>
#include <memory>
#include <string_view>
#include "fuchsia_web/common/test/fake_feedback_service.h"
#include "fuchsia_web/runners/cast/test/cast_runner_features.h"
#include "fuchsia_web/runners/cast/test/fake_cast_agent.h"
#include "third_party/abseil-cpp/absl/types/optional.h"
namespace test {
// Test helper that arranges to launch an isolated `cast_runner.cm` instance
// with the specified features enabled. The instance will start only when
// one of the capabilities that it offers is actually connected-to, via the
// `exposed_services()`.
class CastRunnerLauncher {
public:
// Name of a component collection defined under this launcher's `Realm`,
// into which Cast activities may be launched using the `cast_runner`
// managed by this launcher.
static constexpr char kTestCollectionName[] = "cast-test-collection";
// Name of the CastRunner's Realm protocol, as exposed via the returned
// service directory.
static constexpr char kCastRunnerRealmProtocol[] =
"fuchsia.component.Realm-runner";
explicit CastRunnerLauncher(CastRunnerFeatures runner_features);
~CastRunnerLauncher();
CastRunnerLauncher(const CastRunnerLauncher&) = delete;
CastRunnerLauncher& operator=(const CastRunnerLauncher&) = delete;
// Returns a reference to the set of services exposed by the launcher, which
// includes both the capabilities exposed by the `cast_runner` component, and
// a `Realm` containing the test collection into which Cast activities may
// be launched.
sys::ServiceDirectory& exposed_services() { return *exposed_services_; }
// Returns a fake through which Cast-specific services such as the
// ApplicationConfigManager may be configured by tests.
FakeCastAgent& fake_cast_agent() { return *fake_cast_agent_; }
private:
absl::optional<::component_testing::RealmRoot> realm_root_;
std::unique_ptr<sys::ServiceDirectory> exposed_services_;
raw_ptr<FakeCastAgent> fake_cast_agent_ = nullptr;
};
} // namespace test
#endif // FUCHSIA_WEB_RUNNERS_CAST_TEST_CAST_RUNNER_LAUNCHER_H_