Sha256: 08786087a8bdb800f7ad3e6fb8f45e30ba27dd3b0bcc6b3909d12bda072f2ce2

Contents?: true

Size: 1.92 KB

Versions: 33

Compression:

Stored size: 1.92 KB

Contents

require "logstash/outputs/elasticsearch"
require_relative "../../../spec/es_spec_helper"

describe "whitelisting error types in expected behavior" do
  let(:template) { '{"template" : "not important, will be updated by :index"}' }
  let(:event1) { LogStash::Event.new("somevalue" => 100, "@timestamp" => "2014-11-17T20:37:17.223Z") }
  let(:action1) { ["index", {:_id=>1, :routing=>nil, :_index=>"logstash-2014.11.17", :_type=> doc_type }, event1] }
  let(:settings) { {"manage_template" => true, "index" => "logstash-2014.11.17", "template_overwrite" => true, "hosts" => get_host_port() } }

  subject { LogStash::Outputs::ElasticSearch.new(settings) }

  before :each do
    allow(subject.logger).to receive(:warn)
    allow(subject).to receive(:maximum_seen_major_version).and_return(0)
    allow(subject).to receive(:alive_urls_count).and_return(1)
    allow(subject).to receive(:finish_register)

    subject.register

    allow(subject.client).to receive(:get_xpack_info)
    allow(subject.client).to receive(:bulk).and_return(
      {
        "errors" => true,
        "items" => [{
          "create" => {
            "status" => 409, 
            "error" => {
              "type" => "document_already_exists_exception",
              "reason" => "[shard] document already exists"
            }
          }
        }]
      })

    subject.multi_receive([event1])
  end

  after :each do
    subject.close
  end

  describe "when failure logging is enabled for everything" do
    it "should log a failure on the action" do
      expect(subject.logger).to have_received(:warn).with("Failed action", anything)
    end
  end

  describe "when failure logging is disabled for document exists error" do
    let(:settings) { super().merge("silence_errors_in_log" => ["document_already_exists_exception"]) }

    it "should log a failure on the action" do
      expect(subject.logger).not_to have_received(:warn).with("Failed action", anything)
    end
  end

end

Version data entries

33 entries across 33 versions & 2 rubygems

Version Path
logstash-output-elasticsearch-11.20.0-java spec/unit/outputs/error_whitelist_spec.rb
logstash-output-elasticsearch-11.19.0-java spec/unit/outputs/error_whitelist_spec.rb
logstash-output-elasticsearch-11.18.0-java spec/unit/outputs/error_whitelist_spec.rb
logstash-output-elasticsearch-11.17.0-java spec/unit/outputs/error_whitelist_spec.rb
logstash-output-elasticsearch-test-11.16.1-x86_64-linux spec/unit/outputs/error_whitelist_spec.rb
logstash-output-elasticsearch-test-11.16.0-x86_64-linux spec/unit/outputs/error_whitelist_spec.rb
logstash-output-elasticsearch-11.16.0-java spec/unit/outputs/error_whitelist_spec.rb
logstash-output-elasticsearch-11.15.9-java spec/unit/outputs/error_whitelist_spec.rb
logstash-output-elasticsearch-11.15.8-java spec/unit/outputs/error_whitelist_spec.rb
logstash-output-elasticsearch-11.15.7-java spec/unit/outputs/error_whitelist_spec.rb
logstash-output-elasticsearch-11.15.6-java spec/unit/outputs/error_whitelist_spec.rb
logstash-output-elasticsearch-11.15.5-java spec/unit/outputs/error_whitelist_spec.rb
logstash-output-elasticsearch-11.15.4-java spec/unit/outputs/error_whitelist_spec.rb
logstash-output-elasticsearch-11.15.2-java spec/unit/outputs/error_whitelist_spec.rb
logstash-output-elasticsearch-11.15.1-java spec/unit/outputs/error_whitelist_spec.rb
logstash-output-elasticsearch-11.15.0-java spec/unit/outputs/error_whitelist_spec.rb
logstash-output-elasticsearch-11.14.1-java spec/unit/outputs/error_whitelist_spec.rb
logstash-output-elasticsearch-11.14.0-java spec/unit/outputs/error_whitelist_spec.rb
logstash-output-elasticsearch-11.13.1-java spec/unit/outputs/error_whitelist_spec.rb
logstash-output-elasticsearch-11.13.0-java spec/unit/outputs/error_whitelist_spec.rb