Merge "Remove toggleShift and toggleAlphabetAndSymbols from KeyboardSwitcher"
commit
c9fade6b87
|
@ -148,7 +148,7 @@ public class KeyboardSwitcher implements KeyboardState.SwitchActions,
|
|||
// have separate layouts with unique KeyboardIds for alphabet and alphabet-shifted
|
||||
// respectively.
|
||||
if (mainKeyboardId.isPhoneKeyboard()) {
|
||||
mState.onToggleAlphabetAndSymbols();
|
||||
mState.setSymbolsKeyboard();
|
||||
}
|
||||
updateShiftState();
|
||||
}
|
||||
|
@ -256,13 +256,6 @@ public class KeyboardSwitcher implements KeyboardState.SwitchActions,
|
|||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Toggle keyboard shift state triggered by user touch event.
|
||||
*/
|
||||
public void toggleShift() {
|
||||
mState.onToggleShift();
|
||||
}
|
||||
|
||||
/**
|
||||
* Toggle caps lock state triggered by user touch event.
|
||||
*/
|
||||
|
@ -270,13 +263,6 @@ public class KeyboardSwitcher implements KeyboardState.SwitchActions,
|
|||
mState.onToggleCapsLock();
|
||||
}
|
||||
|
||||
/**
|
||||
* Toggle between alphabet and symbols modes triggered by user touch event.
|
||||
*/
|
||||
public void toggleAlphabetAndSymbols() {
|
||||
mState.onToggleAlphabetAndSymbols();
|
||||
}
|
||||
|
||||
/**
|
||||
* Update keyboard shift state triggered by connected EditText status change.
|
||||
*/
|
||||
|
|
|
@ -31,8 +31,7 @@ import com.android.inputmethod.keyboard.Keyboard;
|
|||
* {@link #onPressShift(boolean)}, {@link #onReleaseShift(boolean)}, {@link #onPressSymbol()},
|
||||
* {@link #onReleaseSymbol()}, {@link #onOtherKeyPressed()},
|
||||
* {@link #onCodeInput(int, boolean, boolean)}, {@link #onCancelInput(boolean)},
|
||||
* {@link #onUpdateShiftState(boolean)}, {@link #onToggleShift()}, {@link #onToggleCapsLock()},
|
||||
* and {@link #onToggleAlphabetAndSymbols()}.
|
||||
* {@link #onUpdateShiftState(boolean)}, and {@link #onToggleCapsLock()}.
|
||||
*
|
||||
* The actions are {@link SwitchActions}'s methods.
|
||||
*/
|
||||
|
@ -219,7 +218,8 @@ public class KeyboardState {
|
|||
mSwitchActions.requestUpdatingShiftState();
|
||||
}
|
||||
|
||||
private void setSymbolsKeyboard() {
|
||||
// TODO: Make this method private
|
||||
public void setSymbolsKeyboard() {
|
||||
if (DEBUG_STATE) {
|
||||
Log.d(TAG, "setSymbolsKeyboard");
|
||||
}
|
||||
|
@ -464,18 +464,6 @@ public class KeyboardState {
|
|||
}
|
||||
}
|
||||
|
||||
public void onToggleShift() {
|
||||
if (DEBUG_STATE) {
|
||||
Log.d(TAG, "onToggleShift: " + this);
|
||||
}
|
||||
if (mIsAlphabetMode) {
|
||||
setShifted(mKeyboardShiftState.isShiftedOrShiftLocked()
|
||||
? SwitchActions.UNSHIFT : SwitchActions.MANUAL_SHIFT);
|
||||
} else {
|
||||
toggleShiftInSymbols();
|
||||
}
|
||||
}
|
||||
|
||||
public void onToggleCapsLock() {
|
||||
if (DEBUG_STATE) {
|
||||
Log.d(TAG, "onToggleCapsLock: " + this);
|
||||
|
@ -492,13 +480,6 @@ public class KeyboardState {
|
|||
}
|
||||
}
|
||||
|
||||
public void onToggleAlphabetAndSymbols() {
|
||||
if (DEBUG_STATE) {
|
||||
Log.d(TAG, "onToggleAlphabetAndSymbols: " + this);
|
||||
}
|
||||
toggleAlphabetAndSymbols();
|
||||
}
|
||||
|
||||
private static String shiftModeToString(int shiftMode) {
|
||||
switch (shiftMode) {
|
||||
case SwitchActions.UNSHIFT: return "UNSHIFT";
|
||||
|
|
|
@ -1261,16 +1261,8 @@ public class LatinIME extends InputMethodServiceCompatWrapper implements Keyboar
|
|||
LatinImeLogger.logOnDelete();
|
||||
break;
|
||||
case Keyboard.CODE_SHIFT:
|
||||
// Shift key is handled in onPress() when device has distinct multi-touch panel.
|
||||
if (!distinctMultiTouch) {
|
||||
switcher.toggleShift();
|
||||
}
|
||||
break;
|
||||
case Keyboard.CODE_SWITCH_ALPHA_SYMBOL:
|
||||
// Symbol key is handled in onPress() when device has distinct multi-touch panel.
|
||||
if (!distinctMultiTouch) {
|
||||
switcher.toggleAlphabetAndSymbols();
|
||||
}
|
||||
// Shift and symbol key is handled in onPress() and onRelease().
|
||||
break;
|
||||
case Keyboard.CODE_SETTINGS:
|
||||
onSettingsKeyPressed();
|
||||
|
@ -2271,10 +2263,9 @@ public class LatinIME extends InputMethodServiceCompatWrapper implements Keyboar
|
|||
if (switcher.isVibrateAndSoundFeedbackRequired()) {
|
||||
hapticAndAudioFeedback(primaryCode);
|
||||
}
|
||||
final boolean distinctMultiTouch = switcher.hasDistinctMultitouch();
|
||||
if (distinctMultiTouch && primaryCode == Keyboard.CODE_SHIFT) {
|
||||
if (primaryCode == Keyboard.CODE_SHIFT) {
|
||||
switcher.onPressShift(withSliding);
|
||||
} else if (distinctMultiTouch && primaryCode == Keyboard.CODE_SWITCH_ALPHA_SYMBOL) {
|
||||
} else if (primaryCode == Keyboard.CODE_SWITCH_ALPHA_SYMBOL) {
|
||||
switcher.onPressSymbol();
|
||||
} else {
|
||||
switcher.onOtherKeyPressed();
|
||||
|
@ -2284,11 +2275,9 @@ public class LatinIME extends InputMethodServiceCompatWrapper implements Keyboar
|
|||
@Override
|
||||
public void onRelease(int primaryCode, boolean withSliding) {
|
||||
KeyboardSwitcher switcher = mKeyboardSwitcher;
|
||||
// Reset any drag flags in the keyboard
|
||||
final boolean distinctMultiTouch = switcher.hasDistinctMultitouch();
|
||||
if (distinctMultiTouch && primaryCode == Keyboard.CODE_SHIFT) {
|
||||
if (primaryCode == Keyboard.CODE_SHIFT) {
|
||||
switcher.onReleaseShift(withSliding);
|
||||
} else if (distinctMultiTouch && primaryCode == Keyboard.CODE_SWITCH_ALPHA_SYMBOL) {
|
||||
} else if (primaryCode == Keyboard.CODE_SWITCH_ALPHA_SYMBOL) {
|
||||
switcher.onReleaseSymbol();
|
||||
}
|
||||
}
|
||||
|
|
|
@ -21,7 +21,11 @@ import android.test.AndroidTestCase;
|
|||
import com.android.inputmethod.keyboard.Keyboard;
|
||||
|
||||
public class KeyboardStateNonDistinctTests extends AndroidTestCase {
|
||||
private MockKeyboardSwitcher mSwitcher;
|
||||
protected MockKeyboardSwitcher mSwitcher;
|
||||
|
||||
public boolean hasDistinctMultitouch() {
|
||||
return false;
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void setUp() throws Exception {
|
||||
|
@ -30,40 +34,39 @@ public class KeyboardStateNonDistinctTests extends AndroidTestCase {
|
|||
mSwitcher = new MockKeyboardSwitcher();
|
||||
|
||||
final String layoutSwitchBackSymbols = "";
|
||||
final boolean hasDistinctMultitouch = false;
|
||||
mSwitcher.loadKeyboard(layoutSwitchBackSymbols, hasDistinctMultitouch);
|
||||
mSwitcher.loadKeyboard(layoutSwitchBackSymbols, hasDistinctMultitouch());
|
||||
}
|
||||
|
||||
// Argument for KeyboardState.onPressShift and onReleaseShift.
|
||||
private static final boolean NOT_SLIDING = false;
|
||||
private static final boolean SLIDING = true;
|
||||
public static final boolean NOT_SLIDING = false;
|
||||
public static final boolean SLIDING = true;
|
||||
// Argument for KeyboardState.onCodeInput.
|
||||
private static final boolean SINGLE = true;
|
||||
private static final boolean MULTI = false;
|
||||
static final boolean NO_AUTO_CAPS = false;
|
||||
private static final boolean AUTO_CAPS = true;
|
||||
public static final boolean SINGLE = true;
|
||||
public static final boolean MULTI = false;
|
||||
public static final boolean NO_AUTO_CAPS = false;
|
||||
public static final boolean AUTO_CAPS = true;
|
||||
|
||||
private void assertAlphabetNormal() {
|
||||
public void assertAlphabetNormal() {
|
||||
assertTrue(mSwitcher.assertAlphabetNormal());
|
||||
}
|
||||
|
||||
private void assertAlphabetManualShifted() {
|
||||
public void assertAlphabetManualShifted() {
|
||||
assertTrue(mSwitcher.assertAlphabetManualShifted());
|
||||
}
|
||||
|
||||
private void assertAlphabetAutomaticShifted() {
|
||||
public void assertAlphabetAutomaticShifted() {
|
||||
assertTrue(mSwitcher.assertAlphabetAutomaticShifted());
|
||||
}
|
||||
|
||||
private void assertAlphabetShiftLocked() {
|
||||
public void assertAlphabetShiftLocked() {
|
||||
assertTrue(mSwitcher.assertAlphabetShiftLocked());
|
||||
}
|
||||
|
||||
private void assertSymbolsNormal() {
|
||||
public void assertSymbolsNormal() {
|
||||
assertTrue(mSwitcher.assertSymbolsNormal());
|
||||
}
|
||||
|
||||
private void assertSymbolsShifted() {
|
||||
public void assertSymbolsShifted() {
|
||||
assertTrue(mSwitcher.assertSymbolsShifted());
|
||||
}
|
||||
|
||||
|
@ -75,23 +78,20 @@ public class KeyboardStateNonDistinctTests extends AndroidTestCase {
|
|||
// Shift key in alphabet mode.
|
||||
public void testShift() {
|
||||
// Press/release shift key, enter into shift state.
|
||||
mSwitcher.onOtherKeyPressed();
|
||||
assertAlphabetNormal();
|
||||
mSwitcher.toggleShift();
|
||||
mSwitcher.onCodeInput(Keyboard.CODE_SHIFT, SINGLE);
|
||||
mSwitcher.onPressShift(NOT_SLIDING);
|
||||
assertAlphabetManualShifted();
|
||||
mSwitcher.onReleaseShift(NOT_SLIDING);
|
||||
assertAlphabetManualShifted();
|
||||
// Press/release shift key, back to normal state.
|
||||
mSwitcher.onOtherKeyPressed();
|
||||
mSwitcher.onPressShift(NOT_SLIDING);
|
||||
assertAlphabetManualShifted();
|
||||
mSwitcher.toggleShift();
|
||||
mSwitcher.onCodeInput(Keyboard.CODE_SHIFT, SINGLE);
|
||||
mSwitcher.onReleaseShift(NOT_SLIDING);
|
||||
assertAlphabetNormal();
|
||||
|
||||
// Press/release shift key, enter into shift state.
|
||||
mSwitcher.onOtherKeyPressed();
|
||||
assertAlphabetNormal();
|
||||
mSwitcher.toggleShift();
|
||||
mSwitcher.onCodeInput(Keyboard.CODE_SHIFT, SINGLE);
|
||||
mSwitcher.onPressShift(NOT_SLIDING);
|
||||
assertAlphabetManualShifted();
|
||||
mSwitcher.onReleaseShift(NOT_SLIDING);
|
||||
assertAlphabetManualShifted();
|
||||
// Press/release letter key, snap back to normal state.
|
||||
mSwitcher.onOtherKeyPressed();
|
||||
|
@ -99,20 +99,36 @@ public class KeyboardStateNonDistinctTests extends AndroidTestCase {
|
|||
assertAlphabetNormal();
|
||||
}
|
||||
|
||||
private void enterSymbolsMode() {
|
||||
// Press/release "?123" key.
|
||||
// Shift key sliding input.
|
||||
public void testShiftSliding() {
|
||||
// Press shift key.
|
||||
mSwitcher.onPressShift(NOT_SLIDING);
|
||||
assertAlphabetManualShifted();
|
||||
// Slide out shift key.
|
||||
mSwitcher.onReleaseShift(SLIDING);
|
||||
assertAlphabetManualShifted();
|
||||
|
||||
// Enter into letter key.
|
||||
mSwitcher.onOtherKeyPressed();
|
||||
assertAlphabetManualShifted();
|
||||
// Release letter key, snap back to alphabet.
|
||||
mSwitcher.onCodeInput('Z', SINGLE);
|
||||
assertAlphabetNormal();
|
||||
mSwitcher.toggleAlphabetAndSymbols();
|
||||
}
|
||||
|
||||
public void enterSymbolsMode() {
|
||||
// Press/release "?123" key.
|
||||
mSwitcher.onPressSymbol();
|
||||
assertSymbolsNormal();
|
||||
mSwitcher.onCodeInput(Keyboard.CODE_SWITCH_ALPHA_SYMBOL, SINGLE);
|
||||
mSwitcher.onReleaseSymbol();
|
||||
assertSymbolsNormal();
|
||||
}
|
||||
|
||||
private void leaveSymbolsMode() {
|
||||
public void leaveSymbolsMode() {
|
||||
// Press/release "ABC" key.
|
||||
mSwitcher.onOtherKeyPressed();
|
||||
assertSymbolsNormal();
|
||||
mSwitcher.toggleAlphabetAndSymbols();
|
||||
mSwitcher.onPressSymbol();
|
||||
assertAlphabetNormal();
|
||||
mSwitcher.onCodeInput(Keyboard.CODE_SWITCH_ALPHA_SYMBOL, SINGLE);
|
||||
assertAlphabetNormal();
|
||||
}
|
||||
|
@ -126,20 +142,31 @@ public class KeyboardStateNonDistinctTests extends AndroidTestCase {
|
|||
// Switching between alphabet shift locked and symbols.
|
||||
public void testAlphabetShiftLockedAndSymbols() {
|
||||
enterShiftLockWithLongPressShift();
|
||||
|
||||
// Press/release "?123" key.
|
||||
mSwitcher.onOtherKeyPressed();
|
||||
assertAlphabetShiftLocked();
|
||||
mSwitcher.toggleAlphabetAndSymbols();
|
||||
mSwitcher.onCodeInput(Keyboard.CODE_SWITCH_ALPHA_SYMBOL, SINGLE);
|
||||
assertSymbolsNormal();
|
||||
enterSymbolsMode();
|
||||
|
||||
// Press/release "ABC" key, switch back to shift locked mode.
|
||||
mSwitcher.onPressSymbol();
|
||||
assertAlphabetShiftLocked();
|
||||
mSwitcher.onCodeInput(Keyboard.CODE_SWITCH_ALPHA_SYMBOL, SINGLE);
|
||||
mSwitcher.onReleaseSymbol();
|
||||
assertAlphabetShiftLocked();
|
||||
}
|
||||
|
||||
// Symbols key sliding input.
|
||||
public void testSymbolsSliding() {
|
||||
// Press "123?" key.
|
||||
mSwitcher.onPressSymbol();
|
||||
assertSymbolsNormal();
|
||||
// Slide out from "123?" key.
|
||||
mSwitcher.onReleaseSymbol();
|
||||
assertSymbolsNormal();
|
||||
|
||||
// Enter into letter key.
|
||||
mSwitcher.onOtherKeyPressed();
|
||||
assertSymbolsNormal();
|
||||
mSwitcher.toggleAlphabetAndSymbols();
|
||||
mSwitcher.onCodeInput(Keyboard.CODE_SWITCH_ALPHA_SYMBOL, SINGLE);
|
||||
assertAlphabetShiftLocked();
|
||||
// Release letter key, snap back to alphabet.
|
||||
mSwitcher.onCodeInput('z', SINGLE);
|
||||
assertAlphabetNormal();
|
||||
}
|
||||
|
||||
// Switching between symbols and symbols shifted.
|
||||
|
@ -147,23 +174,64 @@ public class KeyboardStateNonDistinctTests extends AndroidTestCase {
|
|||
enterSymbolsMode();
|
||||
|
||||
// Press/release "=\<" key.
|
||||
// Press/release shift key, enter into shift state.
|
||||
mSwitcher.onOtherKeyPressed();
|
||||
assertSymbolsNormal();
|
||||
mSwitcher.toggleShift();
|
||||
mSwitcher.onCodeInput(Keyboard.CODE_SHIFT, SINGLE);
|
||||
mSwitcher.onPressShift(NOT_SLIDING);
|
||||
assertSymbolsShifted();
|
||||
mSwitcher.onReleaseShift(NOT_SLIDING);
|
||||
assertSymbolsShifted();
|
||||
|
||||
// Press/release "?123" key.
|
||||
mSwitcher.onOtherKeyPressed();
|
||||
assertSymbolsShifted();
|
||||
mSwitcher.toggleShift();
|
||||
mSwitcher.onCodeInput(Keyboard.CODE_SHIFT, SINGLE);
|
||||
mSwitcher.onPressShift(NOT_SLIDING);
|
||||
assertSymbolsNormal();
|
||||
mSwitcher.onReleaseShift(NOT_SLIDING);
|
||||
assertSymbolsNormal();
|
||||
|
||||
leaveSymbolsMode();
|
||||
}
|
||||
|
||||
// Symbols shift sliding input
|
||||
public void testSymbolsShiftSliding() {
|
||||
enterSymbolsMode();
|
||||
|
||||
// Press "=\<" key.
|
||||
mSwitcher.onPressShift(NOT_SLIDING);
|
||||
assertSymbolsShifted();
|
||||
// Slide out "=\<" key.
|
||||
mSwitcher.onReleaseShift(SLIDING);
|
||||
assertSymbolsShifted();
|
||||
|
||||
// Enter into symbol shifted letter key.
|
||||
mSwitcher.onOtherKeyPressed();
|
||||
assertSymbolsShifted();
|
||||
// Release symbol shifted letter key, snap back to symbols.
|
||||
mSwitcher.onCodeInput('~', SINGLE);
|
||||
assertSymbolsNormal();
|
||||
}
|
||||
|
||||
// Symbols shift sliding input from symbols shifted.
|
||||
public void testSymbolsShiftSliding2() {
|
||||
enterSymbolsMode();
|
||||
|
||||
// Press/release "=\<" key.
|
||||
mSwitcher.onPressShift(NOT_SLIDING);
|
||||
assertSymbolsShifted();
|
||||
mSwitcher.onReleaseShift(NOT_SLIDING);
|
||||
assertSymbolsShifted();
|
||||
|
||||
// Press "123?" key.
|
||||
mSwitcher.onPressShift(NOT_SLIDING);
|
||||
assertSymbolsNormal();
|
||||
// Slide out "123?" key.
|
||||
mSwitcher.onReleaseShift(SLIDING);
|
||||
assertSymbolsNormal();
|
||||
|
||||
// Enter into symbol letter key.
|
||||
mSwitcher.onOtherKeyPressed();
|
||||
assertSymbolsNormal();
|
||||
// Release symbol letter key, snap back to symbols shift.
|
||||
mSwitcher.onCodeInput('1', SINGLE);
|
||||
assertSymbolsShifted();
|
||||
}
|
||||
|
||||
// Automatic snap back to alphabet from symbols by space key.
|
||||
public void testSnapBackBySpace() {
|
||||
enterSymbolsMode();
|
||||
|
@ -178,10 +246,10 @@ public class KeyboardStateNonDistinctTests extends AndroidTestCase {
|
|||
assertSymbolsNormal();
|
||||
mSwitcher.onCodeInput(Keyboard.CODE_SPACE, SINGLE);
|
||||
assertAlphabetNormal();
|
||||
|
||||
// TODO: Add automatic snap back to shift locked test.
|
||||
}
|
||||
|
||||
// TODO: Add automatic snap back to shift locked test.
|
||||
|
||||
// Automatic snap back to alphabet from symbols by registered letters.
|
||||
public void testSnapBack() {
|
||||
final String snapBackChars = "'";
|
||||
|
@ -211,31 +279,79 @@ public class KeyboardStateNonDistinctTests extends AndroidTestCase {
|
|||
assertAlphabetAutomaticShifted();
|
||||
|
||||
// Press shift key.
|
||||
mSwitcher.onOtherKeyPressed();
|
||||
assertAlphabetAutomaticShifted();
|
||||
mSwitcher.onPressShift(NOT_SLIDING);
|
||||
assertAlphabetManualShifted();
|
||||
// Release shift key.
|
||||
mSwitcher.toggleShift();
|
||||
mSwitcher.onCodeInput(Keyboard.CODE_SHIFT, SINGLE);
|
||||
mSwitcher.onReleaseShift(NOT_SLIDING);
|
||||
assertAlphabetNormal();
|
||||
}
|
||||
|
||||
private void enterShiftLockWithLongPressShift() {
|
||||
// Sliding from shift key in automatic upper case.
|
||||
public void testAutomaticUpperCaseSliding() {
|
||||
mSwitcher.setAutoCapsMode(AUTO_CAPS);
|
||||
// Update shift state with auto caps enabled.
|
||||
mSwitcher.updateShiftState();
|
||||
assertAlphabetAutomaticShifted();
|
||||
|
||||
// Press shift key.
|
||||
mSwitcher.onPressShift(NOT_SLIDING);
|
||||
assertAlphabetManualShifted();
|
||||
// Slide out shift key.
|
||||
mSwitcher.onReleaseShift(SLIDING);
|
||||
assertAlphabetManualShifted();
|
||||
// Enter into letter key.
|
||||
mSwitcher.onOtherKeyPressed();
|
||||
assertAlphabetManualShifted();
|
||||
// Release letter key, snap back to alphabet.
|
||||
mSwitcher.onCodeInput('Z', SINGLE);
|
||||
assertAlphabetNormal();
|
||||
}
|
||||
|
||||
// Sliding from symbol key in automatic upper case.
|
||||
public void testAutomaticUpperCaseSliding2() {
|
||||
mSwitcher.setAutoCapsMode(AUTO_CAPS);
|
||||
// Update shift state with auto caps enabled.
|
||||
mSwitcher.updateShiftState();
|
||||
assertAlphabetAutomaticShifted();
|
||||
|
||||
// Press "123?" key.
|
||||
mSwitcher.onPressSymbol();
|
||||
assertSymbolsNormal();
|
||||
// Slide out "123?" key.
|
||||
mSwitcher.onReleaseSymbol();
|
||||
assertSymbolsNormal();
|
||||
// Enter into symbol letter keys.
|
||||
mSwitcher.onOtherKeyPressed();
|
||||
assertSymbolsNormal();
|
||||
// Release symbol letter key, snap back to alphabet.
|
||||
mSwitcher.onCodeInput('1', SINGLE);
|
||||
assertAlphabetNormal();
|
||||
}
|
||||
|
||||
public void enterShiftLockWithLongPressShift() {
|
||||
// Long press shift key
|
||||
mSwitcher.onPressShift(NOT_SLIDING);
|
||||
assertAlphabetManualShifted();
|
||||
// Long press recognized in LatinKeyboardView.KeyTimerHandler.
|
||||
mSwitcher.toggleCapsLock();
|
||||
assertAlphabetShiftLocked();
|
||||
mSwitcher.onCodeInput(Keyboard.CODE_CAPSLOCK, SINGLE);
|
||||
assertAlphabetShiftLocked();
|
||||
mSwitcher.onReleaseShift(NOT_SLIDING);
|
||||
assertAlphabetShiftLocked();
|
||||
}
|
||||
|
||||
private void leaveShiftLockWithLongPressShift() {
|
||||
public void leaveShiftLockWithLongPressShift() {
|
||||
// Press shift key.
|
||||
mSwitcher.onOtherKeyPressed();
|
||||
mSwitcher.onPressShift(NOT_SLIDING);
|
||||
assertAlphabetManualShifted();
|
||||
// Long press recognized in LatinKeyboardView.KeyTimerHandler.
|
||||
mSwitcher.toggleCapsLock();
|
||||
assertAlphabetNormal();
|
||||
mSwitcher.onCodeInput(Keyboard.CODE_CAPSLOCK, SINGLE);
|
||||
assertAlphabetNormal();
|
||||
mSwitcher.onReleaseShift(NOT_SLIDING);
|
||||
assertAlphabetNormal();
|
||||
}
|
||||
|
||||
// Long press shift key.
|
||||
|
@ -251,10 +367,11 @@ public class KeyboardStateNonDistinctTests extends AndroidTestCase {
|
|||
assertAlphabetShiftLocked();
|
||||
|
||||
// Tap shift key.
|
||||
mSwitcher.onOtherKeyPressed();
|
||||
assertAlphabetShiftLocked();
|
||||
mSwitcher.toggleShift();
|
||||
mSwitcher.onPressShift(NOT_SLIDING);
|
||||
assertAlphabetManualShifted();
|
||||
mSwitcher.onCodeInput(Keyboard.CODE_SHIFT, SINGLE);
|
||||
assertAlphabetManualShifted();
|
||||
mSwitcher.onReleaseShift(NOT_SLIDING);
|
||||
assertAlphabetNormal();
|
||||
}
|
||||
|
||||
|
@ -262,11 +379,12 @@ public class KeyboardStateNonDistinctTests extends AndroidTestCase {
|
|||
// TODO: Move double tap recognizing timer/logic into KeyboardState.
|
||||
public void testDoubleTapShift() {
|
||||
// First shift key tap.
|
||||
mSwitcher.onOtherKeyPressed();
|
||||
assertAlphabetNormal();
|
||||
mSwitcher.toggleShift();
|
||||
mSwitcher.onPressShift(NOT_SLIDING);
|
||||
assertAlphabetManualShifted();
|
||||
mSwitcher.onCodeInput(Keyboard.CODE_SHIFT, SINGLE);
|
||||
assertAlphabetManualShifted();
|
||||
mSwitcher.onReleaseShift(NOT_SLIDING);
|
||||
assertAlphabetManualShifted();
|
||||
// Second shift key tap.
|
||||
// Double tap recognized in LatinKeyboardView.KeyTimerHandler.
|
||||
mSwitcher.toggleCapsLock();
|
||||
|
@ -275,10 +393,11 @@ public class KeyboardStateNonDistinctTests extends AndroidTestCase {
|
|||
assertAlphabetShiftLocked();
|
||||
|
||||
// First shift key tap.
|
||||
mSwitcher.onOtherKeyPressed();
|
||||
assertAlphabetShiftLocked();
|
||||
mSwitcher.toggleShift();
|
||||
mSwitcher.onPressShift(NOT_SLIDING);
|
||||
assertAlphabetManualShifted();
|
||||
mSwitcher.onCodeInput(Keyboard.CODE_SHIFT, SINGLE);
|
||||
assertAlphabetManualShifted();
|
||||
mSwitcher.onReleaseShift(NOT_SLIDING);
|
||||
assertAlphabetNormal();
|
||||
// Second shift key tap.
|
||||
// Second tap is ignored in LatinKeyboardView.KeyTimerHandler.
|
||||
|
|
|
@ -16,84 +16,12 @@
|
|||
|
||||
package com.android.inputmethod.keyboard.internal;
|
||||
|
||||
import android.test.AndroidTestCase;
|
||||
|
||||
import com.android.inputmethod.keyboard.Keyboard;
|
||||
|
||||
public class KeyboardStateTests extends AndroidTestCase {
|
||||
private MockKeyboardSwitcher mSwitcher;
|
||||
|
||||
public class KeyboardStateTests extends KeyboardStateNonDistinctTests {
|
||||
@Override
|
||||
protected void setUp() throws Exception {
|
||||
super.setUp();
|
||||
|
||||
mSwitcher = new MockKeyboardSwitcher();
|
||||
|
||||
final String layoutSwitchBackSymbols = "";
|
||||
final boolean hasDistinctMultitouch = true;
|
||||
mSwitcher.loadKeyboard(layoutSwitchBackSymbols, hasDistinctMultitouch);
|
||||
}
|
||||
|
||||
// Argument for KeyboardState.onPressShift and onReleaseShift.
|
||||
private static final boolean NOT_SLIDING = false;
|
||||
private static final boolean SLIDING = true;
|
||||
// Argument for KeyboardState.onCodeInput.
|
||||
private static final boolean SINGLE = true;
|
||||
private static final boolean MULTI = false;
|
||||
static final boolean NO_AUTO_CAPS = false;
|
||||
private static final boolean AUTO_CAPS = true;
|
||||
|
||||
private void assertAlphabetNormal() {
|
||||
assertTrue(mSwitcher.assertAlphabetNormal());
|
||||
}
|
||||
|
||||
private void assertAlphabetManualShifted() {
|
||||
assertTrue(mSwitcher.assertAlphabetManualShifted());
|
||||
}
|
||||
|
||||
private void assertAlphabetAutomaticShifted() {
|
||||
assertTrue(mSwitcher.assertAlphabetAutomaticShifted());
|
||||
}
|
||||
|
||||
private void assertAlphabetShiftLocked() {
|
||||
assertTrue(mSwitcher.assertAlphabetShiftLocked());
|
||||
}
|
||||
|
||||
private void assertSymbolsNormal() {
|
||||
assertTrue(mSwitcher.assertSymbolsNormal());
|
||||
}
|
||||
|
||||
private void assertSymbolsShifted() {
|
||||
assertTrue(mSwitcher.assertSymbolsShifted());
|
||||
}
|
||||
|
||||
// Initial state test.
|
||||
public void testLoadKeyboard() {
|
||||
assertAlphabetNormal();
|
||||
}
|
||||
|
||||
// Shift key in alphabet mode.
|
||||
public void testShift() {
|
||||
// Press/release shift key, enter into shift state.
|
||||
mSwitcher.onPressShift(NOT_SLIDING);
|
||||
assertAlphabetManualShifted();
|
||||
mSwitcher.onReleaseShift(NOT_SLIDING);
|
||||
assertAlphabetManualShifted();
|
||||
// Press/release shift key, back to normal state.
|
||||
mSwitcher.onPressShift(NOT_SLIDING);
|
||||
assertAlphabetManualShifted();
|
||||
mSwitcher.onReleaseShift(NOT_SLIDING);
|
||||
assertAlphabetNormal();
|
||||
|
||||
// Press/release shift key, enter into shift state.
|
||||
mSwitcher.onPressShift(NOT_SLIDING);
|
||||
assertAlphabetManualShifted();
|
||||
mSwitcher.onReleaseShift(NOT_SLIDING);
|
||||
assertAlphabetManualShifted();
|
||||
// Press/release letter key, snap back to normal state.
|
||||
mSwitcher.onOtherKeyPressed();
|
||||
mSwitcher.onCodeInput('Z', SINGLE);
|
||||
assertAlphabetNormal();
|
||||
public boolean hasDistinctMultitouch() {
|
||||
return true;
|
||||
}
|
||||
|
||||
// Shift key chording input.
|
||||
|
@ -117,59 +45,6 @@ public class KeyboardStateTests extends AndroidTestCase {
|
|||
assertAlphabetNormal();
|
||||
}
|
||||
|
||||
// Shift key sliding input.
|
||||
public void testShiftSliding() {
|
||||
// Press shift key.
|
||||
mSwitcher.onPressShift(NOT_SLIDING);
|
||||
assertAlphabetManualShifted();
|
||||
// Slide out shift key.
|
||||
mSwitcher.onReleaseShift(SLIDING);
|
||||
assertAlphabetManualShifted();
|
||||
|
||||
// Enter into letter key.
|
||||
mSwitcher.onOtherKeyPressed();
|
||||
assertAlphabetManualShifted();
|
||||
// Release letter key, snap back to alphabet.
|
||||
mSwitcher.onCodeInput('Z', SINGLE);
|
||||
assertAlphabetNormal();
|
||||
}
|
||||
|
||||
private void enterSymbolsMode() {
|
||||
// Press/release "?123" key.
|
||||
mSwitcher.onPressSymbol();
|
||||
assertSymbolsNormal();
|
||||
mSwitcher.onCodeInput(Keyboard.CODE_SWITCH_ALPHA_SYMBOL, SINGLE);
|
||||
mSwitcher.onReleaseSymbol();
|
||||
assertSymbolsNormal();
|
||||
}
|
||||
|
||||
private void leaveSymbolsMode() {
|
||||
// Press/release "ABC" key.
|
||||
mSwitcher.onPressSymbol();
|
||||
assertAlphabetNormal();
|
||||
mSwitcher.onCodeInput(Keyboard.CODE_SWITCH_ALPHA_SYMBOL, SINGLE);
|
||||
assertAlphabetNormal();
|
||||
}
|
||||
|
||||
// Switching between alphabet and symbols.
|
||||
public void testAlphabetAndSymbols() {
|
||||
enterSymbolsMode();
|
||||
leaveSymbolsMode();
|
||||
}
|
||||
|
||||
// Switching between alphabet shift locked and symbols.
|
||||
public void testAlphabetShiftLockedAndSymbols() {
|
||||
enterShiftLockWithLongPressShift();
|
||||
enterSymbolsMode();
|
||||
|
||||
// Press/release "ABC" key, switch back to shift locked mode.
|
||||
mSwitcher.onPressSymbol();
|
||||
assertAlphabetShiftLocked();
|
||||
mSwitcher.onCodeInput(Keyboard.CODE_SWITCH_ALPHA_SYMBOL, SINGLE);
|
||||
mSwitcher.onReleaseSymbol();
|
||||
assertAlphabetShiftLocked();
|
||||
}
|
||||
|
||||
// Symbols key chording input.
|
||||
public void testSymbolsChording() {
|
||||
// Press symbols key and hold, enter into choring shift state.
|
||||
|
@ -191,138 +66,6 @@ public class KeyboardStateTests extends AndroidTestCase {
|
|||
assertAlphabetNormal();
|
||||
}
|
||||
|
||||
// Symbols key sliding input.
|
||||
public void testSymbolsSliding() {
|
||||
// Press "123?" key.
|
||||
mSwitcher.onPressSymbol();
|
||||
assertSymbolsNormal();
|
||||
// Slide out from "123?" key.
|
||||
mSwitcher.onReleaseSymbol();
|
||||
assertSymbolsNormal();
|
||||
|
||||
// Enter into letter key.
|
||||
mSwitcher.onOtherKeyPressed();
|
||||
assertSymbolsNormal();
|
||||
// Release letter key, snap back to alphabet.
|
||||
mSwitcher.onCodeInput('z', SINGLE);
|
||||
assertAlphabetNormal();
|
||||
}
|
||||
|
||||
// Switching between symbols and symbols shifted.
|
||||
public void testSymbolsAndSymbolsShifted() {
|
||||
enterSymbolsMode();
|
||||
|
||||
// Press/release "=\<" key.
|
||||
mSwitcher.onPressShift(NOT_SLIDING);
|
||||
assertSymbolsShifted();
|
||||
mSwitcher.onReleaseShift(NOT_SLIDING);
|
||||
assertSymbolsShifted();
|
||||
|
||||
// Press/release "?123" key.
|
||||
mSwitcher.onPressShift(NOT_SLIDING);
|
||||
assertSymbolsNormal();
|
||||
mSwitcher.onReleaseShift(NOT_SLIDING);
|
||||
assertSymbolsNormal();
|
||||
|
||||
leaveSymbolsMode();
|
||||
}
|
||||
|
||||
// Symbols shift sliding input
|
||||
public void testSymbolsShiftSliding() {
|
||||
enterSymbolsMode();
|
||||
|
||||
// Press "=\<" key.
|
||||
mSwitcher.onPressShift(NOT_SLIDING);
|
||||
assertSymbolsShifted();
|
||||
// Slide out "=\<" key.
|
||||
mSwitcher.onReleaseShift(SLIDING);
|
||||
assertSymbolsShifted();
|
||||
|
||||
// Enter into symbol shifted letter key.
|
||||
mSwitcher.onOtherKeyPressed();
|
||||
assertSymbolsShifted();
|
||||
// Release symbol shifted letter key, snap back to symbols.
|
||||
mSwitcher.onCodeInput('~', SINGLE);
|
||||
assertSymbolsNormal();
|
||||
}
|
||||
|
||||
// Symbols shift sliding input from symbols shifted.
|
||||
public void testSymbolsShiftSliding2() {
|
||||
enterSymbolsMode();
|
||||
|
||||
// Press/release "=\<" key.
|
||||
mSwitcher.onPressShift(NOT_SLIDING);
|
||||
assertSymbolsShifted();
|
||||
mSwitcher.onReleaseShift(NOT_SLIDING);
|
||||
assertSymbolsShifted();
|
||||
|
||||
// Press "123?" key.
|
||||
mSwitcher.onPressShift(NOT_SLIDING);
|
||||
assertSymbolsNormal();
|
||||
// Slide out "123?" key.
|
||||
mSwitcher.onReleaseShift(SLIDING);
|
||||
assertSymbolsNormal();
|
||||
|
||||
// Enter into symbol letter key.
|
||||
mSwitcher.onOtherKeyPressed();
|
||||
assertSymbolsNormal();
|
||||
// Release symbol letter key, snap back to symbols shift.
|
||||
mSwitcher.onCodeInput('1', SINGLE);
|
||||
assertSymbolsShifted();
|
||||
}
|
||||
|
||||
// Automatic snap back to alphabet from symbols by space key.
|
||||
public void testSnapBackBySpace() {
|
||||
enterSymbolsMode();
|
||||
|
||||
// Enter a symbol letter.
|
||||
mSwitcher.onOtherKeyPressed();
|
||||
assertSymbolsNormal();
|
||||
mSwitcher.onCodeInput('1', SINGLE);
|
||||
assertSymbolsNormal();
|
||||
// Enter space, snap back to alphabet.
|
||||
mSwitcher.onOtherKeyPressed();
|
||||
assertSymbolsNormal();
|
||||
mSwitcher.onCodeInput(Keyboard.CODE_SPACE, SINGLE);
|
||||
assertAlphabetNormal();
|
||||
}
|
||||
|
||||
// Automatic snap back to alphabet from symbols by registered letters.
|
||||
public void testSnapBack() {
|
||||
final String snapBackChars = "'";
|
||||
final int snapBackCode = snapBackChars.codePointAt(0);
|
||||
final boolean hasDistinctMultitouch = true;
|
||||
mSwitcher.loadKeyboard(snapBackChars, hasDistinctMultitouch);
|
||||
|
||||
enterSymbolsMode();
|
||||
|
||||
// Enter a symbol letter.
|
||||
mSwitcher.onOtherKeyPressed();
|
||||
assertSymbolsNormal();
|
||||
mSwitcher.onCodeInput('1', SINGLE);
|
||||
assertSymbolsNormal();
|
||||
// Enter snap back letter, snap back to alphabet.
|
||||
mSwitcher.onOtherKeyPressed();
|
||||
assertSymbolsNormal();
|
||||
mSwitcher.onCodeInput(snapBackCode, SINGLE);
|
||||
assertAlphabetNormal();
|
||||
}
|
||||
|
||||
// Automatic upper case test
|
||||
public void testAutomaticUpperCase() {
|
||||
mSwitcher.setAutoCapsMode(AUTO_CAPS);
|
||||
// Update shift state with auto caps enabled.
|
||||
mSwitcher.updateShiftState();
|
||||
assertAlphabetAutomaticShifted();
|
||||
|
||||
// Press shift key.
|
||||
mSwitcher.onPressShift(NOT_SLIDING);
|
||||
assertAlphabetManualShifted();
|
||||
// Release shift key.
|
||||
mSwitcher.onReleaseShift(NOT_SLIDING);
|
||||
assertAlphabetNormal();
|
||||
}
|
||||
|
||||
// Chording shift key in automatic upper case.
|
||||
public void testAutomaticUpperCaseChording() {
|
||||
mSwitcher.setAutoCapsMode(AUTO_CAPS);
|
||||
|
@ -364,143 +107,5 @@ public class KeyboardStateTests extends AndroidTestCase {
|
|||
assertAlphabetNormal();
|
||||
}
|
||||
|
||||
// Sliding from shift key in automatic upper case.
|
||||
public void testAutomaticUpperCaseSliding() {
|
||||
mSwitcher.setAutoCapsMode(AUTO_CAPS);
|
||||
// Update shift state with auto caps enabled.
|
||||
mSwitcher.updateShiftState();
|
||||
assertAlphabetAutomaticShifted();
|
||||
|
||||
// Press shift key.
|
||||
mSwitcher.onPressShift(NOT_SLIDING);
|
||||
assertAlphabetManualShifted();
|
||||
// Slide out shift key.
|
||||
mSwitcher.onReleaseShift(SLIDING);
|
||||
assertAlphabetManualShifted();
|
||||
// Enter into letter key.
|
||||
mSwitcher.onOtherKeyPressed();
|
||||
assertAlphabetManualShifted();
|
||||
// Release letter key, snap back to alphabet.
|
||||
mSwitcher.onCodeInput('Z', SINGLE);
|
||||
assertAlphabetNormal();
|
||||
}
|
||||
|
||||
// Sliding from symbol key in automatic upper case.
|
||||
public void testAutomaticUpperCaseSliding2() {
|
||||
mSwitcher.setAutoCapsMode(AUTO_CAPS);
|
||||
// Update shift state with auto caps enabled.
|
||||
mSwitcher.updateShiftState();
|
||||
assertAlphabetAutomaticShifted();
|
||||
|
||||
// Press "123?" key.
|
||||
mSwitcher.onPressSymbol();
|
||||
assertSymbolsNormal();
|
||||
// Slide out "123?" key.
|
||||
mSwitcher.onReleaseSymbol();
|
||||
assertSymbolsNormal();
|
||||
// Enter into symbol letter keys.
|
||||
mSwitcher.onOtherKeyPressed();
|
||||
assertSymbolsNormal();
|
||||
// Release symbol letter key, snap back to alphabet.
|
||||
mSwitcher.onCodeInput('1', SINGLE);
|
||||
assertAlphabetNormal();
|
||||
}
|
||||
|
||||
private void enterShiftLockWithLongPressShift() {
|
||||
// Long press shift key
|
||||
mSwitcher.onPressShift(NOT_SLIDING);
|
||||
assertAlphabetManualShifted();
|
||||
// Long press recognized in LatinKeyboardView.KeyTimerHandler.
|
||||
mSwitcher.toggleCapsLock();
|
||||
assertAlphabetShiftLocked();
|
||||
mSwitcher.onCodeInput(Keyboard.CODE_CAPSLOCK, SINGLE);
|
||||
assertAlphabetShiftLocked();
|
||||
mSwitcher.onReleaseShift(NOT_SLIDING);
|
||||
assertAlphabetShiftLocked();
|
||||
}
|
||||
|
||||
private void leaveShiftLockWithLongPressShift() {
|
||||
mSwitcher.onPressShift(NOT_SLIDING);
|
||||
assertAlphabetManualShifted();
|
||||
// Long press recognized in LatinKeyboardView.KeyTimerHandler.
|
||||
mSwitcher.toggleCapsLock();
|
||||
assertAlphabetNormal();
|
||||
mSwitcher.onCodeInput(Keyboard.CODE_CAPSLOCK, SINGLE);
|
||||
assertAlphabetNormal();
|
||||
mSwitcher.onReleaseShift(NOT_SLIDING);
|
||||
assertAlphabetNormal();
|
||||
}
|
||||
|
||||
// Long press shift key.
|
||||
// TODO: Move long press recognizing timer/logic into KeyboardState.
|
||||
public void testLongPressShift() {
|
||||
enterShiftLockWithLongPressShift();
|
||||
leaveShiftLockWithLongPressShift();
|
||||
}
|
||||
|
||||
// Leave shift lock with single tap shift key.
|
||||
public void testShiftInShiftLock() {
|
||||
enterShiftLockWithLongPressShift();
|
||||
assertAlphabetShiftLocked();
|
||||
|
||||
// Tap shift key.
|
||||
mSwitcher.onPressShift(NOT_SLIDING);
|
||||
assertAlphabetManualShifted();
|
||||
mSwitcher.onCodeInput(Keyboard.CODE_SHIFT, SINGLE);
|
||||
assertAlphabetManualShifted();
|
||||
mSwitcher.onReleaseShift(NOT_SLIDING);
|
||||
assertAlphabetNormal();
|
||||
}
|
||||
|
||||
// Double tap shift key.
|
||||
// TODO: Move double tap recognizing timer/logic into KeyboardState.
|
||||
public void testDoubleTapShift() {
|
||||
// First shift key tap.
|
||||
mSwitcher.onPressShift(NOT_SLIDING);
|
||||
assertAlphabetManualShifted();
|
||||
mSwitcher.onCodeInput(Keyboard.CODE_SHIFT, SINGLE);
|
||||
assertAlphabetManualShifted();
|
||||
mSwitcher.onReleaseShift(NOT_SLIDING);
|
||||
assertAlphabetManualShifted();
|
||||
// Second shift key tap.
|
||||
// Double tap recognized in LatinKeyboardView.KeyTimerHandler.
|
||||
mSwitcher.toggleCapsLock();
|
||||
assertAlphabetShiftLocked();
|
||||
mSwitcher.onCodeInput(Keyboard.CODE_SHIFT, SINGLE);
|
||||
assertAlphabetShiftLocked();
|
||||
|
||||
// First shift key tap.
|
||||
mSwitcher.onPressShift(NOT_SLIDING);
|
||||
assertAlphabetManualShifted();
|
||||
mSwitcher.onCodeInput(Keyboard.CODE_SHIFT, SINGLE);
|
||||
assertAlphabetManualShifted();
|
||||
mSwitcher.onReleaseShift(NOT_SLIDING);
|
||||
assertAlphabetNormal();
|
||||
// Second shift key tap.
|
||||
// Second tap is ignored in LatinKeyboardView.KeyTimerHandler.
|
||||
}
|
||||
|
||||
// Update shift state.
|
||||
public void testUpdateShiftState() {
|
||||
mSwitcher.setAutoCapsMode(AUTO_CAPS);
|
||||
// Update shift state.
|
||||
mSwitcher.updateShiftState();
|
||||
assertAlphabetAutomaticShifted();
|
||||
}
|
||||
|
||||
// Update shift state when shift locked.
|
||||
public void testUpdateShiftStateInShiftLocked() {
|
||||
mSwitcher.setAutoCapsMode(AUTO_CAPS);
|
||||
enterShiftLockWithLongPressShift();
|
||||
assertAlphabetShiftLocked();
|
||||
// Update shift state when shift locked
|
||||
mSwitcher.updateShiftState();
|
||||
assertAlphabetShiftLocked();
|
||||
}
|
||||
|
||||
// TODO: Multitouch test
|
||||
|
||||
// TODO: Change focus test.
|
||||
|
||||
// TODO: Change orientation test.
|
||||
}
|
||||
|
|
|
@ -104,18 +104,10 @@ public class MockKeyboardSwitcher implements KeyboardState.SwitchActions {
|
|||
mState.onUpdateShiftState(mAutoCapsMode && mAutoCapsState);
|
||||
}
|
||||
|
||||
public void toggleShift() {
|
||||
mState.onToggleShift();
|
||||
}
|
||||
|
||||
public void toggleCapsLock() {
|
||||
mState.onToggleCapsLock();
|
||||
}
|
||||
|
||||
public void toggleAlphabetAndSymbols() {
|
||||
mState.onToggleAlphabetAndSymbols();
|
||||
}
|
||||
|
||||
public void updateShiftState() {
|
||||
mState.onUpdateShiftState(mAutoCapsMode && mAutoCapsState);
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue