1
0
mirror of https://codeberg.org/Freeyourgadget/Gadgetbridge synced 2025-01-15 12:17:33 +01:00

Add Unittest for Rtl + some small fixes

This commit is contained in:
Roi Greenberg 2018-09-05 01:39:01 +03:00
parent f233ad79fa
commit 761d8327f9
2 changed files with 385 additions and 24 deletions

View File

@ -2,7 +2,6 @@ package nodomain.freeyourgadget.gadgetbridge.util;
import android.text.TextUtils; import android.text.TextUtils;
import android.util.Log; import android.util.Log;
import android.util.Pair;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.HashMap; import java.util.HashMap;
@ -22,7 +21,7 @@ public class RtlUtils {
return GBApplication.getPrefs().getBoolean("rtl", false); return GBApplication.getPrefs().getBoolean("rtl", false);
} }
enum characterType{ public enum characterType{
ltr, ltr,
rtl, rtl,
rtl_arabic, rtl_arabic,
@ -81,7 +80,7 @@ public class RtlUtils {
/** /**
* @return true if the char is in the rtl range, otherwise false * @return true if the char is in the rtl range, otherwise false
*/ */
static boolean isHebrew(Character c){ public static boolean isHebrew(Character c){
return getCharacterType(c) == characterType.rtl; return getCharacterType(c) == characterType.rtl;
} }
@ -89,7 +88,7 @@ public class RtlUtils {
/** /**
* @return true if the char is in the rtl range, otherwise false * @return true if the char is in the rtl range, otherwise false
*/ */
static boolean isArabic(Character c){ public static boolean isArabic(Character c){
return getCharacterType(c) == characterType.rtl_arabic; return getCharacterType(c) == characterType.rtl_arabic;
} }
@ -97,7 +96,7 @@ public class RtlUtils {
/** /**
* @return true if the char is in the rtl range, otherwise false * @return true if the char is in the rtl range, otherwise false
*/ */
static boolean isLtr(Character c){ public static boolean isLtr(Character c){
return getCharacterType(c) == characterType.ltr; return getCharacterType(c) == characterType.ltr;
} }
@ -105,7 +104,7 @@ public class RtlUtils {
/** /**
* @return true if the char is in the rtl range, otherwise false * @return true if the char is in the rtl range, otherwise false
*/ */
static boolean isRtl(Character c){ public static boolean isRtl(Character c){
return (getCharacterType(c) == characterType.rtl) || (getCharacterType(c) == characterType.rtl_arabic); return (getCharacterType(c) == characterType.rtl) || (getCharacterType(c) == characterType.rtl_arabic);
} }
@ -113,7 +112,7 @@ public class RtlUtils {
/** /**
* @return true if the char is in the punctuations range, otherwise false * @return true if the char is in the punctuations range, otherwise false
*/ */
static boolean isPunctuations(Character c){ public static boolean isPunctuations(Character c){
return getCharacterType(c) == characterType.punctuation; return getCharacterType(c) == characterType.punctuation;
} }
@ -122,7 +121,7 @@ public class RtlUtils {
/** /**
* @return true if the char is in the end of word list, otherwise false * @return true if the char is in the end of word list, otherwise false
*/ */
static boolean isSpaceSign(Character c){ public static boolean isSpaceSign(Character c){
return getCharacterType(c) == characterType.space; return getCharacterType(c) == characterType.space;
} }
@ -130,7 +129,7 @@ public class RtlUtils {
/** /**
* @return true if the char is in the end of word list, otherwise false * @return true if the char is in the end of word list, otherwise false
*/ */
static boolean isEndLineSign(Character c){ public static boolean isEndLineSign(Character c){
return getCharacterType(c) == characterType.lineEnd; return getCharacterType(c) == characterType.lineEnd;
} }
@ -284,14 +283,14 @@ public class RtlUtils {
put((char)('ل' + 'ا'), '\uFEFC'); put((char)('ل' + 'ا'), '\uFEFC');
} }
}; };
enum contextualState{ public enum contextualState{
isolate, isolate,
begin, begin,
middle, middle,
end end
} }
private static boolean exceptionAfterLam(Character c){ public static boolean exceptionAfterLam(Character c){
switch (c){ switch (c){
case '\u0622': case '\u0622':
case '\u0623': case '\u0623':
@ -310,7 +309,7 @@ public class RtlUtils {
* @param state - the character state: beginning, middle, end or isolated * @param state - the character state: beginning, middle, end or isolated
* @return the contextual character * @return the contextual character
*/ */
private static Character getContextualSymbol(Character c, contextualState state) { public static Character getContextualSymbol(Character c, contextualState state) {
Character newChar; Character newChar;
switch (state){ switch (state){
case begin: case begin:
@ -341,7 +340,7 @@ public class RtlUtils {
* @param nextChar - the next character or null if none * @param nextChar - the next character or null if none
* @return the current character contextual state * @return the current character contextual state
*/ */
private static contextualState getCharContextualState(contextualState prevState, Character curChar, Character nextChar) { public static contextualState getCharContextualState(contextualState prevState, Character curChar, Character nextChar) {
contextualState curState; contextualState curState;
if ((prevState == contextualState.isolate || prevState == contextualState.end) && if ((prevState == contextualState.isolate || prevState == contextualState.end) &&
contextualArabicBeginning.containsKey(curChar) && contextualArabicBeginning.containsKey(curChar) &&
@ -368,7 +367,7 @@ public class RtlUtils {
* @param s - the given string * @param s - the given string
* @return the contextual form of the string * @return the contextual form of the string
*/ */
static String converToContextual(String s){ public static String convertToContextual(String s){
if (s == null || s.isEmpty() || s.length() == 1){ if (s == null || s.isEmpty() || s.length() == 1){
return s; return s;
} }
@ -417,7 +416,7 @@ public class RtlUtils {
* @param s - the string to reverse * @param s - the string to reverse
* @return reversed string * @return reversed string
*/ */
static String reverse(String s) { public static String reverse(String s) {
int j = s.length(); int j = s.length();
int isEndLine = 0; int isEndLine = 0;
char[] newWord = new char[j]; char[] newWord = new char[j];
@ -426,12 +425,6 @@ public class RtlUtils {
return s; return s;
} }
// remain end-of-word sign at the end
// if (isEndLineSign(s.charAt(s.length() - 1))){
// isEndLine = 1;
// newWord[--j] = s.charAt(s.length() - 1);
// }
for (int i = 0; i < s.length() - isEndLine; i++) { for (int i = 0; i < s.length() - isEndLine; i++) {
if (directionSignsMap.containsKey(s.charAt(i))) { if (directionSignsMap.containsKey(s.charAt(i))) {
newWord[--j] = directionSignsMap.get(s.charAt(i)); newWord[--j] = directionSignsMap.get(s.charAt(i));
@ -443,7 +436,7 @@ public class RtlUtils {
return new String(newWord); return new String(newWord);
} }
static String fixWhitespace(String s){ public static String fixWhitespace(String s){
int length = s.length(); int length = s.length();
if (length > 0 && isSpaceSign(s.charAt(length - 1))){ if (length > 0 && isSpaceSign(s.charAt(length - 1))){
@ -471,7 +464,7 @@ public class RtlUtils {
String newString = ""; String newString = "";
List<String> lines = new ArrayList<>(); List<String> lines = new ArrayList<>();
char[] newWord = new char[length]; char[] newWord = new char[length];
int line_max_size = GBApplication.getPrefs().getInt("rtl_max_line_length", 20);; int line_max_size = GBApplication.getPrefs().getInt("rtl_max_line_length", 18);
int startPos = 0; int startPos = 0;
int endPos = 0; int endPos = 0;
@ -528,7 +521,7 @@ public class RtlUtils {
Log.d("ROIGR", "phrase: |" + phraseString + "|"); Log.d("ROIGR", "phrase: |" + phraseString + "|");
if (PhraseRtlType == characterType.rtl) { if (PhraseRtlType == characterType.rtl) {
if (contextualSupport()) { if (contextualSupport()) {
phraseString = converToContextual(phraseString); phraseString = convertToContextual(phraseString);
} }
phraseString = reverse(phraseString); phraseString = reverse(phraseString);
} }

View File

@ -0,0 +1,368 @@
package nodomain.freeyourgadget.gadgetbridge.test;
import android.content.SharedPreferences;
import org.junit.Test;
import nodomain.freeyourgadget.gadgetbridge.GBApplication;
import nodomain.freeyourgadget.gadgetbridge.util.RtlUtils;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertFalse;
import static org.junit.Assert.assertTrue;
/**
* Tests RtlUtils
*/
public class RtlUtilsTest extends TestBase {
// @Test
private Character hebrew1 = 'א';
private Character hebrew2 = 'ם';
private Character arabic1 = 'ا';
private Character arabic2 = 'ن';
private Character english1 = 'a';
private Character english2 = 'N';
private Character punctuation1 = '.';
private Character punctuation2 = '-';
private Character space = ' ';
private Character endLine1 = '\0';
private Character endLine2 = '\n';
private Character[] contextualIsolated = {'ء', '\uFE80'};
private Character[] contextualBeginning = {'س', '\uFEB3'};
private Character[] contextualMiddle = {'ض', '\uFEC0'};
private Character[] contextualEndNoMiddle = {'آ', '\uFE82'};
private Character[] contextualLam = {(char)('ل' + 'أ'), '\uFEF8'};
private String hebrewWord1 = "שלום";
private String hebrewWord2 = "וברכה";
private String hebrewPhrase = hebrewWord1 + " " + hebrewWord2;
private String arabicWord1 = "سلام";
private String arabicWord2 = "البركة";
private String arabicPhrase = arabicWord1 + " " + arabicWord2;
private String englishWord1 = "Hello";
private String englishWord2 = "Welcome";
private String englishPhrase = englishWord1 + " and " + englishWord2;
@Test
public void testGetCharacterType() throws Exception {
RtlUtils.characterType actual = RtlUtils.getCharacterType(hebrew1);
RtlUtils.characterType expected = RtlUtils.characterType.rtl;
assertEquals("Get Hebrew Character type failed", expected, actual);
actual = RtlUtils.getCharacterType(arabic1);
expected = RtlUtils.characterType.rtl_arabic;
assertEquals("Get Arabic Character type failed", expected, actual);
actual = RtlUtils.getCharacterType(english1);
expected = RtlUtils.characterType.ltr;
assertEquals("Get Hebrew Character type failed", expected, actual);
actual = RtlUtils.getCharacterType(' ');
expected = RtlUtils.characterType.space;
assertEquals("Get Hebrew Character type failed", expected, actual);
}
@Test
public void testIsHebrew() throws Exception {
boolean result = RtlUtils.isHebrew(hebrew1);
assertTrue("Is Hebrew Character failed", result);
result = RtlUtils.isHebrew(hebrew2);
assertTrue("Is Hebrew Character failed", result);
result = RtlUtils.isHebrew(arabic1);
assertFalse("Is Hebrew Character failed", result);
result = RtlUtils.isHebrew(english1);
assertFalse("Is Hebrew Character failed", result);
}
@Test
public void testIsArabic() throws Exception {
boolean result = RtlUtils.isArabic(arabic1);
assertTrue("Is Arabic Character failed", result);
result = RtlUtils.isArabic(arabic2);
assertTrue("Is Arabic Character failed", result);
result = RtlUtils.isArabic(hebrew1);
assertFalse("Is Arabic Character failed", result);
result = RtlUtils.isArabic(english1);
assertFalse("Is Arabic Character failed", result);
}
@Test
public void testIsLtr() throws Exception {
boolean result = RtlUtils.isLtr(english1);
assertTrue("Is Ltr Character failed", result);
result = RtlUtils.isLtr(english1);
assertTrue("Is Ltr Character failed", result);
result = RtlUtils.isLtr(hebrew1);
assertFalse("Is Ltr Character failed", result);
result = RtlUtils.isLtr(arabic1);
assertFalse("Is Ltr Character failed", result);
}
@Test
public void testIsRtl() throws Exception {
boolean result = RtlUtils.isRtl(hebrew1);
assertTrue("Is Rtl Character failed", result);
result = RtlUtils.isRtl(arabic1);
assertTrue("Is Rtl Character failed", result);
result = RtlUtils.isRtl(english1);
assertFalse("Is Rtl Character failed", result);
result = RtlUtils.isRtl(punctuation1);
assertFalse("Is Rtl Character failed", result);
}
@Test
public void testIsPunctuation() throws Exception {
boolean result = RtlUtils.isPunctuations(punctuation1);
assertTrue("Is Punctuation Character failed", result);
result = RtlUtils.isPunctuations(punctuation1);
assertTrue("Is Punctuation Character failed", result);
result = RtlUtils.isPunctuations(english1);
assertFalse("Is Punctuation Character failed", result);
result = RtlUtils.isPunctuations(space);
assertFalse("Is Punctuation Character failed", result);
}
@Test
public void testIsSpaceSign() throws Exception {
boolean result = RtlUtils.isSpaceSign(space);
assertTrue("Is Space Sign Character failed", result);
result = RtlUtils.isSpaceSign(punctuation1);
assertFalse("Is Space Sign Character failed", result);
result = RtlUtils.isSpaceSign(english1);
assertFalse("Is SpaceSign Character failed", result);
result = RtlUtils.isSpaceSign(hebrew1);
assertFalse("Is SpaceSign Character failed", result);
}
@Test
public void testIsEndLineSign() throws Exception {
boolean result = RtlUtils.isEndLineSign(endLine1);
assertTrue("Is End Line Sign Character failed", result);
result = RtlUtils.isEndLineSign(endLine2);
assertTrue("Is End Line Sign Character failed", result);
result = RtlUtils.isEndLineSign(english1);
assertFalse("Is End Line Sign Character failed", result);
result = RtlUtils.isEndLineSign(space);
assertFalse("Is End Line Sign Character failed", result);
}
@Test
public void testExceptionAfterLam() throws Exception {
boolean result = RtlUtils.exceptionAfterLam('\u0623');
assertTrue("Is Exception After Lam failed", result);
result = RtlUtils.exceptionAfterLam('\u0630');
assertFalse("Is Exception After Lam failed", result);
result = RtlUtils.exceptionAfterLam('\u062A');
assertFalse("Is Exception After Lam failed", result);
}
@Test
public void testGetContextualSymbol() throws Exception {
Character actual = RtlUtils.getContextualSymbol(contextualIsolated[0], RtlUtils.contextualState.isolate);
Character expected = contextualIsolated[1];
assertEquals("Get Contextual Symbol failed", expected, actual);
actual = RtlUtils.getContextualSymbol(contextualBeginning[0], RtlUtils.contextualState.begin);
expected = contextualBeginning[1];
assertEquals("Get Contextual Symbol failed", expected, actual);
actual = RtlUtils.getContextualSymbol(contextualMiddle[0], RtlUtils.contextualState.middle);
expected = contextualMiddle[1];
assertEquals("Get Contextual Symbol failed", expected, actual);
actual = RtlUtils.getContextualSymbol(contextualEndNoMiddle[0], RtlUtils.contextualState.end);
expected = contextualEndNoMiddle[1];
assertEquals("Get Contextual Symbol failed", expected, actual);
actual = RtlUtils.getContextualSymbol(contextualEndNoMiddle[0], RtlUtils.contextualState.middle);
expected = contextualEndNoMiddle[0];
assertEquals("Get Contextual Symbol failed", expected, actual);
}
@Test
public void testGetCharContextualState() throws Exception {
RtlUtils.contextualState actual = RtlUtils.getCharContextualState(RtlUtils.contextualState.isolate, contextualBeginning[0], contextualEndNoMiddle[0]);
RtlUtils.contextualState expected = RtlUtils.contextualState.begin;
assertEquals("Get Char Contextual State failed", expected, actual);
actual = RtlUtils.getCharContextualState(RtlUtils.contextualState.begin, contextualMiddle[0], contextualEndNoMiddle[0]);
expected = RtlUtils.contextualState.middle;
assertEquals("Get Char Contextual State failed", expected, actual);
actual = RtlUtils.getCharContextualState(RtlUtils.contextualState.begin, contextualMiddle[0], contextualIsolated[0]);
expected = RtlUtils.contextualState.end;
assertEquals("Get Char Contextual State failed", expected, actual);
actual = RtlUtils.getCharContextualState(RtlUtils.contextualState.begin, contextualIsolated[0], contextualEndNoMiddle[0]);
expected = RtlUtils.contextualState.isolate;
assertEquals("Get Char Contextual State failed", expected, actual);
}
@Test
public void testConvertToContextual() throws Exception {
String actual = RtlUtils.convertToContextual("");
String expected = "";
assertEquals("Convert To Contextual failed", expected, actual);
char[] nonContextual = {'ج', 'ج', 'ج'};
char[] contextual = {'\uFE9F', '\uFEA0', '\uFE9E'};
actual = RtlUtils.convertToContextual(new StringBuilder().append(nonContextual).toString());
expected = new StringBuilder().append(contextual).toString();
assertEquals("Convert To Contextual failed", expected, actual);
char[] nonContextual2 = {'ج', 'ج', 'ل', '\u0622','ج'};
char[] contextual2 = {'\uFE9F', '\uFEA0', '\uFEF6', '\uFE9D'};
actual = RtlUtils.convertToContextual(new StringBuilder().append(nonContextual2).toString());
expected = new StringBuilder().append(contextual2).toString();
assertEquals("Convert To Contextual failed", expected, actual);
}
@Test
public void testReverse() throws Exception {
String actual = RtlUtils.reverse(hebrewWord1);
String expected = "םולש";
assertEquals("Reverse failed", expected, actual);
actual = RtlUtils.reverse(hebrewPhrase);
expected = "הכרבו םולש";
assertEquals("Reverse failed", expected, actual);
actual = RtlUtils.reverse("טקסט עם (סוגריים) וסימן שאלה?");
expected = "?הלאש ןמיסו (םיירגוס) םע טסקט";
assertEquals("Reverse failed", expected, actual);
}
@Test
public void testFixWhitespace() throws Exception {
String actual = RtlUtils.fixWhitespace(englishPhrase + " ");
String expected = " " + englishPhrase;
assertEquals("fix whitespace failed", expected, actual);
actual = RtlUtils.fixWhitespace(englishPhrase);
expected = englishPhrase;
assertEquals("fix whitespace failed", expected, actual);
}
@Test
public void testFixRtl() throws Exception {
String actual = RtlUtils.fixRtl("Only english");
String expected = "Only english";
assertEquals("fix rtl failed", expected, actual);
actual = RtlUtils.fixRtl("Only very long english with more than 18 characters");
expected = " Only very long\n" +
" english with more\n" +
" than 18\n" +
"characters";
assertEquals("fix rtl failed", expected, actual);
actual = RtlUtils.fixRtl("רק עברית");
expected = "תירבע קר";
assertEquals("fix rtl failed", expected, actual);
actual = RtlUtils.fixRtl("English and עברית");
expected = "תירבע English and";
assertEquals("fix rtl failed", expected, actual);
actual = RtlUtils.fixRtl("משפט ארוך עם עברית and English וגם קצת סימנים כמו ?!$ (וגם ^.)");
expected = " םע ךורא טפשמ\n" +
" and English תירבע\n" +
" םינמיס תצק םגו\n" +
"(.^ םגו) $!? ומכ";
assertEquals("fix rtl failed", expected, actual);
actual = RtlUtils.fixRtl("משפט עם כותרת\0ושמכיל גם ירידת\ורה");
expected = "תרתוכ םע טפשמ\0תדירי םג ליכמשו\n" +
"הרוש";
assertEquals("fix rtl failed", expected, actual);
}
@Test
public void testRtlSupport() throws Exception {
setDefaultRtl();
assertFalse("Rtl option fail! Expected 'Off' by default, but result is 'On'", RtlUtils.rtlSupport());
enableRtl(true);
assertTrue("Rtl option fail! Expected 'On', but result is 'Off'", RtlUtils.rtlSupport());
}
private void setDefaultRtl() {
SharedPreferences settings = GBApplication.getPrefs().getPreferences();
SharedPreferences.Editor editor = settings.edit();
editor.remove("rtl");
editor.apply();
}
private void enableRtl(boolean enable) {
SharedPreferences settings = GBApplication.getPrefs().getPreferences();
SharedPreferences.Editor editor = settings.edit();
editor.putBoolean("rtl", enable);
editor.apply();
}
@Test
public void testContextualSupport() throws Exception {
setDefaultContextual();
assertFalse("Contextual option fail! Expected 'Off' by default, but result is 'On'", RtlUtils.contextualSupport());
enableContextual(true);
assertTrue("Contextual option fail! Expected 'On', but result is 'Off'", RtlUtils.contextualSupport());
}
private void setDefaultContextual() {
SharedPreferences settings = GBApplication.getPrefs().getPreferences();
SharedPreferences.Editor editor = settings.edit();
editor.remove("contextualArabic");
editor.apply();
}
private void enableContextual(boolean enable) {
SharedPreferences settings = GBApplication.getPrefs().getPreferences();
SharedPreferences.Editor editor = settings.edit();
editor.putBoolean("contextualArabic", enable);
editor.apply();
}
}