Improve IpBlock model test coverage (#29460)
				
					
				
			This commit is contained in:
		
							parent
							
								
									1d721b21e1
								
							
						
					
					
						commit
						a25014de8f
					
				| @ -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…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user