mirror of
https://github.com/grafana/grafana.git
synced 2025-02-25 18:55:37 -06:00
* more friday any/type assertion improvements * Apply suggestions from code review Co-authored-by: Marcus Andersson <marcus.andersson@grafana.com> * Update public/app/angular/promiseToDigest.test.ts Co-authored-by: Marcus Andersson <marcus.andersson@grafana.com> Co-authored-by: Marcus Andersson <marcus.andersson@grafana.com>
101 lines
3.4 KiB
TypeScript
101 lines
3.4 KiB
TypeScript
import { fireEvent, render, screen, waitFor } from '@testing-library/react';
|
|
import userEvent from '@testing-library/user-event';
|
|
import React from 'react';
|
|
|
|
import * as runtimeMock from '@grafana/runtime';
|
|
|
|
import { LoginPage } from './LoginPage';
|
|
|
|
const postMock = jest.fn();
|
|
jest.mock('@grafana/runtime', () => ({
|
|
__esModule: true,
|
|
getBackendSrv: () => ({
|
|
post: postMock,
|
|
}),
|
|
config: {
|
|
loginError: false,
|
|
buildInfo: {
|
|
version: 'v1.0',
|
|
commit: '1',
|
|
env: 'production',
|
|
edition: 'Open Source',
|
|
},
|
|
licenseInfo: {
|
|
stateInfo: '',
|
|
licenseUrl: '',
|
|
},
|
|
appSubUrl: '',
|
|
verifyEmailEnabled: false,
|
|
},
|
|
}));
|
|
|
|
describe('Login Page', () => {
|
|
beforeEach(() => {
|
|
jest.resetAllMocks();
|
|
});
|
|
|
|
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 userEvent.type(screen.getByRole('textbox', { name: 'Username input field' }), 'admin');
|
|
await waitFor(() => 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 userEvent.type(screen.getByLabelText('Password input field'), 'admin');
|
|
await waitFor(() => 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('/');
|
|
});
|
|
it('renders social logins correctly', () => {
|
|
runtimeMock.config.oauth = {
|
|
okta: {
|
|
name: 'Okta Test',
|
|
icon: 'signin',
|
|
},
|
|
};
|
|
|
|
render(<LoginPage />);
|
|
|
|
expect(screen.getByRole('link', { name: 'Sign in with Okta Test' })).toBeInTheDocument();
|
|
});
|
|
});
|