mirror of https://github.com/go-gitea/gitea.git
Bypass vitest bug (#32647)
This commit is contained in:
parent
88f5d33ab2
commit
722e703c6b
|
@ -1,4 +1,4 @@
|
||||||
import {createElementFromAttrs, createElementFromHTML, querySingleVisibleElem} from './dom.ts';
|
import {createElementFromAttrs, createElementFromHTML, queryElemChildren, querySingleVisibleElem} from './dom.ts';
|
||||||
|
|
||||||
test('createElementFromHTML', () => {
|
test('createElementFromHTML', () => {
|
||||||
expect(createElementFromHTML('<a>foo<span>bar</span></a>').outerHTML).toEqual('<a>foo<span>bar</span></a>');
|
expect(createElementFromHTML('<a>foo<span>bar</span></a>').outerHTML).toEqual('<a>foo<span>bar</span></a>');
|
||||||
|
@ -26,3 +26,9 @@ test('querySingleVisibleElem', () => {
|
||||||
el = createElementFromHTML('<div><span>foo</span><span>bar</span></div>');
|
el = createElementFromHTML('<div><span>foo</span><span>bar</span></div>');
|
||||||
expect(() => querySingleVisibleElem(el, 'span')).toThrowError('Expected exactly one visible element');
|
expect(() => querySingleVisibleElem(el, 'span')).toThrowError('Expected exactly one visible element');
|
||||||
});
|
});
|
||||||
|
|
||||||
|
test('queryElemChildren', () => {
|
||||||
|
const el = createElementFromHTML('<div><span class="a">a</span><span class="b">b</span></div>');
|
||||||
|
const children = queryElemChildren(el, '.a');
|
||||||
|
expect(children.length).toEqual(1);
|
||||||
|
});
|
||||||
|
|
|
@ -76,6 +76,11 @@ export function queryElemSiblings<T extends Element>(el: Element, selector = '*'
|
||||||
|
|
||||||
// it works like jQuery.children: only the direct children are selected
|
// it works like jQuery.children: only the direct children are selected
|
||||||
export function queryElemChildren<T extends Element>(parent: Element | ParentNode, selector = '*', fn?: ElementsCallback<T>): ArrayLikeIterable<T> {
|
export function queryElemChildren<T extends Element>(parent: Element | ParentNode, selector = '*', fn?: ElementsCallback<T>): ArrayLikeIterable<T> {
|
||||||
|
if (window.vitest) {
|
||||||
|
// bypass the vitest bug: it doesn't support ":scope >"
|
||||||
|
const selected = Array.from<T>(parent.children as any).filter((child) => child.matches(selector));
|
||||||
|
return applyElemsCallback<T>(selected, fn);
|
||||||
|
}
|
||||||
return applyElemsCallback<T>(parent.querySelectorAll(`:scope > ${selector}`), fn);
|
return applyElemsCallback<T>(parent.querySelectorAll(`:scope > ${selector}`), fn);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue