Commit d84b3f8a authored by Nicolò Maria Mezzopera's avatar Nicolò Maria Mezzopera Committed by Natalia Tepluhina

Default to empty object and fix conditional

- source
- tests
parent 4089bc95
<script> <script>
import { GlAlert, GlSprintf, GlLink } from '@gitlab/ui'; import { GlAlert, GlSprintf, GlLink } from '@gitlab/ui';
import { isEqual } from 'lodash'; import { isEqual, get } from 'lodash';
import expirationPolicyQuery from '../graphql/queries/get_expiration_policy.graphql'; import expirationPolicyQuery from '../graphql/queries/get_expiration_policy.graphql';
import { FETCH_SETTINGS_ERROR_MESSAGE } from '../../shared/constants'; import { FETCH_SETTINGS_ERROR_MESSAGE } from '../../shared/constants';
...@@ -35,7 +35,7 @@ export default { ...@@ -35,7 +35,7 @@ export default {
}, },
update: data => data.project?.containerExpirationPolicy, update: data => data.project?.containerExpirationPolicy,
result({ data }) { result({ data }) {
this.workingCopy = { ...data.project?.containerExpirationPolicy }; this.workingCopy = { ...get(data, 'project.containerExpirationPolicy', {}) };
}, },
error(e) { error(e) {
this.fetchSettingsError = e; this.fetchSettingsError = e;
...@@ -74,7 +74,7 @@ export default { ...@@ -74,7 +74,7 @@ export default {
<template> <template>
<div> <div>
<settings-form <settings-form
v-if="containerExpirationPolicy" v-if="!isDisabled"
v-model="workingCopy" v-model="workingCopy"
:is-loading="$apollo.queries.containerExpirationPolicy.loading" :is-loading="$apollo.queries.containerExpirationPolicy.loading"
:is-edited="isEdited" :is-edited="isEdited"
......
...@@ -55,6 +55,14 @@ export default { ...@@ -55,6 +55,14 @@ export default {
}; };
}, },
computed: { computed: {
prefilledForm() {
return {
...this.value,
cadence: this.findDefaultOption('cadence'),
keepN: this.findDefaultOption('keepN'),
olderThan: this.findDefaultOption('olderThan'),
};
},
showLoadingIcon() { showLoadingIcon() {
return this.isLoading || this.mutationLoading; return this.isLoading || this.mutationLoading;
}, },
...@@ -77,6 +85,9 @@ export default { ...@@ -77,6 +85,9 @@ export default {
}, },
}, },
methods: { methods: {
findDefaultOption(option) {
return this.value[option] || this.$options.formOptions[option].find(f => f.default)?.key;
},
reset() { reset() {
this.track('reset_form'); this.track('reset_form');
this.apiErrors = null; this.apiErrors = null;
...@@ -135,7 +146,7 @@ export default { ...@@ -135,7 +146,7 @@ export default {
</template> </template>
<template #default> <template #default>
<expiration-policy-fields <expiration-policy-fields
:value="value" :value="prefilledForm"
:form-options="$options.formOptions" :form-options="$options.formOptions"
:is-loading="isLoading" :is-loading="isLoading"
:api-errors="apiErrors" :api-errors="apiErrors"
......
import Vue from 'vue'; import Vue from 'vue';
import { GlToast } from '@gitlab/ui'; import { GlToast } from '@gitlab/ui';
import Translate from '~/vue_shared/translate'; import Translate from '~/vue_shared/translate';
import { parseBoolean } from '~/lib/utils/common_utils';
import RegistrySettingsApp from './components/registry_settings_app.vue'; import RegistrySettingsApp from './components/registry_settings_app.vue';
import { apolloProvider } from './graphql/index'; import { apolloProvider } from './graphql/index';
...@@ -21,9 +22,9 @@ export default () => { ...@@ -21,9 +22,9 @@ export default () => {
}, },
provide: { provide: {
projectPath, projectPath,
isAdmin, isAdmin: parseBoolean(isAdmin),
adminSettingsPath, adminSettingsPath,
enableHistoricEntries, enableHistoricEntries: parseBoolean(enableHistoricEntries),
}, },
render(createElement) { render(createElement) {
return createElement('registry-settings-app', {}); return createElement('registry-settings-app', {});
......
...@@ -11,7 +11,7 @@ import { ...@@ -11,7 +11,7 @@ import {
UNAVAILABLE_USER_FEATURE_TEXT, UNAVAILABLE_USER_FEATURE_TEXT,
} from '~/registry/settings/constants'; } from '~/registry/settings/constants';
import { expirationPolicyPayload } from '../mock_data'; import { expirationPolicyPayload, emptyExpirationPolicyPayload } from '../mock_data';
const localVue = createLocalVue(); const localVue = createLocalVue();
...@@ -115,4 +115,23 @@ describe('Registry Settings App', () => { ...@@ -115,4 +115,23 @@ describe('Registry Settings App', () => {
expect(findAlert().html()).toContain(FETCH_SETTINGS_ERROR_MESSAGE); expect(findAlert().html()).toContain(FETCH_SETTINGS_ERROR_MESSAGE);
}); });
}); });
describe('empty API response', () => {
it.each`
enableHistoricEntries | isShown
${true} | ${true}
${false} | ${false}
`('is $isShown that the form is shown', async ({ enableHistoricEntries, isShown }) => {
const requests = mountComponentWithApollo({
provide: {
...defaultProvidedValues,
enableHistoricEntries,
},
resolver: jest.fn().mockResolvedValue(emptyExpirationPolicyPayload()),
});
await Promise.all(requests);
expect(findSettingsComponent().exists()).toBe(isShown);
});
});
}); });
...@@ -123,6 +123,15 @@ describe('Settings Form', () => { ...@@ -123,6 +123,15 @@ describe('Settings Form', () => {
findFields().vm.$emit('input', { newValue: 'foo', modified: 'baz' }); findFields().vm.$emit('input', { newValue: 'foo', modified: 'baz' });
expect(findFields().props('apiErrors')).toEqual({}); expect(findFields().props('apiErrors')).toEqual({});
}); });
it('shows the default option when none are selected', () => {
mountComponent({ props: { value: {} } });
expect(findFields().props('value')).toEqual({
cadence: 'EVERY_DAY',
keepN: 'TEN_TAGS',
olderThan: 'NINETY_DAYS',
});
});
}); });
describe('form', () => { describe('form', () => {
......
...@@ -14,6 +14,14 @@ export const expirationPolicyPayload = override => ({ ...@@ -14,6 +14,14 @@ export const expirationPolicyPayload = override => ({
}, },
}); });
export const emptyExpirationPolicyPayload = () => ({
data: {
project: {
containerExpirationPolicy: {},
},
},
});
export const expirationPolicyMutationPayload = ({ override, errors = [] } = {}) => ({ export const expirationPolicyMutationPayload = ({ override, errors = [] } = {}) => ({
data: { data: {
updateContainerExpirationPolicy: { updateContainerExpirationPolicy: {
......
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