require 'helper' class StringScrubOutputTest < Test::Unit::TestCase def setup Fluent::Test.setup end CONFIG = %[ remove_prefix input add_prefix scrubbed ] CONFIG_REPLACE_CHAR = %[ remove_prefix input add_prefix scrubbed replace_char ? ] CONFIG_UNICODE_1 = %[ remove_prefix input add_prefix scrubbed replace_char \uFFFD ] CONFIG_UNICODE_2 = %[ remove_prefix input add_prefix scrubbed replace_char \u{FFFD} ] def create_driver(conf = CONFIG) Fluent::Test::Driver::Output.new(Fluent::Plugin::StringScrubOutput).configure(conf) end def test_configure assert_raise(Fluent::ConfigError) { d = create_driver('') } assert_raise(Fluent::ConfigError) { d = create_driver %[ tag foo.bar remove_prefix removed ] } assert_raise(Fluent::ConfigError) { d = create_driver %[ tag foo.bar add_prefix added ] } assert_raise(Fluent::ConfigError) { d = create_driver %[ tag foo.bar remove_prefix removed add_prefix added ] } assert_nothing_raised { d = create_driver %[ tag foo.bar ] } assert_nothing_raised { d = create_driver %[ add_prefix added ] } assert_nothing_raised { d = create_driver %[ remove_prefix removed ] } assert_nothing_raised { d = create_driver %[ remove_prefix removed add_prefix added ] } end def test_emit1_invalid_string orig_message = 'testtesttest' invalid_utf8 = "\xff".force_encoding('UTF-8') d1 = create_driver(CONFIG) d1.run(default_tag: 'input.log') do d1.feed({'message' => orig_message + invalid_utf8}) end emits = d1.events assert_equal 1, emits.length e1 = emits[0] assert_equal "scrubbed.log", e1[0] assert_equal orig_message, e1[2]['message'] invalid_ascii = "\xff".force_encoding('US-ASCII') d2 = create_driver(CONFIG) d2.run(default_tag: 'input.log2') do d2.feed({'message' => orig_message + invalid_utf8}) end emits = d2.events assert_equal 1, emits.length e2 = emits[0] assert_equal "scrubbed.log2", e2[0] assert_equal orig_message, e2[2]['message'] end def test_emit2_replace_char orig_message = 'testtesttest' invalid_utf8 = "\xff".force_encoding('UTF-8') d1 = create_driver(CONFIG_REPLACE_CHAR) d1.run(default_tag: 'input.log') do d1.feed({'message' => orig_message + invalid_utf8}) end emits = d1.events assert_equal 1, emits.length e1 = emits[0] assert_equal "scrubbed.log", e1[0] assert_equal orig_message + '?', e1[2]['message'] invalid_ascii = "\xff".force_encoding('US-ASCII') d2 = create_driver(CONFIG_REPLACE_CHAR) d2.run(default_tag: 'input.log2') do d2.feed({'message' => orig_message + invalid_utf8}) end emits = d2.events assert_equal 1, emits.length e2 = emits[0] assert_equal "scrubbed.log2", e2[0] assert_equal orig_message + '?', e2[2]['message'] end def test_emit3_struct_message orig_message = 'testtesttest' invalid_utf8 = "\xff".force_encoding('UTF-8') d1 = create_driver(CONFIG_REPLACE_CHAR) d1.run(default_tag: 'input.log') do d1.feed({'message' => {'message_child' => orig_message + invalid_utf8}}) end emits = d1.events assert_equal 1, emits.length e1 = emits[0] assert_equal "scrubbed.log", e1[0] assert_equal orig_message + '?', e1[2]['message']['message_child'] end def test_emit4_unicode1 orig_message = 'testtesttest' invalid_utf8 = "\xff".force_encoding('UTF-8') d1 = create_driver(CONFIG_UNICODE_1) d1.run(default_tag: 'input.log') do d1.feed({'message' => {'message_child' => orig_message + invalid_utf8}}) end emits = d1.events assert_equal 1, emits.length e1 = emits[0] assert_equal "scrubbed.log", e1[0] assert_equal orig_message + "\uFFFD".force_encoding('UTF-8'), e1[2]['message']['message_child'] orig_message = 'testtesttest' invalid_utf8 = "\xff".force_encoding('UTF-8') d1 = create_driver(CONFIG_UNICODE_2) d1.run(default_tag: 'input.log') do d1.feed({'message' => {'message_child' => orig_message + invalid_utf8}}) end emits = d1.events assert_equal 1, emits.length e1 = emits[0] assert_equal "scrubbed.log", e1[0] assert_equal orig_message + "\uFFFD".force_encoding('UTF-8'), e1[2]['message']['message_child'] end def test_emit5_frozen_string orig_message = 'testtesttest' invalid_utf8 = "\xff".force_encoding('UTF-8') d1 = create_driver(CONFIG) d1.run(default_tag: 'input.log') do d1.feed({'message' => (orig_message + invalid_utf8).freeze}) end emits = d1.events assert_equal 1, emits.length e1 = emits[0] assert_equal "scrubbed.log", e1[0] assert_equal orig_message, e1[2]['message'] invalid_ascii = "\xff".force_encoding('US-ASCII') d2 = create_driver(CONFIG) d2.run(default_tag: 'input.log2') do d2.feed({'message' => (orig_message + invalid_utf8).freeze}) end emits = d2.events assert_equal 1, emits.length e2 = emits[0] assert_equal "scrubbed.log2", e2[0] assert_equal orig_message, e2[2]['message'] end end