| 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);
|
| + });
|
| +}
|
|
|