RESOLVED FIXED 172299
Web Automation: characters produced with shift modifier on QWERTY keyboard should be delivered as shift-down, char-down, char-up, shift-up events
https://bugs.webkit.org/show_bug.cgi?id=172299
Summary Web Automation: characters produced with shift modifier on QWERTY keyboard sh...
Blaze Burg
Reported 2017-05-18 11:57:26 PDT
Currently, we deliver this as keydown(A), keyup(A) but WebDriver tests expect this to be delivered as keydown(SHIFT), keydown(A), keyup(A), keyup(SHIFT) if the shift modifier is not already set via an earlier key press. Note that this means the text HELLO would keydown/keyup the shift key 5 times, because it's not sustained across keystrokes (even if a user might type it that way).
Attachments
Patch (5.75 KB, patch)
2017-05-19 16:57 PDT, Blaze Burg
joepeck: review+
Radar WebKit Bug Importer
Comment 1 2017-05-18 12:07:16 PDT
Blaze Burg
Comment 2 2017-05-19 16:57:26 PDT
Joseph Pecoraro
Comment 3 2017-05-22 11:36:09 PDT
Comment on attachment 310727 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=310727&action=review r=me > Source/WebKit2/UIProcess/Automation/mac/WebAutomationSessionMac.mm:521 > + case 'A': > + case 'B': > + case 'C': > + case 'E': > + case 'F': > + case 'G': > + case 'H': > + case 'I': > + case 'J': > + case 'K': > + case 'L': > + case 'M': > + case 'N': > + case 'O': > + case 'P': > + case 'Q': > + case 'R': > + case 'S': > + case 'T': > + case 'U': > + case 'V': > + case 'W': > + case 'X': > + case 'Y': > + case 'Z': Can we turn this into an easier to read if statement: if (c >= 'A' && c <= 'Z') return YES; The rest can still be in this switch. I realize by putting them all in the switch the compiler might manage some smarter codegen, but I think readability is more important here.
Blaze Burg
Comment 4 2017-05-22 13:56:54 PDT
Note You need to log in before you can comment on or make changes to this bug.