blob: 4a8212ef765d5d681414616057e8d3a87be4bf2b [file] [log] [blame]
// Copyright 2016 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 "ash/metrics/pointer_metrics_recorder.h"
#include "ash/public/cpp/shell_window_ids.h"
#include "ash/shared/app_types.h"
#include "ash/shell.h"
#include "ash/test/ash_test_base.h"
#include "ash/wm/maximize_mode/maximize_mode_controller.h"
#include "ash/wm_window.h"
#include "base/test/histogram_tester.h"
#include "ui/events/event.h"
#include "ui/views/pointer_watcher.h"
#include "ui/views/widget/widget.h"
using views::PointerWatcher;
namespace ash {
namespace {
const char kFormFactorHistogramName[] = "Event.DownEventCount.PerFormFactor";
const char kInputHistogramName[] = "Event.DownEventCount.PerInput";
const char kDestinationHistogramName[] = "Event.DownEventCount.PerDestination";
// Test fixture for the PointerMetricsRecorder class.
class PointerMetricsRecorderTest : public test::AshTestBase {
public:
PointerMetricsRecorderTest();
~PointerMetricsRecorderTest() override;
// test::AshTestBase:
void SetUp() override;
void TearDown() override;
protected:
// The test target.
std::unique_ptr<PointerMetricsRecorder> pointer_metrics_recorder_;
// Used to verify recorded data.
std::unique_ptr<base::HistogramTester> histogram_tester_;
private:
DISALLOW_COPY_AND_ASSIGN(PointerMetricsRecorderTest);
};
PointerMetricsRecorderTest::PointerMetricsRecorderTest() {}
PointerMetricsRecorderTest::~PointerMetricsRecorderTest() {}
void PointerMetricsRecorderTest::SetUp() {
test::AshTestBase::SetUp();
pointer_metrics_recorder_.reset(new PointerMetricsRecorder());
histogram_tester_.reset(new base::HistogramTester());
}
void PointerMetricsRecorderTest::TearDown() {
pointer_metrics_recorder_.reset();
test::AshTestBase::TearDown();
}
} // namespace
// Verifies that histogram is not recorded when receiving events that are not
// down events.
TEST_F(PointerMetricsRecorderTest, NonDownEventsInAllPointerHistogram) {
std::unique_ptr<views::Widget> target =
CreateTestWidget(nullptr, kShellWindowId_DefaultContainer, gfx::Rect());
const ui::PointerEvent pointer_event(
ui::ET_POINTER_UP, gfx::Point(), gfx::Point(), 0, 0,
ui::PointerDetails(ui::EventPointerType::POINTER_TYPE_MOUSE, 0),
base::TimeTicks());
pointer_metrics_recorder_->OnPointerEventObserved(pointer_event, gfx::Point(),
target.get());
histogram_tester_->ExpectTotalCount(kFormFactorHistogramName, 0);
histogram_tester_->ExpectTotalCount(kInputHistogramName, 0);
histogram_tester_->ExpectTotalCount(kDestinationHistogramName, 0);
}
// Verifies that down events from different inputs are recorded.
TEST_F(PointerMetricsRecorderTest, DownEventPerInput) {
std::unique_ptr<views::Widget> target =
CreateTestWidget(nullptr, kShellWindowId_DefaultContainer, gfx::Rect());
const ui::PointerEvent unknown_event(
ui::ET_POINTER_DOWN, gfx::Point(), gfx::Point(), 0, 0,
ui::PointerDetails(ui::EventPointerType::POINTER_TYPE_UNKNOWN, 0),
base::TimeTicks());
pointer_metrics_recorder_->OnPointerEventObserved(unknown_event, gfx::Point(),
target.get());
histogram_tester_->ExpectBucketCount(kInputHistogramName, 0, 1);
const ui::PointerEvent mouse_event(
ui::ET_POINTER_DOWN, gfx::Point(), gfx::Point(), 0, 0,
ui::PointerDetails(ui::EventPointerType::POINTER_TYPE_MOUSE, 0),
base::TimeTicks());
pointer_metrics_recorder_->OnPointerEventObserved(mouse_event, gfx::Point(),
target.get());
histogram_tester_->ExpectBucketCount(kInputHistogramName, 1, 1);
const ui::PointerEvent stylus_event(
ui::ET_POINTER_DOWN, gfx::Point(), gfx::Point(), 0, 0,
ui::PointerDetails(ui::EventPointerType::POINTER_TYPE_PEN, 0),
base::TimeTicks());
pointer_metrics_recorder_->OnPointerEventObserved(stylus_event, gfx::Point(),
target.get());
histogram_tester_->ExpectBucketCount(kInputHistogramName, 2, 1);
const ui::PointerEvent stylus_event2(
ui::ET_POINTER_DOWN, gfx::Point(), gfx::Point(), 0, 0,
ui::PointerDetails(ui::EventPointerType::POINTER_TYPE_ERASER, 0),
base::TimeTicks());
pointer_metrics_recorder_->OnPointerEventObserved(stylus_event2, gfx::Point(),
target.get());
histogram_tester_->ExpectBucketCount(kInputHistogramName, 2, 2);
const ui::PointerEvent touch_event(
ui::ET_POINTER_DOWN, gfx::Point(), gfx::Point(), 0, 0,
ui::PointerDetails(ui::EventPointerType::POINTER_TYPE_TOUCH, 0),
base::TimeTicks());
pointer_metrics_recorder_->OnPointerEventObserved(touch_event, gfx::Point(),
target.get());
histogram_tester_->ExpectBucketCount(kInputHistogramName, 3, 1);
}
// Verifies that down events in different form factors are recorded.
TEST_F(PointerMetricsRecorderTest, DownEventPerFormFactor) {
std::unique_ptr<views::Widget> target =
CreateTestWidget(nullptr, kShellWindowId_DefaultContainer, gfx::Rect());
const ui::PointerEvent pointer_event(
ui::ET_POINTER_DOWN, gfx::Point(), gfx::Point(), 0, 0,
ui::PointerDetails(ui::EventPointerType::POINTER_TYPE_MOUSE),
base::TimeTicks());
// Enable maximize mode
Shell::Get()->maximize_mode_controller()->EnableMaximizeModeWindowManager(
true);
pointer_metrics_recorder_->OnPointerEventObserved(pointer_event, gfx::Point(),
target.get());
histogram_tester_->ExpectBucketCount(kFormFactorHistogramName, 1, 1);
// Disable maximize mode
Shell::Get()->maximize_mode_controller()->EnableMaximizeModeWindowManager(
false);
pointer_metrics_recorder_->OnPointerEventObserved(pointer_event, gfx::Point(),
target.get());
histogram_tester_->ExpectBucketCount(kFormFactorHistogramName, 0, 1);
}
// Verifies that down events dispatched to different destinations are recorded.
TEST_F(PointerMetricsRecorderTest, DownEventPerDestination) {
std::unique_ptr<views::Widget> target =
CreateTestWidget(nullptr, kShellWindowId_DefaultContainer, gfx::Rect());
const ui::PointerEvent pointer_event(
ui::ET_POINTER_DOWN, gfx::Point(), gfx::Point(), 0, 0,
ui::PointerDetails(ui::EventPointerType::POINTER_TYPE_MOUSE, 0),
base::TimeTicks());
WmWindow* window = WmWindow::Get(target->GetNativeWindow());
CHECK(window);
window->SetAppType(static_cast<int>(AppType::OTHERS));
pointer_metrics_recorder_->OnPointerEventObserved(pointer_event, gfx::Point(),
target.get());
histogram_tester_->ExpectBucketCount(kDestinationHistogramName, 0, 1);
window->SetAppType(static_cast<int>(AppType::BROWSER));
pointer_metrics_recorder_->OnPointerEventObserved(pointer_event, gfx::Point(),
target.get());
histogram_tester_->ExpectBucketCount(kDestinationHistogramName, 1, 1);
window->SetAppType(static_cast<int>(AppType::CHROME_APP));
pointer_metrics_recorder_->OnPointerEventObserved(pointer_event, gfx::Point(),
target.get());
histogram_tester_->ExpectBucketCount(kDestinationHistogramName, 2, 1);
window->SetAppType(static_cast<int>(AppType::ARC_APP));
pointer_metrics_recorder_->OnPointerEventObserved(pointer_event, gfx::Point(),
target.get());
histogram_tester_->ExpectBucketCount(kDestinationHistogramName, 3, 1);
}
} // namespace ash