- Assume that Learning Sequences is available (waffle has been removed) - Stop calling course blocks API, which provided mostly duplicated information now. - Refactor a bit to avoid needing to globally know which units exist in sequences. That is now provided just-in-time for only the current sequence. - Add /first and /last URLs that you can use instead of unit IDs in URL paths, in service of the above point. AA-1040 AA-1153
39 lines
1.2 KiB
JavaScript
39 lines
1.2 KiB
JavaScript
import React from 'react';
|
|
import { screen, render } from '@testing-library/react';
|
|
import JumpNavMenuItem from './JumpNavMenuItem';
|
|
import { fireEvent } from '../../setupTest';
|
|
|
|
jest.mock('@edx/frontend-platform');
|
|
jest.mock('@edx/frontend-platform/analytics');
|
|
|
|
const mockData = {
|
|
sectionId: 'block-v1:edX+DemoX+Demo_Course+type@chapter+block@interactive_demonstrations',
|
|
sequenceId: 'block-v1:edX+DemoX+Demo_Course+type@sequential+block@basic_questions',
|
|
|
|
title: 'Demo Menu Item',
|
|
courseId: 'course-v1:edX+DemoX+Demo_Course',
|
|
currentUnit: 'block-v1:edX+DemoX+Demo_Course+type@chapter+block@interactive_demonstrations',
|
|
sequences: [
|
|
{
|
|
id: 'block-v1:edX+DemoX+Demo_Course+type@sequential+block@19a30717eff543078a5d94ae9d6c18a5',
|
|
},
|
|
{
|
|
id: 'block-v1:edX+DemoX+Demo_Course+type@sequential+block@basic_questions',
|
|
},
|
|
],
|
|
isDefault: false,
|
|
};
|
|
describe('JumpNavMenuItem', () => {
|
|
render(
|
|
<JumpNavMenuItem
|
|
{...mockData}
|
|
/>,
|
|
);
|
|
it('renders menu Item as expected with button and Text and handles clicks', () => {
|
|
expect(screen.queryAllByRole('button')).toHaveLength(1);
|
|
expect(screen.getByText('Demo Menu Item'));
|
|
const navButton = screen.queryAllByRole('button')[0];
|
|
fireEvent.click(navButton);
|
|
});
|
|
});
|