logstash/qa/integration/specs/env_variables_condition_spec.rb
Andres Rodriguez b63ffea472
Enable SpaceAfterColon, SpaceAfterComma, SpaceAfterSemicolon (#15180)
Enable SpaceAfterColon, SpaceAfterComma, SpaceAfterSemicolon and fix occurrences.
2023-07-14 16:46:35 -04:00

98 lines
3.8 KiB
Ruby

# Licensed to Elasticsearch B.V. under one or more contributor
# license agreements. See the NOTICE file distributed with
# this work for additional information regarding copyright
# ownership. Elasticsearch B.V. licenses this file to you under
# the Apache License, Version 2.0 (the "License"); you may
# not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
# KIND, either express or implied. See the License for the
# specific language governing permissions and limitations
# under the License.
require_relative '../framework/fixture'
require_relative '../framework/settings'
require_relative '../services/logstash_service'
require_relative '../framework/helpers'
require "logstash/devutils/rspec/spec_helper"
### Logstash Keystore notes #############
# The logstash.keystore password is `keystore_pa9454w3rd` and contains the following entries:
# input.count = 10
# output.path = mypath
# pipeline.id = mypipeline
# tag1 = mytag1
# tag2 = mytag2
# tag3 = mytag3
####################################
describe "Support environment variable in condition" do
before(:all) {
@fixture = Fixture.new(__FILE__)
}
before(:each) {
@logstash = @fixture.get_service("logstash")
IO.write(File.join(settings_dir, "logstash.yml"), YAML.dump(settings))
FileUtils.cp(File.expand_path("../../logstash.keystore", __FILE__), settings_dir)
}
after(:all) {
@fixture.teardown
}
after(:each) {
@logstash.teardown
}
let(:num_retries) { 50 }
let(:test_path) { Stud::Temporary.directory }
let(:test_env) {
env = Hash.new
env["BIG"] = "100"
env["SMALL"] = "1"
env["APP"] = 'foobar'
env
}
let(:settings_dir) { Stud::Temporary.directory }
let(:settings) {{"pipeline.id" => "${pipeline.id}"}}
let(:logstash_keystore_password) { "keystore_pa9454w3rd" }
it "expands variables and evaluate expression successfully" do
test_env["TEST_ENV_PATH"] = test_path
test_env["LOGSTASH_KEYSTORE_PASS"] = logstash_keystore_password
@logstash.env_variables = test_env
@logstash.start_background_with_config_settings(config_to_temp_file(@fixture.config), settings_dir)
Stud.try(num_retries.times, [StandardError, RSpec::Expectations::ExpectationNotMetError]) do
output = IO.read(File.join(test_path, "env_variables_condition_output.log")).gsub("\n", "")
expect(output).to match /Truthy,Not,>,>=,<,<=,==,!=,in,not in,=~,!~,and,more_and,or,nand,xor/
end
end
it "expands variables in secret store" do
test_env["LOGSTASH_KEYSTORE_PASS"] = logstash_keystore_password
test_env['TAG1'] = "wrong_env" # secret store should take precedence
logstash = @logstash.run_cmd(["bin/logstash", "-e",
"input { generator { count => 1 } }
filter { if (\"${APP}\") { mutate { add_tag => \"${TAG1}\"} } }
output { stdout{} }",
"--path.settings", settings_dir],
true, test_env)
expect(logstash.stderr_and_stdout).to match(/mytag1/)
expect(logstash.stderr_and_stdout).not_to match(/wrong_env/)
expect(logstash.exit_code).to be(0)
end
it "exits with error when env variable is undefined" do
test_env["LOGSTASH_KEYSTORE_PASS"] = logstash_keystore_password
logstash = @logstash.run_cmd(["bin/logstash", "-e", "filter { if \"${NOT_EXIST}\" { mutate {add_tag => \"oh no\"} } }", "--path.settings", settings_dir], true, test_env)
expect(logstash.stderr_and_stdout).to match(/Cannot evaluate `\$\{NOT_EXIST\}`/)
expect(logstash.exit_code).to be(1)
end
end