blob: 20d946edbb4ac271f1e84f6750ba0948363b2d83 [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.
/**
* @assertionElement querySelector(String selectors)
* Finds the first descendant element of this document that matches the specified
* group of selectors.
* selectors should be a string using CSS selector syntax.
* @description Checks various selectors (not exhaustive)
*/
import "dart:html";
import "../../../Utils/expect.dart";
import "../testcommon.dart";
main() {
var e = new Element.html(
'<div>'
'<span>'
'''<hr><pre
id="myid"
class="foo bar"
lang="en">'''
'</pre>'
'</span>'
'</div>',
treeSanitizer: new NullTreeSanitizer());
document.body?.append(e);
Expect.isTrue(
document.querySelector('*') is HtmlElement, 'Universal selector');
Expect.isTrue(document.querySelector('pre') is PreElement, 'Type selector');
Expect.isNull(document.querySelector('table'), 'Type selector, negative');
Expect.isTrue(document.querySelector('span pre') is PreElement,
'Descendant selector, direct');
Expect.isTrue(document.querySelector('div pre') is PreElement,
'Descendant selector, indirect');
Expect.isTrue(document.querySelector('* pre') is PreElement,
'Descendant selector, any');
Expect.isTrue(
document.querySelector('span > pre') is PreElement, 'Child selector');
Expect.isNull(
document.querySelector('div > pre'), 'Child selector, negative');
Expect.isNull(document.querySelector('pre:first-child'),
'The :first-child pseudo-class');
Expect.isTrue(document.querySelector('pre:lang(en)') is PreElement,
'The :lang() pseudo-class');
Expect.isNull(
document.querySelector('pre:lang(fr)'), 'The :lang() pseudo-class');
Expect.isTrue(
document.querySelector('hr + pre') is PreElement, 'Adjacent selector');
Expect.isNull(
document.querySelector('div + pre'), 'Adjacent selector, negative');
Expect.isTrue(
document.querySelector('pre[id]') is PreElement, 'Attribute selector 1');
Expect.isNull(
document.querySelector('pre[foo]'), 'Attribute selector 1, negative');
Expect.isTrue(document.querySelector('pre[id="myid"]') is PreElement,
'Attribute selector 2');
Expect.isNull(document.querySelector('pre[id="myid2"]'),
'Attribute selector 2, negative');
Expect.isTrue(document.querySelector('pre[class~="bar"]') is PreElement,
'Attribute selector 3');
Expect.isNull(document.querySelector('pre[class~="baz"]'),
'Attribute selector 3, negative');
Expect.isTrue(document.querySelector('pre[lang|="en"]') is PreElement,
'Attribute selector 4');
Expect.isNull(document.querySelector('pre[lang|="fr"]'),
'Attribute selector 4, negative');
Expect.isTrue(
document.querySelector('pre.foo') is PreElement, 'Class selector');
Expect.isNull(document.querySelector('pre.baz'), 'Class selector, negative');
Expect.isTrue(
document.querySelector('pre#myid') is PreElement, 'Id selector');
Expect.isNull(document.querySelector('pre#baz'), 'Id selector, negative');
}