LoginPage: add tests (#36226)

* added tests for LoginPage component

* addressed review changes and removed snapshot
This commit is contained in:
Tharun Rajendran 2021-06-29 19:38:50 +05:30 committed by GitHub
parent 603d1cddb8
commit c3e26657e9
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 94 additions and 3 deletions

View File

@ -115,12 +115,12 @@ export class LoginCtrl extends PureComponent<Props, State> {
// Use window.location.href to force page reload
if (this.result.redirectUrl) {
if (config.appSubUrl !== '' && !this.result.redirectUrl.startsWith(config.appSubUrl)) {
window.location.href = config.appSubUrl + this.result.redirectUrl;
window.location.assign(config.appSubUrl + this.result.redirectUrl);
} else {
window.location.href = this.result.redirectUrl;
window.location.assign(this.result.redirectUrl);
}
} else {
window.location.href = config.appSubUrl + '/';
window.location.assign(config.appSubUrl + '/');
}
};

View File

@ -0,0 +1,91 @@
import React from 'react';
import { act, fireEvent, render, screen, waitFor } from '@testing-library/react';
import userEvent from '@testing-library/user-event';
import { LoginPage } from './LoginPage';
const postMock = jest.fn();
jest.mock('@grafana/runtime', () => ({
getBackendSrv: () => ({
post: postMock,
}),
}));
jest.mock('app/core/config', () => {
return {
loginError: false,
buildInfo: {
version: 'v1.0',
commit: '1',
env: 'production',
edition: 'Open Source',
isEnterprise: false,
},
licenseInfo: {
stateInfo: '',
licenseUrl: '',
},
appSubUrl: '',
getConfig: () => ({
appSubUrl: '',
verifyEmailEnabled: false,
}),
};
});
describe('Login Page', () => {
it('renders correctly', () => {
render(<LoginPage />);
expect(screen.getByRole('heading', { name: 'Welcome to Grafana' })).toBeInTheDocument();
expect(screen.getByRole('textbox', { name: 'Username input field' })).toBeInTheDocument();
expect(screen.getByLabelText('Password input field')).toBeInTheDocument();
expect(screen.getByRole('button', { name: 'Login button' })).toBeInTheDocument();
expect(screen.getByRole('link', { name: 'Forgot your password?' })).toBeInTheDocument();
expect(screen.getByRole('link', { name: 'Forgot your password?' })).toHaveAttribute(
'href',
'/user/password/send-reset-email'
);
expect(screen.getByRole('link', { name: 'Sign up' })).toBeInTheDocument();
expect(screen.getByRole('link', { name: 'Sign up' })).toHaveAttribute('href', '/signup');
});
it('should pass validation checks for username field', async () => {
render(<LoginPage />);
fireEvent.click(screen.getByRole('button', { name: 'Login button' }));
expect(await screen.findByText('Email or username is required')).toBeInTheDocument();
await act(async () => {
await userEvent.type(screen.getByRole('textbox', { name: 'Username input field' }), 'admin');
expect(screen.queryByText('Email or username is required')).not.toBeInTheDocument();
});
});
it('should pass validation checks for password field', async () => {
render(<LoginPage />);
fireEvent.click(screen.getByRole('button', { name: 'Login button' }));
expect(await screen.findByText('Password is required')).toBeInTheDocument();
await act(async () => {
await userEvent.type(screen.getByLabelText('Password input field'), 'admin');
expect(screen.queryByText('Password is required')).not.toBeInTheDocument();
});
});
it('should navigate to default url if credentials is valid', async () => {
Object.defineProperty(window, 'location', {
value: {
assign: jest.fn(),
},
});
postMock.mockResolvedValueOnce({ message: 'Logged in' });
render(<LoginPage />);
await userEvent.type(screen.getByLabelText('Username input field'), 'admin');
await userEvent.type(screen.getByLabelText('Password input field'), 'test');
fireEvent.click(screen.getByLabelText('Login button'));
await waitFor(() => expect(postMock).toHaveBeenCalledWith('/login', { password: 'test', user: 'admin' }));
expect(window.location.assign).toHaveBeenCalledWith('/');
});
});