Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix: disable edge runtime by default to enable windows development #1281

Merged
merged 5 commits into from
Jan 12, 2025

Conversation

nickreynolds
Copy link
Contributor

@@ -3,7 +3,7 @@ import { NextRequest, NextResponse } from "next/server";

import { handlers, isSecureContext } from "@acme/auth";

export const runtime = "edge";
export const runtime = process.platform === "win32" ? "nodejs" : "edge";
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Pretty sure This doesn't work as this string need to be statically analyzavlr?

We can just remove it though if it's causing issues?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

it appears to work for me locally (i.e. I'm able to develop on Windows with this change) and my vercel deployments seem fine as well (although I'm not sure if they're using the correct runtime now).

As far as I can tell there are 3 options:

  1. update runtime export as done in this PR
  2. remove runtime export from all pages
  3. leave all code as-is and just add note for Windows developers

I defer to you on the best approach moving forward though, and happy to update this PR at your discretion.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

it appears to work for me locally (i.e. I'm able to develop on Windows with this change) and my vercel deployments seem fine as well (although I'm not sure if they're using the correct runtime now).

if this is the case, it means you're using different runtime in prod vs dev which sounds scary. I prefer no. 2

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Good point. If you think that having windows-compatibility-by-default is more important than edge-runtime-by-default, I can do no. 2. Otherwise, I'd do no. 3. Do you want me to proceed with option 2?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I tried using this before and it wouldn't deploy on vercel. This is only an issue on webpack through, if you are using turbopack this dissapears.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

yes, I was incorrect about my original solution working, my IDE just wasn't reporting the error, and the line was being ignored entirely (which meant it was functionally equivalent to deleting the line, at least for local dev, but obviously not the right solution)

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Do you want me to proceed with option 2?

Yes

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@juliusmarminge I made the changes to this PR that we discussed. Do you think we need to update the drizzle.config.ts as well? I'm not particularly familiar with this, but should we switch to a pooled DB URL now that we aren't using edge runtime?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

you don't want a pooled url when running migrations/schema changes

@nickreynolds nickreynolds changed the title fix: use nodejs runtime instead of edge if running on Windows fix: disable edge runtime by default to enable windows development Jan 7, 2025
@juliusmarminge juliusmarminge merged commit d6c3953 into t3-oss:main Jan 12, 2025
3 of 5 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

bug: Internal Server Error when running nextjs app locally on Windows
3 participants