diff --git a/src/course-outline/card-header/CardHeader.jsx b/src/course-outline/card-header/CardHeader.jsx index 065707b243..3634e42e70 100644 --- a/src/course-outline/card-header/CardHeader.jsx +++ b/src/course-outline/card-header/CardHeader.jsx @@ -62,6 +62,11 @@ const CardHeader = ({ const cardHeaderRef = useRef(null); const [isManageTagsDrawerOpen, openManageTagsDrawer, closeManageTagsDrawer] = useToggle(false); + // Use studio url as base if proctoringExamConfigurationLink is a relative link + const fullProctoringExamConfigurationLink = () => ( + proctoringExamConfigurationLink && new URL(proctoringExamConfigurationLink, getConfig().STUDIO_BASE_URL).href + ); + const isDisabledPublish = (status === ITEM_BADGE_STATUS.live || status === ITEM_BADGE_STATUS.publishedNotLive) && !hasChanges; @@ -156,8 +161,8 @@ const CardHeader = ({ {intl.formatMessage(messages.menuProctoringLinkText)} diff --git a/src/course-outline/card-header/CardHeader.test.jsx b/src/course-outline/card-header/CardHeader.test.jsx index c734300433..d589627173 100644 --- a/src/course-outline/card-header/CardHeader.test.jsx +++ b/src/course-outline/card-header/CardHeader.test.jsx @@ -265,14 +265,31 @@ describe('', () => { it('check if proctoringExamConfigurationLink is visible', async () => { const { findByText, findByTestId } = renderComponent({ ...cardHeaderProps, - proctoringExamConfigurationLink: 'https://localhost:8000/', + proctoringExamConfigurationLink: 'proctoringlink', isSequential: true, }); const menuButton = await findByTestId('subsection-card-header__menu-button'); await act(async () => fireEvent.click(menuButton)); - expect(await findByText(messages.menuProctoringLinkText.defaultMessage)).toBeInTheDocument(); + const element = await findByText(messages.menuProctoringLinkText.defaultMessage); + expect(element).toBeInTheDocument(); + expect(element.getAttribute('href')).toBe(`${getConfig().STUDIO_BASE_URL}/proctoringlink`); + }); + + it('check if proctoringExamConfigurationLink is absolute', async () => { + const { findByText, findByTestId } = renderComponent({ + ...cardHeaderProps, + proctoringExamConfigurationLink: 'http://localhost:9000/proctoringlink', + isSequential: true, + }); + + const menuButton = await findByTestId('subsection-card-header__menu-button'); + await act(async () => fireEvent.click(menuButton)); + + const element = await findByText(messages.menuProctoringLinkText.defaultMessage); + expect(element).toBeInTheDocument(); + expect(element.getAttribute('href')).toBe('http://localhost:9000/proctoringlink'); }); it('check if discussion enabled badge is visible', async () => {