Add tests for StreamEntriesHelper#rtl? (#2286)
We used some random Arabic characters to test that the various RTL conditions got triggered.
This commit is contained in:
		
							parent
							
								
									af7d02da5d
								
							
						
					
					
						commit
						974ac467de
					
				|  | @ -37,20 +37,22 @@ module StreamEntriesHelper | |||
|   end | ||||
| 
 | ||||
|   def rtl?(text) | ||||
|     return false if text.empty? | ||||
|     rtl_characters = /[\p{Hebrew}|\p{Arabic}|\p{Syriac}|\p{Thaana}|\p{Nko}]+/m.match(text) | ||||
| 
 | ||||
|     matches = /[\p{Hebrew}|\p{Arabic}|\p{Syriac}|\p{Thaana}|\p{Nko}]+/m.match(text) | ||||
| 
 | ||||
|     return false unless matches | ||||
| 
 | ||||
|     rtl_size = matches.to_a.reduce(0) { |acc, elem| acc + elem.size }.to_f | ||||
|     ltr_size = text.strip.size.to_f | ||||
| 
 | ||||
|     rtl_size / ltr_size > 0.3 | ||||
|     if rtl_characters.present? | ||||
|       total_size = text.strip.size.to_f | ||||
|       rtl_size(rtl_characters.to_a) / total_size > 0.3 | ||||
|     else | ||||
|       false | ||||
|     end | ||||
|   end | ||||
| 
 | ||||
|   private | ||||
| 
 | ||||
|   def rtl_size(characters) | ||||
|     characters.reduce(0) { |acc, elem| acc + elem.size }.to_f | ||||
|   end | ||||
| 
 | ||||
|   def embedded_view? | ||||
|     params[:controller] == 'stream_entries' && params[:action] == 'embed' | ||||
|   end | ||||
|  |  | |||
|  | @ -14,4 +14,22 @@ RSpec.describe StreamEntriesHelper, type: :helper do | |||
|       expect(helper.display_name(account)).to eq "Username" | ||||
|     end | ||||
|   end | ||||
| 
 | ||||
|   describe '#rtl?' do | ||||
|     it 'is false if text is empty' do | ||||
|       expect(helper).not_to be_rtl '' | ||||
|     end | ||||
| 
 | ||||
|     it 'is false if there are no right to left characters' do | ||||
|       expect(helper).not_to be_rtl 'hello world' | ||||
|     end | ||||
| 
 | ||||
|     it 'is false if right to left characters are fewer than 1/3 of total text' do | ||||
|       expect(helper).not_to be_rtl 'hello ݟ world' | ||||
|     end | ||||
| 
 | ||||
|     it 'is true if right to left characters are greater than 1/3 of total text' do | ||||
|       expect(helper).to be_rtl 'aaݟ' | ||||
|     end | ||||
|   end | ||||
| end | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue