buo/homebrew-cask-upgrade

Error: No such file or directory @ rb_sysopen - /opt/homebrew/Library/Homebrew/vendor/bundle/ruby/2.6.0/gems/addressable-2.8.0/data/unicode.data

tiancheng92 opened this issue ยท 25 comments

# input
brew cu

# output
Error: No such file or directory @ rb_sysopen - /opt/homebrew/Library/Homebrew/vendor/bundle/ruby/2.6.0/gems/addressable-2.8.0/data/unicode.data
# input
brew doctor

# output
Your system is ready to brew.
# input
brew config

# output
HOMEBREW_VERSION: 3.4.11-53-g34dd8e3
ORIGIN: https://github.com/Homebrew/brew
HEAD: 34dd8e305789a5433d345a29b03a4d4f3a568d1e
Last commit: 4 hours ago
Core tap ORIGIN: https://github.com/Homebrew/homebrew-core
Core tap HEAD: 0f98d77858de1aa1738d1d09ad4d226114255cbe
Core tap last commit: 65 minutes ago
Core tap branch: master
HOMEBREW_PREFIX: /opt/homebrew
HOMEBREW_BAT: set
HOMEBREW_CASK_OPTS: []
HOMEBREW_CLEANUP_PERIODIC_FULL_DAYS: 1
HOMEBREW_CLEANUP_MAX_AGE_DAYS: 1
HOMEBREW_CORE_GIT_REMOTE: https://github.com/Homebrew/homebrew-core
HOMEBREW_FORCE_BREWED_CURL: set
HOMEBREW_FORCE_BREWED_GIT: set
HOMEBREW_MAKE_JOBS: 8
HOMEBREW_NO_ANALYTICS: set
HOMEBREW_NO_AUTO_UPDATE: set
Homebrew Ruby: 2.6.8 => /System/Library/Frameworks/Ruby.framework/Versions/2.6/usr/bin/ruby
CPU: octa-core 64-bit arm_firestorm_icestorm
Clang: 13.1.6 build 1316
Git: 2.36.1 => /opt/homebrew/opt/git/bin/git
Curl: 7.83.1 => /opt/homebrew/opt/curl/bin/curl
macOS: 12.4-arm64
CLT: 13.4.0.0.1.1651278267
Xcode: N/A
Rosetta 2: false

Issue looks to be caused by this commit.

Homebrew/brew@fb8a4e5

PR Homebrew/brew#13292

My fix so far has been this:

cp -R /usr/local/lib/ruby/gems/2.6.0/gems/addressable-2.8.0/data /usr/local/Homebrew/Library/Homebrew/vendor/bundle/ruby/2.6.0/gems/addressable-2.8.0

I don't have dir /usr/local/lib/ruby/gems/2.6.0
I have dir /usr/local/lib/ruby/gems/3.10
how to fix this error,plz?

Likely just replace the 2.6.0 with 3.10.

Likely just replace the 2.6.0 with 3.10.

But there is no folder with path like 2.6

Otherwise just get the unicode.data file from here:

https://github.com/sporkmonger/addressable/tree/main/data

It is only this file that needs to be in that directory.

yes! it's work,thanks

Otherwise just get the unicode.data file from here:

https://github.com/sporkmonger/addressable/tree/main/data

It is only this file that needs to be in that directory.

@tiancheng92 did this work for you as well? Can we close this then?

I think this is an issue that will impact others. This may require an update to this addon.

i had the same issue and resolved it by

mkdir /usr/local/Homebrew/Library/Homebrew/vendor/bundle/ruby/2.6.0/gems/addressable-2.8.0/data/
wget https://raw.githubusercontent.com/sporkmonger/addressable/main/data/unicode.data -O /usr/local/Homebrew/Library/Homebrew/vendor/bundle/ruby/2.6.0/gems/addressable-2.8.0/data/unicode.data

I think this is an issue that will impact others. This may require an update to this addon.

@mikelorant What kind of update you have in mind? We're using "standard" brew commands to update the casks, therefore to me it seems is an issue with homebrew itself?

It doesn't happen to me, so it's probably related to some specific conditions? It's hard to "fix" if we can't reproduce :-(

z0rc commented

We're using "standard" brew commands to update the casks

Is there a way to find what brew command triggers this error? I have the same issue with brew cu, but regular brew cli works okay.

@z0rc I don't think there is an easy way. Does it happen immediately or you already get some output before it errors out?

z0rc commented

@ondrejfuhrer Almost immediately after exec, no additional output.

% brew cu
Error: No such file or directory @ rb_sysopen - /usr/local/Homebrew/Library/Homebrew/vendor/bundle/ruby/2.6.0/gems/addressable-2.8.0/data/unicode.data

Tested also brew cu --verbose --no-brew-update, but additional options didn't have an effect, error remains as is. brew cu --help works okay though.

I am also receiving this error. The same as @z0rc, there's also no additional output. cu --help does also work for me.

yes! it's work,thanks

yes! it's work,thanks

@z0rc & @kovalchik can you try running brew vendor-install ruby if that fixes it maybe?
Since there is no input then it means something is off with the initialisation of this extension, but I can't find anything even closely related to the issue described.

@ondrejfuhrer brew vendor-install ruby completed successfully, but didn't fix the issue. ๐Ÿ˜ž

Didn't meant to close it immediately. @kovalchik can you try brew update and then brew cu if it works now? I managed to reproduce the issue and might have found the culprit. Not sure though if it didn't break anything else ๐Ÿ˜† ๐Ÿคž

@ondrejfuhrer That worked! After running brew update, brew cu ran and completed successfully. ๐Ÿ™Œ

z0rc commented

I also confirm that this fixed the issue. Thanks!

From a quick glance, this issue is likely due to needing to run #install_bundler_gems at some point. We usually call Homebrew.install_bundler_gems! in commands that use parts of brew that involve external gems (like addressable) but I forgot to handle that in the aforementioned PR. I imagine it's affecting your code because cask/audit requires livecheck/livecheck which now requires addressable.

Anyone who's seeing this error has already run a dev-cmd before (i.e., my commit isn't in a brew release yet), so they should be able to safely resolve the error by running brew install-bundler-gems.

I'm working on a follow-up PR on our end but, unfortunately, I have to create a separate PR beforehand to modify the behavior of #install_bundler_gems (to be able to safely call it in livecheck). Once that's done and I've added Homebrew.install_bundler_gems! in related parts of brew (livecheck, bump, cask/audit), it may resolve this issue for you.

If you want to resolve this quickly or err on the safe side, you can add a Homebrew.install_bundler_gems! call in your code (somewhere early on, where you're setting things up). If you search the brew codebase for install_bundler_gems!, you'll find some example usage.

Thank you for the context @samford ! I actually removed direct require of cask (which was causing the issue) which probably happens anyways somewhere as the code works without any issues (or at least I haven't spotted any).

That being said, it's great to have the context on this to understand what happened ๐Ÿ™‚

I'll consider this issue being resolved then ๐Ÿ™‚ thank you all for your help investigating this.

After investigating further, we just needed to vendor more of addressable. We were already vendoring the lib directory by default but we also need the data directory, where unicode.data is found. I didn't see the error when I was testing because my addressable directory had all the files from when it was installed. We temporarily reverted the aforementioned commit but a fix will be included when it's reinstated, so this shouldn't require changes on your end (edit: now reinstated with gem-related fixes).

At this point, users can resolve the error by running brew update.