1 <!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML//EN">
4 <script src="../js/resources/js-test-pre.js"></script>
7 <script type="text/javascript">
8 description('Tests for the onspeechchange event with <input type="text" speech>.');
10 function onSpeechChange() {
11 shouldBeEqualToString('document.getElementById("speechInput").value', 'Green eggs and ham');
12 shouldEvaluateTo('window.event.results.length', 3);
13 shouldBeEqualToString('window.event.results[0].utterance', 'Green eggs and ham');
14 shouldEvaluateTo('window.event.results[0].confidence', 0.8);
15 shouldBeEqualToString('window.event.results[1].utterance', 'Green x and ham');
16 shouldEvaluateTo('window.event.results[1].confidence', 0.5);
17 shouldBeEqualToString('window.event.results[2].utterance', '3 x and am');
18 shouldEvaluateTo('window.event.results[2].confidence', 0.2);
23 if (window.layoutTestController && window.eventSender) {
24 layoutTestController.addMockSpeechInputResult('Green eggs and ham', 0.8, '');
25 layoutTestController.addMockSpeechInputResult('Green x and ham', 0.5, '');
26 layoutTestController.addMockSpeechInputResult('3 x and am', 0.2, '');
28 // Clicking the speech button should fill in mock speech-recognized text.
29 var input = document.getElementById('speechInput');
30 var x = input.offsetLeft + input.offsetWidth - 4;
31 var y = input.offsetTop + input.offsetHeight / 2;
32 eventSender.mouseMoveTo(x, y);
33 eventSender.mouseDown();
34 eventSender.mouseUp();
39 window.jsTestIsAsync = true;
41 <script src="../js/resources/js-test-post.js"></script>
42 <input id='speechInput' x-webkit-speech onwebkitspeechchange="onSpeechChange()">