class Pgloader < Formula desc "Data loading tool for PostgreSQL" homepage "https://github.com/dimitri/pgloader" url "https://github.com/dimitri/pgloader/archive/v3.4.1.tar.gz" sha256 "3ac4d03706057a35e1d4d0e63571b84be7d0d07ea09e015d90e242200488fe82" revision 1 head "https://github.com/dimitri/pgloader.git" bottle do sha256 "53730fd18e30016cdff390c71dcd0d8edc73752d8cd6c052712d537be70572ee" => :high_sierra sha256 "439e83a886a19c0833721b3e67aa6a08ab0aff17045c279d7e54d9171637abfe" => :sierra sha256 "0eff8a198207076e8e7e9f56d164c1c705b1310b2af0a79e27afd0be91338426" => :el_capitan end depends_on "sbcl" depends_on "freetds" depends_on "buildapp" => :build depends_on :postgresql => :recommended # Resource stanzas are generated automatically by quicklisp-roundup. # See: https://github.com/benesch/quicklisp-homebrew-roundup resource "alexandria" do url "https://beta.quicklisp.org/archive/alexandria/2017-06-30/alexandria-20170630-git.tgz" sha256 "3aba94f9f45d87eb08e6593b3d6ed2c72eb11e5e02c4315bf9af68190f4a07b2" end resource "anaphora" do url "https://beta.quicklisp.org/archive/anaphora/2017-02-27/anaphora-20170227-git.tgz" sha256 "a9790080e92f451e4bd43ccd8accf69d1e0f2089e0de207bf4271b4fd932dbc6" end resource "asdf-finalizers" do url "https://beta.quicklisp.org/archive/asdf-finalizers/2017-04-03/asdf-finalizers-20170403-git.tgz" sha256 "b22f0fa44b662abdab5e844b03cd104f1c391234ad3d7bd4928bc521025053f0" end resource "asdf-system-connections" do url "https://beta.quicklisp.org/archive/asdf-system-connections/2017-01-24/asdf-system-connections-20170124-git.tgz" sha256 "f8723e0b0b8bd5f964f7726536e52aacb2e9833d475fcde8333cda81d7190241" end resource "babel" do url "https://beta.quicklisp.org/archive/babel/2017-06-30/babel-20170630-git.tgz" sha256 "9d0277f5b93012dd8db4e2288e28cfcb3fc3365022d3fb76fabf4c3adb773270" end resource "bordeaux-threads" do url "https://beta.quicklisp.org/archive/bordeaux-threads/2016-03-18/bordeaux-threads-v0.8.5.tgz" sha256 "edaedd450d9267b0a578c9da421fdc96e5f93b119d1502abb1d428e646eb0127" end resource "cffi" do url "https://beta.quicklisp.org/archive/cffi/2017-06-30/cffi_0.19.0.tgz" sha256 "49366f97ce20f1a9081b1abce89ab62608dc781dfeb40105a6c98d8b8182638b" end resource "chipz" do url "https://beta.quicklisp.org/archive/chipz/2016-03-18/chipz-20160318-git.tgz" sha256 "4620842f94c9431379e9e7e4f27c46381e1730fb1a2c187b39600ed2267afab6" end resource "chunga" do url "https://beta.quicklisp.org/archive/chunga/2014-12-17/chunga-1.1.6.tgz" sha256 "efd3a4a1272cc8c04a0875967175abc65e99ff43a5ca0bad12f74f0953746dc7" end resource "cl+ssl" do url "https://beta.quicklisp.org/archive/cl+ssl/2017-06-30/cl+ssl-20170630-git.tgz" sha256 "0808d95e2775b897ddd458f8ad385628f48453c02b7895ab40d857cbfc780eee" end resource "cl-abnf" do url "https://beta.quicklisp.org/archive/cl-abnf/2015-06-08/cl-abnf-20150608-git.tgz" sha256 "0799bfdc43b7c645934af8c190e58d4d0fac3973ec669ef2feeae0b20f2ca903" end resource "cl-base64" do url "https://beta.quicklisp.org/archive/cl-base64/2015-09-23/cl-base64-20150923-git.tgz" sha256 "17fab703f316d232b477bd2f8b521283cc0c7410f9b787544f3924007ab95141" end resource "cl-containers" do url "https://beta.quicklisp.org/archive/cl-containers/2017-04-03/cl-containers-20170403-git.tgz" sha256 "afafc5d18d07c783e37b1ad6ef29e8bc552292b4ddd5fd7544868cddcb5f9c72" end resource "cl-csv" do url "https://beta.quicklisp.org/archive/cl-csv/2017-04-03/cl-csv-20170403-git.tgz" sha256 "d0f88b2b973a1ae252b4f429c3be41e2de5897ea1fabd57e0bbcfb934186e0d7" end resource "cl-db3" do url "https://beta.quicklisp.org/archive/cl-db3/2015-03-02/cl-db3-20150302-git.tgz" sha256 "b1ffd5c0d0e3eca1a505e20e0c4e888a2ec87f37faa9f1fc62adefc6ceba8d57" end resource "cl-fad" do url "https://beta.quicklisp.org/archive/cl-fad/2016-08-25/cl-fad-0.7.4.tgz" sha256 "3d6d30910217d11bfcef0c2805c9c79e0946bf2696f057bd2efbe66d8c2c77ab" end resource "cl-interpol" do url "https://beta.quicklisp.org/archive/cl-interpol/2016-09-29/cl-interpol-0.2.6.tgz" sha256 "0bc1d45179d4295ee25a012558f7fd167724c9c74b1a7b3e74be3b7217f1519c" end resource "cl-ixf" do url "https://beta.quicklisp.org/archive/cl-ixf/2017-06-30/cl-ixf-20170630-git.tgz" sha256 "c2d1cbc962c0e3136df4d7e1de65f304aa421fa1ad2fb0e3d1aaf945c7d7d5e1" end resource "cl-log" do url "https://beta.quicklisp.org/archive/cl-log/2013-01-28/cl-log.1.0.1.tgz" sha256 "4d7840b9e3bf5a979f780ba937f4e268c73db48e2f91f6c7c541d86e3ac0ab71" end resource "cl-markdown" do url "https://beta.quicklisp.org/archive/cl-markdown/2010-10-06/cl-markdown-20101006-darcs.tgz" sha256 "3c1da678be4f7ee71c245fafa56c1b6f4d3e49e7c6d5cc9b5aafc30abf3e3bc3" end resource "cl-mssql" do url "https://beta.quicklisp.org/archive/cl-mssql/2017-06-30/cl-mssql-20170630-git.tgz" sha256 "be6fb798a33ceb6bb35fc4e09dcb56144f3e08b66c6d9e35b2f8a29ac6d49a6f" end resource "cl-ppcre" do url "https://beta.quicklisp.org/archive/cl-ppcre/2015-09-23/cl-ppcre-2.0.11.tgz" sha256 "626d4e1f78659d0b6e4d675c94e39afb1f602427724c961b1e4f029b348f4cb6" end resource "cl-sqlite" do url "https://beta.quicklisp.org/archive/cl-sqlite/2013-06-15/cl-sqlite-20130615-git.tgz" sha256 "105333bbdccc3c2ab76ce4a35c63e6b27ac8a7a0967971c4addd666df7766135" end resource "cl-unicode" do url "https://beta.quicklisp.org/archive/cl-unicode/2014-12-17/cl-unicode-0.1.5.tgz" sha256 "d690480a82bfaa8d5dba29b68bc24f13e4e485f825904e5822879a280bc6a5c9" end resource "cl-utilities" do url "https://beta.quicklisp.org/archive/cl-utilities/2010-10-06/cl-utilities-1.2.4.tgz" sha256 "07a9318732d73b5195b1a442391d10395c7de471f1fe12feedfe71b1edbd51fc" end resource "closer-mop" do url "https://beta.quicklisp.org/archive/closer-mop/2017-06-30/closer-mop-20170630-git.tgz" sha256 "b3e335dc626d13a1d7545f7ed747d36841287488d27a5906bf367656844896b1" end resource "command-line-arguments" do url "https://beta.quicklisp.org/archive/command-line-arguments/2015-12-18/command-line-arguments-20151218-git.tgz" sha256 "d0fba1c0ac361aab4273425079945ee1ac8e7d7e7b9a960026a8c999e41edb1f" end resource "drakma" do url "https://beta.quicklisp.org/archive/drakma/2017-06-30/drakma-v2.0.3.tgz" sha256 "ad7a7334f42f81524475a6473fb8f869607a608d46d2b506c0f784f744e36bf5" end resource "dynamic-classes" do url "https://beta.quicklisp.org/archive/dynamic-classes/2013-01-28/dynamic-classes-20130128-git.tgz" sha256 "4a93d3a39dca61c87b29877fa9707b647fc08f117f80f2a741f649e4d04c4b44" end resource "esrap" do url "https://beta.quicklisp.org/archive/esrap/2017-06-30/esrap-20170630-git.tgz" sha256 "b08769db4ca71a3b25db32c6bcc9b7144e13570eea2f1fd903d98f354b81579c" end resource "flexi-streams" do url "https://beta.quicklisp.org/archive/flexi-streams/2015-07-09/flexi-streams-1.0.15.tgz" sha256 "f70c76e1724978100e26d9e0e0a0844939cde084b0d7f5623f1adbc8cb187d7e" end resource "garbage-pools" do url "https://beta.quicklisp.org/archive/garbage-pools/2013-07-20/garbage-pools-20130720-git.tgz" sha256 "05f014fd95526107af6d99a612b78292fbf3b8a6e9e2efcb04d6ab7e835ab6c5" end resource "ieee-floats" do url "https://beta.quicklisp.org/archive/ieee-floats/2016-03-18/ieee-floats-20160318-git.tgz" sha256 "a47baa0658b5ab8c202e85327a2dac5f639ae82471aed2b9ebee795fb0c1846f" end resource "ironclad" do url "https://beta.quicklisp.org/archive/ironclad/2017-06-30/ironclad-v0.34.tgz" sha256 "60f6e6fdd1120f2badee65b9d3d465bd01b3c0eac439459406797d78f4b7b423" end resource "iterate" do url "https://beta.quicklisp.org/archive/iterate/2016-08-25/iterate-20160825-darcs.tgz" sha256 "f55db27495b731c65f3d3dee8b453cd55924b22f1ef5e01df86dda6e9f097f4f" end resource "local-time" do url "https://beta.quicklisp.org/archive/local-time/2017-06-30/local-time-20170630-git.tgz" sha256 "b8f463abf0a0447c26063cce7d31cd43caf6f68e6b4c7991dc1c5272ee905dd5" end resource "lparallel" do url "https://beta.quicklisp.org/archive/lparallel/2016-08-25/lparallel-20160825-git.tgz" sha256 "213bc89e6bbabe07fc3bcb21be1021b31f6f2ab1b7a2abb358a01ab9bee69c73" end resource "md5" do url "https://beta.quicklisp.org/archive/md5/2017-06-30/md5-20170630-git.tgz" sha256 "ddc3c29843fecf1af5f39346ff91cebadcc4ffb61d3e64698acbcda90722915e" end resource "metabang-bind" do url "https://beta.quicklisp.org/archive/metabang-bind/2017-01-24/metabang-bind-20170124-git.tgz" sha256 "8c77ec6f258ebedad018f3f474c29a42246361143091b3cca35e009658f6d1f7" end resource "metatilities-base" do url "https://beta.quicklisp.org/archive/metatilities-base/2017-04-03/metatilities-base-20170403-git.tgz" sha256 "799d8a3743660bb98bf517a22aae0c73269061fdf9e69214c3b679f3ee9f8191" end resource "nibbles" do url "https://beta.quicklisp.org/archive/nibbles/2017-04-03/nibbles-20170403-git.tgz" sha256 "64d232bc15c6c6a31d66e09c868c6df901aa41d9f20531ffad7854882197e72d" end resource "parse-number" do url "https://beta.quicklisp.org/archive/parse-number/2014-08-26/parse-number-1.4.tgz" sha256 "90ae04cd1a43fe186d07e5f805faa6cc8a00d1134dd9d99b56e31fa2f5811279" end resource "postmodern" do url "https://beta.quicklisp.org/archive/postmodern/2017-04-03/postmodern-20170403-git.tgz" sha256 "37edfb43fc73a25a482ed5b7adb4a2fad1cc726ee950da57cd5439e0c1ad74de" end resource "puri" do url "https://beta.quicklisp.org/archive/puri/2015-09-23/puri-20150923-git.tgz" sha256 "0a0784c4d592733c1232fdee1074e9898a091359da142985a44b9528bff02a25" end resource "py-configparser" do url "https://beta.quicklisp.org/archive/py-configparser/2013-10-03/py-configparser-20131003-svn.tgz" sha256 "9d5365e66f5d788535d53ebf4c733e7d0d47c5b5e5f817c151503325e8c69a81" end resource "qmynd" do url "https://beta.quicklisp.org/archive/qmynd/2017-06-30/qmynd-20170630-git.tgz" sha256 "71199f944d1de8ff371185901c4a8ee723e31d93ed899fc62b2e054b6a162f07" end resource "quri" do url "https://beta.quicklisp.org/archive/quri/2016-12-04/quri-20161204-git.tgz" sha256 "7b29fe2c2746f2cf59eee703b2ff65b10e6ed2e10232f2c8456657d1e6402e92" end resource "split-sequence" do url "https://beta.quicklisp.org/archive/split-sequence/2015-08-04/split-sequence-1.2.tgz" sha256 "145c5c36e0b4edf77e2cf6df7f8c6b3aa9018211e269cafb97e9631bb7f3a58b" end resource "trivial-backtrace" do url "https://beta.quicklisp.org/archive/trivial-backtrace/2016-05-31/trivial-backtrace-20160531-git.tgz" sha256 "1df68d7d0f4a9611e5470cdacae58d594b26cc63b223e89fd85152b119559bed" end resource "trivial-features" do url "https://beta.quicklisp.org/archive/trivial-features/2016-12-04/trivial-features-20161204-git.tgz" sha256 "424681538abfa8c5af41fae0099c6e5cb9b05f823a094abba42fcac312f35f44" end resource "trivial-garbage" do url "https://beta.quicklisp.org/archive/trivial-garbage/2015-01-13/trivial-garbage-20150113-git.tgz" sha256 "08c0a03595843576835086dc5973cfb535f75f77de4b90e9c9b97c7eba97c1fb" end resource "trivial-gray-streams" do url "https://beta.quicklisp.org/archive/trivial-gray-streams/2014-08-26/trivial-gray-streams-20140826-git.tgz" sha256 "22757737e6b63a21f5e7f44980df8047f8c8294c290eeaaaf01bef1f31b80bda" end resource "trivial-utf-8" do url "https://beta.quicklisp.org/archive/trivial-utf-8/2011-10-01/trivial-utf-8-20111001-darcs.tgz" sha256 "8b17c345da11796663cfd04584445c62f09e789981a83ebefe7970a30b0aafd2" end resource "uiop" do url "https://beta.quicklisp.org/archive/uiop/2017-06-30/uiop-3.2.1.tgz" sha256 "bbb8fa413d23d8236b89ecbb5a9beba9cc3c8d21494a57a8a7acbc355b3086fe" end resource "usocket" do url "https://beta.quicklisp.org/archive/usocket/2016-10-31/usocket-0.7.0.1.tgz" sha256 "c2454e8d8f65bf81aadf877d65d9b6364ed25f8560ad405063e2b4bfb872ecd6" end resource "uuid" do url "https://beta.quicklisp.org/archive/uuid/2013-08-13/uuid-20130813-git.tgz" sha256 "0e8657bdf7ad131641f6d878f953ebf74d3cda06b8be99dd8bb8cffbe34308de" end def install resources.each do |resource| resource.stage buildpath/"lib"/resource.name end ENV["CL_SOURCE_REGISTRY"] = "#{buildpath}/lib//:#{buildpath}//" ENV["ASDF_OUTPUT_TRANSLATIONS"] = "/:/" system "make", "pgloader-standalone", "BUILDAPP=buildapp" bin.install "build/bin/pgloader" man1.install "pgloader.1" end def launch_postgres(socket_dir) require "timeout" socket_dir = Pathname.new(socket_dir) mkdir_p socket_dir postgres_command = [ "postgres", "--listen_addresses=", "--unix_socket_directories=#{socket_dir}", ] IO.popen(postgres_command * " ") do |postgres| begin ohai postgres_command * " " # Postgres won't create the socket until it's ready for connections, but # if it fails to start, we'll be waiting for the socket forever. So we # time out quickly; this is simpler than mucking with child process # signals. Timeout.timeout(5) { sleep 0.2 while socket_dir.children.empty? } yield ensure Process.kill(:TERM, postgres.pid) end end end test do # Remove any Postgres environment variables that might prevent us from # isolating this disposable copy of Postgres. ENV.reject! { |key, _| key.start_with?("PG") } ENV["PGDATA"] = testpath/"data" ENV["PGHOST"] = testpath/"socket" ENV["PGDATABASE"] = "brew" (testpath/"test.load").write <<-EOS.undent LOAD CSV FROM inline (code, country) INTO postgresql:///#{ENV["PGDATABASE"]}?tablename=csv WITH fields terminated by ',' BEFORE LOAD DO $$ CREATE TABLE csv (code char(2), country text); $$; GB,United Kingdom US,United States CA,Canada US,United States GB,United Kingdom CA,Canada EOS system "initdb" launch_postgres(ENV["PGHOST"]) do system "createdb" system "#{bin}/pgloader", testpath/"test.load" assert_equal "6", shell_output("psql -Atc 'SELECT COUNT(*) FROM csv'").strip end end end