Skip to content

Commit

Permalink
Merge pull request #162 from seanpdoyle/turbo-preview
Browse files Browse the repository at this point in the history
Add test coverage for toggling data-turbo-preview
  • Loading branch information
sstephenson authored Apr 9, 2021
2 parents 2f9a281 + 631649b commit 3b418fe
Show file tree
Hide file tree
Showing 5 changed files with 33 additions and 1 deletion.
2 changes: 1 addition & 1 deletion src/tests/fixtures/navigation.html
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
<!DOCTYPE html>
<html>
<html id="document">
<head>
<meta charset="utf-8">
<title>Turbo</title>
Expand Down
2 changes: 2 additions & 0 deletions src/tests/fixtures/one.html
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,8 @@
<body>
<h1>One</h1>

<a id="navigation-link" href="/src/tests/fixtures/navigation.html">Back to Navigation</a>

<!--styles ensure that the element will be scrolled to top when navigated to via an anchored link -->
<a name="named-anchor"></a>
<div id="element-id" style="margin-top: 1em; height: 200vh">An element with an ID</div>
Expand Down
8 changes: 8 additions & 0 deletions src/tests/fixtures/test.js
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,15 @@
function eventListener(event) {
eventLogs.push([event.type, event.detail])
}
window.mutationLogs = []

new MutationObserver((mutations) => {
for (const { attributeName, oldValue, target } of mutations.filter(({ type }) => type == "attributes")) {
if (target instanceof Element) {
mutationLogs.push([attributeName, target.id, target.getAttribute(attributeName)])
}
}
}).observe(document, { subtree: true, childList: true, attributes: true })
})([
"turbo:before-cache",
"turbo:before-render",
Expand Down
11 changes: 11 additions & 0 deletions src/tests/functional/navigation_tests.ts
Original file line number Diff line number Diff line change
Expand Up @@ -121,6 +121,17 @@ export class NavigationTests extends TurboDriveTestCase {
this.assert.equal(await this.visitAction, "load")
}

async "test following a link to a page that has been visited renders a preview the Snapshot cache"() {
await this.clickSelector("#same-origin-unannotated-link")
await this.nextBody
this.assert.notOk(await this.hasSelector("html[data-turbo-preview]"), "does not set data-turbo-preview on a visit")

await this.clickSelector("#navigation-link")
await this.nextBody
this.assert.equal(await this.nextAttributeMutationNamed("document", "data-turbo-preview"), "", "sets [data-turbo-preview] on the <html> element")
this.assert.equal(await this.nextAttributeMutationNamed("document", "data-turbo-preview"), null, "removes [data-turbo-preview] from the <html> element")
}

async "test clicking the back button"() {
this.clickSelector("#same-origin-unannotated-link")
await this.nextBody
Expand Down
11 changes: 11 additions & 0 deletions src/tests/helpers/turbo_drive_test_case.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,9 +3,11 @@ import { RemoteChannel } from "./remote_channel"
import { Element } from "@theintern/leadfoot"

type EventLog = [string, any]
type MutationLog = [string, string, string | null]

export class TurboDriveTestCase extends FunctionalTestCase {
eventLogChannel: RemoteChannel<EventLog> = new RemoteChannel(this.remote, "eventLogs")
mutationLogChannel: RemoteChannel<MutationLog> = new RemoteChannel(this.remote, "mutationLogs")
lastBody?: Element

async beforeTest() {
Expand Down Expand Up @@ -33,6 +35,15 @@ export class TurboDriveTestCase extends FunctionalTestCase {
return record[1]
}

async nextAttributeMutationNamed(elementId: string, attributeName: string): Promise<string | null> {
let record: MutationLog | undefined
while (!record) {
const records = await this.mutationLogChannel.read(1)
record = records.find(([name, id]) => id == elementId && name == attributeName)
}
return record[2]
}

get nextBody(): Promise<Element> {
return (async () => {
let body
Expand Down

0 comments on commit 3b418fe

Please sign in to comment.