| // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file |
| // for details. All rights reserved. Use of this source code is governed by a |
| // BSD-style license that can be found in the LICENSE file. |
| |
| library interactive_test; |
| |
| import 'dart:async'; |
| import 'dart:html'; |
| import 'package:unittest/unittest.dart'; |
| import 'package:unittest/html_individual_config.dart'; |
| import 'utils.dart'; |
| |
| main() { |
| useHtmlIndividualConfiguration(); |
| |
| group('Geolocation', () { |
| test('getCurrentPosition', () { |
| return window.navigator.geolocation.getCurrentPosition().then((position) { |
| expect(position.coords.latitude, isNotNull); |
| expect(position.coords.longitude, isNotNull); |
| expect(position.coords.accuracy, isNotNull); |
| }); |
| }); |
| |
| test('watchPosition', () { |
| return window.navigator.geolocation |
| .watchPosition() |
| .first |
| .then((position) { |
| expect(position.coords.latitude, isNotNull); |
| expect(position.coords.longitude, isNotNull); |
| expect(position.coords.accuracy, isNotNull); |
| }); |
| }); |
| }); |
| |
| group('MediaStream', () { |
| if (MediaStream.supported) { |
| test('getUserMedia', () { |
| return window.navigator.getUserMedia(video: true).then((stream) { |
| expect(stream, isNotNull); |
| |
| var url = Url.createObjectUrlFromStream(stream); |
| expect(url, isNotNull); |
| |
| var video = new VideoElement()..autoplay = true; |
| |
| var completer = new Completer(); |
| video.onError.listen((e) { |
| completer.completeError(e); |
| }); |
| video.onPlaying.first.then((e) { |
| completer.complete(video); |
| }); |
| |
| document.body.append(video); |
| video.src = url; |
| |
| return completer.future; |
| }); |
| }); |
| |
| test('getUserMediaComplexConstructor', () { |
| return window.navigator.getUserMedia(video: { |
| 'mandatory': {'minAspectRatio': 1.333, 'maxAspectRatio': 1.334}, |
| 'optional': [ |
| {'minFrameRate': 60}, |
| {'maxWidth': 640} |
| ] |
| }).then((stream) { |
| expect(stream, isNotNull); |
| |
| var url = Url.createObjectUrlFromStream(stream); |
| expect(url, isNotNull); |
| |
| var video = new VideoElement()..autoplay = true; |
| |
| var completer = new Completer(); |
| video.onError.listen((e) { |
| completer.completeError(e); |
| }); |
| video.onPlaying.first.then((e) { |
| completer.complete(video); |
| }); |
| |
| document.body.append(video); |
| video.src = url; |
| |
| return completer.future; |
| }); |
| }); |
| } |
| }); |
| |
| group('KeyEvent', () { |
| keydownHandlerTest(KeyEvent e) { |
| document.body.innerHtml = |
| '${document.body.innerHtml}KeyDOWN: CharCode: ${e.charCode}, KeyCode:' |
| ' ${e.keyCode}<br />'; |
| expect(e.charCode, 0); |
| } |
| |
| keypressHandlerTest(KeyEvent e) { |
| document.body.innerHtml = |
| '${document.body.innerHtml}KeyPRESS: CharCode: ${e.charCode}, ' |
| 'KeyCode: ${e.keyCode}<br />'; |
| } |
| |
| keyupHandlerTest(KeyEvent e) { |
| document.body.innerHtml = |
| '${document.body.innerHtml}KeyUP: CharCode: ${e.charCode}, KeyCode:' |
| ' ${e.keyCode}<br />'; |
| expect(e.charCode, 0); |
| } |
| |
| keyupHandlerTest2(KeyEvent e) { |
| document.body.innerHtml = |
| '${document.body.innerHtml}A second KeyUP handler: CharCode: ' |
| '${e.charCode}, KeyCode: ${e.keyCode}<br />'; |
| expect(e.charCode, 0); |
| } |
| |
| test('keys', () { |
| document.body.innerHtml = |
| '${document.body.innerHtml}To test keyboard event values, press some ' |
| 'keys on your keyboard.<br /><br />The charcode for keydown and keyup' |
| ' should be 0, and the keycode should (generally) be populated with a' |
| ' value. Keycode and charcode should both have values for the ' |
| 'keypress event.'; |
| KeyboardEventStream.onKeyDown(document.body).listen(keydownHandlerTest); |
| KeyboardEventStream.onKeyPress(document.body).listen(keypressHandlerTest); |
| KeyboardEventStream.onKeyUp(document.body).listen(keyupHandlerTest); |
| KeyboardEventStream.onKeyUp(document.body).listen(keyupHandlerTest2); |
| }); |
| }); |
| } |