From 703dfca10ec08a1741463044178a76da52c5597d Mon Sep 17 00:00:00 2001 From: Jake Landis Date: Mon, 11 Dec 2017 16:35:28 -0600 Subject: [PATCH] LIR: merge arrays of divergent types Specifically this change explictly checks for the Array type to merge into and pushes into the array instead of relying only on the + concat. Fixes #8827 Fixes #8831 --- logstash-core/lib/logstash/compiler/lscl.rb | 2 ++ .../spec/logstash/compiler/compiler_spec.rb | 26 +++++++++++++++++++ 2 files changed, 28 insertions(+) diff --git a/logstash-core/lib/logstash/compiler/lscl.rb b/logstash-core/lib/logstash/compiler/lscl.rb index 255afe5dae5..72f6db7b80c 100644 --- a/logstash-core/lib/logstash/compiler/lscl.rb +++ b/logstash-core/lib/logstash/compiler/lscl.rb @@ -113,6 +113,8 @@ def expr_attributes # interpreted as `{"match" => {"baz" => "bar", "foo" => "blub"}}`. # (NOTE: this bypasses `AST::Hash`'s ability to detect duplicate keys) hash[k] = existing.merge(v) + elsif existing.kind_of?(::Array) + hash[k] = existing.push(*v) else hash[k] = existing + v end diff --git a/logstash-core/spec/logstash/compiler/compiler_spec.rb b/logstash-core/spec/logstash/compiler/compiler_spec.rb index 79436159b3d..b52614a405f 100644 --- a/logstash-core/spec/logstash/compiler/compiler_spec.rb +++ b/logstash-core/spec/logstash/compiler/compiler_spec.rb @@ -194,6 +194,32 @@ def j end end + describe "a plugin with multiple array parameter types" do + let(:plugin_source) { "generator { aarg => [1] aarg => [2] aarg => [3]}" } + let(:expected_plugin_args) do + { + "aarg" => [1, 2, 3] + } + end + + it "should contain the plugin" do + expect(c_plugin).to ir_eql(j.iPlugin(INPUT, "generator", expected_plugin_args)) + end + end + + describe "a plugin with multiple parameter types that converge to an array" do + let(:plugin_source) { "generator { aarg => [1] aarg => 2 aarg => '3' aarg => [4] }"} + let(:expected_plugin_args) do + { + "aarg" => [1, 2, "3", 4] + } + end + + it "should contain the plugin" do + expect(c_plugin).to ir_eql(j.iPlugin(INPUT, "generator", expected_plugin_args)) + end + end + describe "a filter plugin that repeats a Hash directive" do let(:source) { "input { } filter { #{plugin_source} } output { } " } subject(:c_plugin) { compiled[:filter] }