blob: a2039d0ddf5a1189e126dbbfc9a3055de592c77a [file] [log] [blame]
// Copyright 2017 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include <vector>
#include "base/callback_forward.h"
#include "base/macros.h"
#include "base/optional.h"
#include "base/strings/string16.h"
#include "chrome/browser/notifications/notification_common.h"
class Profile;
class StubNotificationDisplayService;
namespace message_center {
class Notification;
// Helper class that enables use of the NotificationDisplayService in tests. The
// Profile* passed when constructing an instance must outlive this class, as
// the service (or internals of the service) may be overridden.
// This class must only be used for testing purposes. Unlike most production
// NotificationDisplayService implementations, all operations on this tester are
// synchronous.
class NotificationDisplayServiceTester {
explicit NotificationDisplayServiceTester(Profile* profile);
// Returns the currently active tester, if any.
static NotificationDisplayServiceTester* Get();
// Sets |closure| to be invoked when any notification has been added.
void SetNotificationAddedClosure(base::RepeatingClosure closure);
// Synchronously gets a vector of the displayed Notifications for the |type|.
std::vector<message_center::Notification> GetDisplayedNotificationsForType(
NotificationHandler::Type type);
const NotificationCommon::Metadata* GetMetadataForNotification(
const message_center::Notification& notification);
base::Optional<message_center::Notification> GetNotification(
const std::string& notification_id) const;
// Simulates the notification identified by |notification_id| being clicked
// on, optionally with the given |action_index| and |reply|.
void SimulateClick(NotificationHandler::Type notification_type,
const std::string& notification_id,
base::Optional<int> action_index,
base::Optional<base::string16> reply);
// Simulates a click on the settings button of the notification identified by
// |notification_id|.
void SimulateSettingsClick(NotificationHandler::Type notification_type,
const std::string& notification_id);
// Simulates the notification identified by |notification_id| being closed due
// to external events, such as the user dismissing it when |by_user| is set.
// When |silent| is set, the notification handlers won't be informed of the
// change to immitate behaviour of operating systems that don't inform apps
// about removed notifications.
void RemoveNotification(NotificationHandler::Type type,
const std::string& notification_id,
bool by_user,
bool silent = false);
// Removes all notifications of the given |type|.
void RemoveAllNotifications(NotificationHandler::Type type, bool by_user);
Profile* profile_;
StubNotificationDisplayService* display_service_;