Skip to content

Commit

Permalink
test: extend timeout on slow test
Browse files Browse the repository at this point in the history
  • Loading branch information
pwnage101 committed Dec 4, 2024
1 parent 5918556 commit 9eda274
Showing 1 changed file with 107 additions and 99 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -769,107 +769,115 @@ describe('<BudgetDetailPage />', () => {
['[email protected]'],
);
});
it('test member status popovers', async () => {
const initialState = {
portalConfiguration: {
...initialStoreState.portalConfiguration,
enterpriseFeatures: {
enterpriseGroupsV1: true,
it(
'test member status popovers',
async () => {
const initialState = {
portalConfiguration: {
...initialStoreState.portalConfiguration,
enterpriseFeatures: {
enterpriseGroupsV1: true,
},
},
},
};
useParams.mockReturnValue({
enterpriseSlug: 'test-enterprise-slug',
enterpriseAppPage: 'test-enterprise-page',
activeTabKey: 'members',
});
useSubsidyAccessPolicy.mockReturnValue({
isInitialLoading: false,
data: mockAssignableSubsidyAccessPolicy,
});
useBudgetDetailActivityOverview.mockReturnValue({
isLoading: false,
data: mockEmptyStateBudgetDetailActivityOverview,
});
useBudgetRedemptions.mockReturnValue({
isLoading: false,
budgetRedemptions: mockEmptyBudgetRedemptions,
fetchBudgetRedemptions: jest.fn(),
});
useEnterpriseGroupLearners.mockReturnValue({
data: {
count: 1,
currentPage: 1,
next: null,
numPages: 1,
results: {
enterpriseGroupMembershipUuid: 'cde2e374-032f-4c08-8c0d-bf3205fa7c7e',
learnerId: 4382,
memberDetails: { userEmail: '[email protected]', userName: 'duke silver' },
};
useParams.mockReturnValue({
enterpriseSlug: 'test-enterprise-slug',
enterpriseAppPage: 'test-enterprise-page',
activeTabKey: 'members',
});
useSubsidyAccessPolicy.mockReturnValue({
isInitialLoading: false,
data: mockAssignableSubsidyAccessPolicy,
});
useBudgetDetailActivityOverview.mockReturnValue({
isLoading: false,
data: mockEmptyStateBudgetDetailActivityOverview,
});
useBudgetRedemptions.mockReturnValue({
isLoading: false,
budgetRedemptions: mockEmptyBudgetRedemptions,
fetchBudgetRedemptions: jest.fn(),
});
useEnterpriseGroupLearners.mockReturnValue({
data: {
count: 1,
currentPage: 1,
next: null,
numPages: 1,
results: {
enterpriseGroupMembershipUuid: 'cde2e374-032f-4c08-8c0d-bf3205fa7c7e',
learnerId: 4382,
memberDetails: { userEmail: '[email protected]', userName: 'duke silver' },
},
},
},
});
useEnterpriseGroupMembersTableData.mockReturnValue({
isLoading: false,
enterpriseGroupMembersTableData: {
itemCount: 5,
pageCount: 1,
results: [{
memberDetails: { userEmail: '[email protected]', userName: 'duke silver' },
status: 'pending',
recentAction: 'Pending: April 02, 2024',
enrollmentCount: 0,
}, {
memberDetails: { userEmail: '[email protected]', userName: 'bobby newport' },
status: 'removed',
recentAction: 'Removed: April 02, 2024',
enrollmentCount: 0,
}, {
memberDetails: { userEmail: '[email protected]', userName: 'ann perkins' },
status: 'accepted',
recentAction: 'Accepted: April 02, 2024',
enrollmentCount: 0,
}, {
memberDetails: { userEmail: '[email protected]', userName: 'andy dwyer' },
status: 'internal_api_error',
recentAction: 'Errored: April 01, 2024',
enrollmentCount: 0,
}, {
memberDetails: { userEmail: '[email protected]', userName: 'donna meagle' },
status: 'email_error',
recentAction: 'Errored: April 01, 2024',
enrollmentCount: 0,
}],
},
fetchEnterpriseGroupMembersTableData: jest.fn(),
});
renderWithRouter(<BudgetDetailPageWrapper initialState={initialState} />);
await waitFor(() => expect(screen.queryByText('[email protected]')).toBeInTheDocument());
userEvent.click(screen.getByText('Waiting for member'));
await waitFor(() => expect(screen.queryByText('Waiting for [email protected]')).toBeInTheDocument());
screen.getByText('This member must accept their invitation to browse this budget\'s catalog and enroll using their '
+ 'member permissions by logging in or creating an account within 90 days.');
// click again to close it out
userEvent.click(screen.getByText('Waiting for member'));

userEvent.click(screen.getByText('Accepted'));
await waitFor(() => expect(screen.queryByText('Invitation accepted')).toBeInTheDocument());
screen.getByText('This member has successfully accepted the member invitation and can '
+ 'now browse this budget\'s catalog and enroll using their member permissions.');
userEvent.click(screen.getByText('Accepted'));

userEvent.click(screen.getByText('Removed'));
await waitFor(() => expect(screen.queryByText('Member removed')).toBeInTheDocument());
screen.getByText('This member has been successfully removed and can not browse this budget\'s '
+ 'catalog and enroll using their member permissions.');

userEvent.click(screen.getByText('Failed: System'));
await waitFor(() => expect(screen.queryByText('Something went wrong behind the scenes.')).toBeInTheDocument());

userEvent.click(screen.getByText('Failed: Bad email'));
await waitFor(() => expect(screen.queryByText('This member invitation failed because a notification to [email protected] '
+ 'could not be sent.')).toBeInTheDocument());
});
});
useEnterpriseGroupMembersTableData.mockReturnValue({
isLoading: false,
enterpriseGroupMembersTableData: {
itemCount: 5,
pageCount: 1,
results: [{
memberDetails: { userEmail: '[email protected]', userName: 'duke silver' },
status: 'pending',
recentAction: 'Pending: April 02, 2024',
enrollmentCount: 0,
}, {
memberDetails: { userEmail: '[email protected]', userName: 'bobby newport' },
status: 'removed',
recentAction: 'Removed: April 02, 2024',
enrollmentCount: 0,
}, {
memberDetails: { userEmail: '[email protected]', userName: 'ann perkins' },
status: 'accepted',
recentAction: 'Accepted: April 02, 2024',
enrollmentCount: 0,
}, {
memberDetails: { userEmail: '[email protected]', userName: 'andy dwyer' },
status: 'internal_api_error',
recentAction: 'Errored: April 01, 2024',
enrollmentCount: 0,
}, {
memberDetails: { userEmail: '[email protected]', userName: 'donna meagle' },
status: 'email_error',
recentAction: 'Errored: April 01, 2024',
enrollmentCount: 0,
}],
},
fetchEnterpriseGroupMembersTableData: jest.fn(),
});
renderWithRouter(<BudgetDetailPageWrapper initialState={initialState} />);
await waitFor(() => expect(screen.queryByText('[email protected]')).toBeInTheDocument());
userEvent.click(screen.getByText('Waiting for member'));
await waitFor(() => expect(screen.queryByText('Waiting for [email protected]')).toBeInTheDocument());
screen.getByText('This member must accept their invitation to browse this budget\'s catalog and enroll using their '
+ 'member permissions by logging in or creating an account within 90 days.');
// click again to close it out
userEvent.click(screen.getByText('Waiting for member'));

userEvent.click(screen.getByText('Accepted'));
await waitFor(() => expect(screen.queryByText('Invitation accepted')).toBeInTheDocument());
screen.getByText('This member has successfully accepted the member invitation and can '
+ 'now browse this budget\'s catalog and enroll using their member permissions.');
userEvent.click(screen.getByText('Accepted'));

userEvent.click(screen.getByText('Removed'));
await waitFor(() => expect(screen.queryByText('Member removed')).toBeInTheDocument());
screen.getByText('This member has been successfully removed and can not browse this budget\'s '
+ 'catalog and enroll using their member permissions.');

userEvent.click(screen.getByText('Failed: System'));
await waitFor(() => expect(screen.queryByText('Something went wrong behind the scenes.')).toBeInTheDocument());

userEvent.click(screen.getByText('Failed: Bad email'));
await waitFor(() => expect(screen.queryByText('This member invitation failed because a notification to [email protected] '
+ 'could not be sent.')).toBeInTheDocument());
},
// Increase the timeout from the default (5000 ms) to 9000 ms to give
// github actions a little more time to run this heavy/flaky test.
// FIXME: Longer term, we should break up this test so that there are not
// so many sequential click + waitFor.
9000,
);
it('download learner flow for multiple selected pages of users', async () => {
// Setup
const initialState = {
Expand Down

0 comments on commit 9eda274

Please sign in to comment.