Commit 725810c9 authored by Paul Slaughter's avatar Paul Slaughter

Refactor EE IDE store extend into plugins

**Why?**
The [Web IDE file mirroring][1] will need to register a plugin,
similar to the terminal plugin.

Since plugins are a [native Vuex thing][2], it is helpful keeping
the consistent terminology and interface (even though we
aren't using the `plugins` property yet).

**References:**
[1]: https://gitlab.com/gitlab-org/gitlab-ee/issues/5276
[2]: https://vuex.vuejs.org/guide/plugins.html
parent 86556b1e
import * as mutationTypes from '~/ide/stores/mutation_types';
import terminalModule from './modules/terminal';
import terminal from './plugins/terminal';
function getPathsFromData(el) {
return {
webTerminalSvgPath: el.dataset.eeWebTerminalSvgPath,
webTerminalHelpPath: el.dataset.eeWebTerminalHelpPath,
webTerminalConfigHelpPath: el.dataset.eeWebTerminalConfigHelpPath,
webTerminalRunnersHelpPath: el.dataset.eeWebTerminalRunnersHelpPath,
};
}
const plugins = [terminal];
export default (store, el) => {
store.registerModule('terminal', terminalModule());
store.dispatch('terminal/setPaths', getPathsFromData(el));
store.subscribe(({ type }) => {
if (type === mutationTypes.SET_BRANCH_WORKING_REFERENCE) {
store.dispatch('terminal/init');
}
});
// plugins is actually an array of plugin factories, so we have to create first then call
plugins.forEach(plugin => plugin(el)(store));
return store;
};
import * as mutationTypes from '~/ide/stores/mutation_types';
import terminalModule from '../modules/terminal';
function getPathsFromData(el) {
return {
webTerminalSvgPath: el.dataset.eeWebTerminalSvgPath,
webTerminalHelpPath: el.dataset.eeWebTerminalHelpPath,
webTerminalConfigHelpPath: el.dataset.eeWebTerminalConfigHelpPath,
webTerminalRunnersHelpPath: el.dataset.eeWebTerminalRunnersHelpPath,
};
}
export default function createTerminalPlugin(el) {
return store => {
store.registerModule('terminal', terminalModule());
store.dispatch('terminal/setPaths', getPathsFromData(el));
store.subscribe(({ type }) => {
if (type === mutationTypes.SET_BRANCH_WORKING_REFERENCE) {
store.dispatch('terminal/init');
}
});
};
}
import extendStore from 'ee/ide/stores/extend';
import terminalPlugin from 'ee/ide/stores/plugins/terminal';
jest.mock('ee/ide/stores/plugins/terminal', () => {
const plugin = jest.fn();
return jest.fn(() => plugin);
});
describe('ee/ide/stores/extend', () => {
let store;
let el;
beforeEach(() => {
store = {};
el = {};
extendStore(store, el);
});
it('creates terminal plugin', () => {
expect(terminalPlugin).toHaveBeenCalledWith(el);
});
it('calls terminal plugin', () => {
expect(terminalPlugin()).toHaveBeenCalledWith(store);
});
});
import { createLocalVue } from '@vue/test-utils';
import Vuex from 'vuex';
import { SET_BRANCH_WORKING_REFERENCE } from '~/ide/stores/mutation_types';
import { TEST_HOST } from 'spec/test_constants';
import { TEST_HOST } from 'helpers/test_constants';
import terminalModule from 'ee/ide/stores/modules/terminal';
import extendStore from 'ee/ide/stores/extend';
import createTerminalPlugin from 'ee/ide/stores/plugins/terminal';
const TEST_DATASET = {
eeWebTerminalSvgPath: `${TEST_HOST}/web/terminal/svg`,
......@@ -27,10 +27,12 @@ describe('ee/ide/stores/extend', () => {
},
});
spyOn(store, 'registerModule');
spyOn(store, 'dispatch');
jest.spyOn(store, 'registerModule').mockImplementation();
jest.spyOn(store, 'dispatch').mockImplementation();
store = extendStore(store, el);
const plugin = createTerminalPlugin(el);
plugin(store);
});
it('registers terminal module', () => {
......@@ -47,7 +49,7 @@ describe('ee/ide/stores/extend', () => {
});
it(`dispatches terminal/init on ${SET_BRANCH_WORKING_REFERENCE}`, () => {
store.dispatch.calls.reset();
store.dispatch.mockReset();
store.commit(SET_BRANCH_WORKING_REFERENCE);
......
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