-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Update Frontend for Custom Result Index Query and Fix Issues
This PR finalizes the frontend changes related to PR #1225. The custom result index query now uses an index pattern instead of a single index. Additionally, this PR addresses an issue where missing custom result indices would appear because the original code checked for the existence of an index name, but now we use it as a prefix. We have updated the logic to perform a prefix search instead of checking for index name equality. This PR also resolves issue opensearch-project#765 by downgrading the version of jest-canvas-mock. Testing Done: * Added unit tests. * Verified that the custom result index missing callout is not shown. * Confirmed that the frontend can still display old and new results after a rollover. Signed-off-by: Kaituo Li <[email protected]>
- Loading branch information
Showing
7 changed files
with
361 additions
and
3 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
136 changes: 136 additions & 0 deletions
136
public/redux/reducers/__tests__/liveAnomalyResults.test.ts
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,136 @@ | ||
/* | ||
* SPDX-License-Identifier: Apache-2.0 | ||
* | ||
* The OpenSearch Contributors require contributions made to | ||
* this file be licensed under the Apache-2.0 license or a | ||
* compatible open source license. | ||
* | ||
* Modifications Copyright OpenSearch Contributors. See | ||
* GitHub history for details. | ||
*/ | ||
|
||
import { MockStore } from 'redux-mock-store'; | ||
import { DetectorResultsQueryParams } from '../../../../server/models/types'; | ||
import { SORT_DIRECTION } from '../../../../server/utils/constants'; | ||
import httpMockedClient from '../../../../test/mocks/httpClientMock'; | ||
import { AD_NODE_API } from '../../../../utils/constants'; | ||
import { mockedStore } from '../../utils/testUtils'; | ||
import { ALL_CUSTOM_AD_RESULT_INDICES } from '../../../pages/utils/constants'; | ||
import reducer, { | ||
getDetectorLiveResults, | ||
initialDetectorLiveResults, | ||
} from '../liveAnomalyResults'; | ||
|
||
jest.mock('../../../services', () => ({ | ||
...jest.requireActual('../../../services'), | ||
|
||
getDataSourceEnabled: () => ({ | ||
enabled: false, | ||
}), | ||
})); | ||
|
||
describe('live anomaly results reducer actions', () => { | ||
let store: MockStore; | ||
beforeEach(() => { | ||
store = mockedStore(); | ||
}); | ||
describe('getDetectorLiveResults', () => { | ||
test('getDetectorLiveResults should append wildcard star at the end of custom result index', async () => { | ||
const response = { | ||
totalAnomalies: 1, | ||
results: [{ anomalyGrade: 0, confidence: 1, starTime: 1, endTime: 2 }], | ||
}; | ||
|
||
httpMockedClient.get = jest | ||
.fn() | ||
.mockResolvedValue({ ok: true, response }); | ||
const tempDetectorId = '123'; | ||
const resultIndex = 'opensearch-ad-plugin-result-test'; | ||
let queryParams: DetectorResultsQueryParams = { | ||
from: 0, | ||
size: 20, | ||
sortDirection: SORT_DIRECTION.ASC, | ||
sortField: 'startTime', | ||
}; | ||
await store.dispatch( | ||
getDetectorLiveResults( | ||
tempDetectorId, | ||
'', | ||
queryParams, | ||
false, | ||
resultIndex, | ||
true | ||
) | ||
); | ||
const actions = store.getActions(); | ||
|
||
expect(actions[0].type).toBe('ad/DETECTOR_LIVE_RESULTS_REQUEST'); | ||
expect(reducer(initialDetectorLiveResults, actions[0])).toEqual({ | ||
...initialDetectorLiveResults, | ||
requesting: true, | ||
}); | ||
expect(actions[1].type).toBe('ad/DETECTOR_LIVE_RESULTS_SUCCESS'); | ||
expect(reducer(initialDetectorLiveResults, actions[1])).toEqual({ | ||
...initialDetectorLiveResults, | ||
requesting: false, | ||
totalLiveAnomalies: response.totalAnomalies, | ||
liveAnomalies: response.results, | ||
errorMessage: '', | ||
}); | ||
expect(httpMockedClient.get).toHaveBeenCalledWith( | ||
`..${ | ||
AD_NODE_API.DETECTOR | ||
}/${tempDetectorId}/results/${false}/${resultIndex}*/true`, | ||
{ query: queryParams } | ||
); | ||
}); | ||
test('getDetectorLiveResults should not append wildcard star at the end of custom result index', async () => { | ||
const response = { | ||
totalAnomalies: 1, | ||
results: [{ anomalyGrade: 0, confidence: 1, starTime: 1, endTime: 2 }], | ||
}; | ||
|
||
httpMockedClient.get = jest | ||
.fn() | ||
.mockResolvedValue({ ok: true, response }); | ||
const tempDetectorId = '123'; | ||
let queryParams: DetectorResultsQueryParams = { | ||
from: 0, | ||
size: 20, | ||
sortDirection: SORT_DIRECTION.ASC, | ||
sortField: 'startTime', | ||
}; | ||
await store.dispatch( | ||
getDetectorLiveResults( | ||
tempDetectorId, | ||
'', | ||
queryParams, | ||
false, | ||
ALL_CUSTOM_AD_RESULT_INDICES, | ||
true | ||
) | ||
); | ||
const actions = store.getActions(); | ||
|
||
expect(actions[0].type).toBe('ad/DETECTOR_LIVE_RESULTS_REQUEST'); | ||
expect(reducer(initialDetectorLiveResults, actions[0])).toEqual({ | ||
...initialDetectorLiveResults, | ||
requesting: true, | ||
}); | ||
expect(actions[1].type).toBe('ad/DETECTOR_LIVE_RESULTS_SUCCESS'); | ||
expect(reducer(initialDetectorLiveResults, actions[1])).toEqual({ | ||
...initialDetectorLiveResults, | ||
requesting: false, | ||
totalLiveAnomalies: response.totalAnomalies, | ||
liveAnomalies: response.results, | ||
errorMessage: '', | ||
}); | ||
expect(httpMockedClient.get).toHaveBeenCalledWith( | ||
`..${ | ||
AD_NODE_API.DETECTOR | ||
}/${tempDetectorId}/results/${false}/${ALL_CUSTOM_AD_RESULT_INDICES}/true`, | ||
{ query: queryParams } | ||
); | ||
}); | ||
}); | ||
}); |
Oops, something went wrong.