From 396c7e97b7717bbb25a6d2c08a162dfbe9ea24c9 Mon Sep 17 00:00:00 2001 From: commitay Date: Sat, 28 Apr 2018 22:06:45 +1000 Subject: [PATCH] mysql@5.7 5.7.22 (new formula) Closes #27210. Signed-off-by: ilovezfs --- Formula/mysql@5.7.rb | 182 +++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 182 insertions(+) create mode 100644 Formula/mysql@5.7.rb diff --git a/Formula/mysql@5.7.rb b/Formula/mysql@5.7.rb new file mode 100644 index 0000000000..3d45ef1495 --- /dev/null +++ b/Formula/mysql@5.7.rb @@ -0,0 +1,182 @@ +class MysqlAT57 < Formula + desc "Open source relational database management system" + homepage "https://dev.mysql.com/doc/refman/5.7/en/" + url "https://cdn.mysql.com/Downloads/MySQL-5.7/mysql-boost-5.7.22.tar.gz" + sha256 "5b2a61700af7c99f5630a7dfdb099af9283c3029843cddd9e123bcdbcc4aad03" + + keg_only :versioned_formula + + option "with-debug", "Build with debug support" + option "with-embedded", "Build the embedded server" + option "with-local-infile", "Build with local infile loading support" + option "with-memcached", "Build with InnoDB Memcached plugin" + option "with-test", "Build with unit tests" + + deprecated_option "enable-debug" => "with-debug" + deprecated_option "enable-local-infile" => "with-local-infile" + deprecated_option "enable-memcached" => "with-memcached" + deprecated_option "with-tests" => "with-test" + + depends_on "cmake" => :build + # https://github.com/Homebrew/homebrew-core/issues/1475 + # Needs at least Clang 3.3, which shipped alongside Lion. + # Note: MySQL themselves don't support anything below El Capitan. + depends_on :macos => :lion + depends_on "openssl" + + def datadir + var/"mysql" + end + + def install + # -DINSTALL_* are relative to `CMAKE_INSTALL_PREFIX` (`prefix`) + args = %W[ + -DCOMPILATION_COMMENT=Homebrew + -DDEFAULT_CHARSET=utf8 + -DDEFAULT_COLLATION=utf8_general_ci + -DINSTALL_DOCDIR=share/doc/#{name} + -DINSTALL_INCLUDEDIR=include/mysql + -DINSTALL_INFODIR=share/info + -DINSTALL_MANDIR=share/man + -DINSTALL_MYSQLSHAREDIR=share/mysql + -DINSTALL_PLUGINDIR=lib/plugin + -DMYSQL_DATADIR=#{datadir} + -DSYSCONFDIR=#{etc} + -DWITH_BOOST=boost + -DWITH_EDITLINE=system + -DWITH_SSL=yes + ] + + # To enable unit testing at build, we need to download the unit testing suite + if build.with? "test" + args << "-DENABLE_DOWNLOADS=ON" + else + args << "-DWITH_UNIT_TESTS=OFF" + end + + # Build with debug support + args << "-DWITH_DEBUG=1" if build.with? "debug" + + # Build the embedded server + args << "-DWITH_EMBEDDED_SERVER=ON" if build.with? "embedded" + + # Build with local infile loading support + args << "-DENABLED_LOCAL_INFILE=1" if build.with? "local-infile" + + # Build with InnoDB Memcached plugin + args << "-DWITH_INNODB_MEMCACHED=ON" if build.with? "memcached" + + # To enable unit testing at build, we need to download the unit testing suite + if build.with? "test" + args << "-DENABLE_DOWNLOADS=ON" + else + args << "-DWITH_UNIT_TESTS=OFF" + end + + system "cmake", ".", *std_cmake_args, *args + system "make" + system "make", "install" + + (prefix/"mysql-test").cd do + system "./mysql-test-run.pl", "status", "--vardir=#{Dir.mktmpdir}" + end + + # Remove the tests directory if they are not built. + rm_rf prefix/"mysql-test" if build.without? "test" + + # Don't create databases inside of the prefix! + # See: https://github.com/Homebrew/homebrew/issues/4975 + rm_rf prefix/"data" + + # 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" + + # 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 datadir exists + datadir.mkpath + unless (datadir/"mysql/user.frm").exist? + ENV["TMPDIR"] = nil + system bin/"mysqld", "--initialize-insecure", "--user=#{ENV["USER"]}", + "--basedir=#{prefix}", "--datadir=#{datadir}", "--tmpdir=/tmp" + end + end + + def caveats + s = <<~EOS + We've installed your MySQL database without a root password. To secure it run: + mysql_secure_installation + + MySQL is configured to only allow connections from localhost by default + + To connect run: + mysql -uroot + EOS + if my_cnf = ["/etc/my.cnf", "/etc/mysql/my.cnf"].find { |x| File.exist? x } + s += <<~EOS + + A "#{my_cnf}" from another install may interfere with a Homebrew-built + server starting up correctly. + EOS + end + s + end + + plist_options :manual => "#{HOMEBREW_PREFIX}/opt/mysql@5.7/bin/mysql.server start" + + def plist; <<~EOS + + + + + KeepAlive + + Label + #{plist_name} + ProgramArguments + + #{opt_bin}/mysqld_safe + --datadir=#{datadir} + + RunAtLoad + + WorkingDirectory + #{datadir} + + + EOS + end + + test do + begin + # Expects datadir to be a completely clean dir, which testpath isn't. + dir = Dir.mktmpdir + system bin/"mysqld", "--initialize-insecure", "--user=#{ENV["USER"]}", + "--basedir=#{prefix}", "--datadir=#{dir}", "--tmpdir=#{dir}" + + pid = fork do + exec bin/"mysqld", "--bind-address=127.0.0.1", "--datadir=#{dir}" + end + sleep 2 + + output = shell_output("curl 127.0.0.1:3306") + output.force_encoding("ASCII-8BIT") if output.respond_to?(:force_encoding) + assert_match version.to_s, output + ensure + Process.kill(9, pid) + Process.wait(pid) + end + end +end