1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117
|
// Copyright 2017 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "chrome/browser/ui/views/session_crashed_bubble_view.h"
#include <string>
#include "base/memory/raw_ptr.h"
#include "build/build_config.h"
#include "build/buildflag.h"
#include "chrome/browser/ui/test/test_browser_dialog.h"
#include "chrome/browser/ui/views/frame/browser_view.h"
#include "chrome/browser/ui/views/toolbar/browser_app_menu_button.h"
#include "chrome/browser/ui/views/toolbar/toolbar_view.h"
#include "chrome/test/base/in_process_browser_test.h"
#include "content/public/test/browser_test.h"
#include "ui/base/buildflags.h"
#include "ui/views/focus/focus_manager.h"
#include "ui/views/test/ax_event_counter.h"
#include "ui/views/view.h"
class SessionCrashedBubbleViewTest : public DialogBrowserTest {
public:
SessionCrashedBubbleViewTest() = default;
SessionCrashedBubbleViewTest(const SessionCrashedBubbleViewTest&) = delete;
SessionCrashedBubbleViewTest& operator=(const SessionCrashedBubbleViewTest&) =
delete;
~SessionCrashedBubbleViewTest() override = default;
void ShowUi(const std::string& name) override {
// TODO(pbos): Set up UMA opt-in conditions instead of providing this bool.
crash_bubble_ = SessionCrashedBubbleView::ShowBubble(
browser(), name == "SessionCrashedBubbleOfferUma");
}
protected:
raw_ptr<views::BubbleDialogDelegate, DanglingUntriaged> crash_bubble_;
};
IN_PROC_BROWSER_TEST_F(SessionCrashedBubbleViewTest,
InvokeUi_SessionCrashedBubble) {
ShowAndVerifyUi();
}
IN_PROC_BROWSER_TEST_F(SessionCrashedBubbleViewTest,
InvokeUi_SessionCrashedBubbleOfferUma) {
ShowAndVerifyUi();
}
// Regression test for https://crbug.com/1042010, it should be possible to focus
// the bubble with the "focus dialog" hotkey combination (Alt+Shift+A).
// TODO(crbug.com/40856612): Flaky on mac-12-arm64-rel.
#if BUILDFLAG(IS_MAC) && defined(ARCH_CPU_ARM64) && defined(NDEBUG)
#define MAYBE_CanFocusBubbleWithFocusDialogHotkey \
DISABLED_CanFocusBubbleWithFocusDialogHotkey
#else
#define MAYBE_CanFocusBubbleWithFocusDialogHotkey \
CanFocusBubbleWithFocusDialogHotkey
#endif
IN_PROC_BROWSER_TEST_F(SessionCrashedBubbleViewTest,
MAYBE_CanFocusBubbleWithFocusDialogHotkey) {
ShowUi("SessionCrashedBubble");
views::FocusManager* focus_manager =
crash_bubble_->GetWidget()->GetFocusManager();
BrowserView* browser_view = BrowserView::GetBrowserViewForBrowser(browser());
views::View* bubble_focused_view = crash_bubble_->GetInitiallyFocusedView();
focus_manager->ClearFocus();
EXPECT_FALSE(bubble_focused_view->HasFocus());
browser_view->FocusInactivePopupForAccessibility();
EXPECT_TRUE(bubble_focused_view->HasFocus());
}
// Regression test for https://crbug.com/1042010, it should be possible to focus
// the bubble with the "rotate pane focus" (F6) hotkey.
// TODO(crbug.com/40852599): Flaky on Mac.
#if BUILDFLAG(IS_MAC)
#define MAYBE_CanFocusBubbleWithRotatePaneFocusHotkey \
DISABLED_CanFocusBubbleWithRotatePaneFocusHotkey
#else
#define MAYBE_CanFocusBubbleWithRotatePaneFocusHotkey \
CanFocusBubbleWithRotatePaneFocusHotkey
#endif
IN_PROC_BROWSER_TEST_F(SessionCrashedBubbleViewTest,
MAYBE_CanFocusBubbleWithRotatePaneFocusHotkey) {
ShowUi("SessionCrashedBubble");
views::FocusManager* focus_manager =
crash_bubble_->GetWidget()->GetFocusManager();
BrowserView* browser_view = BrowserView::GetBrowserViewForBrowser(browser());
views::View* bubble_focused_view = crash_bubble_->GetInitiallyFocusedView();
focus_manager->ClearFocus();
EXPECT_FALSE(bubble_focused_view->HasFocus());
browser_view->RotatePaneFocus(true);
// Rotate pane focus is expected to keep the bubble focused until the user
// deals with it, so a second call should have no effect.
browser_view->RotatePaneFocus(true);
EXPECT_TRUE(bubble_focused_view->HasFocus());
}
IN_PROC_BROWSER_TEST_F(SessionCrashedBubbleViewTest, AlertAccessibleEvent) {
views::test::AXEventCounter counter(views::AXUpdateNotifier::Get());
EXPECT_EQ(0, counter.GetCount(ax::mojom::Event::kAlert));
ShowUi("SessionCrashedBubble");
EXPECT_EQ(1, counter.GetCount(ax::mojom::Event::kAlert));
}
// Regression test for https://crbug.com/1081393.
IN_PROC_BROWSER_TEST_F(SessionCrashedBubbleViewTest, HasCloseButton) {
ShowUi("SessionCrashedBubble");
EXPECT_TRUE(crash_bubble_->ShouldShowCloseButton());
}
|