require 'helper' class WebHDFSOutputTest < Test::Unit::TestCase CONFIG = %[ host namenode.local path /hdfs/path/file.%Y%m%d.log ] def setup Fluent::Test.setup end def create_driver(conf=CONFIG,tag='test') Fluent::Test::OutputTestDriver.new(Fluent::WebHDFSOutput, tag).configure(conf) end class ConfigureTest < self def test_default d = create_driver assert_equal 'namenode.local', d.instance.instance_eval{ @namenode_host } assert_equal 50070, d.instance.instance_eval{ @namenode_port } assert_equal '/hdfs/path/file.%Y%m%d.log', d.instance.path assert_equal '%Y%m%d', d.instance.time_slice_format assert_equal false, d.instance.httpfs assert_nil d.instance.username assert_equal false, d.instance.ignore_start_check_error assert_equal true, d.instance.output_include_time assert_equal true, d.instance.output_include_tag assert_equal 'json', d.instance.output_data_type assert_nil d.instance.remove_prefix assert_equal 'TAB', d.instance.field_separator assert_equal true, d.instance.add_newline assert_equal 'tag_missing', d.instance.default_tag end def test_httpfs d = create_driver %[ namenode server.local:14000 path /hdfs/path/file.%Y%m%d.%H%M.log httpfs yes username hdfs_user ] assert_equal 'server.local', d.instance.instance_eval{ @namenode_host } assert_equal 14000, d.instance.instance_eval{ @namenode_port } assert_equal '/hdfs/path/file.%Y%m%d.%H%M.log', d.instance.path assert_equal '%Y%m%d%H%M', d.instance.time_slice_format assert_equal true, d.instance.httpfs assert_equal 'hdfs_user', d.instance.username end def test_ssl d = create_driver %[ namenode server.local:14000 path /hdfs/path/file.%Y%m%d.%H%M.log ssl true ssl_ca_file /path/to/ca_file.pem ssl_verify_mode peer kerberos true kerberos_keytab /path/to/kerberos.keytab ] assert_equal 'server.local', d.instance.instance_eval{ @namenode_host } assert_equal 14000, d.instance.instance_eval{ @namenode_port } assert_equal '/hdfs/path/file.%Y%m%d.%H%M.log', d.instance.path assert_equal '%Y%m%d%H%M', d.instance.time_slice_format assert_equal true, d.instance.ssl assert_equal '/path/to/ca_file.pem', d.instance.ssl_ca_file assert_equal :peer, d.instance.ssl_verify_mode assert_equal true, d.instance.kerberos assert_equal '/path/to/kerberos.keytab', d.instance.kerberos_keytab end data(gzip: ['gzip', Fluent::WebHDFSOutput::GzipCompressor], bzip2: ['bzip2', Fluent::WebHDFSOutput::Bzip2Compressor], snappy: ['snappy', Fluent::WebHDFSOutput::SnappyCompressor], lzo: ['lzo_command', Fluent::WebHDFSOutput::LZOCommandCompressor]) def test_compress(data) compress_type, compressor_class = data begin d = create_driver %[ namenode server.local:14000 path /hdfs/path/file.%Y%m%d.%H%M.log compress #{compress_type} ] rescue Fluent::ConfigError => ex omit ex.message end assert_equal 'server.local', d.instance.instance_eval{ @namenode_host } assert_equal 14000, d.instance.instance_eval{ @namenode_port } assert_equal '/hdfs/path/file.%Y%m%d.%H%M.log', d.instance.path assert_equal '%Y%m%d%H%M', d.instance.time_slice_format assert_equal compress_type, d.instance.compress assert_equal compressor_class, d.instance.compressor.class end def test_placeholders d = create_driver %[ hostname testing.node.local namenode server.local:50070 path /hdfs/${hostname}/file.%Y%m%d%H.log ] assert_equal '/hdfs/testing.node.local/file.%Y%m%d%H.log', d.instance.path end class PathFormatTest < self def test_default d = create_driver assert_equal '/hdfs/path/file.%Y%m%d.log', d.instance.path assert_equal '%Y%m%d', d.instance.time_slice_format assert_equal '/hdfs/path/file.20120718.log', d.instance.path_format('20120718') end def test_time_slice_format d = create_driver %[ namenode server.local:14000 path /hdfs/path/file.%Y%m%d.%H%M.log ] assert_equal '/hdfs/path/file.%Y%m%d.%H%M.log', d.instance.path assert_equal '%Y%m%d%H%M', d.instance.time_slice_format assert_equal '/hdfs/path/file.20120718.1503.log', d.instance.path_format('201207181503') end end class InvalidTest < self def test_path assert_raise Fluent::ConfigError do d = create_driver %[ namenode server.local:14000 path /hdfs/path/file.%Y%m%d.%H%M.log append false ] end end def test_ssl assert_raise Fluent::ConfigError do create_driver %[ namenode server.local:14000 path /hdfs/path/file.%Y%m%d.%H%M.log ssl true ssl_verify_mode invalid ] end end def test_invalid_compress assert_raise Fluent::ConfigError do create_driver %[ namenode server.local:14000 path /hdfs/path/file.%Y%m%d.%H%M.log compress invalid ] end end data("%{uuid:hostname}" => "%{uuid:hostname}", "%{uuid:timestamp}" => "%{uuid:timestamp}") def test_obsoleted_placeholders(placeholder) assert_raise Fluent::ConfigError do create_driver %[ namenode server.local:14000 path /hdfs/path/#{placeholder}/file.%Y%m%d.%H%M.log append false ] end end end end end