Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

test: SecuredRouteForUser component 100% Test Coverage and fixed uncovered lines #1048

Merged
Original file line number Diff line number Diff line change
@@ -0,0 +1,53 @@
import React from 'react';
import { MemoryRouter, Redirect, Route } from 'react-router-dom';
import { render, screen, waitFor } from '@testing-library/react';
import SecuredRouteForUser from './SecuredRouteForUser';

describe('SecuredRouteForUser', () => {
test('renders the route when the user is logged in', () => {
// Set the 'IsLoggedIn' value to 'TRUE' in localStorage to simulate a logged-in user
localStorage.setItem('IsLoggedIn', 'TRUE');

const { container } = render(
<MemoryRouter initialEntries={['/user/organizations']}>
<SecuredRouteForUser
path="/user/organizations"
component={() => (
<div data-testid="organizations-content">
Organizations Component
</div>
)}
/>
</MemoryRouter>
);

expect(screen.getByTestId('organizations-content')).toBeInTheDocument();
});

test('redirects to /user when the user is not logged in', async () => {
// Set the user as not logged in in local storage
localStorage.setItem('IsLoggedIn', 'FALSE');

const { container } = render(
<MemoryRouter initialEntries={['/secured']}>
<Route
path="/secured"
exact
render={() => (
<SecuredRouteForUser>
<div data-testid="secured-content">Secured Content</div>
</SecuredRouteForUser>
)}
/>
</MemoryRouter>
);

// Ensure that the redirect to / occurred
// waitFor(() => {
// expect(window.location.pathname).toBe('/user');
// }
await waitFor(() => {
expect(window.location.pathname).toBe('/');
});
});
});
Loading