class Filebeat < Formula desc "File harvester to ship log files to Elasticsearch or Logstash" homepage "https://www.elastic.co/products/beats/filebeat" url "https://github.com/elastic/beats/archive/v5.1.2.tar.gz" sha256 "7cd554f8be6b02290ebbc17c9820acde3dc59108672ced7a0cf5486faa3e23ce" head "https://github.com/elastic/beats.git" bottle do sha256 "e43b29210346298b9d219fa7de0127bf5e8de1f7d469727e7c5d0f0a54b5a9d5" => :sierra sha256 "61577ddfc609c4274fe6dec8d538849551355c90044bb330b4dbc0fc87e9169a" => :el_capitan sha256 "814a5a8142ef3fe51ae8cdc7b349988d89e134b873f24d9f98d5e4d5b44554d4" => :yosemite end depends_on "go" => :build def install gopath = buildpath/"gopath" (gopath/"src/github.com/elastic/beats").install Dir["{*,.git,.gitignore}"] ENV["GOPATH"] = gopath cd gopath/"src/github.com/elastic/beats/filebeat" do system "make" libexec.install "filebeat" (etc/"filebeat").install("filebeat.yml", "filebeat.template.json", "filebeat.template-es2x.json") end (bin/"filebeat").write <<-EOS.undent #!/bin/sh exec #{libexec}/filebeat -path.config #{etc}/filebeat -path.home #{prefix} -path.logs #{var}/log/filebeat -path.data #{var}/filebeat $@ EOS end plist_options :manual => "filebeat" def plist; <<-EOS.undent Label #{plist_name} Program #{opt_bin}/filebeat RunAtLoad EOS end test do log_file = testpath/"test.log" touch log_file (testpath/"filebeat.yml").write <<-EOS.undent filebeat: prospectors: - paths: - #{log_file} scan_frequency: 0.1s filebeat.idle_timeout: 0.1s output: file: path: #{testpath} EOS (testpath/"log").mkpath (testpath/"data").mkpath filebeat_pid = fork { exec "#{bin}/filebeat -c #{testpath}/filebeat.yml -path.config #{testpath}/filebeat -path.home=#{testpath} -path.logs #{testpath}/log -path.data #{testpath}" } begin sleep 1 log_file.append_lines "foo bar baz" sleep 5 assert File.exist? testpath/"filebeat" ensure Process.kill("TERM", filebeat_pid) end end end