<html>
<head>
<base href="https://bugs.webkit.org/" />
</head>
<body><table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Bug ID</th>
<td><a class="bz_bug_link
bz_status_NEW "
title="NEW - pushState and navigation sequence causes document to be requested when it shouldn't"
href="https://bugs.webkit.org/show_bug.cgi?id=145953">145953</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>pushState and navigation sequence causes document to be requested when it shouldn't
</td>
</tr>
<tr>
<th>Classification</th>
<td>Unclassified
</td>
</tr>
<tr>
<th>Product</th>
<td>WebKit
</td>
</tr>
<tr>
<th>Version</th>
<td>528+ (Nightly build)
</td>
</tr>
<tr>
<th>Hardware</th>
<td>Unspecified
</td>
</tr>
<tr>
<th>OS</th>
<td>Unspecified
</td>
</tr>
<tr>
<th>Status</th>
<td>NEW
</td>
</tr>
<tr>
<th>Severity</th>
<td>Normal
</td>
</tr>
<tr>
<th>Priority</th>
<td>P2
</td>
</tr>
<tr>
<th>Component</th>
<td>History
</td>
</tr>
<tr>
<th>Assignee</th>
<td>webkit-unassigned@lists.webkit.org
</td>
</tr>
<tr>
<th>Reporter</th>
<td>irae@irae.pro.br
</td>
</tr></table>
<p>
<div>
<pre>When using `window.history.pushState` on Mobile Safari, iOS 7, iOS 8 or iOS 9, and doing the following sequence, webkit is starting a request to the server and rebuilding the document when it shouldn't.
Steps to reproduce (just for the record, but contained in the example below):
1. Go to page A, that implements history.pushState and history.replaceState.
2. Page A uses replaceState to store current page, creating PageA-state1
3. Navigate internally using a link, that uses pushState, does Ajax request then uses replaceState to create PageA-state2
4. Navigate to a different document. After a while, or after "minimizing Safari", press back
Expected: PageA context should be restored, pop state event to fire, and restore to PageA-state2
What's happening: URL that was pushed during step 3 is requested and PageC is constructed from scratch.
I talked to Brady Eidson on WWDC 2015 Lab Sessions and we were able to reproduce. He created a minimal version but the exact conditions were not super precise.
I am submitting additional details here, and I uploaded an example case here:
<a href="https://github.com/irae/pushstate-bugs">https://github.com/irae/pushstate-bugs</a>
During the Safari Labs at WWDC Brady suspected it was a process communication issue, but I believe it's something related to serialization to disk of the history states.
If I load the example on testing devices (which don't have anything special, not even apps installed), the but is not possible to reproduce right away. On the other hand, if you put Safari to background and come back, it triggers the error 100% of the times.
Another way of reproducing the error is to hold your finger on the back button and selecting the entry from the list.
For good measure I tested also Firefox, Chrome and Safari desktop. Chrome has a similar bug, which I will be submitting, but Safari on desktop and Firefox never hit the server for the URL that is not expected to be requested.</pre>
</div>
</p>
<hr>
<span>You are receiving this mail because:</span>
<ul>
<li>You are the assignee for the bug.</li>
</ul>
</body>
</html>