Skip to content

Commit

Permalink
Test Progressive Enhancement of Server Actions
Browse files Browse the repository at this point in the history
  • Loading branch information
sebmarkbage committed Jul 1, 2023
1 parent 5ff4817 commit b8ec504
Show file tree
Hide file tree
Showing 4 changed files with 76 additions and 0 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@
/* eslint-disable jest/no-standalone-expect */
import { createNextDescribe } from 'e2e-utils'
import { check } from 'next-test-utils'

createNextDescribe(
'app-dir action progressive enhancement',
{
files: __dirname,
dependencies: {
react: 'latest',
nanoid: 'latest',
'react-dom': 'latest',
'server-only': 'latest',
},
},
({ next, isNextDev, isNextStart, isNextDeploy }) => {
it('should support formData and redirect without JS', async () => {
const browser = await next.browser('/server', {
disableJavaScript: true,
})

await browser.eval(`document.getElementById('name').value = 'test'`)
await browser.elementByCss('#submit').click()

await check(() => {
return browser.eval('window.location.pathname + window.location.search')
}, '/header?name=test&constructor=FormData&hidden-info=hi')
})

it('should support actions from client without JS', async () => {
const browser = await next.browser('/server', {
disableJavaScript: true,
})

await browser.eval(
`document.getElementById('client-name').value = 'test'`
)
await browser.elementByCss('#there').click()

await check(() => {
return browser.eval('window.location.pathname + window.location.search')
}, '/header?name=test&constructor=FormData&hidden-info=hi')
})
}
)
14 changes: 14 additions & 0 deletions test/e2e/app-dir/actions/app/server/actions.js
Original file line number Diff line number Diff line change
@@ -1,9 +1,23 @@
'use server'

import { redirect } from 'next/navigation'

export async function inc(value) {
return value + 1
}

export default async function dec(value) {
return value - 1
}

export async function redirectAction(formData) {
'use server'
redirect(
'/header?name=' +
formData.get('name') +
'&constructor=' +
formData.constructor.name +
'&hidden-info=' +
formData.get('hidden-info')
)
}
15 changes: 15 additions & 0 deletions test/e2e/app-dir/actions/app/server/client-form.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
'use client'

import { redirectAction } from './actions'

export default function Form() {
return (
<form>
<input type="text" name="hidden-info" value="hi" hidden />
<input type="text" name="name" id="client-name" required />
<button formAction={redirectAction} type="submit" id="there">
Go there
</button>
</form>
)
}
2 changes: 2 additions & 0 deletions test/e2e/app-dir/actions/app/server/page.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
import Counter from './counter'
import Form from './form'
import ClientForm from './client-form'

import dec, { inc } from './actions'
import { log } from './actions-2'
Expand All @@ -17,6 +18,7 @@ export default function Page() {
}}
/>
<Form />
<ClientForm />
<form>
<button id="log" formAction={log}>
log
Expand Down

0 comments on commit b8ec504

Please sign in to comment.