From e1dc3f8258fae03ef632a9d34f2eb00103651c48 Mon Sep 17 00:00:00 2001 From: David Liu Date: Wed, 18 Dec 2024 17:09:22 -0500 Subject: [PATCH 1/2] fix searching for multi partitions --- .../ui-core/src/assets/AssetPartitions.tsx | 24 +++++++++++++------ 1 file changed, 17 insertions(+), 7 deletions(-) diff --git a/js_modules/dagster-ui/packages/ui-core/src/assets/AssetPartitions.tsx b/js_modules/dagster-ui/packages/ui-core/src/assets/AssetPartitions.tsx index eaa05536efbaa..933284f41ceae 100644 --- a/js_modules/dagster-ui/packages/ui-core/src/assets/AssetPartitions.tsx +++ b/js_modules/dagster-ui/packages/ui-core/src/assets/AssetPartitions.tsx @@ -94,10 +94,20 @@ export const AssetPartitions = ({ .filter((s: AssetPartitionStatus) => DISPLAYED_STATUSES.includes(s)), }); - const [searchValue, setSearchValue] = useQueryPersistedState({ - queryKey: 'search', - defaults: {search: ''}, - }); + const [searchValues, setSearchValues] = useState([]); + const updateSearchValue = (idx: number, value: string) => { + setSearchValues((prev) => { + const next = [...prev]; + + // add empty strings for missing indices + while (next.length <= idx) { + next.push(''); + } + + next[idx] = value; + return next; + }); + }; // Determine which axis we will show at the top of the page, if any. const timeDimensionIdx = selections.findIndex((s) => isTimeseriesDimension(s.dimension)); @@ -148,7 +158,7 @@ export const AssetPartitions = ({ const sortType = getSort(sortTypes, idx, selections[idx]!.dimension.type); // Apply the search filter - const searchLower = searchValue.toLocaleLowerCase().trim(); + const searchLower = searchValues?.[idx]?.toLocaleLowerCase().trim() || ''; const filteredKeys = allKeys.filter((key) => key.toLowerCase().includes(searchLower)); const getSelectionKeys = () => @@ -269,8 +279,8 @@ export const AssetPartitions = ({ setSearchValue(e.target.value)} + value={searchValues[idx] || ''} + onChange={(e) => updateSearchValue(idx, e.target.value)} placeholder="Filter by name…" /> From 698de97e502aa380a66d905896df96796f195052 Mon Sep 17 00:00:00 2001 From: David Liu Date: Fri, 20 Dec 2024 13:31:56 -0500 Subject: [PATCH 2/2] add tests --- .../ui-core/src/assets/AssetPartitions.tsx | 1 + .../assets/__tests__/AssetPartitions.test.tsx | 111 ++++++++++++++++++ 2 files changed, 112 insertions(+) diff --git a/js_modules/dagster-ui/packages/ui-core/src/assets/AssetPartitions.tsx b/js_modules/dagster-ui/packages/ui-core/src/assets/AssetPartitions.tsx index 933284f41ceae..a3473ae908d2d 100644 --- a/js_modules/dagster-ui/packages/ui-core/src/assets/AssetPartitions.tsx +++ b/js_modules/dagster-ui/packages/ui-core/src/assets/AssetPartitions.tsx @@ -282,6 +282,7 @@ export const AssetPartitions = ({ value={searchValues[idx] || ''} onChange={(e) => updateSearchValue(idx, e.target.value)} placeholder="Filter by name…" + data-testId={testId(`search-${idx}`)} />
diff --git a/js_modules/dagster-ui/packages/ui-core/src/assets/__tests__/AssetPartitions.test.tsx b/js_modules/dagster-ui/packages/ui-core/src/assets/__tests__/AssetPartitions.test.tsx index 840bd07b01109..418598b3d51b5 100644 --- a/js_modules/dagster-ui/packages/ui-core/src/assets/__tests__/AssetPartitions.test.tsx +++ b/js_modules/dagster-ui/packages/ui-core/src/assets/__tests__/AssetPartitions.test.tsx @@ -242,4 +242,115 @@ describe('AssetPartitions', () => { }); expect(screen.queryByTestId('dimension-range-input')).toBeNull(); }); + + it('should support searching within a multiple asset partition', async () => { + const Component = () => { + const [params, setParams] = useState({}); + return ( + + + + + + ); + }; + + render(); + + await waitFor(() => { + expect(screen.getByTestId('partitions-date')).toBeVisible(); + expect(screen.getByTestId('partitions-zstate')).toBeVisible(); + }); + + await waitFor(() => { + expect( + getByTestId( + screen.getByTestId('partitions-date'), + 'asset-partition-row-2023-02-05-index-0', + ), + ).toBeVisible(); + expect( + getByTestId(screen.getByTestId('partitions-zstate'), 'asset-partition-row-TN-index-0'), + ).toBeVisible(); + }); + + // search partitions + const searchInput = screen.getByTestId(`search-0`); + await userEvent.type(searchInput, '2023-01-3'); + + // verify partitions search results + await waitFor(() => { + expect( + getByTestId( + screen.getByTestId('partitions-date'), + 'asset-partition-row-2023-01-31-index-0', + ), + ).toBeVisible(); + expect( + getByTestId( + screen.getByTestId('partitions-date'), + 'asset-partition-row-2023-01-30-index-1', + ), + ).toBeVisible(); + expect( + screen.queryByTestId('asset-partition-row-2023-02-05-index-0'), + ).not.toBeInTheDocument(); + + // verify zstate is unchanged + expect( + getByTestId(screen.getByTestId('partitions-zstate'), 'asset-partition-row-TN-index-0'), + ).toBeVisible(); + }); + + // search zstate + const searchInput1 = screen.getByTestId(`search-1`); + await userEvent.type(searchInput1, 'VA'); + + await waitFor(() => { + // verify zstate search filters properly + expect( + getByTestId(screen.getByTestId('partitions-zstate'), 'asset-partition-row-VA-index-0'), + ).toBeVisible(); + expect(screen.queryByTestId('asset-partition-row-TN-index-0')).not.toBeInTheDocument(); + + // verify partitions search results are unchanged + expect( + getByTestId( + screen.getByTestId('partitions-date'), + 'asset-partition-row-2023-01-31-index-0', + ), + ).toBeVisible(); + expect( + getByTestId( + screen.getByTestId('partitions-date'), + 'asset-partition-row-2023-01-30-index-1', + ), + ).toBeVisible(); + }); + + // clear the search input + await userEvent.clear(searchInput); + await userEvent.clear(searchInput1); + + // verify original rows are visible again + await waitFor(() => { + expect( + getByTestId( + screen.getByTestId('partitions-date'), + 'asset-partition-row-2023-02-05-index-0', + ), + ).toBeVisible(); + expect( + getByTestId(screen.getByTestId('partitions-zstate'), 'asset-partition-row-TN-index-0'), + ).toBeVisible(); + }); + }); });