| OLD | NEW |
| 1 // Copyright (c) 2016, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2016, the Dart project authors. Please see the AUTHORS file |
| 2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a |
| 3 // BSD-style license that can be found in the LICENSE file. | 3 // BSD-style license that can be found in the LICENSE file. |
| 4 import 'dart:html'; | 4 import 'dart:html'; |
| 5 import 'dart:async'; | 5 import 'dart:async'; |
| 6 import 'package:unittest/unittest.dart'; | 6 import 'package:unittest/unittest.dart'; |
| 7 import 'package:observatory/models.dart'; | 7 import 'package:observatory/models.dart'; |
| 8 import 'package:observatory/mocks.dart'; | 8 import 'package:observatory/mocks.dart'; |
| 9 import 'package:observatory/src/elements/nav/menu.dart'; | 9 import 'package:observatory/src/elements/isolate_ref.dart'; |
| 10 import 'package:observatory/src/elements/nav/isolate_menu.dart'; | |
| 11 | 10 |
| 12 main(){ | 11 main(){ |
| 13 NavIsolateMenuElement.tag.ensureRegistration(); | 12 IsolateRefElement.tag.ensureRegistration(); |
| 14 | |
| 15 final String tag = NavMenuElement.tag.name; | |
| 16 | 13 |
| 17 StreamController<IsolateUpdateEvent> updatesController; | 14 StreamController<IsolateUpdateEvent> updatesController; |
| 18 final IsolateRefMock ref = const IsolateRefMock(id: 'i-id', name: 'old-name'); | 15 final IsolateRefMock ref = new IsolateRefMock(id: 'id', name: 'old-name'); |
| 19 final IsolateMock obj = const IsolateMock(id: 'i-id', name: 'new-name'); | 16 final IsolateMock obj = new IsolateMock(id: 'id', name: 'new-name'); |
| 20 setUp(() { | 17 setUp(() { |
| 21 updatesController = new StreamController<IsolateUpdateEvent>(); | 18 updatesController = new StreamController<IsolateUpdateEvent>(); |
| 22 }); | 19 }); |
| 23 group('instantiation', () { | 20 group('instantiation', () { |
| 24 test('IsolateRef', () { | 21 test('IsolateRef', () { |
| 25 final NavIsolateMenuElement e = new NavIsolateMenuElement(ref, | 22 final IsolateRefElement e = new IsolateRefElement(ref, |
| 26 updatesController.stream); | 23 updatesController.stream); |
| 27 expect(e, isNotNull, reason: 'element correctly created'); | 24 expect(e, isNotNull, reason: 'element correctly created'); |
| 28 expect(e.isolate, equals(ref)); | 25 expect(e.isolate, equals(ref)); |
| 29 }); | 26 }); |
| 30 test('Isolate', () { | 27 test('Isolate', () { |
| 31 final NavIsolateMenuElement e = new NavIsolateMenuElement(obj, | 28 final IsolateRefElement e = new IsolateRefElement(obj, |
| 32 updatesController.stream); | 29 updatesController.stream); |
| 33 expect(e, isNotNull, reason: 'element correctly created'); | 30 expect(e, isNotNull, reason: 'element correctly created'); |
| 34 expect(e.isolate, equals(obj)); | 31 expect(e.isolate, equals(obj)); |
| 35 }); | 32 }); |
| 36 }); | 33 }); |
| 37 test('elements created after attachment', () async { | 34 test('elements created after attachment', () async { |
| 38 final NavIsolateMenuElement e = new NavIsolateMenuElement(ref, | 35 final IsolateRefElement e = new IsolateRefElement(ref, |
| 39 updatesController.stream); | 36 updatesController.stream); |
| 40 document.body.append(e); | 37 document.body.append(e); |
| 41 await e.onRendered.first; | 38 await e.onRendered.first; |
| 42 expect(e.shadowRoot.children.length, isNonZero, reason: 'has elements'); | 39 expect(e.children.length, isNonZero, reason: 'has elements'); |
| 43 e.remove(); | 40 e.remove(); |
| 44 await e.onRendered.first; | 41 await e.onRendered.first; |
| 45 expect(e.shadowRoot.children.length, isZero, reason: 'is empty'); | 42 expect(e.children.length, isZero, reason: 'is empty'); |
| 46 }); | 43 }); |
| 47 group('updates', () { | 44 group('updates', () { |
| 48 test('are correctly listen', () async { | 45 test('are correctly listen', () async { |
| 49 final NavIsolateMenuElement e = new NavIsolateMenuElement(ref, | 46 final IsolateRefElement e = new IsolateRefElement(ref, |
| 50 updatesController.stream); | 47 updatesController.stream); |
| 51 expect(updatesController.hasListener, isFalse); | 48 expect(updatesController.hasListener, isFalse); |
| 52 document.body.append(e); | 49 document.body.append(e); |
| 53 await e.onRendered.first; | 50 await e.onRendered.first; |
| 54 expect(updatesController.hasListener, isTrue); | 51 expect(updatesController.hasListener, isTrue); |
| 55 e.remove(); | 52 e.remove(); |
| 56 await e.onRendered.first; | 53 await e.onRendered.first; |
| 57 expect(updatesController.hasListener, isFalse); | 54 expect(updatesController.hasListener, isFalse); |
| 58 }); | 55 }); |
| 59 test('have effects', () async { | 56 test('have effects', () async { |
| 60 final NavIsolateMenuElement e = new NavIsolateMenuElement(ref, | 57 final IsolateRefElement e = new IsolateRefElement(ref, |
| 61 updatesController.stream); | 58 updatesController.stream); |
| 62 document.body.append(e); | 59 document.body.append(e); |
| 63 await e.onRendered.first; | 60 await e.onRendered.first; |
| 64 expect((e.shadowRoot.querySelector(tag) as NavMenuElement) | 61 expect(e.innerHtml.contains(ref.id), isTrue); |
| 65 .label.contains(ref.name), isTrue); | |
| 66 updatesController.add(new IsolateUpdateEventMock(isolate: obj)); | 62 updatesController.add(new IsolateUpdateEventMock(isolate: obj)); |
| 67 await e.onRendered.first; | 63 await e.onRendered.first; |
| 68 expect((e.shadowRoot.querySelector(tag) as NavMenuElement) | 64 expect(e.innerHtml.contains(ref.name), isFalse); |
| 69 .label.contains(ref.name), isFalse); | 65 expect(e.innerHtml.contains(obj.name), isTrue); |
| 70 expect((e.shadowRoot.querySelector(tag) as NavMenuElement) | |
| 71 .label.contains(obj.name), isTrue); | |
| 72 e.remove(); | 66 e.remove(); |
| 73 }); | 67 }); |
| 74 }); | 68 }); |
| 75 } | 69 } |
| OLD | NEW |