diff --git a/e2e/solid-start/basic-solid-query/package.json b/e2e/solid-start/basic-solid-query/package.json
index 4baacabf7cf..5af0b6150a0 100644
--- a/e2e/solid-start/basic-solid-query/package.json
+++ b/e2e/solid-start/basic-solid-query/package.json
@@ -34,4 +34,4 @@
"vite-plugin-solid": "^2.11.8",
"vite-tsconfig-paths": "^5.1.4"
}
-}
\ No newline at end of file
+}
diff --git a/e2e/solid-start/basic-solid-query/playwright-report/index.html b/e2e/solid-start/basic-solid-query/playwright-report/index.html
index 2d3e74e45dd..98601962cc0 100644
--- a/e2e/solid-start/basic-solid-query/playwright-report/index.html
+++ b/e2e/solid-start/basic-solid-query/playwright-report/index.html
@@ -1,77 +1,19508 @@
-
-
-
-
+
+
-
-
-
+
+
+
Playwright Test Report
-
-
+`.trimStart(),
+ _0 = ({ error: s, testId: l, context: r }) =>
+ h.jsx($0, {
+ code: s,
+ testId: l,
+ children:
+ r &&
+ h.jsx('div', {
+ style: { position: 'absolute', right: 0, padding: '10px' },
+ children: h.jsx(lg, { context: r }),
+ }),
+ }),
+ $0 = ({ code: s, children: l, testId: r }) => {
+ const a = se.useMemo(() => va(s), [s])
+ return h.jsxs('div', {
+ className: 'test-error-container test-error-text',
+ 'data-testid': r,
+ children: [
+ l,
+ h.jsx('div', {
+ className: 'test-error-view',
+ dangerouslySetInnerHTML: { __html: a || '' },
+ }),
+ ],
+ })
+ },
+ lg = ({ context: s }) => {
+ const [l, r] = se.useState(!1)
+ return h.jsx('button', {
+ className: 'button',
+ style: { minWidth: 100 },
+ onClick: async () => {
+ const a = s.body
+ ? s.body
+ : await fetch(s.path).then((c) => c.text())
+ ;(await navigator.clipboard.writeText(ig + a),
+ r(!0),
+ setTimeout(() => {
+ r(!1)
+ }, 3e3))
+ },
+ children: l ? 'Copied' : 'Copy prompt',
+ })
+ },
+ sg = ({ errorPrefix: s, diff: l, errorSuffix: r }) => {
+ const a = se.useMemo(() => va(s), [s]),
+ c = se.useMemo(() => va(r), [r])
+ return h.jsxs('div', {
+ 'data-testid': 'test-screenshot-error-view',
+ className: 'test-error-view',
+ children: [
+ h.jsx('div', {
+ dangerouslySetInnerHTML: { __html: a || '' },
+ className: 'test-error-text',
+ style: { marginBottom: 20 },
+ }),
+ h.jsx(q0, { diff: l, hideDetails: !0 }, 'image-diff'),
+ h.jsx('div', {
+ 'data-testid': 'error-suffix',
+ dangerouslySetInnerHTML: { __html: c || '' },
+ className: 'test-error-text',
+ }),
+ ],
+ })
+ }
+ function va(s) {
+ return tg(s || '', {
+ bg: 'var(--color-canvas-subtle)',
+ fg: 'var(--color-fg-default)',
+ })
+ }
+ function og(s, l) {
+ var a
+ const r = new Map()
+ for (const c of s) {
+ const f = c.name.match(
+ /^(.*)-(expected|actual|diff|previous)(\.[^.]+)?$/,
+ )
+ if (!f) continue
+ const [, d, m, g = ''] = f,
+ w = d + g
+ let v = r.get(w)
+ ;(v || ((v = { name: w, anchors: [`attachment-${d}`] }), r.set(w, v)),
+ v.anchors.push(`attachment-${l.attachments.indexOf(c)}`),
+ m === 'actual' && (v.actual = { attachment: c }),
+ m === 'expected' &&
+ (v.expected = { attachment: c, title: 'Expected' }),
+ m === 'previous' &&
+ (v.expected = { attachment: c, title: 'Previous' }),
+ m === 'diff' && (v.diff = { attachment: c }))
+ }
+ for (const [c, f] of r)
+ !f.actual || !f.expected
+ ? r.delete(c)
+ : (s.delete(f.actual.attachment),
+ s.delete(f.expected.attachment),
+ s.delete((a = f.diff) == null ? void 0 : a.attachment))
+ return [...r.values()]
+ }
+ const ag = ({ test: s, result: l }) => {
+ const {
+ screenshots: r,
+ videos: a,
+ traces: c,
+ otherAttachments: f,
+ diffs: d,
+ errors: m,
+ otherAttachmentAnchors: g,
+ screenshotAnchors: w,
+ } = se.useMemo(() => {
+ const v = l.attachments.filter((O) => !O.name.startsWith('_')),
+ S = new Set(v.filter((O) => O.contentType.startsWith('image/'))),
+ I = [...S].map((O) => `attachment-${v.indexOf(O)}`),
+ B = v.filter((O) => O.contentType.startsWith('video/')),
+ V = v.filter((O) => O.name === 'trace'),
+ A = new Set(v)
+ ;[...S, ...B, ...V].forEach((O) => A.delete(O))
+ const y = [...A].map((O) => `attachment-${v.indexOf(O)}`),
+ E = og(S, l),
+ j = ug(l.errors, E, l.attachments)
+ return {
+ screenshots: [...S],
+ videos: B,
+ traces: V,
+ otherAttachments: A,
+ diffs: E,
+ errors: j,
+ otherAttachmentAnchors: y,
+ screenshotAnchors: I,
+ }
+ }, [l])
+ return h.jsxs('div', {
+ className: 'test-result',
+ children: [
+ !!m.length &&
+ h.jsx(Bt, {
+ header: 'Errors',
+ children: m.map((v, S) =>
+ v.type === 'screenshot'
+ ? h.jsx(
+ sg,
+ {
+ errorPrefix: v.errorPrefix,
+ diff: v.diff,
+ errorSuffix: v.errorSuffix,
+ },
+ 'test-result-error-message-' + S,
+ )
+ : h.jsx(
+ _0,
+ { error: v.error, context: v.context },
+ 'test-result-error-message-' + S,
+ ),
+ ),
+ }),
+ !!l.steps.length &&
+ h.jsx(Bt, {
+ header: 'Test Steps',
+ children: l.steps.map((v, S) =>
+ h.jsx(
+ ep,
+ { step: v, result: l, test: s, depth: 0 },
+ `step-${S}`,
+ ),
+ ),
+ }),
+ d.map((v, S) =>
+ h.jsx(
+ vi,
+ {
+ id: v.anchors,
+ children: h.jsx(Bt, {
+ dataTestId: 'test-results-image-diff',
+ header: `Image mismatch: ${v.name}`,
+ revealOnAnchorId: v.anchors,
+ children: h.jsx(q0, { diff: v }),
+ }),
+ },
+ `diff-${S}`,
+ ),
+ ),
+ !!r.length &&
+ h.jsx(Bt, {
+ header: 'Screenshots',
+ revealOnAnchorId: w,
+ children: r.map((v, S) =>
+ h.jsxs(
+ vi,
+ {
+ id: `attachment-${l.attachments.indexOf(v)}`,
+ children: [
+ h.jsx('a', {
+ href: v.path,
+ children: h.jsx('img', {
+ className: 'screenshot',
+ src: v.path,
+ }),
+ }),
+ h.jsx(Ll, { attachment: v, result: l }),
+ ],
+ },
+ `screenshot-${S}`,
+ ),
+ ),
+ }),
+ !!c.length &&
+ h.jsx(vi, {
+ id: 'attachment-trace',
+ children: h.jsx(Bt, {
+ header: 'Traces',
+ revealOnAnchorId: 'attachment-trace',
+ children: h.jsxs('div', {
+ children: [
+ h.jsx('a', {
+ href: K0(c),
+ children: h.jsx('img', {
+ className: 'screenshot',
+ src: Jm,
+ style: { width: 192, height: 117, marginLeft: 20 },
+ }),
+ }),
+ c.map((v, S) =>
+ h.jsx(
+ Ll,
+ {
+ attachment: v,
+ result: l,
+ linkName:
+ c.length === 1 ? 'trace' : `trace-${S + 1}`,
+ },
+ `trace-${S}`,
+ ),
+ ),
+ ],
+ }),
+ }),
+ }),
+ !!a.length &&
+ h.jsx(vi, {
+ id: 'attachment-video',
+ children: h.jsx(Bt, {
+ header: 'Videos',
+ revealOnAnchorId: 'attachment-video',
+ children: a.map((v) =>
+ h.jsxs(
+ 'div',
+ {
+ children: [
+ h.jsx('video', {
+ controls: !0,
+ children: h.jsx('source', {
+ src: v.path,
+ type: v.contentType,
+ }),
+ }),
+ h.jsx(Ll, { attachment: v, result: l }),
+ ],
+ },
+ v.path,
+ ),
+ ),
+ }),
+ }),
+ !!f.size &&
+ h.jsx(Bt, {
+ header: 'Attachments',
+ revealOnAnchorId: g,
+ dataTestId: 'attachments',
+ children: [...f].map((v, S) =>
+ h.jsx(
+ vi,
+ {
+ id: `attachment-${l.attachments.indexOf(v)}`,
+ children: h.jsx(Ll, {
+ attachment: v,
+ result: l,
+ openInNewTab: v.contentType.startsWith('text/html'),
+ }),
+ },
+ `attachment-link-${S}`,
+ ),
+ ),
+ }),
+ ],
+ })
+ }
+ function ug(s, l, r) {
+ return s.map((a, c) => {
+ const f = a.split(`
+`)[0]
+ if (f.includes('toHaveScreenshot') || f.includes('toMatchSnapshot')) {
+ const m = l.find((g) => {
+ var v
+ const w = (v = g.actual) == null ? void 0 : v.attachment.name
+ return w && a.includes(w)
+ })
+ if (m) {
+ const g = a.split(`
+`),
+ w = g.findIndex((B) => /Expected:|Previous:|Received:/.test(B)),
+ v =
+ w !== -1
+ ? g.slice(0, w).join(`
+`)
+ : g[0],
+ S = g.findIndex((B) => / +Diff:/.test(B)),
+ I =
+ S !== -1
+ ? g.slice(S + 2).join(`
+`)
+ : g.slice(1).join(`
+`)
+ return {
+ type: 'screenshot',
+ diff: m,
+ errorPrefix: v,
+ errorSuffix: I,
+ }
+ }
+ }
+ const d = r.find((m) => m.name === `_error-context-${c}`)
+ return { type: 'regular', error: a, context: d }
+ })
+ }
+ const ep = ({ test: s, step: l, result: r, depth: a }) =>
+ h.jsx(z0, {
+ title: h.jsxs('span', {
+ 'aria-label': l.title,
+ children: [
+ h.jsx('span', {
+ style: { float: 'right' },
+ children: kr(l.duration),
+ }),
+ l.attachments.length > 0 &&
+ h.jsx('a', {
+ style: { float: 'right' },
+ title: 'reveal attachment',
+ href: Zn({
+ test: s,
+ result: r,
+ anchor: `attachment-${l.attachments[0]}`,
+ }),
+ onClick: (c) => {
+ c.stopPropagation()
+ },
+ children: W0(),
+ }),
+ Ei(
+ l.error || l.duration === -1
+ ? 'failed'
+ : l.skipped
+ ? 'skipped'
+ : 'passed',
+ ),
+ h.jsx('span', { children: l.title }),
+ l.count > 1 &&
+ h.jsxs(h.Fragment, {
+ children: [
+ ' ✕ ',
+ h.jsx('span', {
+ className: 'test-result-counter',
+ children: l.count,
+ }),
+ ],
+ }),
+ l.location &&
+ h.jsxs('span', {
+ className: 'test-result-path',
+ children: ['— ', l.location.file, ':', l.location.line],
+ }),
+ ],
+ }),
+ loadChildren:
+ l.steps.length || l.snippet
+ ? () => {
+ const c = l.snippet
+ ? [
+ h.jsx(
+ $0,
+ { testId: 'test-snippet', code: l.snippet },
+ 'line',
+ ),
+ ]
+ : [],
+ f = l.steps.map((d, m) =>
+ h.jsx(
+ ep,
+ { step: d, depth: a + 1, result: r, test: s },
+ m,
+ ),
+ )
+ return c.concat(f)
+ }
+ : void 0,
+ depth: a,
+ }),
+ cg = ({ projectNames: s, test: l, run: r, next: a, prev: c }) => {
+ const [f, d] = se.useState(r),
+ m = se.useContext(Et),
+ g = m.has('q') ? '&q=' + m.get('q') : '',
+ w = se.useMemo(() => {
+ if (l) return l.tags
+ }, [l]),
+ v =
+ (l == null
+ ? void 0
+ : l.annotations.filter((S) => !S.type.startsWith('_'))) ?? []
+ return h.jsxs('div', {
+ className: 'test-case-column vbox',
+ children: [
+ l &&
+ h.jsxs('div', {
+ className: 'hbox',
+ children: [
+ h.jsx('div', {
+ className: 'test-case-path',
+ children: l.path.join(' › '),
+ }),
+ h.jsx('div', { style: { flex: 'auto' } }),
+ h.jsx('div', {
+ className: Qt(!c && 'hidden'),
+ children: h.jsx(ht, {
+ href: Zn({ test: c }) + g,
+ children: '« previous',
+ }),
+ }),
+ h.jsx('div', { style: { width: 10 } }),
+ h.jsx('div', {
+ className: Qt(!a && 'hidden'),
+ children: h.jsx(ht, {
+ href: Zn({ test: a }) + g,
+ children: 'next »',
+ }),
+ }),
+ ],
+ }),
+ l &&
+ h.jsx('div', {
+ className: 'test-case-title',
+ children: l == null ? void 0 : l.title,
+ }),
+ l &&
+ h.jsxs('div', {
+ className: 'hbox',
+ children: [
+ h.jsx('div', {
+ className: 'test-case-location',
+ children: h.jsxs(Oa, {
+ value: `${l == null ? void 0 : l.location.file}:${l == null ? void 0 : l.location.line}`,
+ children: [l.location.file, ':', l.location.line],
+ }),
+ }),
+ h.jsx('div', { style: { flex: 'auto' } }),
+ h.jsx('div', {
+ className: 'test-case-duration',
+ children: kr(l.duration),
+ }),
+ ],
+ }),
+ l &&
+ (!!l.projectName || w) &&
+ h.jsxs('div', {
+ className: 'test-case-project-labels-row',
+ children: [
+ l &&
+ !!l.projectName &&
+ h.jsx(G0, {
+ projectNames: s,
+ projectName: l.projectName,
+ }),
+ w && h.jsx(dg, { labels: w }),
+ ],
+ }),
+ (l == null ? void 0 : l.results.length) === 0 &&
+ v.length !== 0 &&
+ h.jsx(Bt, {
+ header: 'Annotations',
+ dataTestId: 'test-case-annotations',
+ children: v.map((S, I) => h.jsx(Bd, { annotation: S }, I)),
+ }),
+ l &&
+ h.jsx(Zm, {
+ tabs:
+ l.results.map((S, I) => ({
+ id: String(I),
+ title: h.jsxs('div', {
+ style: { display: 'flex', alignItems: 'center' },
+ children: [
+ Ei(S.status),
+ ' ',
+ fg(I),
+ l.results.length > 1 &&
+ h.jsx('span', {
+ className: 'test-case-run-duration',
+ children: kr(S.duration),
+ }),
+ ],
+ }),
+ render: () => {
+ const B = S.annotations.filter(
+ (V) => !V.type.startsWith('_'),
+ )
+ return h.jsxs(h.Fragment, {
+ children: [
+ !!B.length &&
+ h.jsx(Bt, {
+ header: 'Annotations',
+ dataTestId: 'test-case-annotations',
+ children: B.map((V, A) =>
+ h.jsx(Bd, { annotation: V }, A),
+ ),
+ }),
+ h.jsx(ag, { test: l, result: S }),
+ ],
+ })
+ },
+ })) || [],
+ selectedTab: String(f),
+ setSelectedTab: (S) => d(+S),
+ }),
+ ],
+ })
+ }
+ function Bd({ annotation: { type: s, description: l } }) {
+ return h.jsxs('div', {
+ className: 'test-case-annotation',
+ children: [
+ h.jsx('span', { style: { fontWeight: 'bold' }, children: s }),
+ l && h.jsxs(Oa, { value: l, children: [': ', Zl(l)] }),
+ ],
+ })
+ }
+ function fg(s) {
+ return s ? `Retry #${s}` : 'Run'
+ }
+ const dg = ({ labels: s }) =>
+ s.length > 0
+ ? h.jsx(h.Fragment, {
+ children: s.map((l) =>
+ h.jsx(
+ 'a',
+ {
+ style: {
+ textDecoration: 'none',
+ color: 'var(--color-fg-default)',
+ },
+ href: `#?q=${l}`,
+ children: h.jsx('span', {
+ style: { margin: '6px 0 0 6px', cursor: 'pointer' },
+ className: Qt('label', 'label-color-' + J0(l)),
+ children: l.slice(1),
+ }),
+ },
+ l,
+ ),
+ ),
+ })
+ : null,
+ pg = ({
+ file: s,
+ projectNames: l,
+ isFileExpanded: r,
+ setFileExpanded: a,
+ }) => {
+ const c = se.useContext(Et),
+ f = c.has('q') ? '&q=' + c.get('q') : ''
+ return h.jsx(Z0, {
+ expanded: r(s.fileId),
+ noInsets: !0,
+ setExpanded: (d) => a(s.fileId, d),
+ header: h.jsx('span', { children: s.fileName }),
+ children: s.tests.map((d) =>
+ h.jsxs(
+ 'div',
+ {
+ className: Qt(
+ 'test-file-test',
+ 'test-file-test-outcome-' + d.outcome,
+ ),
+ children: [
+ h.jsxs('div', {
+ className: 'hbox',
+ style: { alignItems: 'flex-start' },
+ children: [
+ h.jsxs('div', {
+ className: 'hbox',
+ children: [
+ h.jsx('span', {
+ className: 'test-file-test-status-icon',
+ children: Ei(d.outcome),
+ }),
+ h.jsxs('span', {
+ children: [
+ h.jsx(ht, {
+ href: Zn({ test: d }) + f,
+ title: [...d.path, d.title].join(' › '),
+ children: h.jsx('span', {
+ className: 'test-file-title',
+ children: [...d.path, d.title].join(' › '),
+ }),
+ }),
+ l.length > 1 &&
+ !!d.projectName &&
+ h.jsx(G0, {
+ projectNames: l,
+ projectName: d.projectName,
+ }),
+ h.jsx(vg, { labels: d.tags }),
+ ],
+ }),
+ ],
+ }),
+ h.jsx('span', {
+ 'data-testid': 'test-duration',
+ style: { minWidth: '50px', textAlign: 'right' },
+ children: kr(d.duration),
+ }),
+ ],
+ }),
+ h.jsxs('div', {
+ className: 'test-file-details-row',
+ children: [
+ h.jsx(ht, {
+ href: Zn({ test: d }),
+ title: [...d.path, d.title].join(' › '),
+ className: 'test-file-path-link',
+ children: h.jsxs('span', {
+ className: 'test-file-path',
+ children: [d.location.file, ':', d.location.line],
+ }),
+ }),
+ hg(d),
+ mg(d),
+ gg(d),
+ ],
+ }),
+ ],
+ },
+ `test-${d.testId}`,
+ ),
+ ),
+ })
+ }
+ function hg(s) {
+ for (const l of s.results)
+ for (const r of l.attachments)
+ if (
+ r.contentType.startsWith('image/') &&
+ r.name.match(/-(expected|actual|diff)/)
+ )
+ return h.jsx(ht, {
+ href: Zn({
+ test: s,
+ result: l,
+ anchor: `attachment-${l.attachments.indexOf(r)}`,
+ }),
+ title: 'View images',
+ className: 'test-file-badge',
+ children: Bm(),
+ })
+ }
+ function mg(s) {
+ const l = s.results.find((r) =>
+ r.attachments.some((a) => a.name === 'video'),
+ )
+ return l
+ ? h.jsx(ht, {
+ href: Zn({ test: s, result: l, anchor: 'attachment-video' }),
+ title: 'View video',
+ className: 'test-file-badge',
+ children: Hm(),
+ })
+ : void 0
+ }
+ function gg(s) {
+ const l = s.results
+ .map((r) => r.attachments.filter((a) => a.name === 'trace'))
+ .filter((r) => r.length > 0)[0]
+ if (l)
+ return h.jsxs(ht, {
+ href: K0(l),
+ title: 'View Trace',
+ className: 'button test-file-badge',
+ children: [Fm(), h.jsx('span', { children: 'View Trace' })],
+ })
+ }
+ const vg = ({ labels: s }) => {
+ const l = se.useContext(Et),
+ r = (a, c) => {
+ var m
+ a.preventDefault()
+ const d = (
+ ((m = l.get('q')) == null ? void 0 : m.toString()) || ''
+ ).split(' ')
+ Da(Zt(d, c, a.metaKey || a.ctrlKey))
+ }
+ return s.length > 0
+ ? h.jsx(h.Fragment, {
+ children: s.map((a) =>
+ h.jsx(
+ 'span',
+ {
+ style: { margin: '6px 0 0 6px', cursor: 'pointer' },
+ className: Qt('label', 'label-color-' + J0(a)),
+ onClick: (c) => r(c, a),
+ children: a.slice(1),
+ },
+ a,
+ ),
+ ),
+ })
+ : null
+ }
+ class yg extends se.Component {
+ constructor() {
+ super(...arguments)
+ Gt(this, 'state', { error: null, errorInfo: null })
+ }
+ componentDidCatch(r, a) {
+ this.setState({ error: r, errorInfo: a })
+ }
+ render() {
+ var r, a, c
+ return this.state.error || this.state.errorInfo
+ ? h.jsxs('div', {
+ className: 'metadata-view p-3',
+ children: [
+ h.jsx('p', {
+ children:
+ 'An error was encountered when trying to render metadata.',
+ }),
+ h.jsx('p', {
+ children: h.jsxs('pre', {
+ style: { overflow: 'scroll' },
+ children: [
+ (r = this.state.error) == null ? void 0 : r.message,
+ h.jsx('br', {}),
+ (a = this.state.error) == null ? void 0 : a.stack,
+ h.jsx('br', {}),
+ (c = this.state.errorInfo) == null
+ ? void 0
+ : c.componentStack,
+ ],
+ }),
+ }),
+ ],
+ })
+ : this.props.children
+ }
+ }
+ const xg = (s) =>
+ h.jsx(yg, { children: h.jsx(wg, { metadata: s.metadata }) }),
+ wg = (s) => {
+ const l = se.useContext(Et),
+ r = s.metadata,
+ a = l.has('show-metadata-other')
+ ? Object.entries(s.metadata).filter(([f]) => !tp.has(f))
+ : []
+ if (r.ci || r.gitCommit || a.length > 0)
+ return h.jsxs('div', {
+ className: 'metadata-view',
+ children: [
+ r.ci && !r.gitCommit && h.jsx(Ag, { info: r.ci }),
+ r.gitCommit && h.jsx(Eg, { ci: r.ci, commit: r.gitCommit }),
+ a.length > 0 &&
+ (r.gitCommit || r.ci) &&
+ h.jsx('div', { className: 'metadata-separator' }),
+ h.jsx('div', {
+ className: 'metadata-section metadata-properties',
+ role: 'list',
+ children: a.map(([f, d]) => {
+ const m =
+ typeof d != 'object' || d === null || d === void 0
+ ? String(d)
+ : JSON.stringify(d),
+ g = m.length > 1e3 ? m.slice(0, 1e3) + '…' : m
+ return h.jsx(
+ 'div',
+ {
+ className: 'copyable-property',
+ role: 'listitem',
+ children: h.jsxs(Oa, {
+ value: m,
+ children: [
+ h.jsx('span', {
+ style: { fontWeight: 'bold' },
+ title: f,
+ children: f,
+ }),
+ ': ',
+ h.jsx('span', { title: g, children: Zl(g) }),
+ ],
+ }),
+ },
+ f,
+ )
+ }),
+ }),
+ ],
+ })
+ },
+ Ag = ({ info: s }) => {
+ const l = s.prTitle || `Commit ${s.commitHash}`,
+ r = s.prHref || s.commitHref
+ return h.jsx('div', {
+ className: 'metadata-section',
+ role: 'list',
+ children: h.jsx('div', {
+ role: 'listitem',
+ children: h.jsx('a', {
+ href: r,
+ target: '_blank',
+ rel: 'noopener noreferrer',
+ title: l,
+ children: l,
+ }),
+ }),
+ })
+ },
+ Eg = ({ ci: s, commit: l }) => {
+ const r = (s == null ? void 0 : s.prTitle) || l.subject,
+ a =
+ (s == null ? void 0 : s.prHref) ||
+ (s == null ? void 0 : s.commitHref),
+ c = ` <${l.author.email}>`,
+ f = `${l.author.name}${c}`,
+ d = Intl.DateTimeFormat(void 0, { dateStyle: 'medium' }).format(
+ l.committer.time,
+ ),
+ m = Intl.DateTimeFormat(void 0, {
+ dateStyle: 'full',
+ timeStyle: 'long',
+ }).format(l.committer.time)
+ return h.jsxs('div', {
+ className: 'metadata-section',
+ role: 'list',
+ children: [
+ h.jsxs('div', {
+ role: 'listitem',
+ children: [
+ a &&
+ h.jsx('a', {
+ href: a,
+ target: '_blank',
+ rel: 'noopener noreferrer',
+ title: r,
+ children: r,
+ }),
+ !a && h.jsx('span', { title: r, children: r }),
+ ],
+ }),
+ h.jsxs('div', {
+ role: 'listitem',
+ className: 'hbox',
+ children: [
+ h.jsx('span', { className: 'mr-1', children: f }),
+ h.jsxs('span', { title: m, children: [' on ', d] }),
+ ],
+ }),
+ ],
+ })
+ },
+ tp = new Set(['ci', 'gitCommit', 'gitDiff', 'actualWorkers']),
+ Cg = (s) => {
+ const l = Object.entries(s).filter(([r]) => !tp.has(r))
+ return !s.ci && !s.gitCommit && !l.length
+ },
+ Sg = ({
+ tests: s,
+ expandedFiles: l,
+ setExpandedFiles: r,
+ projectNames: a,
+ }) => {
+ const c = se.useMemo(() => {
+ const f = []
+ let d = 0
+ for (const m of s)
+ ((d += m.tests.length),
+ f.push({ file: m, defaultExpanded: d < 200 }))
+ return f
+ }, [s])
+ return h.jsx(h.Fragment, {
+ children: c.map(({ file: f, defaultExpanded: d }) =>
+ h.jsx(
+ pg,
+ {
+ file: f,
+ projectNames: a,
+ isFileExpanded: (m) => {
+ const g = l.get(m)
+ return g === void 0 ? d : !!g
+ },
+ setFileExpanded: (m, g) => {
+ const w = new Map(l)
+ ;(w.set(m, g), r(w))
+ },
+ },
+ `file-${f.fileId}`,
+ ),
+ ),
+ })
+ },
+ kg = ({
+ report: s,
+ filteredStats: l,
+ metadataVisible: r,
+ toggleMetadataVisible: a,
+ }) =>
+ s
+ ? h.jsxs(h.Fragment, {
+ children: [
+ h.jsxs('div', {
+ className: 'mx-1',
+ style: { display: 'flex', marginTop: 10 },
+ children: [
+ h.jsxs('div', {
+ className: 'test-file-header-info',
+ children: [
+ !Cg(s.metadata) &&
+ h.jsxs('div', {
+ className: 'metadata-toggle',
+ role: 'button',
+ onClick: a,
+ title: r ? 'Hide metadata' : 'Show metadata',
+ children: [r ? Pa() : Kl(), 'Metadata'],
+ }),
+ s.projectNames.length === 1 &&
+ !!s.projectNames[0] &&
+ h.jsxs('div', {
+ 'data-testid': 'project-name',
+ children: ['Project: ', s.projectNames[0]],
+ }),
+ l &&
+ h.jsxs('div', {
+ 'data-testid': 'filtered-tests-count',
+ children: [
+ 'Filtered: ',
+ l.total,
+ ' ',
+ !!l.total && '(' + kr(l.duration) + ')',
+ ],
+ }),
+ ],
+ }),
+ h.jsx('div', { style: { flex: 'auto' } }),
+ h.jsx('div', {
+ 'data-testid': 'overall-time',
+ style: {
+ color: 'var(--color-fg-subtle)',
+ marginRight: '10px',
+ },
+ children: s
+ ? new Date(s.startTime).toLocaleString()
+ : '',
+ }),
+ h.jsxs('div', {
+ 'data-testid': 'overall-duration',
+ style: { color: 'var(--color-fg-subtle)' },
+ children: ['Total time: ', kr(s.duration ?? 0)],
+ }),
+ ],
+ }),
+ r && h.jsx(xg, { metadata: s.metadata }),
+ !!s.errors.length &&
+ h.jsx(Bt, {
+ header: 'Errors',
+ dataTestId: 'report-errors',
+ children: s.errors.map((c, f) =>
+ h.jsx(
+ _0,
+ { error: c },
+ 'test-report-error-message-' + f,
+ ),
+ ),
+ }),
+ ],
+ })
+ : null,
+ Ig = (s) => !s.has('testId'),
+ Rg = (s) => s.has('testId'),
+ Tg = ({ report: s }) => {
+ const l = se.useContext(Et),
+ [r, a] = se.useState(new Map()),
+ [c, f] = se.useState(l.get('q') || ''),
+ [d, m] = se.useState(!1),
+ g = se.useMemo(() => {
+ const I = new Map()
+ for (const B of (s == null ? void 0 : s.json().files) || [])
+ for (const V of B.tests) I.set(V.testId, B.fileId)
+ return I
+ }, [s]),
+ w = se.useMemo(() => Gl.parse(c), [c]),
+ v = se.useMemo(
+ () =>
+ w.empty()
+ ? void 0
+ : Pg((s == null ? void 0 : s.json().files) || [], w),
+ [s, w],
+ ),
+ S = se.useMemo(() => {
+ const I = { files: [], tests: [] }
+ for (const B of (s == null ? void 0 : s.json().files) || []) {
+ const V = B.tests.filter((A) => w.matches(A))
+ ;(V.length && I.files.push({ ...B, tests: V }),
+ I.tests.push(...V))
+ }
+ return I
+ }, [s, w])
+ return h.jsx('div', {
+ className: 'htmlreport vbox px-4 pb-4',
+ children: h.jsxs('main', {
+ children: [
+ (s == null ? void 0 : s.json()) &&
+ h.jsx(Gm, {
+ stats: s.json().stats,
+ filterText: c,
+ setFilterText: f,
+ }),
+ h.jsxs(Dd, {
+ predicate: Ig,
+ children: [
+ h.jsx(kg, {
+ report: s == null ? void 0 : s.json(),
+ filteredStats: v,
+ metadataVisible: d,
+ toggleMetadataVisible: () => m((I) => !I),
+ }),
+ h.jsx(Sg, {
+ tests: S.files,
+ expandedFiles: r,
+ setExpandedFiles: a,
+ projectNames:
+ (s == null ? void 0 : s.json().projectNames) || [],
+ }),
+ ],
+ }),
+ h.jsx(Dd, {
+ predicate: Rg,
+ children:
+ !!s &&
+ h.jsx(jg, {
+ report: s,
+ tests: S.tests,
+ testIdToFileIdMap: g,
+ }),
+ }),
+ ],
+ }),
+ })
+ },
+ jg = ({ report: s, testIdToFileIdMap: l, tests: r }) => {
+ const a = se.useContext(Et),
+ [c, f] = se.useState(),
+ d = a.get('testId'),
+ m = +(a.get('run') || '0'),
+ { prev: g, next: w } = se.useMemo(() => {
+ const v = r.findIndex((B) => B.testId === d),
+ S = v > 0 ? r[v - 1] : void 0,
+ I = v < r.length - 1 ? r[v + 1] : void 0
+ return { prev: S, next: I }
+ }, [d, r])
+ return (
+ se.useEffect(() => {
+ ;(async () => {
+ if (!d || d === (c == null ? void 0 : c.testId)) return
+ const v = l.get(d)
+ if (!v) return
+ const S = await s.entry(`${v}.json`)
+ for (const I of S.tests)
+ if (I.testId === d) {
+ f(I)
+ break
+ }
+ })()
+ }, [c, s, d, l]),
+ h.jsx(cg, {
+ projectNames: s.json().projectNames,
+ next: w,
+ prev: g,
+ test: c,
+ run: m,
+ })
+ )
+ }
+ function Pg(s, l) {
+ const r = { total: 0, duration: 0 }
+ for (const a of s) {
+ const c = a.tests.filter((f) => l.matches(f))
+ r.total += c.length
+ for (const f of c) r.duration += f.duration
+ }
+ return r
+ }
+ const Og =
+ "'
+
diff --git a/e2e/solid-start/basic-solid-query/playwright.config.ts b/e2e/solid-start/basic-solid-query/playwright.config.ts
index 7e0487c881a..84636ab0f9a 100644
--- a/e2e/solid-start/basic-solid-query/playwright.config.ts
+++ b/e2e/solid-start/basic-solid-query/playwright.config.ts
@@ -36,4 +36,4 @@ export default defineConfig({
use: { ...devices['Desktop Chrome'] },
},
],
-})
\ No newline at end of file
+})
diff --git a/e2e/solid-start/basic-solid-query/postcss.config.mjs b/e2e/solid-start/basic-solid-query/postcss.config.mjs
index e99ebc2c0e0..2e7af2b7f1a 100644
--- a/e2e/solid-start/basic-solid-query/postcss.config.mjs
+++ b/e2e/solid-start/basic-solid-query/postcss.config.mjs
@@ -3,4 +3,4 @@ export default {
tailwindcss: {},
autoprefixer: {},
},
-}
\ No newline at end of file
+}
diff --git a/e2e/solid-start/basic-solid-query/src/components/DefaultCatchBoundary.tsx b/e2e/solid-start/basic-solid-query/src/components/DefaultCatchBoundary.tsx
index 92058c37f86..02f53708c94 100644
--- a/e2e/solid-start/basic-solid-query/src/components/DefaultCatchBoundary.tsx
+++ b/e2e/solid-start/basic-solid-query/src/components/DefaultCatchBoundary.tsx
@@ -5,4 +5,4 @@ import {
export function DefaultCatchBoundary(props: ErrorComponentProps) {
return
-}
\ No newline at end of file
+}
diff --git a/e2e/solid-start/basic-solid-query/src/components/NotFound.tsx b/e2e/solid-start/basic-solid-query/src/components/NotFound.tsx
index 4040aa7fcdb..8ca552b501d 100644
--- a/e2e/solid-start/basic-solid-query/src/components/NotFound.tsx
+++ b/e2e/solid-start/basic-solid-query/src/components/NotFound.tsx
@@ -4,7 +4,9 @@ import type { JSX } from 'solid-js'
export function NotFound(props?: { children?: JSX.Element }) {
return (
-
{props?.children || 'The page you are looking for does not exist.'}
+
+ {props?.children || 'The page you are looking for does not exist.'}
+
)
-}
\ No newline at end of file
+}
diff --git a/e2e/solid-start/basic-solid-query/src/routeTree.gen.ts b/e2e/solid-start/basic-solid-query/src/routeTree.gen.ts
index 5f2844e46d2..b7444e1e0c8 100644
--- a/e2e/solid-start/basic-solid-query/src/routeTree.gen.ts
+++ b/e2e/solid-start/basic-solid-query/src/routeTree.gen.ts
@@ -17,6 +17,9 @@ import { Route as UsersIndexRouteImport } from './routes/users.index'
import { Route as PostsIndexRouteImport } from './routes/posts.index'
import { Route as UsersUserIdRouteImport } from './routes/users.$userId'
import { Route as PostsPostIdRouteImport } from './routes/posts.$postId'
+import { Route as ApiUsersRouteImport } from './routes/api.users'
+import { Route as PostsPostIdDeepRouteImport } from './routes/posts_.$postId.deep'
+import { Route as ApiUsersIdRouteImport } from './routes/api/users.$id'
const UsersRoute = UsersRouteImport.update({
id: '/users',
@@ -58,24 +61,45 @@ const PostsPostIdRoute = PostsPostIdRouteImport.update({
path: '/$postId',
getParentRoute: () => PostsRoute,
} as any)
+const ApiUsersRoute = ApiUsersRouteImport.update({
+ id: '/api/users',
+ path: '/api/users',
+ getParentRoute: () => rootRouteImport,
+} as any)
+const PostsPostIdDeepRoute = PostsPostIdDeepRouteImport.update({
+ id: '/posts_/$postId/deep',
+ path: '/posts/$postId/deep',
+ getParentRoute: () => rootRouteImport,
+} as any)
+const ApiUsersIdRoute = ApiUsersIdRouteImport.update({
+ id: '/$id',
+ path: '/$id',
+ getParentRoute: () => ApiUsersRoute,
+} as any)
export interface FileRoutesByFullPath {
'/': typeof IndexRoute
'/deferred': typeof DeferredRoute
'/posts': typeof PostsRouteWithChildren
'/users': typeof UsersRouteWithChildren
+ '/api/users': typeof ApiUsersRouteWithChildren
'/posts/$postId': typeof PostsPostIdRoute
'/users/$userId': typeof UsersUserIdRoute
'/posts/': typeof PostsIndexRoute
'/users/': typeof UsersIndexRoute
+ '/api/users/$id': typeof ApiUsersIdRoute
+ '/posts/$postId/deep': typeof PostsPostIdDeepRoute
}
export interface FileRoutesByTo {
'/': typeof IndexRoute
'/deferred': typeof DeferredRoute
+ '/api/users': typeof ApiUsersRouteWithChildren
'/posts/$postId': typeof PostsPostIdRoute
'/users/$userId': typeof UsersUserIdRoute
'/posts': typeof PostsIndexRoute
'/users': typeof UsersIndexRoute
+ '/api/users/$id': typeof ApiUsersIdRoute
+ '/posts/$postId/deep': typeof PostsPostIdDeepRoute
}
export interface FileRoutesById {
__root__: typeof rootRouteImport
@@ -83,10 +107,13 @@ export interface FileRoutesById {
'/deferred': typeof DeferredRoute
'/posts': typeof PostsRouteWithChildren
'/users': typeof UsersRouteWithChildren
+ '/api/users': typeof ApiUsersRouteWithChildren
'/posts/$postId': typeof PostsPostIdRoute
'/users/$userId': typeof UsersUserIdRoute
'/posts/': typeof PostsIndexRoute
'/users/': typeof UsersIndexRoute
+ '/api/users/$id': typeof ApiUsersIdRoute
+ '/posts_/$postId/deep': typeof PostsPostIdDeepRoute
}
export interface FileRouteTypes {
fileRoutesByFullPath: FileRoutesByFullPath
@@ -95,28 +122,37 @@ export interface FileRouteTypes {
| '/deferred'
| '/posts'
| '/users'
+ | '/api/users'
| '/posts/$postId'
| '/users/$userId'
| '/posts/'
| '/users/'
+ | '/api/users/$id'
+ | '/posts/$postId/deep'
fileRoutesByTo: FileRoutesByTo
to:
| '/'
| '/deferred'
+ | '/api/users'
| '/posts/$postId'
| '/users/$userId'
| '/posts'
| '/users'
+ | '/api/users/$id'
+ | '/posts/$postId/deep'
id:
| '__root__'
| '/'
| '/deferred'
| '/posts'
| '/users'
+ | '/api/users'
| '/posts/$postId'
| '/users/$userId'
| '/posts/'
| '/users/'
+ | '/api/users/$id'
+ | '/posts_/$postId/deep'
fileRoutesById: FileRoutesById
}
export interface RootRouteChildren {
@@ -124,6 +160,8 @@ export interface RootRouteChildren {
DeferredRoute: typeof DeferredRoute
PostsRoute: typeof PostsRouteWithChildren
UsersRoute: typeof UsersRouteWithChildren
+ ApiUsersRoute: typeof ApiUsersRouteWithChildren
+ PostsPostIdDeepRoute: typeof PostsPostIdDeepRoute
}
declare module '@tanstack/solid-router' {
@@ -184,6 +222,27 @@ declare module '@tanstack/solid-router' {
preLoaderRoute: typeof PostsPostIdRouteImport
parentRoute: typeof PostsRoute
}
+ '/api/users': {
+ id: '/api/users'
+ path: '/api/users'
+ fullPath: '/api/users'
+ preLoaderRoute: typeof ApiUsersRouteImport
+ parentRoute: typeof rootRouteImport
+ }
+ '/posts_/$postId/deep': {
+ id: '/posts_/$postId/deep'
+ path: '/posts/$postId/deep'
+ fullPath: '/posts/$postId/deep'
+ preLoaderRoute: typeof PostsPostIdDeepRouteImport
+ parentRoute: typeof rootRouteImport
+ }
+ '/api/users/$id': {
+ id: '/api/users/$id'
+ path: '/$id'
+ fullPath: '/api/users/$id'
+ preLoaderRoute: typeof ApiUsersIdRouteImport
+ parentRoute: typeof ApiUsersRoute
+ }
}
}
@@ -211,11 +270,25 @@ const UsersRouteChildren: UsersRouteChildren = {
const UsersRouteWithChildren = UsersRoute._addFileChildren(UsersRouteChildren)
+interface ApiUsersRouteChildren {
+ ApiUsersIdRoute: typeof ApiUsersIdRoute
+}
+
+const ApiUsersRouteChildren: ApiUsersRouteChildren = {
+ ApiUsersIdRoute: ApiUsersIdRoute,
+}
+
+const ApiUsersRouteWithChildren = ApiUsersRoute._addFileChildren(
+ ApiUsersRouteChildren,
+)
+
const rootRouteChildren: RootRouteChildren = {
IndexRoute: IndexRoute,
DeferredRoute: DeferredRoute,
PostsRoute: PostsRouteWithChildren,
UsersRoute: UsersRouteWithChildren,
+ ApiUsersRoute: ApiUsersRouteWithChildren,
+ PostsPostIdDeepRoute: PostsPostIdDeepRoute,
}
export const routeTree = rootRouteImport
._addFileChildren(rootRouteChildren)
diff --git a/e2e/solid-start/basic-solid-query/src/router.tsx b/e2e/solid-start/basic-solid-query/src/router.tsx
index f93fb9061e1..c090958c01c 100644
--- a/e2e/solid-start/basic-solid-query/src/router.tsx
+++ b/e2e/solid-start/basic-solid-query/src/router.tsx
@@ -27,4 +27,4 @@ export function getRouter() {
queryClient,
})
return router
-}
\ No newline at end of file
+}
diff --git a/e2e/solid-start/basic-solid-query/src/routes/__root.tsx b/e2e/solid-start/basic-solid-query/src/routes/__root.tsx
index 4af6a08ab93..737926dd27b 100644
--- a/e2e/solid-start/basic-solid-query/src/routes/__root.tsx
+++ b/e2e/solid-start/basic-solid-query/src/routes/__root.tsx
@@ -122,4 +122,4 @@ function RootDocument(props: { children?: any }) {