Skip to content

Commit

Permalink
UIBULKED-553 Replace generic error with the detailed error message (#614
Browse files Browse the repository at this point in the history
)
  • Loading branch information
vashjs authored Oct 20, 2024
1 parent 3ec4533 commit 89cb2f6
Show file tree
Hide file tree
Showing 31 changed files with 216 additions and 84 deletions.
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import React from 'react';
import { render, fireEvent, waitFor } from '@testing-library/react';
import '@testing-library/jest-dom/extend-expect';
import '../../../../../../test/jest/__mock__/reactIntl.mock';
import { IntlProvider } from 'react-intl';
import { QueryClientProvider } from 'react-query';
import { Router } from 'react-router-dom';
Expand All @@ -11,8 +12,6 @@ import { ValuesColumn } from './ValuesColumn';
import { useLoanTypes, usePatronGroup } from '../../../../../hooks/api';
import { CAPABILITIES, CONTROL_TYPES } from '../../../../../constants';

import '../../../../../../test/jest/__mock__';

jest.mock('../../../../../hooks/api/useLoanTypes');
jest.mock('../../../../../hooks/api/usePatronGroup');

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,10 +3,11 @@ import { QueryClientProvider } from 'react-query';

import { logDOM, render, screen } from '@testing-library/react';

import '../../../../../test/jest/__mock__';

import { useOkapiKy } from '@folio/stripes/core';
import { runAxeTest } from '@folio/stripes-testing';

import '../../../../../test/jest/__mock__';
import { bulkEditLogsData } from '../../../../../test/jest/__mock__/fakeData';
import { queryClient } from '../../../../../test/jest/utils/queryClient';

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -8,14 +8,11 @@ import {
screen,
} from '@testing-library/react';
import userEvent from '@testing-library/user-event';

import '../../../../../test/jest/__mock__';
import { useOkapiKy } from '@folio/stripes/core';
import { runAxeTest } from '@folio/stripes-testing';

import '../../../../../test/jest/__mock__';

import { queryClient } from '../../../../../test/jest/utils/queryClient';

import { LogsTab } from './LogsTab';

const activeFiltersMock = {
Expand Down
4 changes: 4 additions & 0 deletions src/components/PermissionsModal/hooks/useAllPermissions.js
Original file line number Diff line number Diff line change
@@ -1,12 +1,14 @@
import { useQuery } from 'react-query';
import { useNamespace, useOkapiKy } from '@folio/stripes/core';
import { FILTER_KEYS } from '../constants/core';
import { useErrorMessages } from '../../../hooks/useErrorMessages';

export const ALL_PERMISSIONS_KEY = 'ALL_PERMISSIONS_KEY';

export const useAllPermissions = (options = {}) => {
const ky = useOkapiKy();
const [namespaceKey] = useNamespace({ key: ALL_PERMISSIONS_KEY });
const { showErrorMessage } = useErrorMessages();

const { data: permissions, isLoading: isPermissionsLoading } = useQuery(
{
Expand All @@ -18,6 +20,8 @@ export const useAllPermissions = (options = {}) => {
...permission,
type: permission.mutable ? FILTER_KEYS.PERMISSION_SETS : FILTER_KEYS.PERMISSIONS,
})),
onError: showErrorMessage,
onSuccess: showErrorMessage,
...options,
},
);
Expand Down
4 changes: 4 additions & 0 deletions src/hooks/api/useBulkEditLogs/useBulkEditLogs.js
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ import {
} from '@folio/stripes-acq-components';

import { getFullName } from '../../../utils/getFullName';
import { useErrorMessages } from '../../useErrorMessages';

