gitlab-ce/spec/frontend/profile/components/overview_tab_spec.js

140 lines
4.1 KiB
JavaScript

import { GlLoadingIcon, GlTab, GlLink } from '@gitlab/ui';
import AxiosMockAdapter from 'axios-mock-adapter';
import projects from 'test_fixtures/api/users/projects/get.json';
import events from 'test_fixtures/controller/users/activity.json';
import { s__ } from '~/locale';
import OverviewTab from '~/profile/components/overview_tab.vue';
import { shallowMountExtended } from 'helpers/vue_test_utils_helper';
import ActivityCalendar from '~/profile/components/activity_calendar.vue';
import ProjectsList from '~/vue_shared/components/projects_list/projects_list.vue';
import { convertObjectPropsToCamelCase } from '~/lib/utils/common_utils';
import axios from '~/lib/utils/axios_utils';
import ContributionEvents from '~/contribution_events/components/contribution_events.vue';
import { createAlert } from '~/alert';
import waitForPromises from 'helpers/wait_for_promises';
jest.mock('~/alert');
describe('OverviewTab', () => {
let wrapper;
let axiosMock;
const defaultPropsData = {
personalProjects: convertObjectPropsToCamelCase(projects, { deep: true }),
personalProjectsLoading: false,
};
const defaultProvide = { userActivityPath: '/users/root/activity.json' };
const createComponent = ({ propsData = {} } = {}) => {
wrapper = shallowMountExtended(OverviewTab, {
propsData: { ...defaultPropsData, ...propsData },
provide: defaultProvide,
});
};
beforeEach(() => {
axiosMock = new AxiosMockAdapter(axios);
});
afterEach(() => {
axiosMock.restore();
});
it('renders `GlTab` and sets `title` prop', () => {
createComponent();
expect(wrapper.findComponent(GlTab).attributes('title')).toBe(s__('UserProfile|Overview'));
});
it('renders `ActivityCalendar` component', () => {
createComponent();
expect(wrapper.findComponent(ActivityCalendar).exists()).toBe(true);
});
it('renders personal projects section heading and `View all` link', () => {
createComponent();
expect(
wrapper.findByRole('heading', { name: OverviewTab.i18n.personalProjects }).exists(),
).toBe(true);
expect(wrapper.findComponent(GlLink).text()).toBe(OverviewTab.i18n.viewAll);
});
describe('when personal projects are loading', () => {
it('renders loading icon', () => {
createComponent({
propsData: {
personalProjects: [],
personalProjectsLoading: true,
},
});
expect(
wrapper.findByTestId('personal-projects-section').findComponent(GlLoadingIcon).exists(),
).toBe(true);
});
});
describe('when projects are done loading', () => {
it('renders `ProjectsList` component and passes `projects` prop', () => {
createComponent();
expect(
wrapper
.findByTestId('personal-projects-section')
.findComponent(ProjectsList)
.props('projects'),
).toMatchObject(defaultPropsData.personalProjects);
});
});
describe('when activity API request is loading', () => {
beforeEach(() => {
axiosMock.onGet(defaultProvide.userActivityPath).reply(200, events);
createComponent();
});
it('shows loading icon', () => {
expect(wrapper.findByTestId('activity-section').findComponent(GlLoadingIcon).exists()).toBe(
true,
);
});
});
describe('when activity API request is successful', () => {
beforeEach(() => {
axiosMock.onGet(defaultProvide.userActivityPath).reply(200, events);
createComponent();
});
it('renders `ContributionEvents` component', async () => {
await waitForPromises();
expect(wrapper.findComponent(ContributionEvents).props('events')).toEqual(events);
});
});
describe('when activity API request is not successful', () => {
beforeEach(() => {
axiosMock.onGet(defaultProvide.userActivityPath).networkError();
createComponent();
});
it('calls `createAlert`', async () => {
await waitForPromises();
expect(createAlert).toHaveBeenCalledWith({
message: OverviewTab.i18n.eventsErrorMessage,
error: new Error('Network Error'),
captureError: true,
});
});
});
});