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

Side by Side Diff: pkg/polymer/test/build/log_injector_test.dart

Issue 427623002: Polymer transformer logs now show on the frontend for pub serve. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: dont wrap the logger in release mode Created 6 years, 4 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
(Empty)
1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file
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.
4
5 import 'dart:async';
6 import 'dart:html';
7 import 'package:unittest/unittest.dart';
8 import 'package:unittest/html_config.dart';
9 import 'package:polymer/src/build/log_injector.dart';
10
11
12 main() {
13
14 useHtmlConfiguration();
15
16 setUp(() => new LogInjector().injectLogs(
17 '''[
18 {"level": "Info", "message": "foo"},
19 {"level": "Warning", "message": "bar"},
20 {"level": "Error", "message": "baz"}
21 ]'''
22 ));
23
24 test('can inject a functioning log widget', () {
25 var logsElement = document.querySelector(".build-logs");
26 expect(logsElement, isNotNull);
27
28 var menuElements = logsElement.querySelectorAll(".menu > div");
29 expect(menuElements.length, 3);
30 var contentElements = logsElement.querySelectorAll(".content > div");
31 expect(contentElements.length, 3);
32
33 var expectedClasses = ['info', 'warning', 'error'];
34
35 // Check initial setup.
36 for (var i = 0; i < menuElements.length; ++i) {
37 expect(menuElements[i].classes.contains(expectedClasses[i]), true);
38 expect(menuElements[i].classes.contains('active'), false);
39 expect(contentElements[i].classes.contains(expectedClasses[i]), true);
40 expect(contentElements[i].classes.contains('active'), false);
41 expect(contentElements[i].querySelectorAll('.log').length, 1);
42 }
43
44 // Test clicking each of the tabs.
45 for (var i = 0; i < menuElements.length; ++i) {
46 menuElements[i].click();
47 for (var j = 0; j < menuElements.length; ++j) {
48 expect(menuElements[j].classes.contains('active'), j == i);
49 expect(contentElements[j].classes.contains('active'), j == i);
50 }
51 }
52
53 // Test toggling same tab.
54 expect(menuElements[2].classes.contains('active'), true);
55 menuElements[2].click();
56 expect(menuElements[2].classes.contains('active'), false);
57 expect(contentElements[2].classes.contains('active'), false);
58 });
59 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698