Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(2366)

Unified Diff: runtime/observatory/tests/observatory_ui/vm_connect_target/element_test.dart

Issue 2169313002: Converted Observatory vm-connect-target element (Closed) Base URL: git@github.com:dart-lang/sdk.git@master
Patch Set: Added Uris helper function Created 4 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: runtime/observatory/tests/observatory_ui/vm_connect_target/element_test.dart
diff --git a/runtime/observatory/tests/observatory_ui/vm_connect_target/element_test.dart b/runtime/observatory/tests/observatory_ui/vm_connect_target/element_test.dart
new file mode 100644
index 0000000000000000000000000000000000000000..d5c9080b9c54e034cccac3479e4d46979fee741d
--- /dev/null
+++ b/runtime/observatory/tests/observatory_ui/vm_connect_target/element_test.dart
@@ -0,0 +1,94 @@
+// Copyright (c) 2015, 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.
+import 'dart:html';
+import 'dart:async';
+import 'package:unittest/unittest.dart';
+import 'package:observatory/service_html.dart';
+import 'package:observatory/src/elements/vm_connect_target.dart';
+
+main() {
+ VMConnectTargetElement.tag.ensureRegistration();
+
+ WebSocketVMTarget t;
+ setUp(() {
+ t = new WebSocketVMTarget("a network address");
+ });
+ group('instantiation', () {
+ test('no other parameters', () {
+ final VMConnectTargetElement e = new VMConnectTargetElement(t);
+ expect(e, isNotNull, reason: 'element correctly created');
+ expect(e.target, t, reason: 'target not setted');
+ expect(e.current, isFalse, reason: 'default to not current');
+ });
+ test('isCurrent: false', () {
+ final VMConnectTargetElement e = new VMConnectTargetElement(t,
+ current:false);
+ expect(e, isNotNull, reason: 'element correctly created');
+ expect(e.target, t, reason: 'target not setted');
+ expect(e.current, isFalse, reason: 'default to not current');
+ });
+ test('isCurrent: true', () {
+ final VMConnectTargetElement e = new VMConnectTargetElement(t,
+ current:true);
+ expect(e, isNotNull, reason: 'element correctly created');
+ expect(e.target, t, reason: 'target not setted');
+ expect(e.current, isTrue, reason: 'default to not current');
+ });
+ });
+ test('elements created after attachment', () async {
+ final VMConnectTargetElement e = new VMConnectTargetElement(t);
+ document.body.append(e);
+ await e.onRendered.first;
+ expect(e.children.length, isNonZero, reason: 'has elements');
+ e.remove();
+ await e.onRendered.first;
+ expect(e.children.length, isZero, reason: 'is empty');
+ });
+ group('events are fired', () {
+ VMConnectTargetElement e;
+ StreamSubscription sub;
+ setUp(() async {
+ e = new VMConnectTargetElement(t);
+ document.body.append(e);
+ await e.onRendered.first;
+ });
+ tearDown(() {
+ sub.cancel();
+ e.remove();
+ });
+ test('navigation after connect', () async {
+ sub = window.onPopState.listen(expectAsync((_) {}, count: 1,
+ reason: 'event is fired'));
+ e.querySelector('a').click();
+ });
+ test('onConnect events (DOM)', () async {
+ sub = e.onConnect.listen(expectAsync((TargetEvent event) {
+ expect(event, isNotNull, reason: 'event is passed');
+ expect(event.target, t, reason: 'target is the same');
+ }, count: 1, reason: 'event is fired'));
+ e.querySelector('a').click();
+ });
+ test('onConnect events (code)', () async {
+ sub = e.onConnect.listen(expectAsync((TargetEvent event) {
+ expect(event, isNotNull, reason: 'event is passed');
+ expect(event.target, t, reason: 'target is the same');
+ }, count: 1, reason: 'event is fired'));
+ e.connect();
+ });
+ test('onRemove events (DOM)', () async {
+ sub = e.onDelete.listen(expectAsync((TargetEvent event) {
+ expect(event, isNotNull, reason: 'event is passed');
+ expect(event.target, t, reason: 'target is the same');
+ }, count: 1, reason: 'event is fired'));
+ e.querySelector('button').click();
+ });
+ test('onRemove events (code)', () async {
+ sub = e.onDelete.listen(expectAsync((TargetEvent event) {
+ expect(event, isNotNull, reason: 'event is passed');
+ expect(event.target, t, reason: 'target is the same');
+ }, count: 1, reason: 'event is fired'));
+ e.delete();
+ });
+ });
+}

Powered by Google App Engine
This is Rietveld 408576698