Index: packages/polymer/test/build/log_injector_test.dart |
diff --git a/packages/polymer/test/build/log_injector_test.dart b/packages/polymer/test/build/log_injector_test.dart |
new file mode 100644 |
index 0000000000000000000000000000000000000000..ca251e3bbc44049ad4f539a24cce16623c5ccf43 |
--- /dev/null |
+++ b/packages/polymer/test/build/log_injector_test.dart |
@@ -0,0 +1,82 @@ |
+// 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. |
+ |
+import 'dart:async'; |
+import 'dart:html'; |
+import 'package:unittest/unittest.dart'; |
+import 'package:unittest/html_config.dart'; |
+import 'package:polymer/src/build/log_injector.dart'; |
+ |
+main() { |
+ useHtmlConfiguration(); |
+ |
+ setUp(() => new LogInjector().injectLogs('''{ |
+ "polymer#0":[{ |
+ "level":"Info", |
+ "message":{"id":"polymer#0","snippet":"foo"}} |
+ ], |
+ "polymer#1":[{ |
+ "level":"Info", |
+ "message":{"id":"polymer#1","snippet":"foo"}, |
+ "span":{ |
+ "start":{ |
+ "url":"web/test.html", |
+ "offset":22, |
+ "line":1, |
+ "column":0 |
+ }, |
+ "end":{ |
+ "url":"web/test.html", |
+ "offset":50, |
+ "line":1, |
+ "column":28 |
+ }, |
+ "text":"<polymer-element name=\\"x-a\\">" |
+ } |
+ }], |
+ "polymer#2":[ |
+ {"level":"Warning","message":{"id":"polymer#2","snippet":"bar"}}, |
+ {"level":"Warning","message":{"id":"polymer#2", |
+ "snippet":"bar again"}}, |
+ {"level":"Error","message":{"id":"polymer#2","snippet":"baz1"}} |
+ ], |
+ "foo#44":[{"level":"Error","message":{"id":"foo#44","snippet":"baz2"}}] |
+ }''')); |
+ |
+ test('can inject a functioning log widget', () { |
+ var logsElement = document.querySelector(".build-logs"); |
+ expect(logsElement, isNotNull); |
+ |
+ var menuElements = logsElement.querySelectorAll(".menu > div"); |
+ expect(menuElements.length, 3); |
+ var contentElements = logsElement.querySelectorAll(".content > div"); |
+ expect(contentElements.length, 3); |
+ |
+ var expectedClasses = ['info', 'warning', 'error']; |
+ |
+ // Check initial setup. |
+ for (var i = 0; i < menuElements.length; ++i) { |
+ expect(menuElements[i].classes.contains(expectedClasses[i]), true); |
+ expect(menuElements[i].classes.contains('active'), false); |
+ expect(contentElements[i].classes.contains(expectedClasses[i]), true); |
+ expect(contentElements[i].classes.contains('active'), false); |
+ expect(contentElements[i].querySelectorAll('.log').length, 2); |
+ } |
+ |
+ // Test clicking each of the tabs. |
+ for (var i = 0; i < menuElements.length; ++i) { |
+ menuElements[i].click(); |
+ for (var j = 0; j < menuElements.length; ++j) { |
+ expect(menuElements[j].classes.contains('active'), j == i); |
+ expect(contentElements[j].classes.contains('active'), j == i); |
+ } |
+ } |
+ |
+ // Test toggling same tab. |
+ expect(menuElements[2].classes.contains('active'), true); |
+ menuElements[2].click(); |
+ expect(menuElements[2].classes.contains('active'), false); |
+ expect(contentElements[2].classes.contains('active'), false); |
+ }); |
+} |