Commit 20d0479c authored by Natalia Tepluhina's avatar Natalia Tepluhina

Merge branch '15398-connect-backend-helpers' into 'master'

Connect options helper in container expiration settings

See merge request gitlab-org/gitlab!22112
parents ac4ad52f 71e2f36d
<script> <script>
import { mapActions } from 'vuex'; import { mapActions, mapState } from 'vuex';
import { GlFormGroup, GlToggle, GlFormSelect, GlFormTextarea, GlButton } from '@gitlab/ui'; import { GlFormGroup, GlToggle, GlFormSelect, GlFormTextarea, GlButton, GlCard } from '@gitlab/ui';
import { s__, __, sprintf } from '~/locale'; import { s__, __, sprintf } from '~/locale';
import { NAME_REGEX_LENGTH } from '../constants'; import { NAME_REGEX_LENGTH } from '../constants';
import { mapComputed } from '~/vuex_shared/bindings'; import { mapComputed } from '~/vuex_shared/bindings';
...@@ -12,19 +12,25 @@ export default { ...@@ -12,19 +12,25 @@ export default {
GlFormSelect, GlFormSelect,
GlFormTextarea, GlFormTextarea,
GlButton, GlButton,
GlCard,
}, },
labelsConfig: { labelsConfig: {
cols: 3, cols: 3,
align: 'right', align: 'right',
}, },
computed: { computed: {
...mapComputed('settings', 'updateSettings', [ ...mapState(['formOptions']),
...mapComputed(
[
'enabled', 'enabled',
'cadence', { key: 'cadence', getter: 'getCadence' },
'older_than', { key: 'older_than', getter: 'getOlderThan' },
'keep_n', { key: 'keep_n', getter: 'getKeepN' },
'name_regex', 'name_regex',
]), ],
'updateSettings',
'settings',
),
policyEnabledText() { policyEnabledText() {
return this.enabled ? __('enabled') : __('disabled'); return this.enabled ? __('enabled') : __('disabled');
}, },
...@@ -66,12 +72,12 @@ export default { ...@@ -66,12 +72,12 @@ export default {
</script> </script>
<template> <template>
<div class="card">
<form ref="form-element" @submit.prevent="saveSettings" @reset.prevent="resetSettings"> <form ref="form-element" @submit.prevent="saveSettings" @reset.prevent="resetSettings">
<div class="card-header"> <gl-card>
<template #header>
{{ s__('ContainerRegistry|Tag expiration policy') }} {{ s__('ContainerRegistry|Tag expiration policy') }}
</div> </template>
<div class="card-body"> <template>
<gl-form-group <gl-form-group
id="expiration-policy-toggle-group" id="expiration-policy-toggle-group"
:label-cols="$options.labelsConfig.cols" :label-cols="$options.labelsConfig.cols"
...@@ -92,9 +98,10 @@ export default { ...@@ -92,9 +98,10 @@ export default {
label-for="expiration-policy-interval" label-for="expiration-policy-interval"
:label="s__('ContainerRegistry|Expiration interval:')" :label="s__('ContainerRegistry|Expiration interval:')"
> >
<gl-form-select id="expiration-policy-interval" v-model="older_than"> <gl-form-select id="expiration-policy-interval" v-model="older_than" :disabled="!enabled">
<option value="1">{{ __('Option 1') }}</option> <option v-for="option in formOptions.olderThan" :key="option.key" :value="option.key">
<option value="2">{{ __('Option 2') }}</option> {{ option.label }}
</option>
</gl-form-select> </gl-form-select>
</gl-form-group> </gl-form-group>
...@@ -105,9 +112,10 @@ export default { ...@@ -105,9 +112,10 @@ export default {
label-for="expiration-policy-schedule" label-for="expiration-policy-schedule"
:label="s__('ContainerRegistry|Expiration schedule:')" :label="s__('ContainerRegistry|Expiration schedule:')"
> >
<gl-form-select id="expiration-policy-schedule" v-model="cadence"> <gl-form-select id="expiration-policy-schedule" v-model="cadence" :disabled="!enabled">
<option value="1">{{ __('Option 1') }}</option> <option v-for="option in formOptions.cadence" :key="option.key" :value="option.key">
<option value="2">{{ __('Option 2') }}</option> {{ option.label }}
</option>
</gl-form-select> </gl-form-select>
</gl-form-group> </gl-form-group>
...@@ -118,9 +126,10 @@ export default { ...@@ -118,9 +126,10 @@ export default {
label-for="expiration-policy-latest" label-for="expiration-policy-latest"
:label="s__('ContainerRegistry|Expiration latest:')" :label="s__('ContainerRegistry|Expiration latest:')"
> >
<gl-form-select id="expiration-policy-latest" v-model="keep_n"> <gl-form-select id="expiration-policy-latest" v-model="keep_n" :disabled="!enabled">
<option value="1">{{ __('Option 1') }}</option> <option v-for="option in formOptions.keepN" :key="option.key" :value="option.key">
<option value="2">{{ __('Option 2') }}</option> {{ option.label }}
</option>
</gl-form-select> </gl-form-select>
</gl-form-group> </gl-form-group>
...@@ -140,19 +149,30 @@ export default { ...@@ -140,19 +149,30 @@ export default {
v-model="name_regex" v-model="name_regex"
:placeholder="nameRegexPlaceholder" :placeholder="nameRegexPlaceholder"
:state="nameRegexState" :state="nameRegexState"
:disabled="!enabled"
trim trim
/> />
<template #description> <template #description>
<span ref="regex-description" v-html="regexHelpText"></span> <span ref="regex-description" v-html="regexHelpText"></span>
</template> </template>
</gl-form-group> </gl-form-group>
</div> </template>
<div class="card-footer text-right"> <template #footer>
<gl-button ref="cancel-button" type="reset">{{ __('Cancel') }}</gl-button> <div class="d-flex justify-content-end">
<gl-button ref="save-button" type="submit" :disabled="formIsValid" variant="success"> <gl-button ref="cancel-button" type="reset" class="mr-2 d-block">{{
{{ __('Save Expiration Policy') }} __('Cancel')
}}</gl-button>
<gl-button
ref="save-button"
type="submit"
:disabled="formIsValid"
variant="success"
class="d-block"
>
{{ __('Save expiration policy') }}
</gl-button> </gl-button>
</div> </div>
</template>
</gl-card>
</form> </form>
</div>
</template> </template>
import { findDefaultOption } from '../utils';
export const getCadence = state =>
state.settings.cadence || findDefaultOption(state.formOptions.cadence);
export const getKeepN = state =>
state.settings.keep_n || findDefaultOption(state.formOptions.keepN);
export const getOlderThan = state =>
state.settings.older_than || findDefaultOption(state.formOptions.olderThan);
...@@ -2,6 +2,7 @@ import Vue from 'vue'; ...@@ -2,6 +2,7 @@ import Vue from 'vue';
import Vuex from 'vuex'; import Vuex from 'vuex';
import * as actions from './actions'; import * as actions from './actions';
import mutations from './mutations'; import mutations from './mutations';
import * as getters from './getters';
import state from './state'; import state from './state';
Vue.use(Vuex); Vue.use(Vuex);
...@@ -11,6 +12,7 @@ export const createStore = () => ...@@ -11,6 +12,7 @@ export const createStore = () =>
state, state,
actions, actions,
mutations, mutations,
getters,
}); });
export default createStore(); export default createStore();
...@@ -3,6 +3,11 @@ import * as types from './mutation_types'; ...@@ -3,6 +3,11 @@ import * as types from './mutation_types';
export default { export default {
[types.SET_INITIAL_STATE](state, initialState) { [types.SET_INITIAL_STATE](state, initialState) {
state.projectId = initialState.projectId; state.projectId = initialState.projectId;
state.formOptions = {
cadence: JSON.parse(initialState.cadenceOptions),
keepN: JSON.parse(initialState.keepNOptions),
olderThan: JSON.parse(initialState.olderThanOptions),
};
}, },
[types.UPDATE_SETTINGS](state, settings) { [types.UPDATE_SETTINGS](state, settings) {
state.settings = { ...state.settings, ...settings }; state.settings = { ...state.settings, ...settings };
......
...@@ -23,4 +23,8 @@ export default () => ({ ...@@ -23,4 +23,8 @@ export default () => ({
* Same structure as settings, above but Frozen object and used only in case the user clicks 'cancel' * Same structure as settings, above but Frozen object and used only in case the user clicks 'cancel'
*/ */
original: {}, original: {},
/*
* Contains the options used to populate the form selects
*/
formOptions: {},
}); });
export const findDefaultOption = options => {
const item = options.find(o => o.default);
return item ? item.key : null;
};
export default () => {};
export const mapComputed = (root, updateFn, list) => { /**
* Returns computed properties two way bound to vuex
*
* @param {(string[]|Object[])} list - list of string matching state keys or list objects
* @param {string} list[].key - the key matching the key present in the vuex state
* @param {string} list[].getter - the name of the getter, leave it empty to not use a getter
* @param {string} list[].updateFn - the name of the action, leave it empty to use the default action
* @param {string} defaultUpdateFn - the default function to dispatch
* @param {string} root - the key of the state where to search fo they keys described in list
* @returns {Object} a dictionary with all the computed properties generated
*/
export const mapComputed = (list, defaultUpdateFn, root) => {
const result = {}; const result = {};
list.forEach(key => { list.forEach(item => {
const [getter, key, updateFn] =
typeof item === 'string'
? [false, item, defaultUpdateFn]
: [item.getter, item.key, item.updateFn || defaultUpdateFn];
result[key] = { result[key] = {
get() { get() {
if (getter) {
return this.$store.getters[getter];
} else if (root) {
return this.$store.state[root][key]; return this.$store.state[root][key];
}
return this.$store.state[key];
}, },
set(value) { set(value) {
this.$store.dispatch(updateFn, { [key]: value }); this.$store.dispatch(updateFn, { [key]: value });
......
#js-registry-settings{ data: { project_id: @project.id, } } #js-registry-settings{ data: { project_id: @project.id,
cadence_options: cadence_options.to_json,
keep_n_options: keep_n_options.to_json,
older_than_options: older_than_options.to_json} }
...@@ -12639,12 +12639,6 @@ msgstr "" ...@@ -12639,12 +12639,6 @@ msgstr ""
msgid "OperationsDashboard|The operations dashboard provides a summary of each project's operational health, including pipeline and alert statuses." msgid "OperationsDashboard|The operations dashboard provides a summary of each project's operational health, including pipeline and alert statuses."
msgstr "" msgstr ""
msgid "Option 1"
msgstr ""
msgid "Option 2"
msgstr ""
msgid "Optional" msgid "Optional"
msgstr "" msgstr ""
...@@ -15784,9 +15778,6 @@ msgstr "" ...@@ -15784,9 +15778,6 @@ msgstr ""
msgid "Save Changes" msgid "Save Changes"
msgstr "" msgstr ""
msgid "Save Expiration Policy"
msgstr ""
msgid "Save anyway" msgid "Save anyway"
msgstr "" msgstr ""
...@@ -15802,6 +15793,9 @@ msgstr "" ...@@ -15802,6 +15793,9 @@ msgstr ""
msgid "Save comment" msgid "Save comment"
msgstr "" msgstr ""
msgid "Save expiration policy"
msgstr ""
msgid "Save password" msgid "Save password"
msgstr "" msgstr ""
......
// Jest Snapshot v1, https://goo.gl/fbAQLP // Jest Snapshot v1, https://goo.gl/fbAQLP
exports[`Settings Form renders 1`] = ` exports[`Settings Form renders 1`] = `
<div <form>
<div
class="card" class="card"
> >
<form> <!---->
<div <div
class="card-header" class="card-header"
> >
...@@ -12,11 +13,13 @@ exports[`Settings Form renders 1`] = ` ...@@ -12,11 +13,13 @@ exports[`Settings Form renders 1`] = `
Tag expiration policy Tag expiration policy
</div> </div>
<div <div
class="card-body" class="card-body"
> >
<gl-form-group-stub <!---->
<!---->
<glformgroup-stub
id="expiration-policy-toggle-group" id="expiration-policy-toggle-group"
label="Expiration policy:" label="Expiration policy:"
label-align="right" label-align="right"
...@@ -26,7 +29,7 @@ exports[`Settings Form renders 1`] = ` ...@@ -26,7 +29,7 @@ exports[`Settings Form renders 1`] = `
<div <div
class="d-flex align-items-start" class="d-flex align-items-start"
> >
<gl-toggle-stub <gltoggle-stub
id="expiration-policy-toggle" id="expiration-policy-toggle"
labeloff="Toggle Status: OFF" labeloff="Toggle Status: OFF"
labelon="Toggle Status: ON" labelon="Toggle Status: ON"
...@@ -41,81 +44,96 @@ exports[`Settings Form renders 1`] = ` ...@@ -41,81 +44,96 @@ exports[`Settings Form renders 1`] = `
</strong> </strong>
</span> </span>
</div> </div>
</gl-form-group-stub> </glformgroup-stub>
<gl-form-group-stub <glformgroup-stub
id="expiration-policy-interval-group" id="expiration-policy-interval-group"
label="Expiration interval:" label="Expiration interval:"
label-align="right" label-align="right"
label-cols="3" label-cols="3"
label-for="expiration-policy-interval" label-for="expiration-policy-interval"
> >
<gl-form-select-stub <glformselect-stub
disabled="true"
id="expiration-policy-interval" id="expiration-policy-interval"
value="bar"
> >
<option <option
value="1" value="foo"
> >
Option 1
</option>
Foo
</option>
<option <option
value="2" value="bar"
> >
Option 2
Bar
</option> </option>
</gl-form-select-stub> </glformselect-stub>
</gl-form-group-stub> </glformgroup-stub>
<gl-form-group-stub <glformgroup-stub
id="expiration-policy-schedule-group" id="expiration-policy-schedule-group"
label="Expiration schedule:" label="Expiration schedule:"
label-align="right" label-align="right"
label-cols="3" label-cols="3"
label-for="expiration-policy-schedule" label-for="expiration-policy-schedule"
> >
<gl-form-select-stub <glformselect-stub
disabled="true"
id="expiration-policy-schedule" id="expiration-policy-schedule"
value="bar"
> >
<option <option
value="1" value="foo"
> >
Option 1
</option>
Foo
</option>
<option <option
value="2" value="bar"
> >
Option 2
Bar
</option> </option>
</gl-form-select-stub> </glformselect-stub>
</gl-form-group-stub> </glformgroup-stub>
<gl-form-group-stub <glformgroup-stub
id="expiration-policy-latest-group" id="expiration-policy-latest-group"
label="Expiration latest:" label="Expiration latest:"
label-align="right" label-align="right"
label-cols="3" label-cols="3"
label-for="expiration-policy-latest" label-for="expiration-policy-latest"
> >
<gl-form-select-stub <glformselect-stub
disabled="true"
id="expiration-policy-latest" id="expiration-policy-latest"
value="bar"
> >
<option <option
value="1" value="foo"
> >
Option 1
</option>
Foo
</option>
<option <option
value="2" value="bar"
> >
Option 2
Bar
</option> </option>
</gl-form-select-stub> </glformselect-stub>
</gl-form-group-stub> </glformgroup-stub>
<gl-form-group-stub <glformgroup-stub
id="expiration-policy-name-matching-group" id="expiration-policy-name-matching-group"
invalid-feedback="The value of this input should be less than 255 characters" invalid-feedback="The value of this input should be less than 255 characters"
label="Expire Docker tags with name matching:" label="Expire Docker tags with name matching:"
...@@ -123,33 +141,41 @@ exports[`Settings Form renders 1`] = ` ...@@ -123,33 +141,41 @@ exports[`Settings Form renders 1`] = `
label-cols="3" label-cols="3"
label-for="expiration-policy-name-matching" label-for="expiration-policy-name-matching"
> >
<gl-form-textarea-stub <glformtextarea-stub
disabled="true"
id="expiration-policy-name-matching" id="expiration-policy-name-matching"
placeholder=".*" placeholder=".*"
trim="" trim=""
value="" value=""
/> />
</gl-form-group-stub> </glformgroup-stub>
</div>
</div>
<div
class="card-footer"
>
<div <div
class="card-footer text-right" class="d-flex justify-content-end"
> >
<gl-button-stub <glbutton-stub
class="mr-2 d-block"
type="reset" type="reset"
> >
Cancel Cancel
</gl-button-stub> </glbutton-stub>
<gl-button-stub <glbutton-stub
class="d-block"
type="submit" type="submit"
variant="success" variant="success"
> >
Save Expiration Policy Save expiration policy
</gl-button-stub> </glbutton-stub>
</div>
</div>
<!---->
</div> </div>
</form> </form>
</div>
`; `;
import Vuex from 'vuex'; import Vuex from 'vuex';
import { shallowMount, createLocalVue } from '@vue/test-utils'; import { mount, createLocalVue } from '@vue/test-utils';
import stubChildren from 'helpers/stub_children';
import component from '~/registry/settings/components/settings_form.vue'; import component from '~/registry/settings/components/settings_form.vue';
import { createStore } from '~/registry/settings/store/'; import { createStore } from '~/registry/settings/store/';
import { NAME_REGEX_LENGTH } from '~/registry/settings/constants'; import { NAME_REGEX_LENGTH } from '~/registry/settings/constants';
import { stringifiedFormOptions } from '../mock_data';
const localVue = createLocalVue(); const localVue = createLocalVue();
localVue.use(Vuex); localVue.use(Vuex);
...@@ -13,7 +15,6 @@ describe('Settings Form', () => { ...@@ -13,7 +15,6 @@ describe('Settings Form', () => {
let saveSpy; let saveSpy;
let resetSpy; let resetSpy;
const helpPagePath = 'foo';
const findFormGroup = name => wrapper.find(`#expiration-policy-${name}-group`); const findFormGroup = name => wrapper.find(`#expiration-policy-${name}-group`);
const findFormElements = (name, father = wrapper) => father.find(`#expiration-policy-${name}`); const findFormElements = (name, father = wrapper) => father.find(`#expiration-policy-${name}`);
const findCancelButton = () => wrapper.find({ ref: 'cancel-button' }); const findCancelButton = () => wrapper.find({ ref: 'cancel-button' });
...@@ -23,7 +24,11 @@ describe('Settings Form', () => { ...@@ -23,7 +24,11 @@ describe('Settings Form', () => {
const mountComponent = (options = {}) => { const mountComponent = (options = {}) => {
saveSpy = jest.fn(); saveSpy = jest.fn();
resetSpy = jest.fn(); resetSpy = jest.fn();
wrapper = shallowMount(component, { wrapper = mount(component, {
stubs: {
...stubChildren(component),
GlCard: false,
},
store, store,
methods: { methods: {
saveSettings: saveSpy, saveSettings: saveSpy,
...@@ -35,7 +40,7 @@ describe('Settings Form', () => { ...@@ -35,7 +40,7 @@ describe('Settings Form', () => {
beforeEach(() => { beforeEach(() => {
store = createStore(); store = createStore();
store.dispatch('setInitialState', { helpPagePath }); store.dispatch('setInitialState', stringifiedFormOptions);
mountComponent(); mountComponent();
}); });
...@@ -48,13 +53,13 @@ describe('Settings Form', () => { ...@@ -48,13 +53,13 @@ describe('Settings Form', () => {
}); });
describe.each` describe.each`
elementName | modelName | value elementName | modelName | value | disabledByToggle
${'toggle'} | ${'enabled'} | ${true} ${'toggle'} | ${'enabled'} | ${true} | ${'not disabled'}
${'interval'} | ${'older_than'} | ${'foo'} ${'interval'} | ${'older_than'} | ${'foo'} | ${'disabled'}
${'schedule'} | ${'cadence'} | ${'foo'} ${'schedule'} | ${'cadence'} | ${'foo'} | ${'disabled'}
${'latest'} | ${'keep_n'} | ${'foo'} ${'latest'} | ${'keep_n'} | ${'foo'} | ${'disabled'}
${'name-matching'} | ${'name_regex'} | ${'foo'} ${'name-matching'} | ${'name_regex'} | ${'foo'} | ${'disabled'}
`('%s form element', ({ elementName, modelName, value }) => { `('$elementName form element', ({ elementName, modelName, value, disabledByToggle }) => {
let formGroup; let formGroup;
beforeEach(() => { beforeEach(() => {
formGroup = findFormGroup(elementName); formGroup = findFormGroup(elementName);
...@@ -89,6 +94,12 @@ describe('Settings Form', () => { ...@@ -89,6 +94,12 @@ describe('Settings Form', () => {
expect(wrapper.vm[modelName]).toBe(value); expect(wrapper.vm[modelName]).toBe(value);
}); });
}); });
it(`${elementName} is ${disabledByToggle} by enabled set to false`, () => {
store.dispatch('updateSettings', { enabled: false });
const expectation = disabledByToggle === 'disabled' ? 'true' : undefined;
expect(findFormElements(elementName, formGroup).attributes('disabled')).toBe(expectation);
});
}); });
describe('form actions', () => { describe('form actions', () => {
......
export const options = [{ key: 'foo', label: 'Foo' }, { key: 'bar', label: 'Bar', default: true }];
export const stringifiedOptions = JSON.stringify(options);
export const stringifiedFormOptions = {
cadenceOptions: stringifiedOptions,
keepNOptions: stringifiedOptions,
olderThanOptions: stringifiedOptions,
};
export const formOptions = {
cadence: options,
keepN: options,
olderThan: options,
};
import mutations from '~/registry/settings/store/mutations'; import mutations from '~/registry/settings/store/mutations';
import * as types from '~/registry/settings/store/mutation_types'; import * as types from '~/registry/settings/store/mutation_types';
import createState from '~/registry/settings/store/state'; import createState from '~/registry/settings/store/state';
import { formOptions, stringifiedFormOptions } from '../mock_data';
describe('Mutations Registry Store', () => { describe('Mutations Registry Store', () => {
let mockState; let mockState;
...@@ -11,11 +12,14 @@ describe('Mutations Registry Store', () => { ...@@ -11,11 +12,14 @@ describe('Mutations Registry Store', () => {
describe('SET_INITIAL_STATE', () => { describe('SET_INITIAL_STATE', () => {
it('should set the initial state', () => { it('should set the initial state', () => {
const payload = { helpPagePath: 'foo', projectId: 'bar' }; const expectedState = { ...mockState, projectId: 'foo', formOptions };
const expectedState = { ...mockState, ...payload }; mutations[types.SET_INITIAL_STATE](mockState, {
mutations[types.SET_INITIAL_STATE](mockState, payload); projectId: 'foo',
...stringifiedFormOptions,
});
expect(mockState.projectId).toEqual(expectedState.projectId); expect(mockState.projectId).toEqual(expectedState.projectId);
expect(mockState.formOptions).toEqual(expectedState.formOptions);
}); });
}); });
......
...@@ -3,49 +3,77 @@ import { mapComputed } from '~/vuex_shared/bindings'; ...@@ -3,49 +3,77 @@ import { mapComputed } from '~/vuex_shared/bindings';
describe('Binding utils', () => { describe('Binding utils', () => {
describe('mapComputed', () => { describe('mapComputed', () => {
const dummyComponent = { const defaultArgs = [['baz'], 'bar', 'foo'];
const createDummy = (mapComputedArgs = defaultArgs) => ({
computed: { computed: {
...mapComputed('foo', 'bar', ['baz']), ...mapComputed(...mapComputedArgs),
}, },
render() { render() {
return null; return null;
}, },
});
const mocks = {
$store: {
state: {
baz: 2,
foo: {
baz: 1,
},
},
getters: {
getBaz: 'foo',
},
dispatch: jest.fn(),
},
}; };
it('returns an object with keys equal to the last fn parameter ', () => {
it('returns an object with keys equal to the first fn parameter ', () => {
const keyList = ['foo1', 'foo2']; const keyList = ['foo1', 'foo2'];
const result = mapComputed('foo', 'bar', keyList); const result = mapComputed(keyList, 'foo', 'bar');
expect(Object.keys(result)).toEqual(keyList); expect(Object.keys(result)).toEqual(keyList);
}); });
it('returned object has set and get function', () => { it('returned object has set and get function', () => {
const result = mapComputed('foo', 'bar', ['baz']); const result = mapComputed(['baz'], 'foo', 'bar');
expect(result.baz.set).toBeDefined(); expect(result.baz.set).toBeDefined();
expect(result.baz.get).toBeDefined(); expect(result.baz.get).toBeDefined();
}); });
it('set function invokes $store.dispatch', () => { describe('set function', () => {
const context = shallowMount(dummyComponent, { it('invokes $store.dispatch', () => {
mocks: { const context = shallowMount(createDummy(), { mocks });
$store: {
dispatch: jest.fn(),
},
},
});
context.vm.baz = 'a'; context.vm.baz = 'a';
expect(context.vm.$store.dispatch).toHaveBeenCalledWith('bar', { baz: 'a' }); expect(context.vm.$store.dispatch).toHaveBeenCalledWith('bar', { baz: 'a' });
}); });
it('get function returns $store.state[root][key]', () => { it('uses updateFn in list object mode if updateFn exists', () => {
const context = shallowMount(dummyComponent, { const context = shallowMount(createDummy([[{ key: 'foo', updateFn: 'baz' }]]), { mocks });
mocks: { context.vm.foo = 'b';
$store: { expect(context.vm.$store.dispatch).toHaveBeenCalledWith('baz', { foo: 'b' });
state: { });
foo: { it('in list object mode defaults to defaultUpdateFn if updateFn do not exists', () => {
baz: 1, const context = shallowMount(createDummy([[{ key: 'foo' }], 'defaultFn']), { mocks });
}, context.vm.foo = 'c';
}, expect(context.vm.$store.dispatch).toHaveBeenCalledWith('defaultFn', { foo: 'c' });
}, });
}, });
describe('get function', () => {
it('if root is set returns $store.state[root][key]', () => {
const context = shallowMount(createDummy(), { mocks });
expect(context.vm.baz).toBe(mocks.$store.state.foo.baz);
});
it('if root is not set returns $store.state[key]', () => {
const context = shallowMount(createDummy([['baz'], 'bar']), { mocks });
expect(context.vm.baz).toBe(mocks.$store.state.baz);
});
it('when using getters it invoke the appropriate getter', () => {
const context = shallowMount(createDummy([[{ getter: 'getBaz', key: 'baz' }]]), { mocks });
expect(context.vm.baz).toBe(mocks.$store.getters.getBaz);
}); });
expect(context.vm.baz).toBe(1);
}); });
}); });
}); });
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