require 'helper'
class NotifierOutputTest < Test::Unit::TestCase
def setup
Fluent::Test.setup
end
CONFIG = %[
type notifier
input_tag_remove_prefix test
check numeric
target_key numfield
lower_threshold 2.5
upper_threshold 5000
check regexp
target_key textfield
include_pattern Target.*
exclude_pattern TargetC
pattern pattern1
check numeric_upward
warn_threshold 25
crit_threshold 50
tag_warn alert.warn
tag_crit alert.crit
target_keys num1,num2,num3
pattern pattern2
check string_find
crit_regexp ERROR
warn_regexp WARNING
tag alert
target_key_pattern ^message.*$
]
def create_driver(conf=CONFIG,tag='test')
Fluent::Test::OutputTestDriver.new(Fluent::NotifierOutput, tag).configure(conf)
end
def test_configure
d = create_driver
assert_nil nil # no one exception raised
end
def test_emit
d = create_driver
d.run do
d.emit({'num1' => 20, 'message' => 'INFO'})
end
assert_equal 0, d.emits.size
d = create_driver
d.run do
d.emit({'num1' => 30, 'message' => 'INFO'})
end
assert_equal 0, d.emits.size
d = create_driver(CONFIG, 'test.input')
d.run do
d.emit({'num1' => 30, 'message' => 'INFO', 'numfield' => '30', 'textfield' => 'TargetX'})
end
assert_equal 1, d.emits.size
assert_equal 'alert.warn', d.emits[0][0]
assert_equal 'pattern1', d.emits[0][2]['pattern']
assert_equal 'input', d.emits[0][2]['target_tag']
assert_equal 'numeric_upward', d.emits[0][2]['check_type']
assert_equal 'warn', d.emits[0][2]['level']
assert_equal 25.0, d.emits[0][2]['threshold']
assert_equal 30.0, d.emits[0][2]['value']
d = create_driver
d.run do
d.emit({'num1' => 60, 'message' => 'foo bar WARNING xxxxx', 'numfield' => '30', 'textfield' => 'TargetX'})
end
assert_equal 2, d.emits.size
assert_equal 'alert.crit', d.emits[0][0]
assert_equal 'pattern1', d.emits[0][2]['pattern']
assert_equal 'test', d.emits[0][2]['target_tag']
assert_equal 'numeric_upward', d.emits[0][2]['check_type']
assert_equal 'crit', d.emits[0][2]['level']
assert_equal 50.0, d.emits[0][2]['threshold']
assert_equal 60.0, d.emits[0][2]['value']
assert_equal 'alert', d.emits[1][0]
assert_equal 'pattern2', d.emits[1][2]['pattern']
assert_equal 'test', d.emits[1][2]['target_tag']
assert_equal 'string_find', d.emits[1][2]['check_type']
assert_equal 'warn', d.emits[1][2]['level']
assert_equal '/WARNING/', d.emits[1][2]['regexp']
assert_equal 'foo bar WARNING xxxxx', d.emits[1][2]['value']
d = create_driver
d.run do
d.emit({'num1' => 60, 'message' => 'foo bar WARNING xxxxx', 'numfield' => '2.4', 'textfield' => 'TargetX'})
end
assert_equal 0, d.emits.size
d = create_driver
d.run do
d.emit({'num1' => 60, 'message' => 'foo bar WARNING xxxxx', 'numfield' => '20', 'textfield' => 'TargetC'})
end
assert_equal 0, d.emits.size
d = create_driver
d.run do
d.emit({'num1' => 60, 'message' => 'foo bar WARNING xxxxx', 'numfield' => '20'})
end
assert_equal 0, d.emits.size
end
def test_emit_invalid_byte
invalid_utf8 = "\xff".force_encoding('UTF-8')
d = create_driver
assert_nothing_raised {
d.run do
d.emit({'num1' => 60, 'message' => "foo bar WARNING #{invalid_utf8}", 'numfield' => '30', 'textfield' => 'TargetX'})
end
}
end
end