Sha256: 8ee64f35e121b894dd94a91e78f765f65d34516bdfb9aabc1f55346adad94aa2

Contents?: true

Size: 1.39 KB

Versions: 6

Compression:

Stored size: 1.39 KB

Contents

require "helper"
require "fluent/plugin/buf_memory"
require 'zstandard'

class ZstdCompressorTest < Test::Unit::TestCase
  class Zstd < self

    CONFIG = %[
      host namenode.local
      path /hdfs/path/file.%Y%m%d.log
    ]

    def setup
      omit unless Object.const_defined?(:Zstandard)
      Fluent::Test.setup
      @compressor = Fluent::Plugin::WebHDFSOutput::ZstdCompressor.new
    end

    def create_driver(conf = CONFIG)
      Fluent::Test::Driver::Output.new(Fluent::Plugin::WebHDFSOutput).configure(conf)
    end

    def test_ext
      assert_equal(".zst", @compressor.ext)
    end

    def test_compress
      d = create_driver
      if d.instance.respond_to?(:buffer)
        buffer = d.instance.buffer
      else
        buffer = d.instance.instance_variable_get(:@buffer)
      end

      if buffer.respond_to?(:generate_chunk)
        chunk = buffer.generate_chunk("test")
        chunk.concat("hello gzip\n" * 32 * 1024, 1)
      else
        chunk = buffer.new_chunk("test")
        chunk << "hello gzip\n" * 32 * 1024
      end

      io = Tempfile.new("zstd-")
      @compressor.compress(chunk, io)
      assert !io.closed?
      chunk_bytesize = chunk.respond_to?(:bytesize) ? chunk.bytesize : chunk.size
      assert(chunk_bytesize > io.read.bytesize)
      io.rewind
      reader = Zstandard.inflate(io.read)
      io.rewind
      assert_equal(chunk.read, reader)
      io.close
    end
  end
end

Version data entries

6 entries across 6 versions & 1 rubygems

Version Path
fluent-plugin-webhdfs-1.6.0 test/plugin/test_zstd_compressor.rb
fluent-plugin-webhdfs-1.5.0 test/plugin/test_zstd_compressor.rb
fluent-plugin-webhdfs-1.4.0 test/plugin/test_zstd_compressor.rb
fluent-plugin-webhdfs-1.3.2 test/plugin/test_zstd_compressor.rb
fluent-plugin-webhdfs-1.3.1 test/plugin/test_zstd_compressor.rb
fluent-plugin-webhdfs-1.3.0 test/plugin/test_zstd_compressor.rb