Skip to content

Commit

Permalink
add spec tests for regex validation
Browse files Browse the repository at this point in the history
  • Loading branch information
SimonHoenscheid committed Oct 25, 2023
1 parent 4a031cb commit 3ddc7bb
Showing 1 changed file with 69 additions and 0 deletions.
69 changes: 69 additions & 0 deletions spec/unit/type/postgresql_conf_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -51,5 +51,74 @@
expect { described_class.new(name: 'foo', ensure: :foo) }.to raise_error(Puppet::Error, %r{Invalid value})
end
end
# boolean https://www.postgresql.org/docs/current/datatype-boolean.html
describe 'validate boolean values with newvalues function' do
it 'validates log_checkpoints with value on' do
expect { described_class.new(name: 'log_checkpoints', value: 'on') }.not_to raise_error
end
it 'validates log_checkpoints with value off' do
expect { described_class.new(name: 'log_checkpoints', value: 'off') }.not_to raise_error
end
it 'validates log_checkpoints with value true' do
expect { described_class.new(name: 'log_checkpoints', value: 'true') }.not_to raise_error
end
it 'validates log_checkpoints with value false' do
expect { described_class.new(name: 'log_checkpoints', value: 'false') }.not_to raise_error
end
it 'validates log_checkpoints with value yes' do
expect { described_class.new(name: 'log_checkpoints', value: 'yes') }.not_to raise_error
end
it 'validates log_checkpoints with value no' do
expect { described_class.new(name: 'log_checkpoints', value: 'no') }.not_to raise_error
end
it 'validates log_checkpoints with value 1' do
expect { described_class.new(name: 'log_checkpoints', value: '1') }.not_to raise_error
end
it 'validates log_checkpoints with value 0' do
expect { described_class.new(name: 'log_checkpoints', value: '0') }.not_to raise_error
end
end
# enums https://www.postgresql.org/docs/current/datatype-enum.html
describe 'validate enum values with newvalues function' do
it 'validates ssl_min_protocol_version with value TLSv1.3' do
expect { described_class.new(name: 'ssl_min_protocol_version', value: 'TLSv1.3') }.not_to raise_error
end
it 'validates ssl_min_protocol_version with value TLSv1.1' do
expect { described_class.new(name: 'ssl_min_protocol_version', value: 'TLSv1.1') }.not_to raise_error
end
end
# integer https://www.postgresql.org/docs/current/datatype-numeric.html#DATATYPE-INT
describe 'validate integer values with newvalues function' do
it 'validates max_connections with value 1000' do
expect { described_class.new(name: 'max_connections', value: '1000') }.not_to raise_error
end
end
# real https://www.postgresql.org/docs/current/datatype-numeric.html#DATATYPE-FLOAT
describe 'validate real values with newvalues function' do
it 'validates parallel_tuple_cost with value 0.3' do
expect { described_class.new(name: 'parallel_tuple_cost', value: '0.3') }.not_to raise_error
end
end
# string https://www.postgresql.org/docs/current/datatype-character.html
describe 'validate complex string values with newvalues function' do
it 'validates log_line_prefix with value [%p] %q:%u:%d:%' do
expect { described_class.new(name: 'log_line_prefix', value: '[%p] %q:%u:%d:%x ') }.not_to raise_error
end
it 'validates log_line_prefix with value %t %q%u@%d %p %i' do
expect { described_class.new(name: 'log_line_prefix', value: '%t %q%u@%d %p %i ') }.not_to raise_error
end
it 'validates log_filename with value psql_01-%Y-%m-%d.log' do
expect { described_class.new(name: 'log_filename', value: 'psql_01-%Y-%m-%d.log') }.not_to raise_error
end
end
# string https://www.postgresql.org/docs/current/datatype-character.html
describe 'validate string values with newvalues function' do
it 'validates log_timezone with value UTC' do
expect { described_class.new(name: 'log_timezone', value: 'UTC') }.not_to raise_error
end
it 'validates ssl_ciphers with value HIGH:MEDIUM:+3DES:!aNULL' do
expect { described_class.new(name: 'ssl_ciphers', value: 'HIGH:MEDIUM:+3DES:!aNULL') }.not_to raise_error
end
end
end
end

0 comments on commit 3ddc7bb

Please sign in to comment.