Commit 7f2a32c1 authored by Paul Slaughter's avatar Paul Slaughter

Move store initialization out of job_app component

**Why?**
This was causing things to be very difficult to test
at the component level
parent aac4a1e4
...@@ -8,7 +8,6 @@ import { polyfillSticky } from '~/lib/utils/sticky'; ...@@ -8,7 +8,6 @@ import { polyfillSticky } from '~/lib/utils/sticky';
import CiHeader from '~/vue_shared/components/header_ci_component.vue'; import CiHeader from '~/vue_shared/components/header_ci_component.vue';
import Callout from '~/vue_shared/components/callout.vue'; import Callout from '~/vue_shared/components/callout.vue';
import Icon from '~/vue_shared/components/icon.vue'; import Icon from '~/vue_shared/components/icon.vue';
import createStore from '../store';
import EmptyState from './empty_state.vue'; import EmptyState from './empty_state.vue';
import EnvironmentsBlock from './environments_block.vue'; import EnvironmentsBlock from './environments_block.vue';
import ErasedBlock from './erased_block.vue'; import ErasedBlock from './erased_block.vue';
...@@ -22,7 +21,6 @@ import { isNewJobLogActive } from '../store/utils'; ...@@ -22,7 +21,6 @@ import { isNewJobLogActive } from '../store/utils';
export default { export default {
name: 'JobPageApp', name: 'JobPageApp',
store: createStore(),
components: { components: {
CiHeader, CiHeader,
Callout, Callout,
...@@ -60,27 +58,15 @@ export default { ...@@ -60,27 +58,15 @@ export default {
required: false, required: false,
default: null, default: null,
}, },
endpoint: {
type: String,
required: true,
},
terminalPath: { terminalPath: {
type: String, type: String,
required: false, required: false,
default: null, default: null,
}, },
pagePath: {
type: String,
required: true,
},
projectPath: { projectPath: {
type: String, type: String,
required: true, required: true,
}, },
logState: {
type: String,
required: true,
},
subscriptionsMoreMinutesUrl: { subscriptionsMoreMinutesUrl: {
type: String, type: String,
required: false, required: false,
...@@ -161,15 +147,6 @@ export default { ...@@ -161,15 +147,6 @@ export default {
created() { created() {
this.throttled = _.throttle(this.toggleScrollButtons, 100); this.throttled = _.throttle(this.toggleScrollButtons, 100);
this.setJobEndpoint(this.endpoint);
this.setTraceOptions({
logState: this.logState,
pagePath: this.pagePath,
});
this.fetchJob();
this.fetchTrace();
window.addEventListener('resize', this.onResize); window.addEventListener('resize', this.onResize);
window.addEventListener('scroll', this.updateScroll); window.addEventListener('scroll', this.updateScroll);
}, },
...@@ -184,14 +161,10 @@ export default { ...@@ -184,14 +161,10 @@ export default {
}, },
methods: { methods: {
...mapActions([ ...mapActions([
'setJobEndpoint',
'setTraceOptions',
'fetchJob',
'fetchJobsForStage', 'fetchJobsForStage',
'hideSidebar', 'hideSidebar',
'showSidebar', 'showSidebar',
'toggleSidebar', 'toggleSidebar',
'fetchTrace',
'scrollBottom', 'scrollBottom',
'scrollTop', 'scrollTop',
'stopPollingTrace', 'stopPollingTrace',
...@@ -227,7 +200,7 @@ export default { ...@@ -227,7 +200,7 @@ export default {
<div> <div>
<gl-loading-icon <gl-loading-icon
v-if="isLoading" v-if="isLoading"
:size="2" size="lg"
class="js-job-loading qa-loading-animation prepend-top-20" class="js-job-loading qa-loading-animation prepend-top-20"
/> />
......
import Vue from 'vue'; import Vue from 'vue';
import JobApp from './components/job_app.vue'; import JobApp from './components/job_app.vue';
import createStore from './store';
export default () => { export default () => {
const element = document.getElementById('js-job-vue-app'); const element = document.getElementById('js-job-vue-app');
const store = createStore();
// Let's start initializing the store (i.e. fetching data) right away
store.dispatch('init', element.dataset);
return new Vue({ return new Vue({
el: element, el: element,
store,
components: { components: {
JobApp, JobApp,
}, },
......
...@@ -14,6 +14,16 @@ import { ...@@ -14,6 +14,16 @@ import {
scrollUp, scrollUp,
} from '~/lib/utils/scroll_utils'; } from '~/lib/utils/scroll_utils';
export const init = ({ dispatch }, { endpoint, logState, pagePath }) => {
dispatch('setJobEndpoint', endpoint);
dispatch('setTraceOptions', {
logState,
pagePath,
});
return Promise.all([dispatch('fetchJob'), dispatch('fetchTrace')]);
};
export const setJobEndpoint = ({ commit }, endpoint) => commit(types.SET_JOB_ENDPOINT, endpoint); export const setJobEndpoint = ({ commit }, endpoint) => commit(types.SET_JOB_ENDPOINT, endpoint);
export const setTraceOptions = ({ commit }, options) => commit(types.SET_TRACE_OPTIONS, options); export const setTraceOptions = ({ commit }, options) => commit(types.SET_TRACE_OPTIONS, options);
......
...@@ -4,7 +4,7 @@ import { mountComponentWithStore } from 'spec/helpers/vue_mount_component_helper ...@@ -4,7 +4,7 @@ import { mountComponentWithStore } from 'spec/helpers/vue_mount_component_helper
import { waitForMutation } from 'spec/helpers/vue_test_utils_helper'; import { waitForMutation } from 'spec/helpers/vue_test_utils_helper';
import axios from '~/lib/utils/axios_utils'; import axios from '~/lib/utils/axios_utils';
import jobApp from '~/jobs/components/job_app.vue'; import jobApp from '~/jobs/components/job_app.vue';
import createStore, { initStore } from '~/jobs/store'; import createStore from '~/jobs/store';
import * as types from '~/jobs/store/mutation_types'; import * as types from '~/jobs/store/mutation_types';
import job from '../mock_data'; import job from '../mock_data';
...@@ -15,7 +15,7 @@ describe('Job App ', () => { ...@@ -15,7 +15,7 @@ describe('Job App ', () => {
let vm; let vm;
let mock; let mock;
const settings = { const initSettings = {
endpoint: `${gl.TEST_HOST}jobs/123.json`, endpoint: `${gl.TEST_HOST}jobs/123.json`,
pagePath: `${gl.TEST_HOST}jobs/123`, pagePath: `${gl.TEST_HOST}jobs/123`,
logState: logState:
...@@ -34,10 +34,10 @@ describe('Job App ', () => { ...@@ -34,10 +34,10 @@ describe('Job App ', () => {
const waitForJobReceived = () => waitForMutation(store, types.RECEIVE_JOB_SUCCESS); const waitForJobReceived = () => waitForMutation(store, types.RECEIVE_JOB_SUCCESS);
const setupAndMount = ({ jobData = {}, traceData = {} } = {}) => { const setupAndMount = ({ jobData = {}, traceData = {} } = {}) => {
mock.onGet(settings.endpoint).replyOnce(200, { ...job, ...jobData }); mock.onGet(initSettings.endpoint).replyOnce(200, { ...job, ...jobData });
mock.onGet(`${settings.pagePath}/trace.json`).reply(200, traceData); mock.onGet(`${initSettings.pagePath}/trace.json`).reply(200, traceData);
initStore(store, settings); store.dispatch('init', initSettings);
vm = mountComponentWithStore(Component, { props, store }); vm = mountComponentWithStore(Component, { props, store });
......
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