Chromium Code Reviews| Index: ui/views/cocoa/cocoa_mouse_capture_unittest.mm |
| diff --git a/ui/views/cocoa/cocoa_mouse_capture_unittest.mm b/ui/views/cocoa/cocoa_mouse_capture_unittest.mm |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..911efad428f4968a0e4d4f63368ea21a9fd22ccf |
| --- /dev/null |
| +++ b/ui/views/cocoa/cocoa_mouse_capture_unittest.mm |
| @@ -0,0 +1,127 @@ |
| +// Copyright 2014 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. |
| + |
| +#import "ui/views/cocoa/cocoa_mouse_capture.h" |
| + |
| +#import <Cocoa/Cocoa.h> |
| + |
| +#import "base/mac/scoped_nsobject.h" |
| +#import "ui/events/test/cocoa_test_event_utils.h" |
| +#import "ui/gfx/test/ui_cocoa_test_helper.h" |
| +#import "ui/views/cocoa/cocoa_mouse_capture_delegate.h" |
| + |
| +// Simple test view that counts calls to -[NSView mouseDown:]. |
| +@interface CocoaMouseCaptureTestView : NSView { |
| + @private |
| + int mouseDownCount_; |
|
Andre
2014/12/12 22:57:38
Objective-C style guide says that underscore shoul
tapted
2014/12/17 03:20:51
Ooh - interesting. TBH, I think there is so much m
|
| +} |
| +@property(readonly, nonatomic) int mouseDownCount; |
| +@end |
| + |
| +@implementation CocoaMouseCaptureTestView |
| + |
| +@synthesize mouseDownCount = mouseDownCount_; |
| + |
| +- (void)mouseDown:(NSEvent*)theEvent { |
| + ++mouseDownCount_; |
| +} |
| + |
| +@end |
| + |
| +namespace views { |
| +namespace { |
| + |
| +// Simple capture delegate that just counts events forwarded. |
| +class TestCaptureDelegate : public CocoaMouseCaptureDelegate { |
| + public: |
| + TestCaptureDelegate() : event_count_(0), capture_lost_count_(0) {} |
| + |
| + void Acquire() { mouse_capture_.reset(new CocoaMouseCapture(this)); } |
| + bool IsActive() { return mouse_capture_ && mouse_capture_->IsActive(); } |
| + void SimulateDestroy() { mouse_capture_.reset(); } |
| + |
| + int event_count() { return event_count_; } |
| + int capture_lost_count() { return capture_lost_count_; } |
| + |
| + // CocoaMouseCaptureDelegate: |
| + void PostCapturedEvent(NSEvent* event) override { ++event_count_; } |
| + void OnMouseCaptureLost() override { ++capture_lost_count_; } |
| + |
| + private: |
| + scoped_ptr<CocoaMouseCapture> mouse_capture_; |
| + int event_count_; |
| + int capture_lost_count_; |
| + |
| + DISALLOW_COPY_AND_ASSIGN(TestCaptureDelegate); |
| +}; |
| + |
| +} // namespace |
| + |
| +typedef ui::CocoaTest CocoaMouseCaptureTest; |
| + |
| +// Test that a new capture properly "steals" capture from an existing one. |
| +TEST_F(CocoaMouseCaptureTest, OnCaptureLost) { |
| + TestCaptureDelegate capture; |
| + |
| + capture.Acquire(); |
| + EXPECT_TRUE(capture.IsActive()); |
| + { |
| + TestCaptureDelegate capture2; |
| + EXPECT_EQ(0, capture.capture_lost_count()); |
| + |
| + // A second capture steals from the first. |
| + capture2.Acquire(); |
| + EXPECT_TRUE(capture2.IsActive()); |
| + EXPECT_FALSE(capture.IsActive()); |
| + EXPECT_EQ(1, capture.capture_lost_count()); |
| + EXPECT_EQ(0, capture2.capture_lost_count()); |
| + |
| + // Simulate capture2 going out of scope. Inspect it. |
| + capture2.SimulateDestroy(); |
| + EXPECT_FALSE(capture2.IsActive()); |
| + EXPECT_EQ(1, capture2.capture_lost_count()); |
| + } |
| + |
| + // Re-acquiring is fine (not stealing). |
| + EXPECT_FALSE(capture.IsActive()); |
| + capture.Acquire(); |
| + EXPECT_TRUE(capture.IsActive()); |
| + |
| + // Having no CocoaMouseCapture instance is fine. |
| + capture.SimulateDestroy(); |
| + EXPECT_FALSE(capture.IsActive()); |
| + // Receives OnMouseCaptureLost again, since reacquired. |
| + EXPECT_EQ(2, capture.capture_lost_count()); |
| +} |
| + |
| +// Test event capture. |
| +TEST_F(CocoaMouseCaptureTest, CaptureEvents) { |
| + base::scoped_nsobject<CocoaMouseCaptureTestView> view( |
| + [[CocoaMouseCaptureTestView alloc] initWithFrame:NSZeroRect]); |
| + [test_window() setContentView:view]; |
| + std::pair<NSEvent*, NSEvent*> click = |
| + cocoa_test_event_utils::MouseClickInView(view, 1); |
| + |
| + // First check that the view receives events normally. |
| + EXPECT_EQ(0, [view mouseDownCount]); |
| + [NSApp sendEvent:click.first]; |
| + EXPECT_EQ(1, [view mouseDownCount]); |
| + |
| + { |
| + TestCaptureDelegate capture; |
| + capture.Acquire(); |
| + |
| + // Now check that the capture captures events. |
| + EXPECT_EQ(0, capture.event_count()); |
| + [NSApp sendEvent:click.first]; |
| + EXPECT_EQ(1, [view mouseDownCount]); |
| + EXPECT_EQ(1, capture.event_count()); |
| + } |
| + |
| + // After the capture goes away, events should be received again. |
| + [NSApp sendEvent:click.first]; |
| + EXPECT_EQ(2, [view mouseDownCount]); |
| +} |
| + |
| +} // namespace views |