homebrew-core/Formula/filebeat.rb
2016-12-09 15:11:09 +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.1.1.tar.gz"
sha256 "f280b975afffd5c2e9ddb9aef2823aff065aec8c41325999c2721fa2770dafb0"
head "https://github.com/elastic/beats.git"
bottle do
cellar :any_skip_relocation
sha256 "4ebb69383ffe0fd2f0ec892044165d63125c480878498849e860c14b842e09f1" => :sierra
sha256 "e3d5137278b27025626f98234634d3100a34ff561a1fe146cb662883aad9f46d" => :el_capitan
sha256 "b4f91f12cb2d1310718229fcbf3efb59b7944156e06801f810d3ca09eed4afbc" => :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