Skip to content

Commit

Permalink
Web console: fix progress indication for table input (apache#17334) (a…
Browse files Browse the repository at this point in the history
…pache#17505)

* fix porgress indication for table input

* fix snapshot

Co-authored-by: Vadim Ogievetsky <[email protected]>
  • Loading branch information
clintropolis and vogievetsky authored Nov 22, 2024
1 parent c5d0fcd commit b1802c4
Show file tree
Hide file tree
Showing 8 changed files with 51 additions and 20 deletions.
3 changes: 1 addition & 2 deletions web-console/src/druid-models/stages/stages.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,7 @@ describe('aggregateSortProgressCounters', () => {
},
{
type: 'sortProgress',
totalMergingLevels: 4,
totalMergingLevels: -1,
levelToTotalBatches: { 0: 2, 1: 4, 2: 6, 3: 5 },
levelToMergedBatches: { 0: 2, 1: 4, 2: 6, 3: 5 },
totalMergersForUltimateLevel: 1,
Expand All @@ -41,7 +41,6 @@ describe('aggregateSortProgressCounters', () => {
).toEqual({
totalMergingLevels: {
'2': 1,
'4': 1,
},
levelToBatches: {
'0': {
Expand Down
10 changes: 6 additions & 4 deletions web-console/src/druid-models/stages/stages.ts
Original file line number Diff line number Diff line change
Expand Up @@ -200,7 +200,10 @@ export function aggregateSortProgressCounters(
sortProgressCounters: SortProgressCounter[],
): AggregatedSortProgress {
return {
totalMergingLevels: countBy(sortProgressCounters, c => c.totalMergingLevels),
totalMergingLevels: countBy(
sortProgressCounters.filter(c => c.totalMergingLevels >= 0),
c => c.totalMergingLevels,
),
levelToBatches: groupByAsMap(
sortProgressCounters.flatMap(c =>
Object.entries(c.levelToMergedBatches).map(([level, merged]) => [
Expand Down Expand Up @@ -430,9 +433,8 @@ export class Stages {
if (inputFileCount) {
// If we know how many files there are base the progress on how many files were read
return (
sum(input, (input, i) =>
input.type === 'external' ? this.getTotalCounterForStage(stage, `input${i}`, 'files') : 0,
) / inputFileCount
sum(input, (_, i) => this.getTotalCounterForStage(stage, `input${i}`, 'files')) /
inputFileCount
);
} else {
// Otherwise, base it on the stage input divided by the output of all non-broadcast input stages,
Expand Down
5 changes: 5 additions & 0 deletions web-console/src/react-table/react-table-extra.scss
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,11 @@
padding: 0;
}
}

.rt-th.wrapped,
.rt-td.wrapped {
white-space: normal;
}
}

&.padded-header .rt-thead .rt-th {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -134,7 +134,7 @@ export const CurrentDartPanel = React.memo(function CurrentViberPanel(
const anonymous = w.identity === 'allowAll' && w.authenticator === 'allowAll';
return (
<Popover className="work-entry" key={w.sqlQueryId} position="left" content={menu}>
<div>
<div onDoubleClick={() => setShowSql(w.sql)}>
<div className="line1">
<Icon
className={'status-icon ' + w.state.toLowerCase()}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -80,7 +80,7 @@ exports[`ExecutionStagesPane matches snapshot 1`] = `
"accessor": "stageNumber",
"className": "padded",
"id": "stage",
"width": 140,
"width": 160,
},
{
"Cell": [Function],
Expand All @@ -102,7 +102,7 @@ exports[`ExecutionStagesPane matches snapshot 1`] = `
"accessor": [Function],
"className": "padded",
"id": "rows_processed",
"width": 160,
"width": 200,
},
{
"Cell": [Function],
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -125,6 +125,13 @@
vertical-align: top;
background: $dark-gray3;
}

.detail-counters-for-sort {
.count {
font-style: italic;
opacity: 0.8;
}
}
}

.cpu-label {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -245,7 +245,7 @@ export const ExecutionStagesPane = React.memo(function ExecutionStagesPane(
Header: 'Worker',
id: 'worker',
accessor: d => d.index,
width: 100,
width: 95,
Cell({ value }) {
const taskId = `${execution.id}-worker${value}_0`;
return (
Expand All @@ -270,7 +270,8 @@ export const ExecutionStagesPane = React.memo(function ExecutionStagesPane(
id: 'cpu',
accessor: d => d.cpu?.main?.cpu || 0,
className: 'padded',
width: 220,
width: 240,
show: stages.hasCounterForStage(stage, 'cpu'),
Cell({ original }) {
const cpuTotals = original.cpu || {};
return (
Expand Down Expand Up @@ -310,7 +311,7 @@ export const ExecutionStagesPane = React.memo(function ExecutionStagesPane(
id: counterName,
accessor: d => d[counterName]!.rows,
className: 'padded',
width: 160,
width: 200,
Cell({ value, original }) {
const c = (original as SimpleWideCounter)[counterName]!;
return (
Expand Down Expand Up @@ -397,12 +398,27 @@ export const ExecutionStagesPane = React.memo(function ExecutionStagesPane(
{
Header: `Counts`,
accessor: 'counts',
className: 'padded',
width: 180,
className: 'padded wrapped',
width: 300,
Cell({ value }) {
return Object.entries(value)
.map(([n, v]) => (Number(v) > 1 ? `${n} (${v})` : n))
.join(', ');
const entries = Object.entries(value);
if (!entries.length) return '-';
return (
<>
{entries.map(([n, v], i) => (
<>
<span
key={n}
data-tooltip={`${pluralIfNeeded(Number(v), 'worker')} reporting: ${n}`}
>
{n}
{Number(v) > 1 && <span className="count">{` (${v})`}</span>}
</span>
{i < entries.length - 1 && <span key={`${n}_sep`}>, </span>}
</>
))}
</>
);
},
},
]}
Expand Down Expand Up @@ -686,7 +702,7 @@ ${title} uncompressed size: ${formatBytesCompact(
id: 'stage',
accessor: 'stageNumber',
className: 'padded',
width: 140,
width: 160,
Cell(props) {
const stage = props.original as StageDefinition;
const myError = error && error.stageNumber === stage.stageNumber;
Expand Down Expand Up @@ -770,7 +786,7 @@ ${title} uncompressed size: ${formatBytesCompact(
id: 'rows_processed',
accessor: () => null,
className: 'padded',
width: 160,
width: 200,
Cell({ original }) {
const stage = original as StageDefinition;
const { input, broadcast } = stage.definition;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -217,7 +217,9 @@ LIMIT 100`,
return (
<Popover className="work-entry" key={w.taskId} position="left" content={menu}>
<div
data-tooltip={w.errorMessage}
data-tooltip={
`ID: ${w.taskId}` + (w.errorMessage ? `\n\nError:\n${w.errorMessage}` : '')
}
onDoubleClick={() => onExecutionDetails(w.taskId)}
>
<div className="line1">
Expand Down

0 comments on commit b1802c4

Please sign in to comment.