Add a spec for UniqueUsernameValidator (#6927)
Note that this spec has a pending test about dots in the username, because allowing it has been reverted for now.
This commit is contained in:
		
							parent
							
								
									2a90da1837
								
							
						
					
					
						commit
						a1d0915585
					
				
							
								
								
									
										33
									
								
								spec/validators/unique_username_validator_spec.rb
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								spec/validators/unique_username_validator_spec.rb
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,33 @@
 | 
				
			|||||||
 | 
					# frozen_string_literal: true
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					require 'rails_helper'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					describe UniqueUsernameValidator do
 | 
				
			||||||
 | 
					  describe '#validate' do
 | 
				
			||||||
 | 
					    it 'does not add errors if username is nil' do
 | 
				
			||||||
 | 
					      account = double(username: nil, persisted?: false, errors: double(add: nil))
 | 
				
			||||||
 | 
					      subject.validate(account)
 | 
				
			||||||
 | 
					      expect(account.errors).to_not have_received(:add)
 | 
				
			||||||
 | 
					    end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    it 'does not add errors when existing one is subject itself' do
 | 
				
			||||||
 | 
					      account = Fabricate(:account, username: 'abcdef')
 | 
				
			||||||
 | 
					      expect(account).to be_valid
 | 
				
			||||||
 | 
					    end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    it 'adds an error when the username is already used with ignoring dots' do
 | 
				
			||||||
 | 
					      pending 'allowing dots in username is still in development'
 | 
				
			||||||
 | 
					      Fabricate(:account, username: 'abcd.ef')
 | 
				
			||||||
 | 
					      account = double(username: 'ab.cdef', persisted?: false, errors: double(add: nil))
 | 
				
			||||||
 | 
					      subject.validate(account)
 | 
				
			||||||
 | 
					      expect(account.errors).to have_received(:add)
 | 
				
			||||||
 | 
					    end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    it 'adds an error when the username is already used with ignoring cases' do
 | 
				
			||||||
 | 
					      Fabricate(:account, username: 'ABCdef')
 | 
				
			||||||
 | 
					      account = double(username: 'abcDEF', persisted?: false, errors: double(add: nil))
 | 
				
			||||||
 | 
					      subject.validate(account)
 | 
				
			||||||
 | 
					      expect(account.errors).to have_received(:add)
 | 
				
			||||||
 | 
					    end
 | 
				
			||||||
 | 
					  end
 | 
				
			||||||
 | 
					end
 | 
				
			||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user