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

Unified Diff: runtime/observatory/tests/observatory_ui/nav/vm_menu/element_test.dart

Issue 2170723002: Converted Observatory vm-nav-menu element (Closed) Base URL: git@github.com:dart-lang/sdk.git@master
Patch Set: Added missing space 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/nav/vm_menu/element_test.dart
diff --git a/runtime/observatory/tests/observatory_ui/nav/vm_menu/element_test.dart b/runtime/observatory/tests/observatory_ui/nav/vm_menu/element_test.dart
new file mode 100644
index 0000000000000000000000000000000000000000..b0539ff46979a3fbf79798c12d6c0b8bac481d39
--- /dev/null
+++ b/runtime/observatory/tests/observatory_ui/nav/vm_menu/element_test.dart
@@ -0,0 +1,85 @@
+// Copyright (c) 2016, 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/mocks.dart';
+import 'package:observatory/models.dart' as M;
+import 'package:observatory/src/elements/nav/menu.dart';
+import 'package:observatory/src/elements/nav/menu_item.dart';
+import 'package:observatory/src/elements/nav/vm_menu.dart';
+
+main(){
+ NavVMMenuElement.tag.ensureRegistration();
+
+ final mTag = NavMenuElement.tag.name;
+ final miTag = NavMenuItemElement.tag.name;
+
+ StreamController<M.VMUpdateEvent> updatesController;
+ final TargetMock target = new TargetMock(name: 'target-name');
+ final VMMock vm1 = const VMMock(name: 'vm-name-1',
+ isolates: const [const IsolateRefMock(id: 'i-id-1', name: 'i-name-1')]);
+ final VMMock vm2 = const VMMock(name: 'vm-name-2',
+ isolates: const [const IsolateRefMock(id: 'i-id-1', name: 'i-name-1'),
+ const IsolateRefMock(id: 'i-id-2', name: 'i-name-2')]);
+ setUp(() {
+ updatesController = new StreamController<M.VMUpdateEvent>.broadcast();
+ });
+ group('instantiation', () {
+ test('no target', () {
+ final NavVMMenuElement e = new NavVMMenuElement(vm1,
+ updatesController.stream);
+ expect(e, isNotNull, reason: 'element correctly created');
+ expect(e.vm, equals(vm1));
+ expect(e.target, isNull);
+ });
+ test('target', () {
+ final NavVMMenuElement e = new NavVMMenuElement(vm1,
+ updatesController.stream, target: target);
+ expect(e, isNotNull, reason: 'element correctly created');
+ expect(e.vm, equals(vm1));
+ expect(e.target, equals(target));
+ });
+ });
+ test('elements created after attachment', () async {
+ final NavVMMenuElement e = new NavVMMenuElement(vm1,
+ updatesController.stream);
+ document.body.append(e);
+ await e.onRendered.first;
+ expect(e.shadowRoot.children.length, isNonZero, reason: 'has elements');
+ e.remove();
+ await e.onRendered.first;
+ expect(e.shadowRoot.children.length, isZero, reason: 'is empty');
+ });
+ group('updates', () {
+ test('are correctly listen', () async {
+ final NavVMMenuElement e = new NavVMMenuElement(vm1,
+ updatesController.stream);
+ expect(updatesController.hasListener, isFalse);
+ document.body.append(e);
+ await e.onRendered.first;
+ expect(updatesController.hasListener, isTrue);
+ e.remove();
+ await e.onRendered.first;
+ expect(updatesController.hasListener, isFalse);
+ });
+ test('have effects', () async {
+ final NavVMMenuElement e = new NavVMMenuElement(vm1,
+ updatesController.stream);
+ document.body.append(e);
+ await e.onRendered.first;
+ expect((e.shadowRoot.querySelector(mTag) as NavMenuElement).label,
+ equals(vm1.name));
+ expect(e.shadowRoot.querySelectorAll(miTag).length,
+ equals(vm1.isolates.length));
+ updatesController.add(new VMUpdateEventMock(vm: vm2));
+ await e.onRendered.first;
+ expect((e.shadowRoot.querySelector(mTag) as NavMenuElement).label,
+ equals(vm2.name));
+ expect(e.shadowRoot.querySelectorAll(miTag).length,
+ equals(vm2.isolates.length));
+ e.remove();
+ });
+ });
+}
« no previous file with comments | « runtime/observatory/observatory_sources.gypi ('k') | runtime/observatory/tests/observatory_ui/nav/vm_menu/element_test.html » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698