require 'fluent/test' require 'helper' require 'net/http' class HttpInputTest < Test::Unit::TestCase def setup Fluent::Test.setup end PORT = unused_port CONFIG = %[ port #{PORT} bind 127.0.0.1 body_size_limit 10m keepalive_timeout 5 ] def create_driver(conf=CONFIG) Fluent::Test::InputTestDriver.new(Fluent::HttpInput).configure(conf) end def test_configure d = create_driver assert_equal PORT, d.instance.port assert_equal '127.0.0.1', d.instance.bind assert_equal 10*1024*1024, d.instance.body_size_limit assert_equal 5, d.instance.keepalive_timeout assert_equal false, d.instance.add_http_headers end def test_time d = create_driver time = Time.parse("2011-01-02 13:14:15 UTC").to_i Fluent::Engine.now = time d.expect_emit "tag1", time, {"a"=>1} d.expect_emit "tag2", time, {"a"=>2} d.run do d.expected_emits.each {|tag,time,record| res = post("/#{tag}", {"json"=>record.to_json}) assert_equal "200", res.code } end end def test_json d = create_driver time = Time.parse("2011-01-02 13:14:15 UTC").to_i d.expect_emit "tag1", time, {"a"=>1} d.expect_emit "tag2", time, {"a"=>2} d.run do d.expected_emits.each {|tag,time,record| res = post("/#{tag}", {"json"=>record.to_json, "time"=>time.to_s}) assert_equal "200", res.code } end d.emit_streams.each { |tag, es| assert !include_http_header?(es.first[1]) } end def test_json_with_add_http_headers d = create_driver(CONFIG + "add_http_headers true") time = Time.parse("2011-01-02 13:14:15 UTC").to_i records = [["tag1", time, {"a"=>1}], ["tag2", time, {"a"=>2}]] d.run do records.each {|tag,time,record| res = post("/#{tag}", {"json"=>record.to_json, "time"=>time.to_s}) assert_equal "200", res.code } end d.emit_streams.each { |tag, es| assert include_http_header?(es.first[1]) } end def test_application_json d = create_driver time = Time.parse("2011-01-02 13:14:15 UTC").to_i d.expect_emit "tag1", time, {"a"=>1} d.expect_emit "tag2", time, {"a"=>2} d.run do d.expected_emits.each {|tag,time,record| http = Net::HTTP.new("127.0.0.1", PORT) req = Net::HTTP::Post.new("/#{tag}?time=#{time.to_s}", {"content-type"=>"application/json; charset=utf-8"}) req.body = record.to_json res = http.request(req) assert_equal "200", res.code } end end def test_msgpack d = create_driver time = Time.parse("2011-01-02 13:14:15 UTC").to_i d.expect_emit "tag1", time, {"a"=>1} d.expect_emit "tag2", time, {"a"=>2} d.run do d.expected_emits.each {|tag,time,record| res = post("/#{tag}", {"msgpack"=>record.to_msgpack, "time"=>time.to_s}) assert_equal "200", res.code } end end def post(path, params) http = Net::HTTP.new("127.0.0.1", PORT) req = Net::HTTP::Post.new(path, {}) req.set_form_data(params) http.request(req) end def include_http_header?(record) record.keys.find { |header| header.start_with?('HTTP_') } end end