spec/classes/datadog_agent_integrations_elasticsearch_spec.rb (117 lines of code) (raw):
require 'spec_helper'
describe 'datadog_agent::integrations::elasticsearch' do
  context 'supported agents - v5 and v6' do
    agents = { '5' => true, '6' => false }
    agents.each do |_, enabled|
      let(:pre_condition) { "class {'::datadog_agent': agent5_enable => #{enabled}}" }
      let(:facts) {{
        operatingsystem: 'Ubuntu',
      }}
      if enabled
        let(:conf_dir) { '/etc/dd-agent/conf.d' }
      else
        let(:conf_dir) { '/etc/datadog-agent/conf.d' }
      end
      let(:dd_user) { 'dd-agent' }
      let(:dd_group) { 'root' }
      let(:dd_package) { 'datadog-agent' }
      let(:dd_service) { 'datadog-agent' }
      let(:conf_file) { "#{conf_dir}/elastic.yaml" }
      it { should compile.with_all_deps }
      it { should contain_file(conf_file).with(
        owner: dd_user,
        group: dd_group,
        mode: '0644',
      )}
      it { should contain_file(conf_file).that_requires("Package[#{dd_package}]") }
      it { should contain_file(conf_file).that_notifies("Service[#{dd_service}]") }
      context 'with default parameters' do
        it { should contain_file(conf_file).with_content(%r{    - url: http://localhost:9200}) }
        it { should contain_file(conf_file).with_content(%r{      cluster_stats: false}) }
        it { should contain_file(conf_file).with_content(%r{      pending_task_stats: true}) }
        it { should contain_file(conf_file).with_content(%r{      pshard_stats: false}) }
        it { should_not contain_file(conf_file).with_content(%r{      username}) }
        it { should_not contain_file(conf_file).with_content(%r{      password}) }
        it { should_not contain_file(conf_file).with_content(%r{      ssl_verify}) }
        it { should_not contain_file(conf_file).with_content(%r{      ssl_cert}) }
        it { should_not contain_file(conf_file).with_content(%r{      ssl_key}) }
        it { should_not contain_file(conf_file).with_content(%r{      tags:}) }
      end
      context 'with parameters set' do
        let(:params) {{
          password:           'password',
          pending_task_stats: false,
          url:                'https://foo:4242',
          username:           'username',
          ssl_cert:           '/etc/ssl/certs/client.pem',
          ssl_key:            '/etc/ssl/private/client.key',
          tags:               ['tag1:key1'],
        }}
        it { should contain_file(conf_file).with_content(%r{    - url: https://foo:4242}) }
        it { should contain_file(conf_file).with_content(%r{      pending_task_stats: false}) }
        it { should contain_file(conf_file).with_content(%r{      username: username}) }
        it { should contain_file(conf_file).with_content(%r{      password: password}) }
        it { should contain_file(conf_file).with_content(%r{      ssl_verify: true}) }
        it { should contain_file(conf_file).with_content(%r{      ssl_cert: /etc/ssl/certs/client.pem}) }
        it { should contain_file(conf_file).with_content(%r{      ssl_key: /etc/ssl/private/client.key}) }
        it { should contain_file(conf_file).with_content(%r{      tags:}) }
        it { should contain_file(conf_file).with_content(%r{        - tag1:key1}) }
      end
      context 'with multiple instances set' do
        let(:params) {
          {
            instances: [
              {
                'cluster_stats'      => true,
                'password'           => 'password',
                'pending_task_stats' => false,
                'pshard_stats'       => false,
                'url'                => 'https://foo:4242',
                'username'           => 'username',
                'ssl_verify'         => true,
                'ssl_cert'           => '/etc/ssl/certs/client.pem',
                'ssl_key'            => '/etc/ssl/private/client.key',
                'tags'               => ['tag1:key1'],
              },
              {
                'cluster_stats'      => true,
                'password'           => 'password_2',
                'pending_task_stats' => true,
                'pshard_stats'       => false,
                'url'                => 'https://bar:2424',
                'username'           => 'username_2',
                'ssl_verify'         => false,
                'ssl_cert'           => '/etc/ssl/certs/client.pem',
                'ssl_key'            => '/etc/ssl/private/client.key',
                'tags'               => ['tag2:key2'],
              }
            ]
          }
        }
        it { should contain_file(conf_file).with_content(%r{instances:}) }
        it { should contain_file(conf_file).with_content(%r{    - url: https://foo:4242}) }
        it { should contain_file(conf_file).with_content(%r{      cluster_stats: true}) }
        it { should contain_file(conf_file).with_content(%r{      pending_task_stats: false}) }
        it { should contain_file(conf_file).with_content(%r{      username: username}) }
        it { should contain_file(conf_file).with_content(%r{      password: password}) }
        it { should contain_file(conf_file).with_content(%r{      pshard_stats: false}) }
        it { should contain_file(conf_file).with_content(%r{      ssl_verify: true}) }
        it { should contain_file(conf_file).with_content(%r{      ssl_cert: /etc/ssl/certs/client.pem}) }
        it { should contain_file(conf_file).with_content(%r{      ssl_key: /etc/ssl/private/client.key}) }
        it { should contain_file(conf_file).with_content(%r{      tags:}) }
        it { should contain_file(conf_file).with_content(%r{        - tag1:key1}) }
        it { should contain_file(conf_file).with_content(%r{    - url: https://bar:2424}) }
        it { should contain_file(conf_file).with_content(%r{      cluster_stats: true}) }
        it { should contain_file(conf_file).with_content(%r{      pending_task_stats: true}) }
        it { should contain_file(conf_file).with_content(%r{      username: username_2}) }
        it { should contain_file(conf_file).with_content(%r{      password: password_2}) }
        it { should contain_file(conf_file).with_content(%r{      pshard_stats: false}) }
        it { should contain_file(conf_file).with_content(%r{      ssl_verify: false}) }
        it { should contain_file(conf_file).with_content(%r{      ssl_cert: /etc/ssl/certs/client.pem}) }
        it { should contain_file(conf_file).with_content(%r{      ssl_key: /etc/ssl/private/client.key}) }
        it { should contain_file(conf_file).with_content(%r{      tags:}) }
        it { should contain_file(conf_file).with_content(%r{        - tag2:key2}) }
      end
    end
  end
end