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
1ee67e28
Commit
1ee67e28
authored
Jan 29, 2020
by
Florie Guibert
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Delete description diff in notes
- Frontend tests in ee/spec - Fix linting error
parent
c84238ff
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
113 additions
and
56 deletions
+113
-56
app/assets/javascripts/notes/stores/actions.js
app/assets/javascripts/notes/stores/actions.js
+2
-2
app/assets/stylesheets/pages/notes.scss
app/assets/stylesheets/pages/notes.scss
+1
-1
ee/spec/frontend/vue_shared/components/notes/system_note_spec.js
.../frontend/vue_shared/components/notes/system_note_spec.js
+110
-0
spec/frontend/vue_shared/components/notes/system_note_spec.js
.../frontend/vue_shared/components/notes/system_note_spec.js
+0
-53
No files found.
app/assets/javascripts/notes/stores/actions.js
View file @
1ee67e28
...
@@ -509,7 +509,6 @@ export const fetchDescriptionVersion = (_, { endpoint, startingVersion }) => {
...
@@ -509,7 +509,6 @@ export const fetchDescriptionVersion = (_, { endpoint, startingVersion }) => {
export
const
setCurrentDiscussionId
=
({
commit
},
discussionId
)
=>
export
const
setCurrentDiscussionId
=
({
commit
},
discussionId
)
=>
commit
(
types
.
SET_CURRENT_DISCUSSION_ID
,
discussionId
);
commit
(
types
.
SET_CURRENT_DISCUSSION_ID
,
discussionId
);
export
const
softDeleteDescriptionVersion
=
(
_
,
{
endpoint
,
startingVersion
})
=>
{
export
const
softDeleteDescriptionVersion
=
(
_
,
{
endpoint
,
startingVersion
})
=>
{
let
requestUrl
=
endpoint
;
let
requestUrl
=
endpoint
;
...
@@ -520,8 +519,9 @@ export const softDeleteDescriptionVersion = (_, { endpoint, startingVersion }) =
...
@@ -520,8 +519,9 @@ export const softDeleteDescriptionVersion = (_, { endpoint, startingVersion }) =
return
axios
return
axios
.
delete
(
requestUrl
)
.
delete
(
requestUrl
)
.
then
(
res
=>
res
.
data
)
.
then
(
res
=>
res
.
data
)
.
catch
(
()
=>
{
.
catch
(
e
=>
{
Flash
(
__
(
'
Something went wrong while deleting description changes. Please try again.
'
));
Flash
(
__
(
'
Something went wrong while deleting description changes. Please try again.
'
));
return
Promise
.
reject
(
e
);
});
});
};
};
...
...
app/assets/stylesheets/pages/notes.scss
View file @
1ee67e28
...
@@ -318,7 +318,7 @@ $note-form-margin-left: 72px;
...
@@ -318,7 +318,7 @@ $note-form-margin-left: 72px;
top
:
18px
;
top
:
18px
;
right
:
0
;
right
:
0
;
}
}
pre
{
pre
{
max-height
:
$dropdown-max-height-lg
;
max-height
:
$dropdown-max-height-lg
;
white-space
:
pre-wrap
;
white-space
:
pre-wrap
;
...
...
ee/spec/frontend/vue_shared/components/notes/system_note_spec.js
0 → 100644
View file @
1ee67e28
import
{
mount
}
from
'
@vue/test-utils
'
;
import
axios
from
'
~/lib/utils/axios_utils
'
;
import
MockAdapter
from
'
axios-mock-adapter
'
;
import
IssueSystemNote
from
'
~/vue_shared/components/notes/system_note.vue
'
;
import
createStore
from
'
~/notes/stores
'
;
import
waitForPromises
from
'
helpers/wait_for_promises
'
;
describe
(
'
system note component
'
,
()
=>
{
let
wrapper
;
let
props
;
let
mock
;
const
diffData
=
'
<span class="idiff">Description</span><span class="idiff addition">Diff</span>
'
;
function
mockFetchDiff
()
{
mock
.
onGet
(
'
/path/to/diff
'
).
replyOnce
(
200
,
diffData
);
}
function
mockDeleteDiff
()
{
mock
.
onDelete
(
'
/path/to/diff/1
'
).
replyOnce
(
200
);
}
beforeEach
(()
=>
{
props
=
{
note
:
{
id
:
'
1424
'
,
author
:
{
id
:
1
,
name
:
'
Root
'
,
username
:
'
root
'
,
state
:
'
active
'
,
avatar_url
:
'
path
'
,
path
:
'
/root
'
,
},
note_html
:
'
<p dir="auto">closed</p>
'
,
system_note_icon_name
:
'
status_closed
'
,
created_at
:
'
2017-08-02T10:51:58.559Z
'
,
description_version_id
:
1
,
description_diff_path
:
'
path/to/diff
'
,
delete_description_version_path
:
'
path/to/diff/1
'
,
can_delete_description_version
:
true
,
description_version_deleted
:
false
,
},
};
const
store
=
createStore
();
store
.
dispatch
(
'
setTargetNoteHash
'
,
`note_
${
props
.
note
.
id
}
`
);
mock
=
new
MockAdapter
(
axios
);
wrapper
=
mount
(
IssueSystemNote
,
{
store
,
propsData
:
props
,
provide
:
{
glFeatures
:
{
saveDescriptionVersions
:
true
,
descriptionDiffs
:
true
},
},
});
});
afterEach
(()
=>
{
mock
.
restore
();
wrapper
.
destroy
();
});
it
(
'
should display button to toggle description diff, description version does not display
'
,
()
=>
{
const
button
=
wrapper
.
find
(
'
.note-headline-light .btn-blank
'
);
expect
(
button
.
exists
()).
toBe
(
true
);
expect
(
button
.
text
()).
toContain
(
'
Compare with previous version
'
);
expect
(
wrapper
.
find
(
'
.description-version
'
).
exists
()).
toBe
(
false
);
});
it
(
'
click on button to toggle description diff displays description diff with delete icon button
'
,
done
=>
{
mockFetchDiff
();
expect
(
wrapper
.
find
(
'
.description-version
'
).
exists
()).
toBe
(
false
);
const
button
=
wrapper
.
find
(
'
.note-headline-light .btn-blank
'
);
button
.
trigger
(
'
click
'
);
return
wrapper
.
vm
.
$nextTick
()
.
then
(()
=>
waitForPromises
())
.
then
(()
=>
{
expect
(
wrapper
.
find
(
'
.description-version
'
).
exists
()).
toBe
(
true
);
expect
(
wrapper
.
find
(
'
.description-version
'
).
html
()).
toContain
(
diffData
);
expect
(
wrapper
.
find
(
'
.description-version button.delete-description-history svg.ic-remove
'
)
.
exists
(),
).
toBe
(
true
);
done
();
});
});
it
(
'
click on delete icon button deletes description diff
'
,
done
=>
{
mockFetchDiff
();
mockDeleteDiff
();
wrapper
.
find
(
'
.note-headline-light .btn-blank
'
).
trigger
(
'
click
'
);
return
wrapper
.
vm
.
$nextTick
()
.
then
(()
=>
waitForPromises
())
.
then
(()
=>
{
const
button
=
wrapper
.
find
(
'
.description-version button.delete-description-history
'
);
button
.
trigger
(
'
click
'
);
})
.
then
(()
=>
waitForPromises
())
.
then
(()
=>
{
expect
(
wrapper
.
find
(
'
.description-version
'
).
text
()).
toContain
(
'
Deleted
'
);
done
();
});
});
});
spec/frontend/vue_shared/components/notes/system_note_spec.js
View file @
1ee67e28
import
Vue
from
'
vue
'
;
import
{
mount
}
from
'
@vue/test-utils
'
;
import
{
mount
}
from
'
@vue/test-utils
'
;
import
axios
from
'
~/lib/utils/axios_utils
'
;
import
MockAdapter
from
'
axios-mock-adapter
'
;
import
IssueSystemNote
from
'
~/vue_shared/components/notes/system_note.vue
'
;
import
IssueSystemNote
from
'
~/vue_shared/components/notes/system_note.vue
'
;
import
createStore
from
'
~/notes/stores
'
;
import
createStore
from
'
~/notes/stores
'
;
import
initMRPopovers
from
'
~/mr_popover/index
'
;
import
initMRPopovers
from
'
~/mr_popover/index
'
;
...
@@ -11,7 +8,6 @@ jest.mock('~/mr_popover/index', () => jest.fn());
...
@@ -11,7 +8,6 @@ jest.mock('~/mr_popover/index', () => jest.fn());
describe
(
'
system note component
'
,
()
=>
{
describe
(
'
system note component
'
,
()
=>
{
let
vm
;
let
vm
;
let
props
;
let
props
;
let
mock
;
beforeEach
(()
=>
{
beforeEach
(()
=>
{
props
=
{
props
=
{
...
@@ -28,30 +24,19 @@ describe('system note component', () => {
...
@@ -28,30 +24,19 @@ describe('system note component', () => {
note_html
:
'
<p dir="auto">closed</p>
'
,
note_html
:
'
<p dir="auto">closed</p>
'
,
system_note_icon_name
:
'
status_closed
'
,
system_note_icon_name
:
'
status_closed
'
,
created_at
:
'
2017-08-02T10:51:58.559Z
'
,
created_at
:
'
2017-08-02T10:51:58.559Z
'
,
description_version_id
:
1
,
description_diff_path
:
'
path/to/diff
'
,
delete_description_version_path
:
'
path/to/diff/1
'
,
can_delete_description_version
:
true
,
description_version_deleted
:
false
,
},
},
};
};
const
store
=
createStore
();
const
store
=
createStore
();
store
.
dispatch
(
'
setTargetNoteHash
'
,
`note_
${
props
.
note
.
id
}
`
);
store
.
dispatch
(
'
setTargetNoteHash
'
,
`note_
${
props
.
note
.
id
}
`
);
mock
=
new
MockAdapter
(
axios
);
vm
=
mount
(
IssueSystemNote
,
{
vm
=
mount
(
IssueSystemNote
,
{
store
,
store
,
propsData
:
props
,
propsData
:
props
,
provide
:
{
glFeatures
:
{
saveDescriptionVersions
:
true
,
descriptionDiffs
:
true
},
},
});
});
});
});
afterEach
(()
=>
{
afterEach
(()
=>
{
mock
.
restore
();
vm
.
destroy
();
vm
.
destroy
();
});
});
...
@@ -77,42 +62,4 @@ describe('system note component', () => {
...
@@ -77,42 +62,4 @@ describe('system note component', () => {
it
(
'
should initMRPopovers onMount
'
,
()
=>
{
it
(
'
should initMRPopovers onMount
'
,
()
=>
{
expect
(
initMRPopovers
).
toHaveBeenCalled
();
expect
(
initMRPopovers
).
toHaveBeenCalled
();
});
});
it
(
'
should display button to toggle description diff, description version does not display
'
,
()
=>
{
const
button
=
vm
.
find
(
'
.note-headline-light .btn-blank
'
);
expect
(
button
).
toExist
();
expect
(
button
.
text
()).
toContain
(
'
Compare with previous version
'
);
expect
(
vm
.
find
(
'
.description-version
'
).
exists
()).
toBe
(
false
);
});
it
(
'
click on button to toggle description diff displays description diff with delete icon button
'
,
done
=>
{
const
diffData
=
'
<span class="idiff">Description</span><span class="idiff addition">Diff</span>
'
;
mock
.
onGet
(
`/path/to/diff/1`
).
replyOnce
(
200
,
{
data
:
diffData
,
});
const
button
=
vm
.
find
(
'
.note-headline-light .btn-blank
'
);
button
.
trigger
(
'
click
'
);
Vue
.
nextTick
(()
=>
{
expect
(
vm
.
find
(
'
.description-version
'
).
exists
()).
toBe
(
true
);
expect
(
vm
.
find
(
'
.description-version
'
).
html
()).
toContain
(
diffData
);
expect
(
vm
.
find
(
'
.description-version button.delete-description-history svg.s16
'
).
exists
(),
).
toBe
(
true
);
done
();
});
});
it
(
'
click on delete icon button deletes description diff
'
,
done
=>
{
vm
.
find
(
'
.note-headline-light .btn-blank
'
).
trigger
(
'
click
'
);
Vue
.
nextTick
(()
=>
{
const
button
=
vm
.
find
(
'
.description-version button.delete-description-history
'
);
button
.
trigger
(
'
click
'
);
expect
(
vm
.
find
(
'
.description-version
'
).
text
()).
toContain
(
'
Deleted
'
);
done
();
});
});
});
});
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