
This commit enable redis master failover. After a period of time a new master will be elected by the sentinel and the haproxy will route the stream to the correct redis node. Change-Id: Ib107fdf37e9d0a24f9be4ae73c1a1092507f84b6
87 lines
2.2 KiB
Ruby
87 lines
2.2 KiB
Ruby
#
|
|
# Copyright (C) 2014 eNovance SAS <licensing@enovance.com>
|
|
#
|
|
# Licensed 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.
|
|
#
|
|
# Unit tests for cloud::cache::redis::sentinel
|
|
#
|
|
|
|
require 'spec_helper'
|
|
|
|
describe 'cloud::database::nosql::redis::sentinel' do
|
|
|
|
shared_examples_for 'redis sentinel' do
|
|
|
|
let :params do
|
|
{ :port => '26379' }
|
|
end
|
|
|
|
it { should create_class('redis::sentinel') }
|
|
|
|
it { should contain_file('/bin/redis-notifications.sh').with(
|
|
:ensure => 'present',
|
|
:owner => 'root',
|
|
:group => 'root',
|
|
:mode => '0755',
|
|
) }
|
|
|
|
context 'with default firewall enabled' do
|
|
let :pre_condition do
|
|
"class { 'cloud': manage_firewall => true }"
|
|
end
|
|
it 'configure redis firewall rules' do
|
|
is_expected.to contain_firewall('100 allow redis sentinel access').with(
|
|
:port => '26379',
|
|
:proto => 'tcp',
|
|
:action => 'accept',
|
|
)
|
|
end
|
|
end
|
|
|
|
context 'with custom firewall enabled' do
|
|
let :pre_condition do
|
|
"class { 'cloud': manage_firewall => true }"
|
|
end
|
|
before :each do
|
|
params.merge!(:firewall_settings => { 'limit' => '50/sec' } )
|
|
end
|
|
it 'configure redis firewall rules with custom parameter' do
|
|
is_expected.to contain_firewall('100 allow redis sentinel access').with(
|
|
:port => '26379',
|
|
:proto => 'tcp',
|
|
:action => 'accept',
|
|
:limit => '50/sec',
|
|
)
|
|
end
|
|
end
|
|
|
|
end
|
|
|
|
context 'on Debian platforms' do
|
|
let :facts do
|
|
{ :osfamily => 'Debian' }
|
|
end
|
|
|
|
it_configures 'redis sentinel'
|
|
end
|
|
|
|
context 'on RedHat platforms' do
|
|
let :facts do
|
|
{ :osfamily => 'RedHat' }
|
|
end
|
|
|
|
it_configures 'redis sentinel'
|
|
end
|
|
|
|
end
|