Skip to content

Commit

Permalink
test(form-test.ts): add int test to ensure forms have correct action …
Browse files Browse the repository at this point in the history
…when app defines custom routes
  • Loading branch information
penspinner committed May 9, 2022
1 parent 73a1baa commit ad1aa99
Showing 1 changed file with 61 additions and 0 deletions.
61 changes: 61 additions & 0 deletions integration/form-test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -576,3 +576,64 @@ test.describe("Forms", () => {
});
});
});

test.describe("Forms in an app with custom defineRoutes", () => {
let fixture: Fixture;
let appFixture: AppFixture;

test.beforeAll(async () => {
fixture = await createFixture({
files: {
"remix.config.js": `
module.exports = {
ignoredRouteFiles: ["**/.*"],
routes(defineRoutes) {
return defineRoutes((defineRoute) => {
defineRoute("form-custom-route", "routes/form-custom-route/_route.jsx", () => {
defineRoute("", "routes/form-custom-route.index/_route.jsx", { index: true });
});
});
},
};
`,
"app/routes/form-custom-route/_route.jsx": `
import { Form, Outlet } from "@remix-run/react"
export default function FormCustomRoute() {
return (
<>
<Form id="form" />
<Outlet />
</>
)
}
`,
"app/routes/form-custom-route.index/_route.jsx": `
import { Form } from "@remix-run/react"
export default function FormCustomRouteIndex() {
return (
<Form id="form-index" />
)
}
`,
},
});
appFixture = await createAppFixture(fixture);
});

test.afterAll(async () => {
await appFixture.close();
});

test("Form has correct action in a layout route and an index route", async ({
page,
}) => {
let app = new PlaywrightFixture(appFixture, page);
await app.goto("/form-custom-route");
expect((await app.getElement("#form")).attr("action")).toBe(
"/form-custom-route"
);
expect((await app.getElement("#form-index")).attr("action")).toBe(
"/form-custom-route?index"
);
});
});

0 comments on commit ad1aa99

Please sign in to comment.