-
Notifications
You must be signed in to change notification settings - Fork 57
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
Crashing in Getting Started #320
Comments
I got this working by disabling Spring: |
I just wanted to chime in my two cents, as I have encountered this issue today. The reason for this error is occuring is that this library either directly or indirectly (probably more likely, I go into more details below on what I think the cause is) links to the macOS Foundation framework, and Objective-C classes defined by the macOS Foundation framework are fork-unsafe. https://blog.phusion.nl/2017/10/13/why-ruby-app-servers-break-on-macos-high-sierra-and-what-can-be-done-about-it/ does a pretty good job explaining this issue in detail. The solution is to make sure that the dynamic library at issue is loaded before the fork occurs. With puma (which forks when running in cluster mode) this can be done by telling it to load offending the library before it forks: before_fork do
# load offending library here
end I'm pretty sure I've narrowed this issue down to Typhoeus, because calling require 'ethon'
Ethon::Curl.init before a fork occurs eliminates the issue entirely in my application on my local machine. For rails applications there is a simple solution, just tell rails to load the dynamic library in an initializer, all initializers are ran before the applicaiton will be forked. I believe the library that hubspot is using that causes this issue is A simple solution to this problem is to create a rails generator that defines a hubspot-api-ruby initializer that runs: require 'ethon'
Ethon::Curl.init And to recommend that rails users run this as part of the setup process. I would also add documentation to the readme regarding this setup for those running this gem in other frameworks. It is worth pointing out that this is only an issue on OSX. Other options are:
|
Hello, I'm trying to use this gem for the first time with a private app. Whenever the last line of code
contacts = client.crm.contacts.basic_api.get_page
runs from the Getting Started section,I get this error:
objc[18591]: +[__NSCFConstantString initialize] may have been in progress in another thread when fork() was called.
objc[18591]: +[__NSCFConstantString initialize] may have been in progress in another thread when fork() was called. We cannot safely call it or ignore it in the fork() child process. Crashing instead. Set a breakpoint on objc_initializeAfterForkError to debug.
ruby "3.3.0"
gem "rails", "6.1.7.7"
hubspot-api-client (18.0.0)
json (~ > 2.1, >= 2.1.0)
typhoeus (~> 1.4.0)
The text was updated successfully, but these errors were encountered: