-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpg_jsonschema.rb
92 lines (76 loc) · 3.35 KB
/
pg_jsonschema.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
class PgJsonschema < Formula
desc "PostgreSQL extension providing JSON Schema validation"
homepage "https://github.com/supabase/pg_jsonschema"
url "https://github.com/supabase/pg_jsonschema/archive/refs/tags/v0.3.3.tar.gz"
sha256 "40c2cffab4187e0233cb8c3bde013be92218c282f95f4469c5282f6b30d64eac"
license "Apache-2.0"
bottle do
root_url "https://ghcr.io/v2/bayandin/tap"
rebuild 1
sha256 cellar: :any, arm64_sequoia: "e3a77022397eb1e79d78a69f34b76a17f73d9cf7818a519f2b4233962e5209cf"
sha256 cellar: :any, arm64_sonoma: "875700a8fe39cedff87090605cf84c400dd7a2d1cb07025e2bfb82a3b4876279"
sha256 cellar: :any, ventura: "a04700eaa07bdf64b19fa9f03739dcb796dd7f578b9504404bb1f638a339e0d7"
sha256 cellar: :any_skip_relocation, x86_64_linux: "bfd714b65a6b4972606126073d32533800ad72dab2bb68aeb2851647c47af03c"
end
depends_on "rust" => :build
depends_on "bayandin/tap/neon-postgres"
uses_from_macos "llvm" => :build
resource "pgrx" do
url "https://github.com/pgcentralfoundation/pgrx/archive/refs/tags/v0.12.6.tar.gz"
sha256 "ba04f50b3f9f160a1c70861ad2358b3eb6485dbc13608eef09b4094460487a57"
end
def neon_postgres
Formula["bayandin/tap/neon-postgres"]
end
def pg_versions
neon_postgres.pg_versions
end
def install
resource("pgrx").stage do
system "cargo", "install", *std_cargo_args(root: buildpath/"pgrx", path: "cargo-pgrx")
ENV.prepend_path "PATH", buildpath/"pgrx/bin"
end
inreplace "Cargo.toml", /pgrx = "([^"]+)"/,
"pgrx = { version = \"\\1\", features = [ \"unsafe-postgres\" ] }"
# Postgres symbols won't be available until runtime
ENV["RUSTFLAGS"] = "-Clink-arg=-Wl,-undefined,dynamic_lookup"
args = []
pg_versions.each do |v|
args << "--pg#{v.delete_prefix("v")}" << (neon_postgres.pg_bin_for(v)/"pg_config")
end
system "cargo", "pgrx", "init", *args
pg_versions.each do |v|
system "cargo", "pgrx", "package", "--profile", "release",
"--pg-config", neon_postgres.pg_bin_for(v)/"pg_config",
"--out-dir", "stage-#{v}"
stage_dir = Pathname("stage-#{v}#{HOMEBREW_PREFIX}")
mkdir_p lib/neon_postgres.name/v
mv stage_dir/"lib/neon-postgres/#{v}/pg_jsonschema.#{neon_postgres.dlsuffix(v)}", lib/neon_postgres.name/v
from_ext_dir = stage_dir/"share/neon-postgres/#{v}/extension"
to_ext_dir = share/neon_postgres.name/v/"extension"
mkdir_p to_ext_dir
mv from_ext_dir/"pg_jsonschema.control", to_ext_dir
mv Dir[from_ext_dir/"pg_jsonschema--*.sql"], to_ext_dir
end
end
test do
pg_versions.each do |v|
pg_ctl = neon_postgres.pg_bin_for(v)/"pg_ctl"
psql = neon_postgres.pg_bin_for(v)/"psql"
port = free_port
system pg_ctl, "initdb", "-D", testpath/"test-#{v}"
(testpath/"test-#{v}/postgresql.conf").write <<~EOS, mode: "a+"
port = #{port}
EOS
system pg_ctl, "start", "-D", testpath/"test-#{v}", "-l", testpath/"log-#{v}"
begin
system psql, "-p", port.to_s, "-c", <<~SQL, "postgres"
CREATE EXTENSION pg_jsonschema;
SELECT json_matches_schema('{"type": "object"}', '{}');
SQL
ensure
system pg_ctl, "stop", "-D", testpath/"test-#{v}"
end
end
end
end