storj/web/satellite/tests/unit/ignore/common/HeaderArea.spec.ts
Vitalii fc3d31e732 web/satellite: use app pinia module instead of vuex module
Use new pinia module instead of old vuex module.
Removed 'do you want to leave object browser with ongoing uploads?' feature for now because it doesn't make sense with project level passphrase

Change-Id: I2249ee9a497d3fa7c59b583849e70366491c3eeb
2023-04-12 17:08:50 +00:00

121 lines
4.4 KiB
TypeScript

// Copyright (C) 2019 Storj Labs, Inc.
// See LICENSE for copying information.
import Vuex from 'vuex';
import { createLocalVue, shallowMount } from '@vue/test-utils';
import { makeNotificationsModule } from '@/store/modules/notifications';
import { ProjectMemberHeaderState } from '@/types/projectMembers';
import HeaderArea from '@/components/team/HeaderArea.vue';
const localVue = createLocalVue();
const notificationsModule = makeNotificationsModule();
localVue.use(Vuex);
const store = new Vuex.Store({ modules: { notificationsModule } });
describe('Team HeaderArea', () => {
it('renders correctly', () => {
const wrapper = shallowMount<HeaderArea>(HeaderArea, {
store,
localVue,
});
const addNewTemMemberPopup = wrapper.findAll('adduserpopup-stub');
expect(wrapper).toMatchSnapshot();
expect(addNewTemMemberPopup.length).toBe(0);
expect(wrapper.findAll('.header-default-state').length).toBe(1);
expect(wrapper.findAll('.blur-content').length).toBe(0);
expect(wrapper.findAll('.blur-search').length).toBe(0);
expect(wrapper.vm.isDeleteClicked).toBe(false);
});
it('renders correctly with opened Add team member popup', () => {
const wrapper = shallowMount<HeaderArea>(HeaderArea, {
store,
localVue,
});
expect(wrapper).toMatchSnapshot();
expect(wrapper.findAll('.header-default-state').length).toBe(1);
expect(wrapper.vm.isDeleteClicked).toBe(false);
expect(wrapper.findAll('.blur-content').length).toBe(0);
expect(wrapper.findAll('.blur-search').length).toBe(0);
});
it('renders correctly with selected users', () => {
const selectedUsersCount = 2;
const wrapper = shallowMount<HeaderArea>(HeaderArea, {
store,
localVue,
propsData: {
selectedProjectMembersCount: selectedUsersCount,
headerState: ProjectMemberHeaderState.ON_SELECT,
},
});
expect(wrapper.findAll('.header-selected-members').length).toBe(1);
expect(wrapper).toMatchSnapshot();
expect(wrapper.vm.selectedProjectMembersCount).toBe(selectedUsersCount);
expect(wrapper.vm.isDeleteClicked).toBe(false);
expect(wrapper.findAll('.blur-content').length).toBe(0);
expect(wrapper.findAll('.blur-search').length).toBe(0);
});
it('renders correctly with 2 selected users and delete clicked once', async () => {
const selectedUsersCount = 2;
const wrapper = shallowMount<HeaderArea>(HeaderArea, {
store,
localVue,
propsData: {
selectedProjectMembersCount: selectedUsersCount,
headerState: ProjectMemberHeaderState.ON_SELECT,
},
});
await wrapper.vm.onFirstDeleteClick();
expect(wrapper).toMatchSnapshot();
expect(wrapper.vm.selectedProjectMembersCount).toBe(selectedUsersCount);
expect(wrapper.vm.userCountTitle).toBe('users');
expect(wrapper.vm.isDeleteClicked).toBe(true);
expect(wrapper.findAll('.blur-content').length).toBe(1);
expect(wrapper.findAll('.blur-search').length).toBe(1);
const expectedSectionRendered = wrapper.find('.header-after-delete-click');
expect(expectedSectionRendered.text()).toBe(`Are you sure you want to delete ${selectedUsersCount} users?`);
});
it('renders correctly with 1 selected user and delete clicked once', async () => {
const selectedUsersCount = 1;
const wrapper = shallowMount<HeaderArea>(HeaderArea, {
store,
localVue,
propsData: {
selectedProjectMembersCount: selectedUsersCount,
headerState: ProjectMemberHeaderState.ON_SELECT,
},
});
await wrapper.vm.onFirstDeleteClick();
expect(wrapper).toMatchSnapshot();
expect(wrapper.vm.selectedProjectMembersCount).toBe(selectedUsersCount);
expect(wrapper.vm.userCountTitle).toBe('user');
expect(wrapper.vm.isDeleteClicked).toBe(true);
expect(wrapper.findAll('.blur-content').length).toBe(1);
expect(wrapper.findAll('.blur-search').length).toBe(1);
const expectedSectionRendered = wrapper.find('.header-after-delete-click');
expect(expectedSectionRendered.text()).toBe(`Are you sure you want to delete ${selectedUsersCount} user?`);
});
});