200 lines
6.6 KiB
Ruby
200 lines
6.6 KiB
Ruby
class MariadbAT105 < Formula
|
|
desc "Drop-in replacement for MySQL"
|
|
homepage "https://mariadb.org/"
|
|
url "https://downloads.mariadb.com/MariaDB/mariadb-10.5.18/source/mariadb-10.5.18.tar.gz"
|
|
sha256 "3593b0dcc0f2e80e98177019f5dcfa5cc8c14172ce161a6fa50f8084f2cef749"
|
|
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: "bc80c77d9f4a3a28e0153a1dac034cef0fc9aaa9d9351a1595e1834a75d4b9bd"
|
|
sha256 arm64_monterey: "bf27d9ea362b63d341bdeda012038353aa4c60fcc7c3f047ec0fd21da330be6a"
|
|
sha256 arm64_big_sur: "f72530344593bd8a62a978e2231be8790a6e45fcc0175c5ebaa88d6a9dc74396"
|
|
sha256 ventura: "9e803e1804cdbfb51f189efe5a8ec76e719c9d1a176cba83230cc3f3f3398772"
|
|
sha256 monterey: "73610fe37c88a355e8bf355fc1f4ed3fa7a0e2751aa5252fd0bd3d92ded087bb"
|
|
sha256 big_sur: "2ba8f105270ce3d186f0c275ae83c019dafc3d69c6dfc825b3812e5f2d5d1893"
|
|
sha256 catalina: "316b4c289dd011c0324b8f6efa35531bd021ecbafd623becda73121a80526c45"
|
|
sha256 x86_64_linux: "cf20e43dd1ee034cb495e08110bde9b5f4cc3388e7cb5a3255c4fd4919985127"
|
|
end
|
|
|
|
keg_only :versioned_formula
|
|
|
|
# See: https://mariadb.com/kb/en/changes-improvements-in-mariadb-105/
|
|
deprecate! date: "2025-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=#{tap.user}
|
|
]
|
|
|
|
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"
|
|
|
|
# Disable RocksDB on Apple Silicon (currently not supported)
|
|
args << "-DPLUGIN_ROCKSDB=NO" if Hardware::CPU.arm?
|
|
|
|
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
|