197 lines
6.4 KiB
Ruby
197 lines
6.4 KiB
Ruby
class MariadbAT104 < Formula
|
|
desc "Drop-in replacement for MySQL"
|
|
homepage "https://mariadb.org/"
|
|
url "https://downloads.mariadb.com/MariaDB/mariadb-10.4.27/source/mariadb-10.4.27.tar.gz"
|
|
sha256 "48a1f220ca18bb0c46379d77fe98eb750bcc7052e73f10e3276ea2a5c51b8ab2"
|
|
license "GPL-2.0-only"
|
|
|
|
# This uses a placeholder regex to satisfy the `PageMatch` strategy
|
|
# requirement. In the future, this will be updated to use a `Json` strategy
|
|
# and we can remove the unused regex at that time.
|
|
livecheck do
|
|
url "https://downloads.mariadb.org/rest-api/mariadb/all-releases/?olderReleases=false"
|
|
regex(/unused/i)
|
|
strategy :page_match do |page|
|
|
json = JSON.parse(page)
|
|
json["releases"]&.map do |release|
|
|
next unless release["release_number"]&.start_with?(version.major_minor)
|
|
next unless release["status"]&.include?("stable")
|
|
|
|
release["release_number"]
|
|
end
|
|
end
|
|
end
|
|
|
|
bottle do
|
|
sha256 arm64_ventura: "dacc583af292a9699b052f3588af1fe549346975c97d43423f4dc857197625ea"
|
|
sha256 arm64_monterey: "28ec07df45dd336fcc093950c12b2c90cc02ddcceb06861a8a252906385fd1fc"
|
|
sha256 arm64_big_sur: "f7af5030d7915f839e836f75abc255fe5e2a08b157d10acb1b29f0d580a67900"
|
|
sha256 ventura: "831b58c27fb6f75b5c717f4849f4aa5c7b77918512714c22276e13d6fb8c6aa6"
|
|
sha256 monterey: "8b50eb5e4a7031c800586c8d08bc16738de3e6a94ba9bb8b7aa91e36ebdb5c80"
|
|
sha256 big_sur: "ecb5b904f1da5253aa7cec9581bc2466e32b00a2c13700950fb7946625c5c437"
|
|
sha256 catalina: "338e9d081ecd9ca9cd9b5d8e4422d480432f9c07bc68b3b0cd38f9a34fc717d6"
|
|
sha256 x86_64_linux: "8f0a814226bec5e3f629b454ae70de4ade43dc192b7e9938436e8ce4925e14f4"
|
|
end
|
|
|
|
keg_only :versioned_formula
|
|
|
|
# See: https://mariadb.com/kb/en/changes-improvements-in-mariadb-104/
|
|
deprecate! date: "2024-06-01", because: :unsupported
|
|
|
|
depends_on "bison" => :build
|
|
depends_on "cmake" => :build
|
|
depends_on "pkg-config" => :build
|
|
depends_on "groonga"
|
|
depends_on "openssl@1.1"
|
|
depends_on "pcre2"
|
|
|
|
uses_from_macos "bzip2"
|
|
uses_from_macos "libxcrypt"
|
|
uses_from_macos "libxml2"
|
|
uses_from_macos "ncurses"
|
|
uses_from_macos "zlib"
|
|
|
|
on_linux do
|
|
depends_on "linux-pam"
|
|
end
|
|
|
|
fails_with gcc: "5"
|
|
|
|
def install
|
|
# Set basedir and ldata so that mysql_install_db can find the server
|
|
# without needing an explicit path to be set. This can still
|
|
# be overridden by calling --basedir= when calling.
|
|
inreplace "scripts/mysql_install_db.sh" do |s|
|
|
s.change_make_var! "basedir", "\"#{prefix}\""
|
|
s.change_make_var! "ldata", "\"#{var}/mysql\""
|
|
end
|
|
|
|
# Use brew groonga
|
|
rm_r "storage/mroonga/vendor/groonga"
|
|
|
|
# -DINSTALL_* are relative to prefix
|
|
args = %W[
|
|
-DMYSQL_DATADIR=#{var}/mysql
|
|
-DINSTALL_INCLUDEDIR=include/mysql
|
|
-DINSTALL_MANDIR=share/man
|
|
-DINSTALL_DOCDIR=share/doc/#{name}
|
|
-DINSTALL_INFODIR=share/info
|
|
-DINSTALL_MYSQLSHAREDIR=share/mysql
|
|
-DWITH_READLINE=yes
|
|
-DWITH_SSL=yes
|
|
-DWITH_UNIT_TESTS=OFF
|
|
-DDEFAULT_CHARSET=utf8mb4
|
|
-DDEFAULT_COLLATION=utf8mb4_general_ci
|
|
-DINSTALL_SYSCONFDIR=#{etc}
|
|
-DCOMPILATION_COMMENT=Homebrew
|
|
]
|
|
|
|
if OS.linux?
|
|
args << "-DWITH_NUMA=OFF"
|
|
args << "-DENABLE_DTRACE=NO"
|
|
args << "-DCONNECT_WITH_JDBC=OFF"
|
|
end
|
|
|
|
if OS.mac?
|
|
args << "-DWITH_READLINE=NO" # uses libedit on macOS
|
|
end
|
|
|
|
# disable TokuDB, which is currently not supported on macOS
|
|
args << "-DPLUGIN_TOKUDB=NO"
|
|
|
|
system "cmake", ".", *std_cmake_args, *args
|
|
|
|
system "make"
|
|
system "make", "install"
|
|
|
|
# Fix my.cnf to point to #{etc} instead of /etc
|
|
(etc/"my.cnf.d").mkpath
|
|
inreplace "#{etc}/my.cnf", "!includedir /etc/my.cnf.d",
|
|
"!includedir #{etc}/my.cnf.d"
|
|
touch etc/"my.cnf.d/.homebrew_dont_prune_me"
|
|
|
|
# Don't create databases inside of the prefix!
|
|
# See: https://github.com/Homebrew/homebrew/issues/4975
|
|
rm_rf prefix/"data"
|
|
|
|
# Save space
|
|
(prefix/"mysql-test").rmtree
|
|
(prefix/"sql-bench").rmtree
|
|
|
|
# Link the setup script into bin
|
|
bin.install_symlink prefix/"scripts/mysql_install_db"
|
|
|
|
# Fix up the control script and link into bin
|
|
inreplace "#{prefix}/support-files/mysql.server", /^(PATH=".*)(")/, "\\1:#{HOMEBREW_PREFIX}/bin\\2"
|
|
|
|
bin.install_symlink prefix/"support-files/mysql.server"
|
|
|
|
# Move sourced non-executable out of bin into libexec
|
|
libexec.install "#{bin}/wsrep_sst_common"
|
|
# Fix up references to wsrep_sst_common
|
|
%w[
|
|
wsrep_sst_mysqldump
|
|
wsrep_sst_rsync
|
|
wsrep_sst_mariabackup
|
|
].each do |f|
|
|
inreplace "#{bin}/#{f}", "$(dirname \"$0\")/wsrep_sst_common",
|
|
"#{libexec}/wsrep_sst_common"
|
|
end
|
|
|
|
# Install my.cnf that binds to 127.0.0.1 by default
|
|
(buildpath/"my.cnf").write <<~EOS
|
|
# Default Homebrew MySQL server config
|
|
[mysqld]
|
|
# Only allow connections from localhost
|
|
bind-address = 127.0.0.1
|
|
EOS
|
|
etc.install "my.cnf"
|
|
end
|
|
|
|
def post_install
|
|
# Make sure the var/mysql directory exists
|
|
(var/"mysql").mkpath
|
|
|
|
# Don't initialize database, it clashes when testing other MySQL-like implementations.
|
|
return if ENV["HOMEBREW_GITHUB_ACTIONS"]
|
|
|
|
unless File.exist? "#{var}/mysql/mysql/user.frm"
|
|
ENV["TMPDIR"] = nil
|
|
system "#{bin}/mysql_install_db", "--verbose", "--user=#{ENV["USER"]}",
|
|
"--basedir=#{prefix}", "--datadir=#{var}/mysql", "--tmpdir=/tmp"
|
|
end
|
|
end
|
|
|
|
def caveats
|
|
<<~EOS
|
|
A "/etc/my.cnf" from another install may interfere with a Homebrew-built
|
|
server starting up correctly.
|
|
|
|
MySQL is configured to only allow connections from localhost by default
|
|
EOS
|
|
end
|
|
|
|
service do
|
|
run [opt_bin/"mysqld_safe", "--datadir=#{var}/mysql"]
|
|
keep_alive true
|
|
working_dir var
|
|
end
|
|
|
|
test do
|
|
(testpath/"mysql").mkpath
|
|
(testpath/"tmp").mkpath
|
|
system bin/"mysql_install_db", "--no-defaults", "--user=#{ENV["USER"]}",
|
|
"--basedir=#{prefix}", "--datadir=#{testpath}/mysql", "--tmpdir=#{testpath}/tmp",
|
|
"--auth-root-authentication-method=normal"
|
|
port = free_port
|
|
fork do
|
|
system "#{bin}/mysqld", "--no-defaults", "--user=#{ENV["USER"]}",
|
|
"--datadir=#{testpath}/mysql", "--port=#{port}", "--tmpdir=#{testpath}/tmp"
|
|
end
|
|
sleep 5
|
|
assert_match "information_schema",
|
|
shell_output("#{bin}/mysql --port=#{port} --user=root --password= --execute='show databases;'")
|
|
system "#{bin}/mysqladmin", "--port=#{port}", "--user=root", "--password=", "shutdown"
|
|
end
|
|
end
|