blob: 1d5e2f6381e63c1e4d83ff2b71518615432a117f [file] [log] [blame]
/*
* Copyright (c) 2014, 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.
*/
/**
* @description Class selectors in rightmost compound selector should cause
* LocalStyleChange even if we cannot use invalidation sets.
*/
import "dart:html";
import "../../../testcommon.dart";
import "../../../../Utils/async_utils.dart";
import "pwd.dart";
main() {
var style = new Element.html('''
<style>
#t1 div + .test { background-color: green }
#t2 div ~ .test { background-color: green }
#t3 :not(.nomatch) .test { background-color: green }
</style>
''', treeSanitizer: new NullTreeSanitizer());
document.head.append(style);
document.body.setInnerHtml('''
<div id="t1">
<div></div>
<div>
<span></span>
<span></span>
<span></span>
<span></span>
</div>
</div>
<div id="t2">
<div></div>
<span></span>
<div>
<span></span>
<span></span>
<span></span>
<span></span>
</div>
</div>
<div id="t3">
<div>
<div>
<span></span>
<span></span>
<span></span>
<span></span>
</div>
</div>
</div>
<div>PASS</div>
''', treeSanitizer: new NullTreeSanitizer());
var tests = [
[ "#t1 > div + div", 1 ],
[ "#t2 > div ~ div", 1 ],
[ "#t3 > div > div", 1 ]
];
var green = 'rgb(0, 128, 0)';
for (var i=0; i<tests.length; i++) {
var test = tests[i];
var elm = document.querySelector(test[0]);
document.body.offsetLeft;
elm.className = "test";
shouldBe(getComputedStyle(elm, null).backgroundColor, green);
}
}