Skip to content

Commit

Permalink
chore: merge main into develop (#1474)
Browse files Browse the repository at this point in the history
  • Loading branch information
vtsvetkov-splunk authored Nov 22, 2024
2 parents 4cfb72d + 3a59ed7 commit 2ee1792
Show file tree
Hide file tree
Showing 8 changed files with 64 additions and 21 deletions.
6 changes: 3 additions & 3 deletions NOTICE
Original file line number Diff line number Diff line change
Expand Up @@ -7,9 +7,9 @@

The following 3rd-party software packages may be used by or distributed with addonfactory-ucc-generator. Any information relevant to third-party vendors listed below are collected using common, reasonable means.

Date generated: 2024-11-18
Date generated: 2024-11-21

Revision ID: b59b29993757676871905494386cd9de0c4dfcd1
Revision ID: ee2101c2d1a05439736fa2bf3ef446736ac437a5

================================================================================
================================================================================
Expand Down Expand Up @@ -28969,4 +28969,4 @@ either expressed or implied, of the FreeBSD Project.
--------------------------------------------------------------------------------
--------------------------------------------------------------------------------

Report Generated by FOSSA on 2024-11-18
Report Generated by FOSSA on 2024-11-21
6 changes: 6 additions & 0 deletions docs/CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,11 @@
# Changelog

## [5.53.2](https://github.com/splunk/addonfactory-ucc-generator/compare/v5.53.1...v5.53.2) (2024-11-21)


### Bug Fixes

* **api:** cancelled requests don't emit user facing errors ([#1472](https://github.com/splunk/addonfactory-ucc-generator/issues/1472)) ([0970441](https://github.com/splunk/addonfactory-ucc-generator/commit/09704416b5a56ddb518eabd01d596ec5e23157e3))

## [5.53.1](https://github.com/splunk/addonfactory-ucc-generator/compare/v5.53.0...v5.53.1) (2024-11-18)

Expand Down
2 changes: 1 addition & 1 deletion pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@

[tool.poetry]
name = "splunk_add_on_ucc_framework"
version = "5.53.1"
version = "5.53.2"
description = "Splunk Add-on SDK formerly UCC is a build and code generation framework"
license = "Apache-2.0"
authors = ["Splunk <[email protected]>"]
Expand Down
2 changes: 1 addition & 1 deletion splunk_add_on_ucc_framework/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@
# See the License for the specific language governing permissions and
# limitations under the License.
#
__version__ = "5.53.1"
__version__ = "5.53.2"

import logging

Expand Down
10 changes: 5 additions & 5 deletions ui/src/components/MultiInputComponent/MultiInputComponent.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -78,7 +78,7 @@ function MultiInputComponent(props: MultiInputComponentProps) {
return;
}

let current = true;
let mounted = true;
const abortController = new AbortController();

const url = referenceName
Expand All @@ -102,7 +102,7 @@ function MultiInputComponent(props: MultiInputComponentProps) {
setLoading(true);
getRequest<{ entry: FilterResponseParams }>(apiCallOptions)
.then((data) => {
if (current) {
if (mounted) {
setOptions(
generateOptions(
filterResponse(
Expand All @@ -117,15 +117,15 @@ function MultiInputComponent(props: MultiInputComponentProps) {
}
})
.finally(() => {
if (current) {
if (mounted) {
setLoading(false);
}
});
}
// eslint-disable-next-line consistent-return
return () => {
abortController.abort('Operation canceled.');
current = false;
mounted = false;
abortController.abort();
};
// eslint-disable-next-line react-hooks/exhaustive-deps
}, [dependencyValues]);
Expand Down
12 changes: 6 additions & 6 deletions ui/src/components/SingleInputComponent/SingleInputComponent.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -128,7 +128,7 @@ function SingleInputComponent(props: SingleInputComponentProps) {
return;
}

let current = true;
let mounted = true;
const abortController = new AbortController();

const backendCallOptions = {
Expand All @@ -145,7 +145,7 @@ function SingleInputComponent(props: SingleInputComponentProps) {
setLoading(true);
getRequest<{ entry: FilterResponseParams }>(backendCallOptions)
.then((data) => {
if (current) {
if (mounted) {
setOptions(
generateOptions(
filterResponse(data.entry, labelField, valueField, allowList, denyList)
Expand All @@ -155,16 +155,16 @@ function SingleInputComponent(props: SingleInputComponentProps) {
}
})
.catch(() => {
if (current) {
if (mounted) {
setLoading(false);
setOptions([]);
}
setOptions([]);
});

// eslint-disable-next-line consistent-return
return () => {
abortController.abort('Operation canceled.');
current = false;
mounted = false;
abortController.abort();
};
// eslint-disable-next-line react-hooks/exhaustive-deps
}, [dependencyValues]);
Expand Down
44 changes: 40 additions & 4 deletions ui/src/util/api.test.ts → ui/src/util/api.test.tsx
Original file line number Diff line number Diff line change
@@ -1,9 +1,15 @@
import { http, HttpResponse } from 'msw';
import { delay, http, HttpResponse } from 'msw';
import { generateEndPointUrl, getRequest } from './api';
import { getGlobalConfigMock } from '../mocks/globalConfigMock';
import { setUnifiedConfig } from './util';
import { server } from '../mocks/server';

const mockGenerateToastFn = jest.fn();
jest.mock('./util', () => ({
...jest.requireActual('./util'),
generateToast: () => mockGenerateToastFn(),
}));

describe('generateEndPointUrl', () => {
it('should return the correct endpoint URL', () => {
const mockConfig = getGlobalConfigMock();
Expand All @@ -23,7 +29,7 @@ describe('generateEndPointUrl', () => {
});

describe('getRequest', () => {
beforeEach(() => {
function setup() {
const mockConfig = getGlobalConfigMock();
setUnifiedConfig({
...mockConfig,
Expand All @@ -32,9 +38,12 @@ describe('getRequest', () => {
restRoot: 'testing_name',
},
});
server.use(http.get('*', () => HttpResponse.json({}, { status: 500 })));
});
}

it('should call callbackOnError if handleError is true', async () => {
setup();
server.use(http.get('*', () => HttpResponse.json({}, { status: 500 })));

const callbackOnError = jest.fn();

await expect(() =>
Expand All @@ -45,9 +54,12 @@ describe('getRequest', () => {
})
).rejects.toThrow();

expect(mockGenerateToastFn).toHaveBeenCalledTimes(1);
expect(callbackOnError).toHaveBeenCalled();
});
it('should not call callbackOnError if handleError is false', async () => {
setup();
server.use(http.get('*', () => HttpResponse.json({}, { status: 500 })));
const callbackOnError = jest.fn();

await expect(() =>
Expand All @@ -58,6 +70,30 @@ describe('getRequest', () => {
})
).rejects.toThrow();

expect(mockGenerateToastFn).not.toHaveBeenCalled();
expect(callbackOnError).not.toHaveBeenCalled();
});

it('should not show error if request is cancelled', async () => {
setup();
server.use(
http.get('*', async () => {
await delay('infinite');

return HttpResponse.json();
})
);
const abortController = new AbortController();

const request = getRequest({
endpointUrl: 'testing_endpoint',
handleError: true,
signal: abortController.signal,
});

abortController.abort();

await expect(request).rejects.toThrow();
expect(mockGenerateToastFn).not.toHaveBeenCalled();
});
});
3 changes: 2 additions & 1 deletion ui/src/util/api.ts
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,8 @@ async function fetchWithErrorHandling<TData>(
}
return await response.json();
} catch (error) {
if (handleError) {
const isAborted = error instanceof DOMException && error.name === 'AbortError';
if (handleError && !isAborted) {
const errorMsg = parseErrorMsg(error);
generateToast(errorMsg, 'error');
if (callbackOnError) {
Expand Down

0 comments on commit 2ee1792

Please sign in to comment.