require "helper"
require "fluent/plugin/in_tcp"
class TcpInputWithGrokTest < Test::Unit::TestCase
if defined?(ServerEngine)
class << self
def startup
socket_manager_path = ServerEngine::SocketManager::Server.generate_path
@server = ServerEngine::SocketManager::Server.open(socket_manager_path)
ENV["SERVERENGINE_SOCKETMANAGER_PATH"] = socket_manager_path.to_s
end
def shutdown
@server.close
end
end
end
def setup
Fluent::Test.setup
end
PORT = unused_port
BASE_CONFIG = %[
port #{PORT}
tag tcp
]
CONFIG = BASE_CONFIG + %[
bind 127.0.0.1
@type grok
pattern %{GREEDYDATA:message}
]
IPv6_CONFIG = BASE_CONFIG + %[
bind ::1
@type grok
pattern %{GREEDYDATA:message}
]
def create_driver(conf)
Fluent::Test::Driver::Input.new(Fluent::Plugin::TcpInput).configure(conf)
end
data do
configs = {}
configs[:ipv4] = ["127.0.0.1", CONFIG]
configs[:ipv6] = ["::1", IPv6_CONFIG] if ipv6_enabled?
configs
end
def test_configure(data)
k, config = data
d = create_driver(config)
assert_equal PORT, d.instance.port
assert_equal k, d.instance.bind
assert_equal "\n", d.instance.delimiter
end
def test_grok_pattern
tests = [
{"msg" => "tcptest1\n", "expected" => "tcptest1"},
{"msg" => "tcptest2\n", "expected" => "tcptest2"},
]
config = %[
@type grok
grok_pattern %{GREEDYDATA:message}
]
internal_test_grok(config, tests)
end
def test_grok_pattern_block_config
tests = [
{"msg" => "tcptest1\n", "expected" => "tcptest1"},
{"msg" => "tcptest2\n", "expected" => "tcptest2"},
]
block_config = %[
@type grok
pattern %{GREEDYDATA:message}
]
internal_test_grok(block_config, tests)
end
def test_grok_multi_patterns
tests = [
{"msg" => "Current time is 2014-01-01T00:00:00+0900\n", "expected" => "2014-01-01T00:00:00+0900"},
{"msg" => "The first word matches\n", "expected" => "The"}
]
block_config = %[
@type grok
pattern %{TIMESTAMP_ISO8601:message}
pattern %{WORD:message}
]
internal_test_grok(block_config, tests)
end
def internal_test_grok(conf, tests)
d = create_driver(BASE_CONFIG + conf)
d.run(expect_emits: tests.size) do
tests.each {|test|
TCPSocket.open("127.0.0.1", PORT) do |s|
s.send(test["msg"], 0)
end
}
end
compare_test_result(d.events, tests)
end
def compare_test_result(events, tests)
assert_equal(2, events.size)
events.each_index {|i|
assert_equal(tests[i]["expected"], events[i][2]["message"])
}
end
end