-
-
Save mcdurdin/9341d4a8fd628c6cfea095e9d52cf582 to your computer and use it in GitHub Desktop.
sample |
This is a rewrite of keymanapp/keyman#5412 (comment) for experimental purposes.
User Testing
@keymanapp/testers
Instructions
As this PR is centered around how the OSK is constructed within KMW, simply make sure that the keyboard loads as expected on each different device type.
There's nothing particular to specific types of keyboards for this one, so just pick one or two. Test a few keystrokes for good measure; I don't expect any collateral effects here, but it's good to be sure.
Desktop instructions (important!)
The important part: pay extra attention to in-browser desktop form-factor tests, as those are the most likely to break. Make sure the UI modules load properly and allow keyboard-swapping as expected. Use the standard unminified test page:

In order to test compatibility with the different UI module types, you'll need to mildly edit the unminified test page's source:
The four UI modules use the following filenames:
- kmwuibutton.js
- Note: the button will likely display above the first input element, rather than beside the current text input receiver. This is fine.
- kmwuifloat.js
- kmwuitoggle.js (The default state for the "Unminified" test page.)
- kmwuitoolbar.js (This is also used by the "Toolbar UI" test page.)
Simply swap out the filename at the line above within unminified.html
and reload in order to test a different UI module.
Windows / Chrome
Using web/testing/unminified.html
and the instructions above about swapping the UI modules out:
Button UI
- TEST-CHROME.LOAD.BUTTON.1: Confirm that KMW loads properly and displays the Button UI (
kmwuibutton.ts
). - TEST-CHROME.LOAD.BUTTON.2: Use the Button UI to select
sil_euro_latin
and confirm the keyboard swaps properly.
Float UI
- TEST-CHROME.LOAD.FLOAT.1: Confirm that KMW loads properly and displays the Float UI (
kmwuifloat.ts
) when the OSK is visible. - TEST-CHROME.LOAD.FLOAT.2: Use the Float UI to select
sil_euro_latin
and confirm the keyboard swaps properly.
Toggle UI
- TEST-CHROME.LOAD.TOGGLE.1: Confirm that KMW loads properly and displays the Toggle UI (
kmwuitoggle.ts
) when the OSK is visible. - TEST-CHROME.LOAD.TOGGLE.2: Use the Toggle UI to select
sil_euro_latin
and confirm the keyboard swaps properly.
Toolbar UI
- TEST-CHROME.LOAD.TOOLBAR.1: Confirm that KMW loads properly and displays the Toolbar UI (
kmwuitoolbar.ts
). - TEST-CHROME.LOAD.TOOLBAR.2: Use the Toolbar UI to select
sil_euro_latin
and confirm the keyboard swaps properly.- Most easily done through the "Europe" region, then the "English" language.
Windows / Firefox
Using web/testing/unminified.html
and the instructions above about swapping the UI modules out:
Button UI
- TEST-FIREFOX.LOAD.BUTTON.1: Confirm that KMW loads properly and displays the Button UI (
kmwuibutton.ts
). - TEST-FIREFOX.LOAD.BUTTON.2: Use the Button UI to select
sil_euro_latin
and confirm the keyboard swaps properly.
Float UI
- TEST-FIREFOX.LOAD.FLOAT.1: Confirm that KMW loads properly and displays the Float UI (
kmwuifloat.ts
) when the OSK is visible. - TEST-FIREFOX.LOAD.FLOAT.2: Use the Float UI to select
sil_euro_latin
and confirm the keyboard swaps properly.
Toggle UI
- TEST-FIREFOX.LOAD.TOGGLE.1: Confirm that KMW loads properly and displays the Toggle UI (
kmwuitoggle.ts
) when the OSK is visible. - TEST-FIREFOX.LOAD.TOGGLE.2: Use the Toggle UI to select
sil_euro_latin
and confirm the keyboard swaps properly.
Toolbar UI
- TEST-FIREFOX.LOAD.TOOLBAR.1: Confirm that KMW loads properly and displays the Toolbar UI (
kmwuitoolbar.ts
). - TEST-FIREFOX.LOAD.TOOLBAR.2: Use the Toolbar UI to select
sil_euro_latin
and confirm the keyboard swaps properly.- Most easily done through the "Europe" region, then the "English" language.
iOS / in-app keyboard
Mobile instructions
As the OSK will be loading at a later time than it used to, we need to ensure that this doesn't cause obvious blank-keyboard bugs.
It would be wise to ensure that the keyboard loads correctly and consistently in both portrait and landscape orientations (issue #5252 not withstanding) within the apps and as system keyboard.
Portrait
- TEST-IOS-MOBILE.PORTRAIT.1: Verify that the keyboard loads correctly on the first attempt.
- TEST-IOS-MOBILE.PORTRAIT.2: Swap to a different keyboard and verify that it, also, works correctly.
Landscape
- TEST-IOS-MOBILE.LANDSCAPE.1: Verify that the keyboard loads correctly on the first attempt.
- TEST-IOS-MOBILE.LANDSCAPE.2: Swap to a different keyboard and verify that it, also, works correctly.
Settings
- TEST-IOS-MOBILE.APP.SETTINGS: Enter the settings menu and install a new keyboard, then return to the main app. Verify that the new keyboard has loaded properly.
Android / in-app keyboard
Mobile instructions
As the OSK will be loading at a later time than it used to, we need to ensure that this doesn't cause obvious blank-keyboard bugs.
It would be wise to ensure that the keyboard loads correctly and consistently in both portrait and landscape orientations (issue #5252 not withstanding) within the apps and as system keyboard.
Portrait
- TEST-ANDROID-MOBILE.PORTRAIT.1: Verify that the keyboard loads correctly on the first attempt.
- TEST-ANDROID-MOBILE.PORTRAIT.2: Swap to a different keyboard and verify that it, also, works correctly.
Landscape
- TEST-ANDROID-MOBILE.LANDSCAPE.1: Verify that the keyboard loads correctly on the first attempt.
- TEST-ANDROID-MOBILE.LANDSCAPE.2: Swap to a different keyboard and verify that it, also, works correctly.
Settings
- TEST-ANDROID-MOBILE.APP.SETTINGS: Enter the settings menu and install a new keyboard, then return to the main app. Verify that the new keyboard has loaded properly.
Android / system keyboard
Mobile instructions
As the OSK will be loading at a later time than it used to, we need to ensure that this doesn't cause obvious blank-keyboard bugs.
It would be wise to ensure that the keyboard loads correctly and consistently in both portrait and landscape orientations (issue #5252 not withstanding) within the apps and as system keyboard.
Portrait
- TEST-ANDROID-SYSTEM.MOBILE.PORTRAIT.1: Verify that the keyboard loads correctly on the first attempt.
- TEST-ANDROID-SYSTEM.MOBILE.PORTRAIT.2: Swap to a different keyboard and verify that it, also, works correctly.
Landscape
- TEST-ANDROID-SYSTEM.MOBILE.LANDSCAPE.1: Verify that the keyboard loads correctly on the first attempt.
- TEST-ANDROID-SYSTEM.MOBILE.LANDSCAPE.2: Swap to a different keyboard and verify that it, also, works correctly.
It's mostly the same as the previous suite, just without the in-app-only test.
This looks easier on the eyes. :)
@MakaraSok, did you mean to paste that image here? This is only an experiment area 😁
Yes, it's actually for my own conveniences when needed to use the bit in the future. I don't want to retype it every time. :)
You might want to build your own gists for doing this (just go to gist.github.com) so that we don't get confused in the future!
This is a rewrite of keymanapp/keyman#5430 (comment) for experimental purposes.
User Testing
@keymanapp/testers
General Description
Plain-text description
Run the following tests, when possible, for the two following keyboards:
sil_euro_latin
.khmer_angkor
. (Selected as a "control" / "more normal" keyboard.)Loading test (LOAD): As this PR is centered around how the OSK is constructed within KMW, simply make sure that the keyboard loads as expected on each different device type.
Collateral prevention (ROBUST): Test a few keystrokes for good measure; I don't expect any collateral effects here, but it's good to be sure.
=
thene
: should emitə
m
: should emitm
Help text insertion (SHORTCUT): Click the desktop form-factor's "help page" link for
ə
and verify that it is properly output.Windows / Firefox
sil_euro_latin
keyboard; verify everything looks correct=
thene
.ə
m
.m
ə
buttonə
khmer_angkor
keyboard; verify everything looks correct.ស
.Windows / Chrome
sil_euro_latin
keyboard; verify everything looks correct=
thene
.ə
m
.m
ə
buttonə
khmer_angkor
keyboard; verify everything looks correct.ស
.macOS / Safari
sil_euro_latin
keyboard; verify everything looks correct=
thene
.ə
m
.m
ə
buttonə
khmer_angkor
keyboard; verify everything looks correct.ស
.macOS / Chrome emulation / iPhone X
sil_euro_latin
keyboard; verify everything looks correct=
(numeric layer) thene
.=e
e
to typeə
. (Second-to-last subkey)ə
khmer_angkor
keyboard; verify everything looks correct.ស
.Android / Keyman app
sil_euro_latin
keyboard; verify everything looks correct=
(numeric layer) thene
.=e
e
to typeə
. (Second-to-last subkey)ə
khmer_angkor
keyboard; verify everything looks correct.ស
.