OLD | NEW |
| (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/polymer.dart'; | |
10 | |
11 // Test ported from: | |
12 // https://github.com/Polymer/polymer-dev/blob/0.3.4/test/html/computedPropertie
s.html | |
13 @CustomTag('x-foo') | |
14 class XFoo extends PolymerElement { | |
15 XFoo.created() : super.created(); | |
16 | |
17 // Left like this to illustrate the old-style @published pattern next to the | |
18 // new style below. | |
19 @published int count; | |
20 | |
21 @published | |
22 String get foo => readValue(#foo); | |
23 set foo(String v) => writeValue(#foo, v); | |
24 | |
25 @published | |
26 String get bar => readValue(#bar); | |
27 set bar(String v) => writeValue(#bar, v); | |
28 | |
29 @ComputedProperty('repeat(fooBar, count)') | |
30 String get fooBarCounted => readValue(#fooBarCounted); | |
31 | |
32 @ComputedProperty('foo + "-" + bar') | |
33 String get fooBar => readValue(#fooBar); | |
34 | |
35 @ComputedProperty('this.foo') | |
36 String get foo2 => readValue(#foo2); | |
37 set foo2(v) => writeValue(#foo2, v); | |
38 | |
39 @ComputedProperty('bar + ""') | |
40 String get bar2 => readValue(#bar2); | |
41 set bar2(v) => writeValue(#bar2, v); | |
42 | |
43 repeat(String s, int count) { | |
44 var sb = new StringBuffer(); | |
45 for (var i = 0; i < count; i++) { | |
46 if (i > 0) sb.write(' '); | |
47 sb.write(s); | |
48 sb.write('($i)'); | |
49 } | |
50 return sb.toString(); | |
51 } | |
52 } | |
53 | |
54 main() => initPolymer().then((zone) => zone.run(() { | |
55 useHtmlConfiguration(); | |
56 | |
57 setUp(() => Polymer.onReady); | |
58 | |
59 test('computed properties basic', () { | |
60 var xFoo = querySelector('x-foo'); | |
61 var html = xFoo.shadowRoot.innerHtml; | |
62 expect(html, 'mee-too:mee-too(0) mee-too(1) mee-too(2)'); | |
63 expect(xFoo.fooBar, 'mee-too'); | |
64 }); | |
65 | |
66 // Dart note: the following tests were not in the original JS test. | |
67 test('computed properties can be updated', () { | |
68 var xFoo = querySelector('x-foo'); | |
69 expect(xFoo.foo, 'mee'); | |
70 expect(xFoo.foo2, 'mee'); | |
71 xFoo.foo2 = 'hi'; | |
72 expect(xFoo.foo, 'hi'); | |
73 expect(xFoo.foo2, 'hi'); | |
74 }); | |
75 | |
76 test('only assignable expressions can be updated', () { | |
77 var xFoo = querySelector('x-foo'); | |
78 expect(xFoo.bar, 'too'); | |
79 expect(xFoo.bar2, 'too'); | |
80 xFoo.bar2 = 'hi'; | |
81 expect(xFoo.bar, 'too'); | |
82 expect(xFoo.bar2, 'too'); | |
83 }); | |
84 })); | |
OLD | NEW |