Sha256: fa50b728d61e22dad953e1bae80ee9efa395bcbbfa7bfe3359e5caedd9db5f3c

Contents?: true

Size: 1.82 KB

Versions: 116

Compression:

Stored size: 1.82 KB

Contents

require_relative '../helper'
require 'fluent/test/driver/formatter'
require 'fluent/plugin/formatter_ltsv'

class LabeledTSVFormatterTest < ::Test::Unit::TestCase
  def setup
    @time = event_time
  end

  def create_driver(conf = "")
    Fluent::Test::Driver::Formatter.new(Fluent::Plugin::LabeledTSVFormatter).configure(conf)
  end

  def tag
    "tag"
  end

  def record
    {'message' => 'awesome', 'greeting' => 'hello'}
  end

  def test_config_params
    d = create_driver
    assert_equal "\t", d.instance.delimiter
    assert_equal  ":", d.instance.label_delimiter
    assert_equal  true, d.instance.add_newline

    d = create_driver(
      'delimiter'       => ',',
      'label_delimiter' => '=',
      'add_newline' => false,
    )

    assert_equal ",", d.instance.delimiter
    assert_equal "=", d.instance.label_delimiter
    assert_equal  false, d.instance.add_newline
  end

  data("newline (LF)" => ["lf", "\n"],
       "newline (CRLF)" => ["crlf", "\r\n"])
  def test_format(data)
    newline_conf, newline = data
    d = create_driver({"newline" => newline_conf})
    formatted = d.instance.format(tag, @time, record)

    assert_equal("message:awesome\tgreeting:hello#{newline}", formatted)
  end

  def test_format_without_newline
    d = create_driver('add_newline' => false)
    formatted = d.instance.format(tag, @time, record)

    assert_equal("message:awesome\tgreeting:hello", formatted)
  end

  data("newline (LF)" => ["lf", "\n"],
       "newline (CRLF)" => ["crlf", "\r\n"])
  def test_format_with_customized_delimiters(data)
    newline_conf, newline = data

    d = create_driver(
      'delimiter'       => ',',
      'label_delimiter' => '=',
      'newline' => newline_conf,
    )
    formatted = d.instance.format(tag, @time, record)

    assert_equal("message=awesome,greeting=hello#{newline}", formatted)
  end
end

Version data entries

116 entries across 116 versions & 7 rubygems

Version Path
fluentd-1.16.4-x64-mingw-ucrt test/plugin/test_formatter_ltsv.rb
fluentd-1.16.4-x86-mingw32 test/plugin/test_formatter_ltsv.rb
fluentd-1.16.4-x64-mingw32 test/plugin/test_formatter_ltsv.rb
fluentd-1.16.4 test/plugin/test_formatter_ltsv.rb
fluentd222-1.16.2-x86_64-linux test/plugin/test_formatter_ltsv.rb
fluentd-1.16.3-x86-mingw32 test/plugin/test_formatter_ltsv.rb
fluentd-1.16.3-x64-mingw32 test/plugin/test_formatter_ltsv.rb
fluentd-1.16.3-x64-mingw-ucrt test/plugin/test_formatter_ltsv.rb
fluentd-1.16.3 test/plugin/test_formatter_ltsv.rb
fluentd-1.16.2-x86-mingw32 test/plugin/test_formatter_ltsv.rb
fluentd-1.16.2-x64-mingw32 test/plugin/test_formatter_ltsv.rb
fluentd-1.16.2-x64-mingw-ucrt test/plugin/test_formatter_ltsv.rb
fluentd-1.16.2 test/plugin/test_formatter_ltsv.rb
fluent-plugin-google-cloud-logging-on-prem-0.1.0 vendor/ruby/3.1.0/gems/fluentd-1.16.1/test/plugin/test_formatter_ltsv.rb
fluentd-1.16.1-x64-mingw-ucrt test/plugin/test_formatter_ltsv.rb
fluentd-1.16.1-x64-mingw32 test/plugin/test_formatter_ltsv.rb
fluentd-1.16.1-x86-mingw32 test/plugin/test_formatter_ltsv.rb
fluentd-1.16.1 test/plugin/test_formatter_ltsv.rb
fluentd-1.16.0-x64-mingw32 test/plugin/test_formatter_ltsv.rb
fluentd-1.16.0-x64-mingw-ucrt test/plugin/test_formatter_ltsv.rb