I’ve been trying to deploy Hilla on Fly.io, using Paketo buildpacks.
However, I get some intermittent errors, and the latest example is here - it’s a Spring Boot app.
I was just curious if anyone had any ideas on how to resolve this? The app needs to be a native image, so I can scale from zero when the app is first hit.
The recurring error is as follows. I believe it’s a bug, but I can see the Hilla Maven plugin goal referenced in the log is just extended from Flow - hence why I mentioned it on GitHub:
[INFO]
[INFO] >>> hilla:2.5.7:prepare-frontend (default) > :configure @ shsponsors >>>
[INFO]
[INFO] --- hilla:2.5.7:configure (configure) @ shsponsors ---
[INFO]
[INFO] <<< hilla:2.5.7:prepare-frontend (default) < :configure @ shsponsors <<<
[INFO]
[INFO]
[INFO] --- hilla:2.5.7:prepare-frontend (default) @ shsponsors ---
[INFO] Couldn't find node. Installing Node and npm to /home/cnb/.vaadin.
[INFO] Installing node version v20.11.1
[INFO] Downloading https://nodejs.org/dist/v20.11.1/node-v20.11.1-linux-x64.tar.gz to /home/cnb/.vaadin/node-v20.11.1-linux-x64.tar.gz
[INFO] No proxies configured. If you are behind a proxy server, see https://vaadin.com/docs/latest/configuration/development-mode/node-js#proxy-settings-for-downloading-frontend-toolchain for information on proxy configuration.
[INFO] Unpacking /home/cnb/.vaadin/node-v20.11.1-linux-x64.tar.gz (46621070 bytes) into /home/cnb/.vaadin/node/tmp
[INFO] ------------------------------------------------------------------------
[INFO] BUILD FAILURE
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 12.524 s
[INFO] Finished at: 2024-04-25T15:15:28Z
[INFO] ------------------------------------------------------------------------
Error: ERROR] Failed to execute goal dev.hilla:hilla-maven-plugin:2.5.7:prepare-frontend (default) on project shsponsors: Execution default of goal dev.hilla:hilla-maven-plugin:2.5.7:prepare-frontend failed: An API incompatibility was encountered while executing dev.hilla:hilla-maven-plugin:2.5.7:prepare-frontend: java.lang.NoSuchMethodError: 'long org.apache.commons.io.IOUtils.skip(java.io.InputStream, long, java.util.function.Supplier)'
Just looking at your exception; I’ve got a strong feeling you are using outdated libraries - like your commons-io. Please update to the latest version.
You can check with mvn -X the full stack trace. It would probably also help to just specify the dependency then. Looks like a missmatch; commons-io is widely used.
Sorry for the delay. In the end, I went back to Vaadin. I am going to push the last commit where it used Hilla (and broken) to a separate, minimal repository on GitHub. I’ll get that done this weekend. This should be useful to debug in an isolated, reproducible environment.
I’ve identified another issue on a different project. I can’t share the sources of this, but in this case, running Paketo CLI directly, I get a very different error.
The command used to generate the project was via the CLI. This was the command: npx @hilla/cli init --preset=hilla-crm-tutorial $projectdir, where $projectdir is the name of the project’s directory.
This is the stack trace from the freshly created Hilla project (using the CLI):
[builder] [INFO] --- hilla:2.5.7:build-frontend (default) @ <REDACTED> ---
[builder] [INFO] Reflections took 444 ms to scan 134 urls, producing 9576 keys and 50677 values
[builder] [INFO] Scanning classes to find frontend configurations and dependencies...
[builder] [INFO] Visited 4123 classes. Took 1335 ms.
[builder] [INFO] Checking if a production mode bundle build is needed
[builder] [WARNING] There is no prod-bundle in the project or on the classpath nor is there a default production bundle included.
[builder] [INFO] No bundle's stats.json found for production-bundle validation.
[builder] [INFO] A production mode bundle build is needed
[builder] [INFO] Running `npm install` to resolve and optionally download frontend dependencies. This may take a moment, please stand by...
[builder] [INFO] using '/layers/paketo-buildpacks_node-engine/node/bin/npm --no-update-notifier --no-audit --scripts-prepend-node-path=true --ignore-scripts install' for frontend package installation
[builder] [INFO] Frontend dependencies resolved successfully.
[builder] [INFO] Search for endpoints in directories [/workspace/target/classes]
[builder] [INFO] Copying frontend resources from jar files ...
[builder] [INFO] Visited 133 resources. Took 45 ms.
[builder] [INFO] ------------------------------------------------------------------------
[builder] [INFO] BUILD FAILURE
[builder] [INFO] ------------------------------------------------------------------------
[builder] [INFO] Total time: 18.082 s
[builder] [INFO] Finished at: 2024-05-03T20:49:45Z
[builder] [INFO] ------------------------------------------------------------------------
[builder] [ERROR] Failed to execute goal dev.hilla:hilla-maven-plugin:2.5.7:build-frontend (default) on project <REDACTED>: Execution default of goal dev.hilla:hilla-maven-plugin:2.5.7:build-frontend failed: Unable to locate Vite executable by path '/workspace/node_modules/vite/bin/vite.js'. Double check that the plugin is executed correctly -> [Help 1]
I can’t help but wonder if I need to make an upstream issue for these two bugs. The forums are a good place for troubleshooting, but given the commons-io error, and then the vite.js error, I think this is something more sets of eyes need to investigate. Of course, it’s not up to me what the priority is; as a maintainer myself, I understand this. But possibly worth investigating.
I found this happened even outside of a Paketo build, I resolved it by adding the following dependency override to the hilla-maven-plugin section of my pom.xml
I found that the latest version of Hilla fixed this for me.
But before that, I tried @Stuart.4’s fix, and that worked. I am now using Flow and Hilla on my Spring Boot apps, and having a great experience. It works on -Pnative,production - so yes, all good here!