OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "content/browser/web_contents/aura/overscroll_navigation_overlay.h" | 5 #include "content/browser/web_contents/aura/overscroll_navigation_overlay.h" |
6 | 6 |
7 #include "content/browser/frame_host/navigation_entry_impl.h" | 7 #include "content/browser/frame_host/navigation_entry_impl.h" |
8 #include "content/browser/web_contents/aura/image_window_delegate.h" | 8 #include "content/browser/web_contents/aura/image_window_delegate.h" |
9 #include "content/browser/web_contents/web_contents_view.h" | 9 #include "content/browser/web_contents/web_contents_view.h" |
10 #include "content/common/view_messages.h" | 10 #include "content/common/view_messages.h" |
(...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
49 RenderViewHostTester::TestOnMessageReceived(test_rvh(), msg); | 49 RenderViewHostTester::TestOnMessageReceived(test_rvh(), msg); |
50 } | 50 } |
51 | 51 |
52 void PerformBackNavigationViaSliderCallbacks() { | 52 void PerformBackNavigationViaSliderCallbacks() { |
53 // Sets slide direction to SLIDE_BACK, sets screenshot from NavEntry at | 53 // Sets slide direction to SLIDE_BACK, sets screenshot from NavEntry at |
54 // offset -1 on layer_delegate_. | 54 // offset -1 on layer_delegate_. |
55 delete GetOverlay()->CreateBackLayer(); | 55 delete GetOverlay()->CreateBackLayer(); |
56 // Performs BACK navigation, sets image from layer_delegate_ on | 56 // Performs BACK navigation, sets image from layer_delegate_ on |
57 // image_delegate_. | 57 // image_delegate_. |
58 GetOverlay()->OnWindowSlideCompleting(); | 58 GetOverlay()->OnWindowSlideCompleting(); |
59 GetOverlay()->OnWindowSlideCompleted(); | 59 GetOverlay()->OnWindowSlideCompleted(scoped_ptr<ui::Layer>()); |
60 } | 60 } |
61 | 61 |
62 protected: | 62 protected: |
63 // RenderViewHostImplTestHarness: | 63 // RenderViewHostImplTestHarness: |
64 virtual void SetUp() OVERRIDE { | 64 virtual void SetUp() OVERRIDE { |
65 RenderViewHostImplTestHarness::SetUp(); | 65 RenderViewHostImplTestHarness::SetUp(); |
66 | 66 |
67 const GURL first("https://www.google.com"); | 67 const GURL first("https://www.google.com"); |
68 contents()->NavigateAndCommit(first); | 68 contents()->NavigateAndCommit(first); |
69 EXPECT_TRUE(controller().GetVisibleEntry()); | 69 EXPECT_TRUE(controller().GetVisibleEntry()); |
(...skipping 49 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
119 private: | 119 private: |
120 scoped_ptr<OverscrollNavigationOverlay> overlay_; | 120 scoped_ptr<OverscrollNavigationOverlay> overlay_; |
121 | 121 |
122 DISALLOW_COPY_AND_ASSIGN(OverscrollNavigationOverlayTest); | 122 DISALLOW_COPY_AND_ASSIGN(OverscrollNavigationOverlayTest); |
123 }; | 123 }; |
124 | 124 |
125 TEST_F(OverscrollNavigationOverlayTest, FirstVisuallyNonEmptyPaint_NoImage) { | 125 TEST_F(OverscrollNavigationOverlayTest, FirstVisuallyNonEmptyPaint_NoImage) { |
126 ReceivePaintUpdate(); | 126 ReceivePaintUpdate(); |
127 EXPECT_TRUE(GetOverlay()->received_paint_update_); | 127 EXPECT_TRUE(GetOverlay()->received_paint_update_); |
128 EXPECT_FALSE(GetOverlay()->loading_complete_); | 128 EXPECT_FALSE(GetOverlay()->loading_complete_); |
129 | |
130 EXPECT_TRUE(GetOverlay()->received_paint_update_); | |
131 EXPECT_FALSE(GetOverlay()->loading_complete_); | |
132 // The paint update will hide the overlay. | 129 // The paint update will hide the overlay. |
133 EXPECT_FALSE(GetOverlay()->web_contents()); | 130 EXPECT_FALSE(GetOverlay()->web_contents()); |
134 } | 131 } |
135 | 132 |
136 TEST_F(OverscrollNavigationOverlayTest, FirstVisuallyNonEmptyPaint_WithImage) { | 133 TEST_F(OverscrollNavigationOverlayTest, FirstVisuallyNonEmptyPaint_WithImage) { |
137 GetOverlay()->image_delegate_->SetImage(CreateDummyScreenshot()); | 134 GetOverlay()->image_delegate_->SetImage(CreateDummyScreenshot()); |
138 | 135 |
139 ReceivePaintUpdate(); | 136 ReceivePaintUpdate(); |
140 EXPECT_TRUE(GetOverlay()->received_paint_update_); | 137 EXPECT_TRUE(GetOverlay()->received_paint_update_); |
141 EXPECT_FALSE(GetOverlay()->loading_complete_); | 138 EXPECT_FALSE(GetOverlay()->loading_complete_); |
142 // The paint update will hide the overlay. | 139 // The paint update will hide the overlay. |
143 EXPECT_FALSE(GetOverlay()->web_contents()); | 140 EXPECT_FALSE(GetOverlay()->web_contents()); |
144 } | 141 } |
145 | 142 |
146 TEST_F(OverscrollNavigationOverlayTest, PaintUpdateWithoutNonEmptyPaint) { | 143 TEST_F(OverscrollNavigationOverlayTest, LoadUpdateWithoutNonEmptyPaint) { |
147 GetOverlay()->image_delegate_->SetImage(CreateDummyScreenshot()); | 144 GetOverlay()->image_delegate_->SetImage(CreateDummyScreenshot()); |
148 process()->sink().ClearMessages(); | 145 process()->sink().ClearMessages(); |
149 | 146 |
150 // The page load is complete, but the overlay should still be visible, because | |
151 // there hasn't been any paint update. | |
152 // This should also send a repaint request to the renderer, so that the | |
153 // renderer repaints the contents. | |
154 contents()->TestSetIsLoading(false); | 147 contents()->TestSetIsLoading(false); |
| 148 EXPECT_TRUE(GetOverlay()->loading_complete_); |
155 EXPECT_FALSE(GetOverlay()->received_paint_update_); | 149 EXPECT_FALSE(GetOverlay()->received_paint_update_); |
156 EXPECT_TRUE(GetOverlay()->loading_complete_); | 150 // The page load should hide the overlay. |
157 EXPECT_TRUE(GetOverlay()->web_contents()); | |
158 EXPECT_TRUE(process()->sink().GetFirstMessageMatching(ViewMsg_Repaint::ID)); | |
159 | |
160 // Receive a repaint ack update. This should hide the overlay. | |
161 ViewHostMsg_UpdateRect_Params params; | |
162 memset(¶ms, 0, sizeof(params)); | |
163 params.view_size = gfx::Size(10, 10); | |
164 params.flags = ViewHostMsg_UpdateRect_Flags::IS_REPAINT_ACK; | |
165 ViewHostMsg_UpdateRect rect(test_rvh()->GetRoutingID(), params); | |
166 RenderViewHostTester::TestOnMessageReceived(test_rvh(), rect); | |
167 EXPECT_TRUE(GetOverlay()->received_paint_update_); | |
168 EXPECT_FALSE(GetOverlay()->web_contents()); | 151 EXPECT_FALSE(GetOverlay()->web_contents()); |
169 } | 152 } |
170 | 153 |
171 TEST_F(OverscrollNavigationOverlayTest, MultiNavigation_PaintUpdate) { | 154 TEST_F(OverscrollNavigationOverlayTest, MultiNavigation_PaintUpdate) { |
172 GetOverlay()->image_delegate_->SetImage(CreateDummyScreenshot()); | 155 GetOverlay()->image_delegate_->SetImage(CreateDummyScreenshot()); |
173 SetDummyScreenshotOnNavEntry(controller().GetEntryAtOffset(-1)); | 156 SetDummyScreenshotOnNavEntry(controller().GetEntryAtOffset(-1)); |
174 | 157 |
175 PerformBackNavigationViaSliderCallbacks(); | 158 PerformBackNavigationViaSliderCallbacks(); |
176 // Screenshot was set on NavEntry at offset -1. | 159 // Screenshot was set on NavEntry at offset -1. |
177 EXPECT_TRUE(GetOverlay()->image_delegate_->has_image()); | 160 EXPECT_TRUE(GetOverlay()->image_delegate_->has_image()); |
178 EXPECT_FALSE(GetOverlay()->received_paint_update_); | 161 EXPECT_FALSE(GetOverlay()->received_paint_update_); |
179 | 162 |
180 ReceivePaintUpdate(); | 163 ReceivePaintUpdate(); |
181 // Paint updates until the navigation is committed represent updates | 164 // Paint updates until the navigation is committed represent updates |
182 // for the previous page, so they shouldn't affect the flag. | 165 // for the previous page, so they shouldn't affect the flag. |
183 EXPECT_FALSE(GetOverlay()->received_paint_update_); | 166 EXPECT_FALSE(GetOverlay()->received_paint_update_); |
184 | 167 |
185 contents()->CommitPendingNavigation(); | 168 contents()->CommitPendingNavigation(); |
186 ReceivePaintUpdate(); | 169 ReceivePaintUpdate(); |
187 // Navigation was committed and the paint update was received - the flag | 170 // Navigation was committed and the paint update was received - the flag |
188 // should now be updated. | 171 // should now be updated. |
189 EXPECT_TRUE(GetOverlay()->received_paint_update_); | 172 EXPECT_TRUE(GetOverlay()->received_paint_update_); |
190 | 173 |
191 EXPECT_FALSE(GetOverlay()->web_contents()); | 174 EXPECT_FALSE(GetOverlay()->web_contents()); |
192 } | 175 } |
193 | 176 |
194 TEST_F(OverscrollNavigationOverlayTest, MultiNavigation_LoadingUpdate) { | 177 TEST_F(OverscrollNavigationOverlayTest, MultiNavigation_LoadingUpdate) { |
195 GetOverlay()->image_delegate_->SetImage(CreateDummyScreenshot()); | 178 GetOverlay()->image_delegate_->SetImage(CreateDummyScreenshot()); |
196 | 179 |
197 contents()->TestSetIsLoading(false); | |
198 EXPECT_TRUE(GetOverlay()->loading_complete_); | |
199 | |
200 PerformBackNavigationViaSliderCallbacks(); | 180 PerformBackNavigationViaSliderCallbacks(); |
201 // No screenshot was set on NavEntry at offset -1. | 181 // No screenshot was set on NavEntry at offset -1. |
202 EXPECT_FALSE(GetOverlay()->image_delegate_->has_image()); | 182 EXPECT_FALSE(GetOverlay()->image_delegate_->has_image()); |
203 // Navigation was started, so the loading status flag should be reset. | 183 // Navigation was started, so the loading status flag should be reset. |
204 EXPECT_FALSE(GetOverlay()->loading_complete_); | 184 EXPECT_FALSE(GetOverlay()->loading_complete_); |
205 | 185 |
206 // Load updates until the navigation is committed represent updates for the | 186 // Load updates until the navigation is committed represent updates for the |
207 // previous page, so they shouldn't affect the flag. | 187 // previous page, so they shouldn't affect the flag. |
208 contents()->TestSetIsLoading(true); | 188 contents()->TestSetIsLoading(true); |
209 contents()->TestSetIsLoading(false); | 189 contents()->TestSetIsLoading(false); |
210 EXPECT_FALSE(GetOverlay()->loading_complete_); | 190 EXPECT_FALSE(GetOverlay()->loading_complete_); |
211 | 191 |
212 contents()->CommitPendingNavigation(); | 192 contents()->CommitPendingNavigation(); |
213 contents()->TestSetIsLoading(true); | 193 contents()->TestSetIsLoading(true); |
214 contents()->TestSetIsLoading(false); | 194 contents()->TestSetIsLoading(false); |
215 // Navigation was committed and the load update was received - the flag | 195 // Navigation was committed and the load update was received - the flag |
216 // should now be updated. | 196 // should now be updated. |
217 EXPECT_TRUE(GetOverlay()->loading_complete_); | 197 EXPECT_TRUE(GetOverlay()->loading_complete_); |
218 | 198 |
219 EXPECT_TRUE(GetOverlay()->web_contents()); | |
220 ReceivePaintUpdate(); | |
221 EXPECT_FALSE(GetOverlay()->web_contents()); | 199 EXPECT_FALSE(GetOverlay()->web_contents()); |
222 } | 200 } |
223 | 201 |
224 } // namespace content | 202 } // namespace content |
OLD | NEW |