|
43 | 43 | import com.vaadin.flow.component.page.Page;
|
44 | 44 | import com.vaadin.flow.component.page.PendingJavaScriptResult;
|
45 | 45 | import com.vaadin.flow.dom.Element;
|
| 46 | +import com.vaadin.flow.router.AfterNavigationEvent; |
| 47 | +import com.vaadin.flow.router.AfterNavigationObserver; |
| 48 | +import com.vaadin.flow.router.BeforeEnterEvent; |
| 49 | +import com.vaadin.flow.router.BeforeEnterObserver; |
| 50 | +import com.vaadin.flow.router.BeforeLeaveEvent; |
46 | 51 | import com.vaadin.flow.router.Location;
|
47 | 52 | import com.vaadin.flow.router.NavigationEvent;
|
48 | 53 | import com.vaadin.flow.router.NavigationState;
|
@@ -82,6 +87,29 @@ private static class PreservedView extends Text {
|
82 | 87 | }
|
83 | 88 | }
|
84 | 89 |
|
| 90 | + @Route(value = "preserved") |
| 91 | + @PreserveOnRefresh |
| 92 | + private static class PreservedEventView extends Text |
| 93 | + implements BeforeEnterObserver, AfterNavigationObserver { |
| 94 | + static boolean refreshBeforeEnter; |
| 95 | + static boolean refreshAfterNavigation; |
| 96 | + |
| 97 | + PreservedEventView() { |
| 98 | + super(""); |
| 99 | + } |
| 100 | + |
| 101 | + @Override |
| 102 | + public void beforeEnter(BeforeEnterEvent event) { |
| 103 | + refreshBeforeEnter = event.isRefreshEvent(); |
| 104 | + } |
| 105 | + |
| 106 | + @Override |
| 107 | + public void afterNavigation(AfterNavigationEvent event) { |
| 108 | + refreshAfterNavigation = event.isRefreshEvent(); |
| 109 | + |
| 110 | + } |
| 111 | + } |
| 112 | + |
85 | 113 | @Route(value = "regular")
|
86 | 114 | private static class RegularView extends Text {
|
87 | 115 | RegularView() {
|
@@ -324,6 +352,59 @@ public void handle_preserveOnRefreshAndWindowNameKnown_componentIsCachedRetrieve
|
324 | 352 | session, new Location("preserved")));
|
325 | 353 | }
|
326 | 354 |
|
| 355 | + @Test |
| 356 | + public void handle_preserveOnRefresh_refreshIsFlaggedInEvent() { |
| 357 | + // given a service with instantiator |
| 358 | + MockVaadinServletService service = createMockServiceWithInstantiator(); |
| 359 | + |
| 360 | + // given a locked session |
| 361 | + MockVaadinSession session = new AlwaysLockedVaadinSession(service); |
| 362 | + session.setConfiguration(new MockDeploymentConfiguration()); |
| 363 | + |
| 364 | + // given a UI that contain a window name ROOT.123 |
| 365 | + MockUI ui = new MockUI(session); |
| 366 | + ExtendedClientDetails details = Mockito |
| 367 | + .mock(ExtendedClientDetails.class); |
| 368 | + Mockito.when(details.getWindowName()).thenReturn("ROOT.123"); |
| 369 | + ui.getInternals().setExtendedClientDetails(details); |
| 370 | + |
| 371 | + // given a NavigationStateRenderer mapping to PreservedEventView |
| 372 | + NavigationStateRenderer renderer = new NavigationStateRenderer( |
| 373 | + navigationStateFromTarget(PreservedEventView.class)); |
| 374 | + |
| 375 | + // when a navigation event reaches the renderer |
| 376 | + renderer.handle(new NavigationEvent(new Router(new TestRouteRegistry()), |
| 377 | + new Location("preserved"), ui, NavigationTrigger.PAGE_LOAD)); |
| 378 | + |
| 379 | + // then the session has a cached record of the view |
| 380 | + Assert.assertTrue("Session expected to have cached view", |
| 381 | + AbstractNavigationStateRenderer.getPreservedChain(session, |
| 382 | + "ROOT.123", new Location("preserved")).isPresent()); |
| 383 | + |
| 384 | + // given the recently instantiated view |
| 385 | + final PreservedEventView view = (PreservedEventView) ui.getInternals() |
| 386 | + .getActiveRouterTargetsChain().get(0); |
| 387 | + Assert.assertFalse( |
| 388 | + "Initial view load should not be a refresh for before", |
| 389 | + view.refreshBeforeEnter); |
| 390 | + Assert.assertFalse( |
| 391 | + "Initial view load should not be a refresh for after", |
| 392 | + view.refreshAfterNavigation); |
| 393 | + |
| 394 | + // when another navigation targets the same location |
| 395 | + renderer.handle(new NavigationEvent(new Router(new TestRouteRegistry()), |
| 396 | + new Location("preserved"), ui, NavigationTrigger.PAGE_LOAD)); |
| 397 | + |
| 398 | + // then the same view is routed to |
| 399 | + Assert.assertEquals("Expected same view", view, |
| 400 | + ui.getInternals().getActiveRouterTargetsChain().get(0)); |
| 401 | + |
| 402 | + Assert.assertTrue("Reload should be flagged for before", |
| 403 | + view.refreshBeforeEnter); |
| 404 | + Assert.assertTrue("Reload should be flagged for after", |
| 405 | + view.refreshAfterNavigation); |
| 406 | + } |
| 407 | + |
327 | 408 | @Test
|
328 | 409 | public void handle_preserveOnRefresh_otherUIChildrenAreMoved() {
|
329 | 410 | // given a service with instantiator
|
|
0 commit comments