Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
gitlab-ce
Commits
f4134d95
Commit
f4134d95
authored
Mar 26, 2021
by
Nicolò Maria Mezzopera
Committed by
Natalia Tepluhina
Mar 26, 2021
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Always save default on empty values in Exp Policies
parent
d4bb48b8
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
71 additions
and
28 deletions
+71
-28
app/assets/javascripts/registry/settings/components/settings_form.vue
...avascripts/registry/settings/components/settings_form.vue
+6
-6
changelogs/unreleased/325429-container-registry-cleanup-policy-wiped-all-images.yml
...29-container-registry-cleanup-policy-wiped-all-images.yml
+5
-0
spec/frontend/registry/settings/components/settings_form_spec.js
...ontend/registry/settings/components/settings_form_spec.js
+60
-22
No files found.
app/assets/javascripts/registry/settings/components/settings_form.vue
View file @
f4134d95
...
@@ -110,12 +110,12 @@ export default {
...
@@ -110,12 +110,12 @@ export default {
mutationVariables
()
{
mutationVariables
()
{
return
{
return
{
projectPath
:
this
.
projectPath
,
projectPath
:
this
.
projectPath
,
enabled
:
this
.
value
.
enabled
,
enabled
:
this
.
prefilledForm
.
enabled
,
cadence
:
this
.
value
.
cadence
,
cadence
:
this
.
prefilledForm
.
cadence
,
olderThan
:
this
.
value
.
olderThan
,
olderThan
:
this
.
prefilledForm
.
olderThan
,
keepN
:
this
.
value
.
keepN
,
keepN
:
this
.
prefilledForm
.
keepN
,
nameRegex
:
this
.
value
.
nameRegex
,
nameRegex
:
this
.
prefilledForm
.
nameRegex
,
nameRegexKeep
:
this
.
value
.
nameRegexKeep
,
nameRegexKeep
:
this
.
prefilledForm
.
nameRegexKeep
,
};
};
},
},
},
},
...
...
changelogs/unreleased/325429-container-registry-cleanup-policy-wiped-all-images.yml
0 → 100644
View file @
f4134d95
---
title
:
Always save default on empty values in Exp Policies
merge_request
:
57470
author
:
type
:
fixed
spec/frontend/registry/settings/components/settings_form_spec.js
View file @
f4134d95
...
@@ -77,33 +77,47 @@ describe('Settings Form', () => {
...
@@ -77,33 +77,47 @@ describe('Settings Form', () => {
});
});
};
};
const
mountComponentWithApollo
=
({
provide
=
defaultProvidedValues
,
resolver
}
=
{})
=>
{
const
mountComponentWithApollo
=
({
provide
=
defaultProvidedValues
,
mutationResolver
,
queryPayload
=
expirationPolicyPayload
(),
}
=
{})
=>
{
localVue
.
use
(
VueApollo
);
localVue
.
use
(
VueApollo
);
const
requestHandlers
=
[
const
requestHandlers
=
[
[
updateContainerExpirationPolicyMutation
,
r
esolver
],
[
updateContainerExpirationPolicyMutation
,
mutationR
esolver
],
[
expirationPolicyQuery
,
jest
.
fn
().
mockResolvedValue
(
expirationPolicyPayload
()
)],
[
expirationPolicyQuery
,
jest
.
fn
().
mockResolvedValue
(
queryPayload
)],
];
];
fakeApollo
=
createMockApollo
(
requestHandlers
);
fakeApollo
=
createMockApollo
(
requestHandlers
);
// This component does not do the query directly, but we need a proper cache to update
fakeApollo
.
defaultClient
.
cache
.
writeQuery
({
fakeApollo
.
defaultClient
.
cache
.
writeQuery
({
query
:
expirationPolicyQuery
,
query
:
expirationPolicyQuery
,
variables
:
{
variables
:
{
projectPath
:
provide
.
projectPath
,
projectPath
:
provide
.
projectPath
,
},
},
...
expirationPolicyPayload
()
,
...
queryPayload
,
});
});
// we keep in sync what prop we pass to the component with the cache
const
{
data
:
{
project
:
{
containerExpirationPolicy
:
value
},
},
}
=
queryPayload
;
mountComponent
({
mountComponent
({
provide
,
provide
,
props
:
{
...
defaultProps
,
value
,
},
config
:
{
config
:
{
localVue
,
localVue
,
apolloProvider
:
fakeApollo
,
apolloProvider
:
fakeApollo
,
},
},
});
});
return
requestHandlers
.
map
((
resolvers
)
=>
resolvers
[
1
]);
};
};
beforeEach
(()
=>
{
beforeEach
(()
=>
{
...
@@ -253,19 +267,44 @@ describe('Settings Form', () => {
...
@@ -253,19 +267,44 @@ describe('Settings Form', () => {
expect
(
findSaveButton
().
attributes
(
'
type
'
)).
toBe
(
'
submit
'
);
expect
(
findSaveButton
().
attributes
(
'
type
'
)).
toBe
(
'
submit
'
);
});
});
it
(
'
dispatches the correct apollo mutation
'
,
async
()
=>
{
it
(
'
dispatches the correct apollo mutation
'
,
()
=>
{
const
[
expirationPolicyMutationResolver
]
=
mountComponentWithApollo
({
const
mutationResolver
=
jest
.
fn
().
mockResolvedValue
(
expirationPolicyMutationPayload
());
resolver
:
jest
.
fn
().
mockResolvedValue
(
expirationPolicyMutationPayload
()),
mountComponentWithApollo
({
mutationResolver
,
});
});
findForm
().
trigger
(
'
submit
'
);
findForm
().
trigger
(
'
submit
'
);
await
expirationPolicyMutationResolver
();
expect
(
expirationPolicyMutationResolver
).
toHaveBeenCalled
();
expect
(
mutationResolver
).
toHaveBeenCalled
();
});
it
(
'
saves the default values when a value is missing did not change the default options
'
,
async
()
=>
{
const
mutationResolver
=
jest
.
fn
().
mockResolvedValue
(
expirationPolicyMutationPayload
());
mountComponentWithApollo
({
mutationResolver
,
queryPayload
:
expirationPolicyPayload
({
keepN
:
null
,
cadence
:
null
,
olderThan
:
null
}),
});
await
waitForPromises
();
findForm
().
trigger
(
'
submit
'
);
expect
(
mutationResolver
).
toHaveBeenCalledWith
({
input
:
{
cadence
:
'
EVERY_DAY
'
,
enabled
:
true
,
keepN
:
'
TEN_TAGS
'
,
nameRegex
:
'
asdasdssssdfdf
'
,
nameRegexKeep
:
'
sss
'
,
olderThan
:
'
NINETY_DAYS
'
,
projectPath
:
'
path
'
,
},
});
});
});
it
(
'
tracks the submit event
'
,
()
=>
{
it
(
'
tracks the submit event
'
,
()
=>
{
mountComponentWithApollo
({
mountComponentWithApollo
({
r
esolver
:
jest
.
fn
().
mockResolvedValue
(
expirationPolicyMutationPayload
()),
mutationR
esolver
:
jest
.
fn
().
mockResolvedValue
(
expirationPolicyMutationPayload
()),
});
});
findForm
().
trigger
(
'
submit
'
);
findForm
().
trigger
(
'
submit
'
);
...
@@ -274,12 +313,12 @@ describe('Settings Form', () => {
...
@@ -274,12 +313,12 @@ describe('Settings Form', () => {
});
});
it
(
'
show a success toast when submit succeed
'
,
async
()
=>
{
it
(
'
show a success toast when submit succeed
'
,
async
()
=>
{
const
handlers
=
mountComponentWithApollo
({
mountComponentWithApollo
({
r
esolver
:
jest
.
fn
().
mockResolvedValue
(
expirationPolicyMutationPayload
()),
mutationR
esolver
:
jest
.
fn
().
mockResolvedValue
(
expirationPolicyMutationPayload
()),
});
});
findForm
().
trigger
(
'
submit
'
);
findForm
().
trigger
(
'
submit
'
);
await
Promise
.
all
(
handlers
);
await
waitForPromises
(
);
await
wrapper
.
vm
.
$nextTick
();
await
wrapper
.
vm
.
$nextTick
();
expect
(
wrapper
.
vm
.
$toast
.
show
).
toHaveBeenCalledWith
(
UPDATE_SETTINGS_SUCCESS_MESSAGE
,
{
expect
(
wrapper
.
vm
.
$toast
.
show
).
toHaveBeenCalledWith
(
UPDATE_SETTINGS_SUCCESS_MESSAGE
,
{
...
@@ -290,14 +329,14 @@ describe('Settings Form', () => {
...
@@ -290,14 +329,14 @@ describe('Settings Form', () => {
describe
(
'
when submit fails
'
,
()
=>
{
describe
(
'
when submit fails
'
,
()
=>
{
describe
(
'
user recoverable errors
'
,
()
=>
{
describe
(
'
user recoverable errors
'
,
()
=>
{
it
(
'
when there is an error is shown in a toast
'
,
async
()
=>
{
it
(
'
when there is an error is shown in a toast
'
,
async
()
=>
{
const
handlers
=
mountComponentWithApollo
({
mountComponentWithApollo
({
r
esolver
:
jest
mutationR
esolver
:
jest
.
fn
()
.
fn
()
.
mockResolvedValue
(
expirationPolicyMutationPayload
({
errors
:
[
'
foo
'
]
})),
.
mockResolvedValue
(
expirationPolicyMutationPayload
({
errors
:
[
'
foo
'
]
})),
});
});
findForm
().
trigger
(
'
submit
'
);
findForm
().
trigger
(
'
submit
'
);
await
Promise
.
all
(
handlers
);
await
waitForPromises
(
);
await
wrapper
.
vm
.
$nextTick
();
await
wrapper
.
vm
.
$nextTick
();
expect
(
wrapper
.
vm
.
$toast
.
show
).
toHaveBeenCalledWith
(
'
foo
'
,
{
expect
(
wrapper
.
vm
.
$toast
.
show
).
toHaveBeenCalledWith
(
'
foo
'
,
{
...
@@ -308,13 +347,12 @@ describe('Settings Form', () => {
...
@@ -308,13 +347,12 @@ describe('Settings Form', () => {
describe
(
'
global errors
'
,
()
=>
{
describe
(
'
global errors
'
,
()
=>
{
it
(
'
shows an error
'
,
async
()
=>
{
it
(
'
shows an error
'
,
async
()
=>
{
const
handlers
=
mountComponentWithApollo
({
mountComponentWithApollo
({
r
esolver
:
jest
.
fn
().
mockRejectedValue
(
expirationPolicyMutationPayload
()),
mutationR
esolver
:
jest
.
fn
().
mockRejectedValue
(
expirationPolicyMutationPayload
()),
});
});
findForm
().
trigger
(
'
submit
'
);
findForm
().
trigger
(
'
submit
'
);
await
Promise
.
all
(
handlers
);
await
waitForPromises
();
await
wrapper
.
vm
.
$nextTick
();
await
wrapper
.
vm
.
$nextTick
();
await
wrapper
.
vm
.
$nextTick
();
expect
(
wrapper
.
vm
.
$toast
.
show
).
toHaveBeenCalledWith
(
UPDATE_SETTINGS_ERROR_MESSAGE
,
{
expect
(
wrapper
.
vm
.
$toast
.
show
).
toHaveBeenCalledWith
(
UPDATE_SETTINGS_ERROR_MESSAGE
,
{
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment