Improve IpBlock
model test coverage (#29460)
This commit is contained in:
parent
1d721b21e1
commit
a25014de8f
1 changed files with 52 additions and 1 deletions
|
@ -3,7 +3,32 @@
|
|||
require 'rails_helper'
|
||||
|
||||
describe IpBlock do
|
||||
describe 'to_log_human_identifier' do
|
||||
describe 'validations' do
|
||||
it 'validates ip presence', :aggregate_failures do
|
||||
ip_block = described_class.new(ip: nil, severity: :no_access)
|
||||
|
||||
expect(ip_block).to_not be_valid
|
||||
expect(ip_block).to model_have_error_on_field(:ip)
|
||||
end
|
||||
|
||||
it 'validates severity presence', :aggregate_failures do
|
||||
ip_block = described_class.new(ip: '127.0.0.1', severity: nil)
|
||||
|
||||
expect(ip_block).to_not be_valid
|
||||
expect(ip_block).to model_have_error_on_field(:severity)
|
||||
end
|
||||
|
||||
it 'validates ip uniqueness', :aggregate_failures do
|
||||
described_class.create!(ip: '127.0.0.1', severity: :no_access)
|
||||
|
||||
ip_block = described_class.new(ip: '127.0.0.1', severity: :no_access)
|
||||
|
||||
expect(ip_block).to_not be_valid
|
||||
expect(ip_block).to model_have_error_on_field(:ip)
|
||||
end
|
||||
end
|
||||
|
||||
describe '#to_log_human_identifier' do
|
||||
let(:ip_block) { described_class.new(ip: '192.168.0.1') }
|
||||
|
||||
it 'combines the IP and prefix into a string' do
|
||||
|
@ -12,4 +37,30 @@ describe IpBlock do
|
|||
expect(result).to eq('192.168.0.1/32')
|
||||
end
|
||||
end
|
||||
|
||||
describe '.blocked?' do
|
||||
context 'when the IP is blocked' do
|
||||
it 'returns true' do
|
||||
described_class.create!(ip: '127.0.0.1', severity: :no_access)
|
||||
|
||||
expect(described_class.blocked?('127.0.0.1')).to be true
|
||||
end
|
||||
end
|
||||
|
||||
context 'when the IP is not blocked' do
|
||||
it 'returns false' do
|
||||
expect(described_class.blocked?('127.0.0.1')).to be false
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
describe 'after_commit' do
|
||||
it 'resets the cache' do
|
||||
allow(Rails.cache).to receive(:delete)
|
||||
|
||||
described_class.create!(ip: '127.0.0.1', severity: :no_access)
|
||||
|
||||
expect(Rails.cache).to have_received(:delete).with(described_class::CACHE_KEY)
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
Loading…
Reference in a new issue