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
0
Merge Requests
0
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
Boxiang Sun
gitlab-ce
Commits
647f045d
Commit
647f045d
authored
Feb 04, 2019
by
Winnie Hellmann
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Convert note_app_spec.js to Vue test utils
parent
1350e3ae
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
86 additions
and
81 deletions
+86
-81
spec/javascripts/notes/components/note_app_spec.js
spec/javascripts/notes/components/note_app_spec.js
+86
-81
No files found.
spec/javascripts/notes/components/note_app_spec.js
View file @
647f045d
import
$
from
'
jquery
'
;
import
$
from
'
jquery
'
;
import
_
from
'
underscore
'
;
import
_
from
'
underscore
'
;
import
Vue
from
'
vue
'
;
import
Vue
from
'
vue
'
;
import
notesApp
from
'
~/notes/components/notes_app.vue
'
;
import
{
mount
,
createLocalVue
}
from
'
@vue/test-utils
'
;
import
NotesApp
from
'
~/notes/components/notes_app.vue
'
;
import
service
from
'
~/notes/services/notes_service
'
;
import
service
from
'
~/notes/services/notes_service
'
;
import
createStore
from
'
~/notes/stores
'
;
import
createStore
from
'
~/notes/stores
'
;
import
'
~/behaviors/markdown/render_gfm
'
;
import
'
~/behaviors/markdown/render_gfm
'
;
import
{
mountComponentWithStore
}
from
'
spec/helpers
'
;
import
*
as
mockData
from
'
../mock_data
'
;
import
*
as
mockData
from
'
../mock_data
'
;
const
vueMatchers
=
{
toIncludeElement
()
{
return
{
compare
(
vm
,
selector
)
{
const
result
=
{
pass
:
vm
.
$el
.
querySelector
(
selector
)
!==
null
,
};
return
result
;
},
};
},
};
describe
(
'
note_app
'
,
()
=>
{
describe
(
'
note_app
'
,
()
=>
{
let
mountComponent
;
let
mountComponent
;
let
vm
;
let
wrapper
;
let
store
;
let
store
;
beforeEach
(()
=>
{
beforeEach
(()
=>
{
jasmine
.
addMatchers
(
vueMatchers
);
$
(
'
body
'
).
attr
(
'
data-page
'
,
'
projects:merge_requests:show
'
);
$
(
'
body
'
).
attr
(
'
data-page
'
,
'
projects:merge_requests:show
'
);
setFixtures
(
'
<div class="js-vue-notes-event"><div id="app"></div></div>
'
);
const
IssueNotesApp
=
Vue
.
extend
(
notesApp
);
store
=
createStore
();
store
=
createStore
();
mountComponent
=
data
=>
{
mountComponent
=
data
=>
{
const
props
=
data
||
{
const
props
Data
=
data
||
{
noteableData
:
mockData
.
noteableDataMock
,
noteableData
:
mockData
.
noteableDataMock
,
notesData
:
mockData
.
notesDataMock
,
notesData
:
mockData
.
notesDataMock
,
userData
:
mockData
.
userDataMock
,
userData
:
mockData
.
userDataMock
,
};
};
const
localVue
=
createLocalVue
();
return
mountComponentWithStore
(
IssueNotesApp
,
{
props
,
return
mount
(
store
,
{
el
:
document
.
getElementById
(
'
app
'
),
components
:
{
});
NotesApp
,
},
template
:
'
<div class="js-vue-notes-event"><notes-app v-bind="$attrs" /></div>
'
,
},
{
propsData
,
store
,
localVue
,
sync
:
false
,
},
);
};
};
});
});
afterEach
(()
=>
{
afterEach
(()
=>
{
vm
.
$
destroy
();
wrapper
.
destroy
();
});
});
describe
(
'
set data
'
,
()
=>
{
describe
(
'
set data
'
,
()
=>
{
...
@@ -65,7 +57,7 @@ describe('note_app', () => {
...
@@ -65,7 +57,7 @@ describe('note_app', () => {
beforeEach
(()
=>
{
beforeEach
(()
=>
{
Vue
.
http
.
interceptors
.
push
(
responseInterceptor
);
Vue
.
http
.
interceptors
.
push
(
responseInterceptor
);
vm
=
mountComponent
();
wrapper
=
mountComponent
();
});
});
afterEach
(()
=>
{
afterEach
(()
=>
{
...
@@ -73,26 +65,26 @@ describe('note_app', () => {
...
@@ -73,26 +65,26 @@ describe('note_app', () => {
});
});
it
(
'
should set notes data
'
,
()
=>
{
it
(
'
should set notes data
'
,
()
=>
{
expect
(
vm
.
$
store
.
state
.
notesData
).
toEqual
(
mockData
.
notesDataMock
);
expect
(
store
.
state
.
notesData
).
toEqual
(
mockData
.
notesDataMock
);
});
});
it
(
'
should set issue data
'
,
()
=>
{
it
(
'
should set issue data
'
,
()
=>
{
expect
(
vm
.
$
store
.
state
.
noteableData
).
toEqual
(
mockData
.
noteableDataMock
);
expect
(
store
.
state
.
noteableData
).
toEqual
(
mockData
.
noteableDataMock
);
});
});
it
(
'
should set user data
'
,
()
=>
{
it
(
'
should set user data
'
,
()
=>
{
expect
(
vm
.
$
store
.
state
.
userData
).
toEqual
(
mockData
.
userDataMock
);
expect
(
store
.
state
.
userData
).
toEqual
(
mockData
.
userDataMock
);
});
});
it
(
'
should fetch discussions
'
,
()
=>
{
it
(
'
should fetch discussions
'
,
()
=>
{
expect
(
vm
.
$
store
.
state
.
discussions
).
toEqual
([]);
expect
(
store
.
state
.
discussions
).
toEqual
([]);
});
});
});
});
describe
(
'
render
'
,
()
=>
{
describe
(
'
render
'
,
()
=>
{
beforeEach
(()
=>
{
beforeEach
(()
=>
{
Vue
.
http
.
interceptors
.
push
(
mockData
.
individualNoteInterceptor
);
Vue
.
http
.
interceptors
.
push
(
mockData
.
individualNoteInterceptor
);
vm
=
mountComponent
();
wrapper
=
mountComponent
();
});
});
afterEach
(()
=>
{
afterEach
(()
=>
{
...
@@ -107,51 +99,50 @@ describe('note_app', () => {
...
@@ -107,51 +99,50 @@ describe('note_app', () => {
setTimeout
(()
=>
{
setTimeout
(()
=>
{
expect
(
expect
(
vm
.
$el
.
querySelector
(
'
.main-notes-list .note-header-author-name
'
).
textContent
.
trim
(),
wrapper
.
find
(
'
.main-notes-list .note-header-author-name
'
)
.
text
()
.
trim
(),
).
toEqual
(
note
.
author
.
name
);
).
toEqual
(
note
.
author
.
name
);
expect
(
vm
.
$el
.
querySelector
(
'
.main-notes-list .note-text
'
).
innerHTML
).
toEqual
(
expect
(
wrapper
.
find
(
'
.main-notes-list .note-text
'
).
html
()).
toContain
(
note
.
note_html
);
note
.
note_html
,
);
done
();
done
();
},
0
);
},
0
);
});
});
it
(
'
should render form
'
,
()
=>
{
it
(
'
should render form
'
,
()
=>
{
expect
(
vm
.
$el
.
querySelector
(
'
.js-main-target-form
'
).
tagName
).
toEqual
(
'
FORM
'
);
expect
(
wrapper
.
find
(
'
.js-main-target-form
'
).
name
()).
toEqual
(
'
form
'
);
expect
(
expect
(
wrapper
.
find
(
'
.js-main-target-form textarea
'
).
attributes
(
'
placeholder
'
)).
toEqual
(
vm
.
$el
.
querySelector
(
'
.js-main-target-form textarea
'
).
getAttribute
(
'
placeholder
'
)
,
'
Write a comment or drag your files here…
'
,
)
.
toEqual
(
'
Write a comment or drag your files here…
'
)
;
);
});
});
it
(
'
should not render form when commenting is disabled
'
,
()
=>
{
it
(
'
should not render form when commenting is disabled
'
,
()
=>
{
store
.
state
.
commentsDisabled
=
true
;
store
.
state
.
commentsDisabled
=
true
;
vm
=
mountComponent
();
wrapper
=
mountComponent
();
expect
(
vm
.
$el
.
querySelector
(
'
.js-main-target-form
'
)).
toEqual
(
null
);
expect
(
wrapper
.
find
(
'
.js-main-target-form
'
).
exists
()).
toBe
(
false
);
});
});
it
(
'
should render form comment button as disabled
'
,
()
=>
{
it
(
'
should render form comment button as disabled
'
,
()
=>
{
expect
(
vm
.
$el
.
querySelector
(
'
.js-note-new-discussion
'
).
getAttribute
(
'
disabled
'
)).
toEqual
(
expect
(
wrapper
.
find
(
'
.js-note-new-discussion
'
).
attributes
(
'
disabled
'
)).
toEqual
(
'
disabled
'
);
'
disabled
'
,
);
});
});
});
});
describe
(
'
while fetching data
'
,
()
=>
{
describe
(
'
while fetching data
'
,
()
=>
{
beforeEach
(()
=>
{
beforeEach
(()
=>
{
vm
=
mountComponent
();
wrapper
=
mountComponent
();
});
});
it
(
'
renders skeleton notes
'
,
()
=>
{
it
(
'
renders skeleton notes
'
,
()
=>
{
expect
(
vm
).
toIncludeElement
(
'
.animation-container
'
);
expect
(
wrapper
.
find
(
'
.animation-container
'
).
exists
()).
toBe
(
true
);
});
});
it
(
'
should render form
'
,
()
=>
{
it
(
'
should render form
'
,
()
=>
{
expect
(
vm
.
$el
.
querySelector
(
'
.js-main-target-form
'
).
tagName
).
toEqual
(
'
FORM
'
);
expect
(
wrapper
.
find
(
'
.js-main-target-form
'
).
name
()).
toEqual
(
'
form
'
);
expect
(
expect
(
wrapper
.
find
(
'
.js-main-target-form textarea
'
).
attributes
(
'
placeholder
'
)).
toEqual
(
vm
.
$el
.
querySelector
(
'
.js-main-target-form textarea
'
).
getAttribute
(
'
placeholder
'
)
,
'
Write a comment or drag your files here…
'
,
)
.
toEqual
(
'
Write a comment or drag your files here…
'
)
;
);
});
});
});
});
...
@@ -160,9 +151,9 @@ describe('note_app', () => {
...
@@ -160,9 +151,9 @@ describe('note_app', () => {
beforeEach
(
done
=>
{
beforeEach
(
done
=>
{
Vue
.
http
.
interceptors
.
push
(
mockData
.
individualNoteInterceptor
);
Vue
.
http
.
interceptors
.
push
(
mockData
.
individualNoteInterceptor
);
spyOn
(
service
,
'
updateNote
'
).
and
.
callThrough
();
spyOn
(
service
,
'
updateNote
'
).
and
.
callThrough
();
vm
=
mountComponent
();
wrapper
=
mountComponent
();
setTimeout
(()
=>
{
setTimeout
(()
=>
{
vm
.
$el
.
querySelector
(
'
.js-note-edit
'
).
click
(
);
wrapper
.
find
(
'
.js-note-edit
'
).
trigger
(
'
click
'
);
Vue
.
nextTick
(
done
);
Vue
.
nextTick
(
done
);
},
0
);
},
0
);
});
});
...
@@ -175,12 +166,12 @@ describe('note_app', () => {
...
@@ -175,12 +166,12 @@ describe('note_app', () => {
});
});
it
(
'
renders edit form
'
,
()
=>
{
it
(
'
renders edit form
'
,
()
=>
{
expect
(
vm
).
toIncludeElement
(
'
.js-vue-issue-note-form
'
);
expect
(
wrapper
.
find
(
'
.js-vue-issue-note-form
'
).
exists
()).
toBe
(
true
);
});
});
it
(
'
calls the service to update the note
'
,
done
=>
{
it
(
'
calls the service to update the note
'
,
done
=>
{
vm
.
$el
.
querySelector
(
'
.js-vue-issue-note-form
'
).
value
=
'
this is a note
'
;
wrapper
.
find
(
'
.js-vue-issue-note-form
'
).
value
=
'
this is a note
'
;
vm
.
$el
.
querySelector
(
'
.js-vue-issue-save
'
).
click
(
);
wrapper
.
find
(
'
.js-vue-issue-save
'
).
trigger
(
'
click
'
);
expect
(
service
.
updateNote
).
toHaveBeenCalled
();
expect
(
service
.
updateNote
).
toHaveBeenCalled
();
// Wait for the requests to finish before destroying
// Wait for the requests to finish before destroying
...
@@ -194,10 +185,10 @@ describe('note_app', () => {
...
@@ -194,10 +185,10 @@ describe('note_app', () => {
beforeEach
(
done
=>
{
beforeEach
(
done
=>
{
Vue
.
http
.
interceptors
.
push
(
mockData
.
discussionNoteInterceptor
);
Vue
.
http
.
interceptors
.
push
(
mockData
.
discussionNoteInterceptor
);
spyOn
(
service
,
'
updateNote
'
).
and
.
callThrough
();
spyOn
(
service
,
'
updateNote
'
).
and
.
callThrough
();
vm
=
mountComponent
();
wrapper
=
mountComponent
();
setTimeout
(()
=>
{
setTimeout
(()
=>
{
vm
.
$el
.
querySelector
(
'
.js-note-edit
'
).
click
(
);
wrapper
.
find
(
'
.js-note-edit
'
).
trigger
(
'
click
'
);
Vue
.
nextTick
(
done
);
Vue
.
nextTick
(
done
);
},
0
);
},
0
);
});
});
...
@@ -210,12 +201,12 @@ describe('note_app', () => {
...
@@ -210,12 +201,12 @@ describe('note_app', () => {
});
});
it
(
'
renders edit form
'
,
()
=>
{
it
(
'
renders edit form
'
,
()
=>
{
expect
(
vm
).
toIncludeElement
(
'
.js-vue-issue-note-form
'
);
expect
(
wrapper
.
find
(
'
.js-vue-issue-note-form
'
).
exists
()).
toBe
(
true
);
});
});
it
(
'
updates the note and resets the edit form
'
,
done
=>
{
it
(
'
updates the note and resets the edit form
'
,
done
=>
{
vm
.
$el
.
querySelector
(
'
.js-vue-issue-note-form
'
).
value
=
'
this is a note
'
;
wrapper
.
find
(
'
.js-vue-issue-note-form
'
).
value
=
'
this is a note
'
;
vm
.
$el
.
querySelector
(
'
.js-vue-issue-save
'
).
click
(
);
wrapper
.
find
(
'
.js-vue-issue-save
'
).
trigger
(
'
click
'
);
expect
(
service
.
updateNote
).
toHaveBeenCalled
();
expect
(
service
.
updateNote
).
toHaveBeenCalled
();
// Wait for the requests to finish before destroying
// Wait for the requests to finish before destroying
...
@@ -228,30 +219,36 @@ describe('note_app', () => {
...
@@ -228,30 +219,36 @@ describe('note_app', () => {
describe
(
'
new note form
'
,
()
=>
{
describe
(
'
new note form
'
,
()
=>
{
beforeEach
(()
=>
{
beforeEach
(()
=>
{
vm
=
mountComponent
();
wrapper
=
mountComponent
();
});
});
it
(
'
should render markdown docs url
'
,
()
=>
{
it
(
'
should render markdown docs url
'
,
()
=>
{
const
{
markdownDocsPath
}
=
mockData
.
notesDataMock
;
const
{
markdownDocsPath
}
=
mockData
.
notesDataMock
;
expect
(
vm
.
$el
.
querySelector
(
`a[href="
${
markdownDocsPath
}
"]`
).
textContent
.
trim
()).
toEqual
(
expect
(
'
Markdown
'
,
wrapper
);
.
find
(
`a[href="
${
markdownDocsPath
}
"]`
)
.
text
()
.
trim
(),
).
toEqual
(
'
Markdown
'
);
});
});
it
(
'
should render quick action docs url
'
,
()
=>
{
it
(
'
should render quick action docs url
'
,
()
=>
{
const
{
quickActionsDocsPath
}
=
mockData
.
notesDataMock
;
const
{
quickActionsDocsPath
}
=
mockData
.
notesDataMock
;
expect
(
vm
.
$el
.
querySelector
(
`a[href="
${
quickActionsDocsPath
}
"]`
).
textContent
.
trim
()).
toEqual
(
expect
(
'
quick actions
'
,
wrapper
);
.
find
(
`a[href="
${
quickActionsDocsPath
}
"]`
)
.
text
()
.
trim
(),
).
toEqual
(
'
quick actions
'
);
});
});
});
});
describe
(
'
edit form
'
,
()
=>
{
describe
(
'
edit form
'
,
()
=>
{
beforeEach
(()
=>
{
beforeEach
(()
=>
{
Vue
.
http
.
interceptors
.
push
(
mockData
.
individualNoteInterceptor
);
Vue
.
http
.
interceptors
.
push
(
mockData
.
individualNoteInterceptor
);
vm
=
mountComponent
();
wrapper
=
mountComponent
();
});
});
afterEach
(()
=>
{
afterEach
(()
=>
{
...
@@ -260,12 +257,15 @@ describe('note_app', () => {
...
@@ -260,12 +257,15 @@ describe('note_app', () => {
it
(
'
should render markdown docs url
'
,
done
=>
{
it
(
'
should render markdown docs url
'
,
done
=>
{
setTimeout
(()
=>
{
setTimeout
(()
=>
{
vm
.
$el
.
querySelector
(
'
.js-note-edit
'
).
click
(
);
wrapper
.
find
(
'
.js-note-edit
'
).
trigger
(
'
click
'
);
const
{
markdownDocsPath
}
=
mockData
.
notesDataMock
;
const
{
markdownDocsPath
}
=
mockData
.
notesDataMock
;
Vue
.
nextTick
(()
=>
{
Vue
.
nextTick
(()
=>
{
expect
(
expect
(
vm
.
$el
.
querySelector
(
`.edit-note a[href="
${
markdownDocsPath
}
"]`
).
textContent
.
trim
(),
wrapper
.
find
(
`.edit-note a[href="
${
markdownDocsPath
}
"]`
)
.
text
()
.
trim
(),
).
toEqual
(
'
Markdown is supported
'
);
).
toEqual
(
'
Markdown is supported
'
);
done
();
done
();
});
});
...
@@ -274,13 +274,11 @@ describe('note_app', () => {
...
@@ -274,13 +274,11 @@ describe('note_app', () => {
it
(
'
should not render quick actions docs url
'
,
done
=>
{
it
(
'
should not render quick actions docs url
'
,
done
=>
{
setTimeout
(()
=>
{
setTimeout
(()
=>
{
vm
.
$el
.
querySelector
(
'
.js-note-edit
'
).
click
(
);
wrapper
.
find
(
'
.js-note-edit
'
).
trigger
(
'
click
'
);
const
{
quickActionsDocsPath
}
=
mockData
.
notesDataMock
;
const
{
quickActionsDocsPath
}
=
mockData
.
notesDataMock
;
Vue
.
nextTick
(()
=>
{
Vue
.
nextTick
(()
=>
{
expect
(
vm
.
$el
.
querySelector
(
`.edit-note a[href="
${
quickActionsDocsPath
}
"]`
)).
toEqual
(
expect
(
wrapper
.
find
(
`.edit-note a[href="
${
quickActionsDocsPath
}
"]`
).
exists
()).
toBe
(
false
);
null
,
);
done
();
done
();
});
});
},
0
);
},
0
);
...
@@ -295,12 +293,19 @@ describe('note_app', () => {
...
@@ -295,12 +293,19 @@ describe('note_app', () => {
noteId
:
1
,
noteId
:
1
,
},
},
});
});
const
toggleAwardAction
=
jasmine
.
createSpy
(
'
toggleAward
'
);
wrapper
.
vm
.
$store
.
hotUpdate
({
actions
:
{
toggleAward
:
toggleAwardAction
,
},
});
spyOn
(
vm
.
$store
,
'
dispatch
'
);
wrapper
.
vm
.
$parent
.
$el
.
dispatchEvent
(
toggleAwardEvent
);
vm
.
$el
.
parentElement
.
dispatchEvent
(
toggleAwardEvent
);
expect
(
toggleAwardAction
).
toHaveBeenCalledTimes
(
1
);
const
[,
payload
]
=
toggleAwardAction
.
calls
.
argsFor
(
0
);
expect
(
vm
.
$store
.
dispatch
).
toHaveBeenCalledWith
(
'
toggleAward
'
,
{
expect
(
payload
).
toEqual
(
{
awardName
:
'
test
'
,
awardName
:
'
test
'
,
noteId
:
1
,
noteId
:
1
,
});
});
...
...
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