Commit d2e3ad54 authored by Kushal Pandya's avatar Kushal Pandya

Merge branch 'xanf-vtu-v1-dashboards' into 'master'

Upgrading VTU to v1: Remove deprecate `methods` from `environments_dashboard`

See merge request gitlab-org/gitlab!50499
parents 5e1a58d1 e5381c71
...@@ -6,9 +6,10 @@ import * as actions from './actions'; ...@@ -6,9 +6,10 @@ import * as actions from './actions';
Vue.use(Vuex); Vue.use(Vuex);
export default () => export const getStoreConfig = () => ({
new Vuex.Store({
state, state,
mutations, mutations,
actions, actions,
}); });
export default () => new Vuex.Store(getStoreConfig());
import { GlButton, GlEmptyState, GlModal, GlSprintf, GlLink, GlPagination } from '@gitlab/ui'; import { GlButton, GlEmptyState, GlModal, GlSprintf, GlLink, GlPagination } from '@gitlab/ui';
import { shallowMount, createLocalVue } from '@vue/test-utils'; import { shallowMount } from '@vue/test-utils';
import Vue, { nextTick } from 'vue';
import Vuex from 'vuex'; import Vuex from 'vuex';
import component from 'ee/environments_dashboard/components/dashboard/dashboard.vue'; import component from 'ee/environments_dashboard/components/dashboard/dashboard.vue';
import Environment from 'ee/environments_dashboard/components/dashboard/environment.vue'; import Environment from 'ee/environments_dashboard/components/dashboard/environment.vue';
import ProjectHeader from 'ee/environments_dashboard/components/dashboard/project_header.vue'; import ProjectHeader from 'ee/environments_dashboard/components/dashboard/project_header.vue';
import createStore from 'ee/vue_shared/dashboards/store/index'; import { getStoreConfig } from 'ee/vue_shared/dashboards/store/index';
import state from 'ee/vue_shared/dashboards/store/state'; import state from 'ee/vue_shared/dashboards/store/state';
import { trimText } from 'helpers/text_helper'; import { trimText } from 'helpers/text_helper';
import ProjectSelector from '~/vue_shared/components/project_selector/project_selector.vue'; import ProjectSelector from '~/vue_shared/components/project_selector/project_selector.vue';
import environment from './mock_environment.json'; import environment from './mock_environment.json';
const localVue = createLocalVue(); Vue.use(Vuex);
localVue.use(Vuex);
describe('dashboard', () => { describe('dashboard', () => {
let actionSpies; let actionSpies;
const store = createStore();
let wrapper; let wrapper;
let propsData; let propsData;
let store;
beforeEach(() => { beforeEach(() => {
actionSpies = { actionSpies = {
...@@ -31,6 +31,16 @@ describe('dashboard', () => { ...@@ -31,6 +31,16 @@ describe('dashboard', () => {
fetchNextPage: jest.fn(), fetchNextPage: jest.fn(),
fetchProjects: jest.fn(), fetchProjects: jest.fn(),
}; };
const { actions, ...storeConfig } = getStoreConfig();
store = new Vuex.Store({
...storeConfig,
actions: {
...actions,
...actionSpies,
},
});
propsData = { propsData = {
addPath: 'mock-addPath', addPath: 'mock-addPath',
listPath: 'mock-listPath', listPath: 'mock-listPath',
...@@ -41,11 +51,7 @@ describe('dashboard', () => { ...@@ -41,11 +51,7 @@ describe('dashboard', () => {
wrapper = shallowMount(component, { wrapper = shallowMount(component, {
propsData, propsData,
localVue,
store, store,
methods: {
...actionSpies,
},
stubs: { GlSprintf }, stubs: { GlSprintf },
}); });
}); });
...@@ -143,7 +149,7 @@ describe('dashboard', () => { ...@@ -143,7 +149,7 @@ describe('dashboard', () => {
describe('project selector modal', () => { describe('project selector modal', () => {
beforeEach(() => { beforeEach(() => {
wrapper.find(GlButton).trigger('click'); wrapper.find(GlButton).trigger('click');
return wrapper.vm.$nextTick(); return nextTick();
}); });
it('should fire the add projects action on ok', () => { it('should fire the add projects action on ok', () => {
...@@ -158,7 +164,7 @@ describe('dashboard', () => { ...@@ -158,7 +164,7 @@ describe('dashboard', () => {
it('should set the search query when searching', () => { it('should set the search query when searching', () => {
wrapper.find(ProjectSelector).vm.$emit('searched', 'test'); wrapper.find(ProjectSelector).vm.$emit('searched', 'test');
expect(actionSpies.setSearchQuery).toHaveBeenCalledWith('test'); expect(actionSpies.setSearchQuery).toHaveBeenCalledWith(expect.any(Object), 'test');
}); });
it('should fetch query results when searching', () => { it('should fetch query results when searching', () => {
...@@ -168,7 +174,10 @@ describe('dashboard', () => { ...@@ -168,7 +174,10 @@ describe('dashboard', () => {
it('should toggle a project when clicked', () => { it('should toggle a project when clicked', () => {
wrapper.find(ProjectSelector).vm.$emit('projectClicked', { name: 'test', id: 1 }); wrapper.find(ProjectSelector).vm.$emit('projectClicked', { name: 'test', id: 1 });
expect(actionSpies.toggleSelectedProject).toHaveBeenCalledWith({ name: 'test', id: 1 }); expect(actionSpies.toggleSelectedProject).toHaveBeenCalledWith(expect.any(Object), {
name: 'test',
id: 1,
});
}); });
it('should fetch the next page when bottom is reached', () => { it('should fetch the next page when bottom is reached', () => {
...@@ -176,14 +185,13 @@ describe('dashboard', () => { ...@@ -176,14 +185,13 @@ describe('dashboard', () => {
expect(actionSpies.fetchNextPage).toHaveBeenCalled(); expect(actionSpies.fetchNextPage).toHaveBeenCalled();
}); });
it('should get the page info from the state', () => { it('should get the page info from the state', async () => {
store.state.pageInfo = { totalResults: 100 }; store.state.pageInfo = { totalResults: 100 };
return wrapper.vm.$nextTick().then(() => { await nextTick();
expect(wrapper.find(ProjectSelector).props('totalResults')).toBe(100); expect(wrapper.find(ProjectSelector).props('totalResults')).toBe(100);
}); });
}); });
});
describe('pagination', () => { describe('pagination', () => {
const testPagination = async ({ totalPages }) => { const testPagination = async ({ totalPages }) => {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment