| <!DOCTYPE html> |
| <style> |
| body { |
| height: 2000px; |
| width: 2000px; |
| } |
| </style> |
| |
| <div id='console'></div> |
| <script src="../../resources/js-test.js"></script> |
| <script> |
| window.jsTestIsAsync = true; |
| description('This test verifies that navigating to entries created by ' + |
| 'pushState or replaceState correctly restores scroll position ' + |
| 'correctly and respects "scrollRestoration" flag.'); |
| |
| var tests = { |
| '#1': {type: 'push', expectedScroll: [50, 100]}, |
| '#2': {type: 'replace', expectedScroll: [100, 200]}, |
| '#3': {type: 'push', expectedScroll: [150, 300], options: {scrollRestoration: 'auto'}}, |
| '#4': {type: 'replace', expectedScroll: [200, 400], options: {scrollRestoration: 'auto'}}, |
| /* Scroll position should not be restored for these two. */ |
| '#5': {type: 'push', expectedScroll: [0, 0], options: {scrollRestoration: 'manual'}}, |
| '#6': {type: 'replace', expectedScroll: [0, 0], options: {scrollRestoration: 'manual'}} |
| }; |
| |
| // Navigation steps: |
| // 1. Create a history entry using pushState then scroll |
| // 2. Create a history entry and replace it then scroll |
| // 3-6. Repeat 1 & 2 with different option values |
| // 7. Navigate away and come back |
| // 8-13. Verify 6 to 1 and keep navigating back |
| function handleNavigation() { |
| if (window.name !== 'verification phase') { |
| for (var key in tests) { |
| var test = tests[key]; |
| var args = [{key: key}, '', key]; |
| |
| if (test.type == 'push') { |
| history.pushState.apply(history, args); |
| } else { |
| history.pushState(null, '', key); |
| history.replaceState.apply(history, args); |
| } |
| |
| if ('options' in test) |
| history.scrollRestoration = test.options.scrollRestoration; |
| |
| window.scrollBy(50, 100); |
| } |
| |
| setTimeout(function() { |
| window.name = 'verification phase'; |
| window.location.href = 'resources/empty-document-goes-back.html'; |
| }, 0); |
| } else { |
| var key = location.hash, |
| test = tests[key]; |
| |
| debug('verifying ' + key); |
| shouldBeEqualToString('history.state.key', '' + key); |
| shouldBe('document.scrollingElement.scrollLeft', test.expectedScroll[0].toString()); |
| shouldBe('document.scrollingElement.scrollTop', test.expectedScroll[1].toString()); |
| |
| if (key !== '#1') { |
| window.history.back(); |
| } else { |
| window.name = ''; |
| finishJSTest(); |
| } |
| } |
| } |
| |
| window.addEventListener('pageshow', handleNavigation); |
| window.addEventListener('hashchange', handleNavigation); |
| </script> |