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

chore: allow Vite 5 #817

Closed
wants to merge 12 commits into from
Closed

chore: allow Vite 5 #817

wants to merge 12 commits into from

Conversation

benmccann
Copy link
Member

@benmccann benmccann commented Nov 28, 2023

sveltejs/kit#10818 is very complicated and a breaking change. This would be a much simpler solution. We can bump the dependency version in a couple of months to move everyone to vite-plugin-svelte 3 when we release SvelteKit 2

We don't have to fix any bugs in v2. We can still fix them just in v3 and tell non-SvelteKit users to upgrade to v3 and tell SvelteKit users they'll get any fixes in a couple of months. If there are any major issues that arise that need to be backported I can send PRs for it, I'm not too worried about that as vite-plugin-svelte has been very stable and battle tested already.

@dominikg
Copy link
Member

not a fan of this. if you volunteer to maintain v2 and add vite5 to the test matrix it can work, but kit needs more changes to be compatible ( the manifest changes for example )

@dominikg
Copy link
Member

also vite5 uses newer majors for esbuild and rollup, adapters and svelte-package could be affected too

@benmccann
Copy link
Member Author

Sure, I'm happy to maintain v2

I'm trying to figure out I'd add Vite 5 to the test matrix. I think it'd have to be in a separate PR targeting the main branch? Because I see in main a reference to the v2 branch:

So I'm assuming GitHub only runs the file located in main and the version in the v2 branch doesn't do anything. But perhaps we could wait until future changes are needed on the v2 branch? We already know that no changes were needed to vite-plugin-svelte for Vite 5 support when we updated main to Vite 5.

I'm not sure what needs to change in Kit regarding the manifest, but those changes would need to happen regardless. I'll bump esbuild and rollup in the adapters, etc. so that folks who are current only need a single version of them pulled into their project

@dominikg
Copy link
Member

no, i think it has to be in this branch (the merge target). on main, there is a preparation to add svelte5 to the test matrix, you can use that as a template how to add vite 5 in this PR

@bluwy
Copy link
Member

bluwy commented Nov 29, 2023

I'm wondering another trick: Could we have v-p-s both as a dep and an optional peer dep in SvelteKit? That way if the user wants to use Vite 5, they can install v-p-s v3 and SvelteKit can pick that up through the peer dep; If they stick with Vite 4, it'll fallback to SvelteKit's normal v-p-s v2 dep. I have not tested it though.

Personally, I'm fine with relaxing the peer dep range only and not needing to tweak the CI and tests. We can say "we allow vite 5 only temporarily for svelte kit, but it's not something we guarantee. use at your own risk."

@dominikg
Copy link
Member

we need the tests. if we do this, other setups can use v-p-s@2 + vite@5 as well, not just sveltekit. I'd prefer a solution on the sveltekit side aswell. That being said, if the work to maintain this is considered less than the work on sveltekit side, happy to accomodate - as long as it is treated as actual support -. We should also be clear that active support for v-p-s@2 is going to end soon after kit is able to use v-p-s@3, even if thats in a new major.

@benmccann
Copy link
Member Author

I get really nervous about having two versions of v-p-s in a kit project. How will users know they need to install v-p-s themselves? Will npm, pnpm, yarn, etc. all handle it the same way? Will it make it harder to tell what version a user is on for bug reports? It just seems like an extra complication that we can easily avoid

I'm also not convinced the CI matrix is truly necessary, but at this point it has been added and there's certainly no harm in it. It is marginally safer, so I feel we might as well go with it since it's done.

In terms of support, I'd like to support it more than "use at your own risk". I do think that non-SvelteKit users could be lightly encouraged to upgrade though. E.g. I think it would be fine to say we're only going to backport large bug fixes (e.g. anything we discover related to Vite 5 support) and users should upgrade if they want fixes for edge cases that are unique to their projects.

@benmccann
Copy link
Member Author

Closing given our latest discussions

@benmccann benmccann closed this Dec 1, 2023
@benmccann benmccann deleted the vite5 branch December 1, 2023 16:25
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.

4 participants