homebrew-core/Formula/filebeat.rb
2016-11-16 11:55:02 +01:00

87 lines
2.5 KiB
Ruby

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.0.1.tar.gz"
sha256 "707bea8d8eb8cc358bddfcaffa5e90da2a09fab00f2fc53608cc013c79743117"
head "https://github.com/elastic/beats.git"
bottle do
cellar :any_skip_relocation
sha256 "8520059d8497bad8ce4f090efd6fcfa282daa54175e7562b17882a3be7a76588" => :sierra
sha256 "9772d07ced27ce00a510af00e54810c580ed7c6d9e51a3e6456586feb38354e2" => :el_capitan
sha256 "6641c4ff2be404cadc441c61ad946024a6e7afd0097a521c7def3e6058d23665" => :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
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple Computer//DTD PLIST 1.0//EN"
"http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>Label</key>
<string>#{plist_name}</string>
<key>Program</key>
<string>#{opt_bin}/filebeat</string>
<key>RunAtLoad</key>
<true/>
</dict>
</plist>
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