2016-04-19 20:37:18 +00:00
|
|
|
class Citus < Formula
|
|
|
|
desc "PostgreSQL-based distributed RDBMS"
|
|
|
|
homepage "https://www.citusdata.com"
|
2016-11-08 20:43:37 +00:00
|
|
|
url "https://github.com/citusdata/citus/archive/v6.0.0.tar.gz"
|
2016-11-10 01:46:41 +00:00
|
|
|
sha256 "90bad0e57256ca3e72c080b58877e396216cbd46c5820a8f0ec2a0ca4d062dfb"
|
2016-04-19 20:37:18 +00:00
|
|
|
head "https://github.com/citusdata/citus.git"
|
2016-11-10 01:46:41 +00:00
|
|
|
revision 1
|
2016-04-19 20:37:18 +00:00
|
|
|
|
2016-04-19 23:35:54 +00:00
|
|
|
bottle do
|
2016-11-09 12:14:35 +00:00
|
|
|
cellar :any
|
2016-11-10 02:39:56 +00:00
|
|
|
sha256 "a9a2666ca0423cd1795f7f7aa6fa316005c86365d553d8c24855ab14fed08463" => :sierra
|
|
|
|
sha256 "ede4a084ff294465c38fcff10db1d72f21163dd589a3c8d9a3e71a0b61cadc59" => :el_capitan
|
|
|
|
sha256 "68cd7026eacf87596becb4213e1b53694c1a37c877bba20f69997cf4d8635f33" => :yosemite
|
2016-04-19 23:35:54 +00:00
|
|
|
end
|
|
|
|
|
2016-04-19 20:37:18 +00:00
|
|
|
depends_on "postgresql"
|
2016-09-20 12:20:49 +00:00
|
|
|
depends_on "readline"
|
2016-04-19 20:37:18 +00:00
|
|
|
|
|
|
|
def install
|
|
|
|
ENV["PG_CONFIG"] = Formula["postgresql"].opt_bin/"pg_config"
|
|
|
|
|
|
|
|
system "./configure"
|
|
|
|
|
|
|
|
# workaround for https://github.com/Homebrew/homebrew/issues/49948
|
|
|
|
system "make", "libpq=-L#{Formula["postgresql"].opt_lib} -lpq"
|
|
|
|
|
|
|
|
# Use stage directory to prevent installing to pg_config-defined dirs,
|
|
|
|
# which would not be within this package's Cellar.
|
|
|
|
mkdir "stage"
|
|
|
|
system "make", "install", "DESTDIR=#{buildpath}/stage"
|
|
|
|
|
|
|
|
bin.install Dir["stage/**/bin/*"]
|
|
|
|
lib.install Dir["stage/**/lib/*"]
|
|
|
|
include.install Dir["stage/**/include/*"]
|
|
|
|
(share/"postgresql/extension").install Dir["stage/**/share/postgresql/extension/*"]
|
|
|
|
end
|
|
|
|
|
|
|
|
test do
|
|
|
|
pg_bin = Formula["postgresql"].opt_bin
|
|
|
|
pg_port = "55561"
|
|
|
|
system "#{pg_bin}/initdb", testpath/"test"
|
|
|
|
pid = fork do
|
|
|
|
exec("#{pg_bin}/postgres",
|
|
|
|
"-D", testpath/"test",
|
|
|
|
"-c", "shared_preload_libraries=citus",
|
|
|
|
"-p", pg_port)
|
|
|
|
end
|
|
|
|
|
|
|
|
begin
|
|
|
|
sleep 2
|
|
|
|
|
|
|
|
count_workers_query = "SELECT COUNT(*) FROM master_get_active_worker_nodes();"
|
|
|
|
|
|
|
|
system "#{pg_bin}/createdb", "-p", pg_port, "test"
|
|
|
|
system "#{pg_bin}/psql", "-p", pg_port, "-d", "test", "--command", "CREATE EXTENSION citus;"
|
|
|
|
|
|
|
|
assert_equal "0", shell_output("#{pg_bin}/psql -p #{pg_port} -d test -Atc" \
|
|
|
|
"'#{count_workers_query}'").strip
|
|
|
|
ensure
|
|
|
|
Process.kill 9, pid
|
|
|
|
Process.wait pid
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|