From 9c320e4a7026afaa1e1500186c3a6060cc85b81c Mon Sep 17 00:00:00 2001 From: Peter Kulko Date: Thu, 16 Jan 2025 13:16:26 +0200 Subject: [PATCH] refactor: updated tests --- src/course-unit/CourseUnit.test.jsx | 22 ++++++++++++++++------ src/course-unit/data/thunk.js | 13 +++++++++---- src/course-unit/hooks.jsx | 6 +----- 3 files changed, 26 insertions(+), 15 deletions(-) diff --git a/src/course-unit/CourseUnit.test.jsx b/src/course-unit/CourseUnit.test.jsx index 6d64615de..ea7b4fab0 100644 --- a/src/course-unit/CourseUnit.test.jsx +++ b/src/course-unit/CourseUnit.test.jsx @@ -243,7 +243,7 @@ describe('', () => { ); simulatePostMessageEvent(messageTypes.deleteXBlock, { - id: courseVerticalChildrenMock.children[0].block_id, + usageId: courseVerticalChildrenMock.children[0].block_id, }); expect(getByText(/Delete this component?/i)).toBeInTheDocument(); @@ -257,10 +257,10 @@ describe('', () => { const deleteButton = getAllByRole('button', { name: /Delete/i }) .find(({ classList }) => classList.contains('btn-primary')); - userEvent.click(cancelButton); + expect(cancelButton).toBeInTheDocument(); simulatePostMessageEvent(messageTypes.deleteXBlock, { - id: courseVerticalChildrenMock.children[0].block_id, + usageId: courseVerticalChildrenMock.children[0].block_id, }); expect(getByRole('dialog')).toBeInTheDocument(); @@ -296,8 +296,12 @@ describe('', () => { axiosMock .onDelete(getXBlockBaseApiUrl(courseVerticalChildrenMock.children[0].block_id)) - .replyOnce(200, { dummy: 'value' }); - await executeThunk(deleteUnitItemQuery(courseId, blockId), store.dispatch); + .reply(200, { dummy: 'value' }); + await executeThunk(deleteUnitItemQuery( + courseId, + courseVerticalChildrenMock.children[0].block_id, + simulatePostMessageEvent, + ), store.dispatch); const updatedCourseVerticalChildren = courseVerticalChildrenMock.children.filter( child => child.block_id !== courseVerticalChildrenMock.children[0].block_id, @@ -1392,7 +1396,11 @@ describe('', () => { global.localStorage.setItem('staticFileNotices', JSON.stringify(clipboardMockResponse.staticFileNotices)); await executeThunk(fetchCourseSectionVerticalData(blockId), store.dispatch); - await executeThunk(createNewCourseXBlock(camelCaseObject(postXBlockBody), null, blockId), store.dispatch); + await executeThunk(createNewCourseXBlock( + camelCaseObject(postXBlockBody), + () => simulatePostMessageEvent(messageTypes.addXBlock, { data: updatedAncestorsChild }), + blockId, + ), store.dispatch); const errorFilesAlert = getByTestId('has-error-files-alert'); expect(within(errorFilesAlert) @@ -1617,6 +1625,8 @@ describe('', () => { callbackFn: requestData.callbackFn, }), store.dispatch); + simulatePostMessageEvent(messageTypes.rollbackMovedXBlock, { locator: requestData.sourceLocator }); + const dismissButton = queryByRole('button', { name: /dismiss/i, hidden: true, }); diff --git a/src/course-unit/data/thunk.js b/src/course-unit/data/thunk.js index b0f693074..e99574271 100644 --- a/src/course-unit/data/thunk.js +++ b/src/course-unit/data/thunk.js @@ -9,6 +9,7 @@ import { RequestStatus } from '../../data/constants'; import { NOTIFICATION_MESSAGES } from '../../constants'; import { updateModel, updateModels } from '../../generic/model-store'; import { updateClipboardData } from '../../generic/data/slice'; +import { messageTypes } from '../constants'; import { getCourseUnitData, editUnitDisplayName, @@ -219,14 +220,14 @@ export function fetchCourseVerticalChildrenData(itemId) { }; } -export function deleteUnitItemQuery(itemId, xblockId, callback) { +export function deleteUnitItemQuery(itemId, xblockId, sendMessageToIframe) { return async (dispatch) => { dispatch(updateSavingStatus({ status: RequestStatus.PENDING })); dispatch(showProcessingNotification(NOTIFICATION_MESSAGES.deleting)); try { await deleteUnitItem(xblockId); - callback(); + sendMessageToIframe(messageTypes.completeXBlockDeleting, null); const { userClipboard } = await getCourseSectionVerticalData(itemId); dispatch(updateClipboardData(userClipboard)); const courseUnit = await getCourseUnitData(itemId); @@ -301,8 +302,12 @@ export function patchUnitItemQuery({ dispatch(updateMovedXBlockParams(xBlockParams)); dispatch(updateCourseOutlineInfo({})); dispatch(updateCourseOutlineInfoLoadingStatus({ status: RequestStatus.IN_PROGRESS })); - const courseUnit = await getCourseUnitData(currentParentLocator); - dispatch(fetchCourseItemSuccess(courseUnit)); + try { + const courseUnit = await getCourseUnitData(currentParentLocator); + dispatch(fetchCourseItemSuccess(courseUnit)); + } catch (error) { + handleResponseErrors(error, dispatch, updateSavingStatus); + } callbackFn(sourceLocator); } catch (error) { handleResponseErrors(error, dispatch, updateSavingStatus); diff --git a/src/course-unit/hooks.jsx b/src/course-unit/hooks.jsx index 7fb8edaff..50702e4e0 100644 --- a/src/course-unit/hooks.jsx +++ b/src/course-unit/hooks.jsx @@ -124,11 +124,7 @@ export const useCourseUnit = ({ courseId, blockId }) => { const unitXBlockActions = { handleDelete: (XBlockId) => { - dispatch(deleteUnitItemQuery( - blockId, - XBlockId, - () => sendMessageToIframe(messageTypes.completeXBlockDeleting, null), - )); + dispatch(deleteUnitItemQuery(blockId, XBlockId, sendMessageToIframe)); }, handleDuplicate: (XBlockId) => { dispatch(duplicateUnitItemQuery(