Allows frontend-app-learning to be configured at runtime using the LMS's new MFE Configuration API. Part of openedx/frontend-wg#103
45 lines
1.7 KiB
JavaScript
45 lines
1.7 KiB
JavaScript
import React from 'react';
|
|
import { initializeTestStore, render, screen } from '../../../setupTest';
|
|
import SequenceContent from './SequenceContent';
|
|
|
|
describe('Sequence Content', () => {
|
|
let mockData;
|
|
let store;
|
|
|
|
beforeAll(async () => {
|
|
store = await initializeTestStore();
|
|
const { models, courseware } = store.getState();
|
|
mockData = {
|
|
gated: false,
|
|
courseId: courseware.courseId,
|
|
sequenceId: courseware.sequenceId,
|
|
unitId: models.sequences[courseware.sequenceId].unitIds[0],
|
|
unitLoadedHandler: () => { },
|
|
};
|
|
});
|
|
|
|
it('displays loading message', () => {
|
|
render(<SequenceContent {...mockData} />);
|
|
expect(screen.getByText('Loading learning sequence...')).toBeInTheDocument();
|
|
});
|
|
|
|
it('displays messages for the locked content', async () => {
|
|
const { gatedContent } = store.getState().models.sequences[mockData.sequenceId];
|
|
const { container } = render(<SequenceContent {...mockData} gated />);
|
|
|
|
expect(screen.getByText('Loading locked content messaging...')).toBeInTheDocument();
|
|
expect(await screen.findByText('Content Locked')).toBeInTheDocument();
|
|
expect(screen.queryByText('Loading locked content messaging...')).not.toBeInTheDocument();
|
|
expect(container.querySelector('svg')).toHaveClass('fa-lock');
|
|
expect(screen.getByText(
|
|
`You must complete the prerequisite: '${gatedContent.prereqSectionName}' to access this content.`,
|
|
)).toBeInTheDocument();
|
|
expect(screen.getByRole('button', { name: 'Go To Prerequisite Section' })).toBeInTheDocument();
|
|
});
|
|
|
|
it('displays message for no content', () => {
|
|
render(<SequenceContent {...mockData} unitId={null} />);
|
|
expect(screen.getByText('There is no content here.')).toBeInTheDocument();
|
|
});
|
|
});
|