const buildLogsQuery = makeQueryBuilder(
'cql.allRecords=1',
Expand All @@ -27,6 +28,7 @@ export const useBulkEditLogs = ({ filters = {}, pagination }) => {
const usersMap = useRef({});
const ky = useOkapiKy();
const [namespaceKey] = useNamespace({ key: BULK_EDIT_LOGS_KEY });
const { showErrorMessage } = useErrorMessages();

const logsQuery = buildLogsQuery(filters);
const filtersCount = getFiltersCount(filters);
Expand Down Expand Up @@ -83,6 +85,8 @@ export const useBulkEditLogs = ({ filters = {}, pagination }) => {
queryFn,
enabled: Boolean(pagination.timestamp),
keepPreviousData: true,
onError: showErrorMessage,
onSuccess: showErrorMessage,
});

return {
Expand Down
3 changes: 1 addition & 2 deletions src/hooks/api/useBulkEditLogs/useBulkEditLogs.test.js
Original file line number Diff line number Diff line change
@@ -1,15 +1,14 @@
import { renderHook } from '@testing-library/react-hooks';
import { QueryClient, QueryClientProvider } from 'react-query';

import '../../../../test/jest/__mock__/reactIntl.mock';
import { useOkapiKy } from '@folio/stripes/core';

import { bulkEditLogsData } from '../../../../test/jest/__mock__/fakeData';

import { LOGS_FILTERS, JOB_STATUSES } from '../../../constants';
import { useBulkEditLogs } from './useBulkEditLogs';
import { getFullName } from '../../../utils/getFullName';

import '../../../../test/jest/__mock__/stripesCore.mock';

const users = [
{
Expand Down
6 changes: 5 additions & 1 deletion src/hooks/api/useBulkOperationDelete.js
Original file line number Diff line number Diff line change
@@ -1,13 +1,17 @@
import { useOkapiKy } from '@folio/stripes/core';
import { useMutation } from 'react-query';
import { useErrorMessages } from '../useErrorMessages';

export const useBulkOperationDelete = (mutationOptions = {}) => {
const ky = useOkapiKy();
const { showErrorMessage } = useErrorMessages();

const { mutateAsync: bulkOperationDelete, isLoading } = useMutation({
mutationFn: async ({ operationId }) => {
await ky.post(`bulk-operations/${operationId}/cancel`);
return ky.post(`bulk-operations/${operationId}/cancel`).json();
},
onError: showErrorMessage,
onSuccess: showErrorMessage,
...mutationOptions,
});

Expand Down
8 changes: 4 additions & 4 deletions src/hooks/api/useBulkOperationStart.js
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ import { useErrorMessages } from '../useErrorMessages';
export const useBulkOperationStart = (mutationOptions = {}) => {
const params = useRef({});
const ky = useOkapiKy();
const { checkErrorMessage } = useErrorMessages();
const { showErrorMessage } = useErrorMessages();

const { refetch: fetchBulkOperation } = useQuery({
queryFn: async () => {
Expand Down Expand Up @@ -60,19 +60,19 @@ export const useBulkOperationStart = (mutationOptions = {}) => {
params.current = { id, step };

try {
const startResult = await ky.post(`bulk-operations/${id}/start`, {
return await ky.post(`bulk-operations/${id}/start`, {
json: body,
}).json();

checkErrorMessage(startResult);

// eslint-disable-next-line no-empty
} catch (e) {}

const { data } = await fetchBulkOperation();

return data;
},
onSuccess: showErrorMessage,
onError: showErrorMessage,
...mutationOptions,
});

Expand Down
4 changes: 4 additions & 0 deletions src/hooks/api/useBulkOperationUsers.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@ import { omit } from 'lodash';
import { makeQueryBuilder } from '@folio/stripes-acq-components';
import noop from 'lodash/noop';
import { LOGS_FILTERS, PAGINATION_CONFIG as pagination } from '../../constants';
import { useErrorMessages } from '../useErrorMessages';

export const BULK_OPERATION_USERS_KEY = 'BULK_OPERATION_USERS_KEY';

Expand All @@ -17,6 +18,7 @@ const buildLogsQuery = makeQueryBuilder(
export const useBulkOperationUsers = (filters, options) => {
const ky = useOkapiKy();
const [namespaceKey] = useNamespace({ key: BULK_OPERATION_USERS_KEY });
const { showErrorMessage } = useErrorMessages();

const logsQuery = buildLogsQuery(omit(filters, [LOGS_FILTERS.USER]));

Expand All @@ -29,6 +31,8 @@ export const useBulkOperationUsers = (filters, options) => {
const { data, isLoading } = useQuery({
queryKey: [namespaceKey, filters],
queryFn: () => ky.get('bulk-operations/list-users', { searchParams }).json(),
onError: showErrorMessage,
onSuccess: showErrorMessage,
...options,
});

Expand Down
2 changes: 2 additions & 0 deletions src/hooks/api/useBulkOperationUsers.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,8 @@ import {
QueryClientProvider,
} from 'react-query';

import '../../../test/jest/__mock__/reactIntl.mock';

import { useOkapiKy } from '@folio/stripes/core';
import { renderHook } from '@testing-library/react-hooks';
import { waitFor, act } from '@testing-library/react';
Expand Down
6 changes: 5 additions & 1 deletion src/hooks/api/useContentUpdate.js
Original file line number Diff line number Diff line change
@@ -1,15 +1,19 @@
import { useMutation } from 'react-query';
import { useOkapiKy } from '@folio/stripes/core';
import { useErrorMessages } from '../useErrorMessages';

export const useContentUpdate = ({ id }) => {
const ky = useOkapiKy();
const { showErrorMessage } = useErrorMessages();

const { data, mutateAsync: contentUpdate, isLoading } = useMutation({
mutationFn: ({ contentUpdates }) => {
return ky.post(`bulk-operations/${id}/content-update`, {
json: contentUpdates,
});
}).json();
},
onError: showErrorMessage,
onSuccess: showErrorMessage,
});

return { contentUpdate, isLoading, data };
Expand Down
4 changes: 4 additions & 0 deletions src/hooks/api/useElectronicAccess.js
Original file line number Diff line number Diff line change
@@ -1,18 +1,22 @@
import { useNamespace, useOkapiKy } from '@folio/stripes/core';
import { useQuery } from 'react-query';
import { useErrorMessages } from '../useErrorMessages';

export const ELECTRONIC_ACCESS_RELATIONSHIPS_KEY = 'ELECTRONIC_ACCESS_RELATIONSHIPS_KEY';

export const useElectronicAccessRelationships = (options = {}) => {
const ky = useOkapiKy();
const [namespaceKey] = useNamespace({ key: ELECTRONIC_ACCESS_RELATIONSHIPS_KEY });
const { showErrorMessage } = useErrorMessages();

const { data, isLoading: isElectronicAccessLoading } = useQuery(
{
queryKey: [namespaceKey],
cacheTime: Infinity,
staleTime: Infinity,
queryFn: () => ky.get('electronic-access-relationships?limit=1000&query=cql.allRecords=1 sortby name').json(),
onError: showErrorMessage,
onSuccess: showErrorMessage,
...options,
},
);
Expand Down
5 changes: 5 additions & 0 deletions src/hooks/api/useErrorsPreview.js
Original file line number Diff line number Diff line change
@@ -1,18 +1,23 @@
import { useQuery } from 'react-query';
import { useNamespace, useOkapiKy } from '@folio/stripes/core';
import { useErrorMessages } from '../useErrorMessages';

export const PREVIEW_ERRORS_KEY = 'PREVIEW_ERRORS_KEY';

export const useErrorsPreview = ({ id }) => {
const ky = useOkapiKy();
const [namespaceKey] = useNamespace({ key: PREVIEW_ERRORS_KEY });

const { showErrorMessage } = useErrorMessages();

const { data, isLoading } = useQuery(
{
queryKey: [namespaceKey, id],
cacheTime: 0,
enabled: !!id,
queryFn: () => ky.get(`bulk-operations/${id}/errors`, { searchParams: { limit: 10 } }).json(),
onError: showErrorMessage,
onSuccess: showErrorMessage,
},
);

Expand Down
4 changes: 4 additions & 0 deletions src/hooks/api/useEscCommon.js
Original file line number Diff line number Diff line change
@@ -1,12 +1,14 @@
import { useNamespace } from '@folio/stripes/core';
import { useQuery } from 'react-query';
import { usePublishCoordinator } from '../usePublishCoordinator';
import { useErrorMessages } from '../useErrorMessages';

const DEFAULT_DATA = {};

export const useEscCommon = (key, url, tenants, mapResponse, options = {}) => {
const [namespace] = useNamespace({ key });
const { initPublicationRequest } = usePublishCoordinator(namespace);
const { showErrorMessage } = useErrorMessages();

const { data = DEFAULT_DATA, isFetching } = useQuery({
queryKey: [namespace, tenants],
Expand All @@ -21,6 +23,8 @@ export const useEscCommon = (key, url, tenants, mapResponse, options = {}) => {
keepPreviousData: true,
cacheTime: Infinity,
staleTime: Infinity,
onError: showErrorMessage,
onSuccess: showErrorMessage,
...options
});

Expand Down
8 changes: 7 additions & 1 deletion src/hooks/api/useFileDownload.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
import { useQuery } from 'react-query';
import { useNamespace, useOkapiKy } from '@folio/stripes/core';
import { useErrorMessages } from '../useErrorMessages';

export const QUERY_KEY_DOWNLOAD_LOGS = 'downloadLogs';
export const QUERY_KEY_DOWNLOAD_ACTION_MENU = 'downloadActionMenu';
Expand All @@ -16,6 +17,7 @@ export const useFileDownload = ({
}) => {
const ky = useOkapiKy();
const [namespaceKey] = useNamespace({ key: queryKey });
const { showErrorMessage } = useErrorMessages();

const { refetch, isFetching } = useQuery(
{
Expand All @@ -24,7 +26,11 @@ export const useFileDownload = ({
searchParams: { fileContentType: fileInfo?.fileContentType },
}).blob(),
enabled: !!fileInfo,
onSuccess,
onSuccess: response => {
showErrorMessage(response);
onSuccess?.(response);
},
onError: showErrorMessage,
onSettled,
...queryProps,
},
Expand Down
4 changes: 4 additions & 0 deletions src/hooks/api/useHoldingsNotes.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,20 +4,24 @@ import { useIntl } from 'react-intl';
import { useMemo } from 'react';
import { OPTIONS, PARAMETERS_KEYS } from '../../constants';
import { getMappedAndSortedNotes } from '../../utils/helpers';
import { useErrorMessages } from '../useErrorMessages';

export const HOLDINGS_NOTES_KEY = 'HOLDINGS_NOTES_KEY';

export const useHoldingsNotes = (options = {}) => {
const ky = useOkapiKy();
const [namespaceKey] = useNamespace({ key: HOLDINGS_NOTES_KEY });
const { formatMessage } = useIntl();
const { showErrorMessage } = useErrorMessages();

const { data, isLoading: isHoldingsNotesLoading } = useQuery(
{
queryKey: [namespaceKey],
cacheTime: Infinity,
staleTime: Infinity,
queryFn: () => ky.get('holdings-note-types', { searchParams: { limit: 1000 } }).json(),
onError: showErrorMessage,
onSuccess: showErrorMessage,
...options,
},
);
Expand Down
4 changes: 4 additions & 0 deletions src/hooks/api/useInstanceNotes.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,20 +4,24 @@ import { useIntl } from 'react-intl';
import { useMemo } from 'react';
import { OPTIONS, PARAMETERS_KEYS } from '../../constants';
import { getMappedAndSortedNotes } from '../../utils/helpers';
import { useErrorMessages } from '../useErrorMessages';

export const INSTANCE_NOTES_KEY = 'INSTANCE_NOTES_KEY';

export const useInstanceNotes = (options = {}) => {
const ky = useOkapiKy();
const [namespaceKey] = useNamespace({ key: INSTANCE_NOTES_KEY });
const { formatMessage } = useIntl();
const { showErrorMessage } = useErrorMessages();

const { data, isLoading: isInstanceNotesLoading } = useQuery(
{
queryKey: [namespaceKey],
cacheTime: Infinity,
staleTime: Infinity,
queryFn: () => ky.get('instance-note-types', { searchParams: { limit: 1000 } }).json(),
onError: showErrorMessage,
onSuccess: showErrorMessage,
...options,
},
);
Expand Down
4 changes: 4 additions & 0 deletions src/hooks/api/useItemNotes.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,20 +4,24 @@ import { useIntl } from 'react-intl';
import { useMemo } from 'react';
import { OPTIONS, PARAMETERS_KEYS } from '../../constants';
import { getMappedAndSortedNotes } from '../../utils/helpers';
import { useErrorMessages } from '../useErrorMessages';

export const ITEM_NOTES_KEY = 'ITEM_NOTES_KEY';

export const useItemNotes = (options = {}) => {
const ky = useOkapiKy();
const [namespaceKey] = useNamespace({ key: ITEM_NOTES_KEY });
const { formatMessage } = useIntl();
const { showErrorMessage } = useErrorMessages();

const { data, isLoading: isItemNotesLoading } = useQuery(
{
queryKey: [namespaceKey],
cacheTime: Infinity,
staleTime: Infinity,
queryFn: () => ky.get('item-note-types', { searchParams: { limit: 1000 } }).json(),
onError: showErrorMessage,
onSuccess: showErrorMessage,
...options,
},
);
Expand Down
Loading

0 comments on commit 89cb2f6

Please sign in to comment.