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

Test if yalc can be used in the CI for the build tests #124

Closed
wants to merge 52 commits into from

Conversation

fulopkovacs
Copy link
Contributor

Make sure that @theatre/core and @theatre/studio can be used with the most popular setups (parcel, vite, vanilla rollup, etc.).

Note: Our first approach was this PR which had to be closed due to the limitations of yarn workspaces.

@fulopkovacs
Copy link
Contributor Author

fulopkovacs commented Apr 14, 2022

Build setups

Here's a list of the build setups that I'm planning to test in this PR (feel free to add more):

Implement in this PR

  • vite + r3f
  • create-react-app + r3f

Implement in the future

NOTE: The following configs will be implemented in the future:

TODO list

  • Add the problematic projects to the builds, but make sure that the CI doesn't fail when these particular tests do
  • Fix the CI
  • Update build_tests/README.md with the build tests that are actually implemented (after the CI is fixed!)

Related tasks that should be handled in different PRs

UPDATES

  • Next.js v12 is currently not compatible with Theatre.js (check out this conversation on our Discord's #help channel). This issue is still being investigated.
  • Next.js v11 has the same problem as v12
  • we ran into some problems with yarn workspaces, so decided to not use them for the build tests. Currently I'm checking out yalc as our next best option.
  • Fix various issues with the build system #129 might fix our build issues with the problematic projects
  • I ran into this issue with the Parcel v2 setup after a rebase: Release 0.8, or 0.7.4? mozilla/source-map#452, so Parcel v2 has been moved to the Implement in the future section.
  • When I tried to add the r3f extension to the parcel v1 and the rollup setup I had some issues, so I moved both of them to the "Implement in the future" section

@fulopkovacs fulopkovacs force-pushed the use-yalc-for-the-build-tests branch 6 times, most recently from ff18f61 to 55832e1 Compare April 14, 2022 20:26
@DennisSmolek
Copy link

@fulop how are you clearing vite?
I'm guessing you aren't using the r3f extension?

I'm getting:

✘ [ERROR] [plugin vite:dep-pre-bundle] Missing "./examples/js/libs/stats.min" export in "three" package

    node_modules/vite/dist/node/chunks/dep-27bc1ab8.js:37698:7:
      37698 │   throw new Error(
            ╵         ^

    at bail (/Users/Shared/sharedGit/r3f-theatre-fresh/node_modules/vite/dist/node/chunks/dep-27bc1ab8.js:37698:8)
    at resolve (/Users/Shared/sharedGit/r3f-theatre-fresh/node_modules/vite/dist/node/chunks/dep-27bc1ab8.js:37775:10)
    at resolveExports (/Users/Shared/sharedGit/r3f-theatre-fresh/node_modules/vite/dist/node/chunks/dep-27bc1ab8.js:38441:12)
    at resolveDeepImport (/Users/Shared/sharedGit/r3f-theatre-fresh/node_modules/vite/dist/node/chunks/dep-27bc1ab8.js:38459:31)
    at tryNodeResolve (/Users/Shared/sharedGit/r3f-theatre-fresh/node_modules/vite/dist/node/chunks/dep-27bc1ab8.js:38232:20)
    at Context.resolveId (/Users/Shared/sharedGit/r3f-theatre-fresh/node_modules/vite/dist/node/chunks/dep-27bc1ab8.js:38040:28)
    at Object.resolveId (/Users/Shared/sharedGit/r3f-theatre-fresh/node_modules/vite/dist/node/chunks/dep-27bc1ab8.js:36609:55)
    at processTicksAndRejections (internal/process/task_queues.js:95:5)
    at async /Users/Shared/sharedGit/r3f-theatre-fresh/node_modules/vite/dist/node/chunks/dep-27bc1ab8.js:61261:27
    at async /Users/Shared/sharedGit/r3f-theatre-fresh/node_modules/vite/dist/node/chunks/dep-27bc1ab8.js:30513:34

  This error came from the "onResolve" callback registered here:

    node_modules/vite/dist/node/chunks/dep-27bc1ab8.js:30492:18:
      30492 │             build.onResolve({ filter: /^[\w@][^:]/ }, async ({ path: id, importer, kind }) => {
            ╵                   ~~~~~~~~~

    at setup (/Users/Shared/sharedGit/r3f-theatre-fresh/node_modules/vite/dist/node/chunks/dep-27bc1ab8.js:30492:19)
    at handlePlugins (/Users/Shared/sharedGit/r3f-theatre-fresh/node_modules/esbuild/lib/main.js:843:23)
    at Object.buildOrServe (/Users/Shared/sharedGit/r3f-theatre-fresh/node_modules/esbuild/lib/main.js:1137:7)
    at /Users/Shared/sharedGit/r3f-theatre-fresh/node_modules/esbuild/lib/main.js:2079:17
    at new Promise (<anonymous>)
    at Object.build (/Users/Shared/sharedGit/r3f-theatre-fresh/node_modules/esbuild/lib/main.js:2078:14)
    at Object.build (/Users/Shared/sharedGit/r3f-theatre-fresh/node_modules/esbuild/lib/main.js:1927:51)
    at runOptimizeDeps (/Users/Shared/sharedGit/r3f-theatre-fresh/node_modules/vite/dist/node/chunks/dep-27bc1ab8.js:37342:34)
    at processTicksAndRejections (internal/process/task_queues.js:95:5)

  The plugin "vite:dep-pre-bundle" was triggered by this import

    node_modules/@theatre/r3f/node_modules/@react-three/drei/core/Stats.js:3:22:
      3 │ import StatsImpl from 'three/examples/js/libs/stats.min';
        ╵                       ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

7:59:42 AM [vite] error while updating dependencies:
Error: Build failed with 1 error:
node_modules/vite/dist/node/chunks/dep-27bc1ab8.js:37698:7: ERROR: [plugin: vite:dep-pre-bundle] Missing "./examples/js/libs/stats.min" export in "three" package
    at failureErrorWithLog (/Users/Shared/sharedGit/r3f-theatre-fresh/node_modules/esbuild/lib/main.js:1603:15)
    at /Users/Shared/sharedGit/r3f-theatre-fresh/node_modules/esbuild/lib/main.js:1249:28
    at runOnEndCallbacks (/Users/Shared/sharedGit/r3f-theatre-fresh/node_modules/esbuild/lib/main.js:1034:63)
    at buildResponseToResult (/Users/Shared/sharedGit/r3f-theatre-fresh/node_modules/esbuild/lib/main.js:1247:7)
    at /Users/Shared/sharedGit/r3f-theatre-fresh/node_modules/esbuild/lib/main.js:1356:14
    at /Users/Shared/sharedGit/r3f-theatre-fresh/node_modules/esbuild/lib/main.js:666:9
    at handleIncomingPacket (/Users/Shared/sharedGit/r3f-theatre-fresh/node_modules/esbuild/lib/main.js:763:9)
    at Socket.readFromStdout (/Users/Shared/sharedGit/r3f-theatre-fresh/node_modules/esbuild/lib/main.js:632:7)
    at Socket.emit (events.js:400:28)
    at addChunk (internal/streams/readable.js:293:12)

@fulopkovacs
Copy link
Contributor Author

fulopkovacs commented Apr 19, 2022

Hey, @DennisSmolek , sorry for the late response (holidays... ) ☺️!

The reason why vite and r3f are not included in this PR is because we're planning to build all the projects in packages/playground/src/shared using Netlify's build preview for every PR. These projects do use vite, and one of them uses r3f. Unfortunately the Build Previews currently have a bug (issue), so we have to wait until the fix we submitted (PR) gets merged.

I'm not really familiar with the error in your comment. Checked the playground project that uses the r3f extension, but it seems to be fine. Could you check it too to see if I'm missing something? Here's how you could do it:

  1. Run this command in the cloned repo's root after you've installed the dependencies:
yarn playground
  1. Visit http://localhost:8080/shared/r3f-rocket in the browser. (Replace the port with the the one that the playground server is using if necessary)
  2. You should be presented with something like this:
    image

I hope I was able to help you, please tell me if that's not the case ☺️.

EDIT: In the meantime I discovered that the playground loads the r3f extension from the repo itself, so it won't be that useful for you. I'll check if I can make the playground projects work with the latest published version of @theatre/r3f.

@fulopkovacs fulopkovacs force-pushed the use-yalc-for-the-build-tests branch 8 times, most recently from cf52385 to 7a489a0 Compare April 25, 2022 08:01
Copy link
Member

@AriaMinaei AriaMinaei left a comment

Choose a reason for hiding this comment

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

Did a first pass at this draft PR. Looks very good!

scripts/build-tests/link-theatre-packages.mjs Outdated Show resolved Hide resolved
scripts/publish-to-yalc.mjs Outdated Show resolved Hide resolved
@AriaMinaei AriaMinaei marked this pull request as draft April 25, 2022 11:17
@AriaMinaei
Copy link
Member

Could this be a mac issue?

image

@fulopkovacs fulopkovacs force-pushed the use-yalc-for-the-build-tests branch from fc8f038 to 85de3b5 Compare April 26, 2022 10:24
@fulopkovacs
Copy link
Contributor Author

fulopkovacs commented Apr 26, 2022

Could this be a mac issue?

image

Note for the people looking at this PR: We talked with Aria and solved the issue by adding node-gyp to the project's dependencies (also had to run yarn rebuild before that if I remember correctly). This issue was macOS-specific, but houldn't come up again.

@fulopkovacs fulopkovacs requested a review from AriaMinaei April 26, 2022 15:23
@fulopkovacs fulopkovacs force-pushed the use-yalc-for-the-build-tests branch from 606b461 to 1a3efec Compare May 2, 2022 06:44
@vercel
Copy link

vercel bot commented May 2, 2022

The latest updates on your projects. Learn more about Vercel for Git ↗︎

Name Status Preview Updated
theatre-playground ✅ Ready (Inspect) Visit Preview May 16, 2022 at 9:01AM (UTC)

fulopkovacs and others added 26 commits May 16, 2022 10:57
@fulopkovacs
Copy link
Contributor Author

This PR ran into a error in the CI and after a considerable amount of debugging we decided to restart it from scratch. See the new version of the PR here: #165

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.

3 participants