-
Notifications
You must be signed in to change notification settings - Fork 548
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
MacOS: Add a Homebrew OpenSSL directory configuration option. #1301
Conversation
Am I missing it where the builds do not factor in the case without the ENV var set, nor the case where openssl@3 is installed under the Mac OS? |
Good question! As far as I know, we don't find how to install openssl3 on MacOS environment because of this issue: #1297. If the env is not set, and the openssl@3 directory by |
That would be an interesting case also to test against: in essence, the wholly negative case where there is no ENV var, no command line switch, and |
If there is no ENV var, there is no command line switch. That is the MacOS cases on the current master branch. I added the 2 cases to the CI on my forked repo's testing branch. I am not sure that we need total 4 MacOS cases on the CI. If the maintainers want to add the cases, I am happy to add the cases to this PR. https://github.com/junaruga/mysql2/actions/runs/3912863766/jobs/6688047019 |
2fac913
to
97e2cbf
Compare
Would it be more general to solve this by adding a |
Sure. Good point! I will try it. You meant the |
56353bd
to
90214cf
Compare
I just rebased this PR with the way you mentioned on the lastet master branch, and updated the commit message too. The |
This commit is to enable users to set a custom Homebrew openssl directory configuration option to set the openssl library path on MacOS. Previously we got the openssl library path by `brew --prefix openssl` on MacOS. However, there is a case where the directory actually doesn't exist. And this option enables users to build mysql2 in the case. ``` + brew --prefix openssl /usr/local/opt/openssl@3 + ls -ld /usr/local/opt/openssl* lrwxr-xr-x 1 runner admin 36 Dec 16 01:28 /usr/local/opt/openssl -> /usr/local/Cellar/[email protected]/1.1.1s lrwxr-xr-x 1 runner admin 28 Dec 16 01:19 /usr/local/opt/[email protected] -> ../Cellar/[email protected]/1.1.1s /usr/local/opt/[email protected] ``` == How to use == In the development, you can run like this. ``` $ RUBY_MYSQL2_SSL_DIR=/usr/local/opt/[email protected] rake ``` In the installation, you can run like this. ``` $ gem install mysql2 -- --with-ssl-dir=/usr/local/opt/[email protected] ``` == Note == In this commit, the directory existing check is added in the `extconf.rb`. If the openssl directory doesn't exist, the build fails with the error message below. ``` Cannot find library dir(s) /usr/local/opt/openssl@3/lib ```
90214cf
to
b8987e3
Compare
# https://github.com/ruby/setup-ruby | ||
- uses: ruby/setup-ruby@v1 | ||
with: | ||
ruby-version: ${{ matrix.ruby }} | ||
bundler-cache: true # runs 'bundle install' and caches installed gems automatically | ||
- if: matrix.db != '' | ||
run: echo 'DB=${{ matrix.db }}' >> $GITHUB_ENV | ||
- if: startsWith(matrix.os, 'macos') && matrix.ssl != '' | ||
run: echo "RUBY_MYSQL2_SSL_DIR=$(brew --prefix ${{ matrix.ssl }})" >> $GITHUB_ENV |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Rather than threading a new environment variable into the app code, I'd prefer to add an argument to the build step, like:
bundle exec rake clean compile -- --with-mysql-dir=/var/tmp
(demonstrating that this will forcibly fail the build because there's no /var/tmp/lib or /var/tmp/include)
@@ -28,8 +28,16 @@ def add_ssl_defines(header) | |||
|
|||
# Homebrew openssl | |||
if RUBY_PLATFORM =~ /darwin/ && system("command -v brew") | |||
openssl_location = `brew --prefix openssl`.strip | |||
$LDFLAGS << " -L#{openssl_location}/lib" if openssl_location | |||
_, lib = dir_config('ssl') |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I double-checked, Ruby is calling with --with-openssl-dir
so we should go with that. I'm thinking a recommendation to be made is something like:
bundle exec rake clean compile -- $(ruby -r rbconfig -e 'puts RbConfig::CONFIG["configure_args"]' | xargs -n1 | grep with-openssl-dir)
The same could be made a Bundle config option so that bundle install
builds mysql2 against the version of Ruby and whichever openssl it's linked against
I think the include dir is required as well:
inc, lib = dir_config('openssl')
$INCFLAGS << " -I#{inc}"
$LDFLAGS << " -L#{lib}"
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Oh maybe the include dir isn't required -- I don't think any openssl functions are called from code, rather, the libmysqlclient needs to be able to load an openssl library at runtime.
@@ -28,8 +28,16 @@ def add_ssl_defines(header) | |||
|
|||
# Homebrew openssl | |||
if RUBY_PLATFORM =~ /darwin/ && system("command -v brew") |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Move dir_config(openssl
) outside of the Darwin block
Superseded by #1303 |
This PR is to add Homebrew OpenSSL directory configuration option in MacOS environment. This fixes #1300. It is related to and #1297, as this PR passes CI MacOS cases.
There are 3 commits. The first 2 commits come from another PR: #1299. The third commit is the main one of this PR.
What do you think? If the PR will be merged, then we need to add this option to the README.md - Configuration options section, and I am happy to help. Note I don't have MacOS environment. I appreciate if someone can help to test this PR on MacOS environment.
I confirmed the CI passed on my forked repository. (CI link), and the error case by directory existing check (CI link).
In the GitHub Actions build.yml, the way of how to set the matrix environment variables is used in ruby/ruby. You can see this.
Commit message
MacOS: Add a Homebrew OpenSSL directory configuration option.
This commit is to enable users to set a custom Homebrew openssl directory
configuration option to set the openssl library path on MacOS.
Previously we got the openssl library path by
brew --prefix openssl
on MacOS.However, there is a case where the directory actually doesn't exist. And this
option enables users to build mysql2 in the case.
== How to use ==
In the development, you can run like this.
In the installation, you can run like this.
== Note ==
In this commit, the directory existing check is added in the
extconf.rb
. Ifthe openssl directory doesn't exist, the build fails with the error message
below.