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
Jérome Perrin
gitlab-ce
Commits
12aab8ff
Commit
12aab8ff
authored
Apr 19, 2018
by
Filipa Lacerda
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Prettify vue shared component & improve tests to match guidelines
parent
0517e1d8
Changes
5
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
191 additions
and
199 deletions
+191
-199
app/assets/javascripts/vue_shared/components/ci_badge_link.vue
...ssets/javascripts/vue_shared/components/ci_badge_link.vue
+44
-44
app/assets/javascripts/vue_shared/components/ci_icon.vue
app/assets/javascripts/vue_shared/components/ci_icon.vue
+37
-38
app/assets/javascripts/vue_shared/components/clipboard_button.vue
...ts/javascripts/vue_shared/components/clipboard_button.vue
+43
-33
spec/javascripts/vue_shared/components/ci_icon_spec.js
spec/javascripts/vue_shared/components/ci_icon_spec.js
+66
-83
spec/javascripts/vue_shared/components/clipboard_button_spec.js
...avascripts/vue_shared/components/clipboard_button_spec.js
+1
-1
No files found.
app/assets/javascripts/vue_shared/components/ci_badge_link.vue
View file @
12aab8ff
<
script
>
<
script
>
import
c
iIcon
from
'
./ci_icon.vue
'
;
import
C
iIcon
from
'
./ci_icon.vue
'
;
import
tooltip
from
'
../directives/tooltip
'
;
import
tooltip
from
'
../directives/tooltip
'
;
/**
/**
* Renders CI Badge link with CI icon and status text based on
* Renders CI Badge link with CI icon and status text based on
* API response shared between all places where it is used.
* API response shared between all places where it is used.
*
*
...
@@ -22,9 +22,9 @@
...
@@ -22,9 +22,9 @@
* - MR widget
* - MR widget
*/
*/
export
default
{
export
default
{
components
:
{
components
:
{
c
iIcon
,
C
iIcon
,
},
},
directives
:
{
directives
:
{
tooltip
,
tooltip
,
...
@@ -46,7 +46,7 @@
...
@@ -46,7 +46,7 @@
return
className
?
`ci-status ci-
${
className
}
`
:
'
ci-status
'
;
return
className
?
`ci-status ci-
${
className
}
`
:
'
ci-status
'
;
},
},
},
},
};
};
</
script
>
</
script
>
<
template
>
<
template
>
<a
<a
...
...
app/assets/javascripts/vue_shared/components/ci_icon.vue
View file @
12aab8ff
<
script
>
<
script
>
import
i
con
from
'
../../vue_shared/components/icon.vue
'
;
import
I
con
from
'
../../vue_shared/components/icon.vue
'
;
/**
/**
* Renders CI icon based on API response shared between all places where it is used.
* Renders CI icon based on API response shared between all places where it is used.
*
*
* Receives status object containing:
* Receives status object containing:
...
@@ -22,9 +22,9 @@
...
@@ -22,9 +22,9 @@
* - Jobs show view header
* - Jobs show view header
* - Jobs show view sidebar
* - Jobs show view sidebar
*/
*/
export
default
{
export
default
{
components
:
{
components
:
{
i
con
,
I
con
,
},
},
props
:
{
props
:
{
status
:
{
status
:
{
...
@@ -32,14 +32,13 @@
...
@@ -32,14 +32,13 @@
required
:
true
,
required
:
true
,
},
},
},
},
computed
:
{
computed
:
{
cssClass
()
{
cssClass
()
{
const
status
=
this
.
status
.
group
;
const
status
=
this
.
status
.
group
;
return
`ci-status-icon ci-status-icon-
${
status
}
js-ci-status-icon-
${
status
}
`
;
return
`ci-status-icon ci-status-icon-
${
status
}
js-ci-status-icon-
${
status
}
`
;
},
},
},
},
};
};
</
script
>
</
script
>
<
template
>
<
template
>
<span
:class=
"cssClass"
>
<span
:class=
"cssClass"
>
...
...
app/assets/javascripts/vue_shared/components/clipboard_button.vue
View file @
12aab8ff
<
script
>
<
script
>
/**
/**
* Falls back to the code used in `copy_to_clipboard.js`
* Falls back to the code used in `copy_to_clipboard.js`
*
* Renders a button with a clipboard icon that copies the content of `data-clipboard-text`
* when clicked.
*
* @example
* <clipboard-button
* title="Copy to clipbard"
* text="Content to be copied"
* css-class="btn-transparent"
* />
*/
*/
import
tooltip
from
'
../directives/tooltip
'
;
import
tooltip
from
'
../directives/tooltip
'
;
export
default
{
export
default
{
name
:
'
ClipboardButton
'
,
name
:
'
ClipboardButton
'
,
directives
:
{
directives
:
{
tooltip
,
tooltip
,
...
@@ -34,7 +44,7 @@
...
@@ -34,7 +44,7 @@
default
:
'
btn-default
'
,
default
:
'
btn-default
'
,
},
},
},
},
};
};
</
script
>
</
script
>
<
template
>
<
template
>
...
...
spec/javascripts/vue_shared/components/ci_icon_spec.js
View file @
12aab8ff
import
Vue
from
'
vue
'
;
import
Vue
from
'
vue
'
;
import
ciIcon
from
'
~/vue_shared/components/ci_icon.vue
'
;
import
ciIcon
from
'
~/vue_shared/components/ci_icon.vue
'
;
import
mountComponent
from
'
spec/helpers/vue_mount_component_helper
'
;
describe
(
'
CI Icon component
'
,
()
=>
{
describe
(
'
CI Icon component
'
,
()
=>
{
let
CiIcon
;
const
Component
=
Vue
.
extend
(
ciIcon
);
beforeEach
(()
=>
{
let
vm
;
CiIcon
=
Vue
.
extend
(
ciIcon
);
afterEach
(()
=>
{
vm
.
$destroy
();
});
});
it
(
'
should render a span element with an svg
'
,
()
=>
{
it
(
'
should render a span element with an svg
'
,
()
=>
{
const
component
=
new
CiIcon
({
vm
=
mountComponent
(
Component
,
{
propsData
:
{
status
:
{
status
:
{
icon
:
'
icon_status_success
'
,
icon
:
'
icon_status_success
'
,
},
},
},
});
}).
$mount
();
expect
(
component
.
$el
.
tagName
).
toEqual
(
'
SPAN
'
);
expect
(
vm
.
$el
.
tagName
).
toEqual
(
'
SPAN
'
);
expect
(
component
.
$el
.
querySelector
(
'
span > svg
'
)).
toBeDefined
();
expect
(
vm
.
$el
.
querySelector
(
'
span > svg
'
)).
toBeDefined
();
});
});
it
(
'
should render a success status
'
,
()
=>
{
it
(
'
should render a success status
'
,
()
=>
{
const
component
=
new
CiIcon
({
vm
=
mountComponent
(
Component
,
{
propsData
:
{
status
:
{
status
:
{
icon
:
'
icon_status_success
'
,
icon
:
'
icon_status_success
'
,
group
:
'
success
'
,
group
:
'
success
'
,
},
},
},
});
}).
$mount
();
expect
(
component
.
$el
.
classList
.
contains
(
'
ci-status-icon-success
'
)).
toEqual
(
true
);
expect
(
vm
.
$el
.
classList
.
contains
(
'
ci-status-icon-success
'
)).
toEqual
(
true
);
});
});
it
(
'
should render a failed status
'
,
()
=>
{
it
(
'
should render a failed status
'
,
()
=>
{
const
component
=
new
CiIcon
({
vm
=
mountComponent
(
Component
,
{
propsData
:
{
status
:
{
status
:
{
icon
:
'
icon_status_failed
'
,
icon
:
'
icon_status_failed
'
,
group
:
'
failed
'
,
group
:
'
failed
'
,
},
},
},
});
}).
$mount
();
expect
(
component
.
$el
.
classList
.
contains
(
'
ci-status-icon-failed
'
)).
toEqual
(
true
);
expect
(
vm
.
$el
.
classList
.
contains
(
'
ci-status-icon-failed
'
)).
toEqual
(
true
);
});
});
it
(
'
should render success with warnings status
'
,
()
=>
{
it
(
'
should render success with warnings status
'
,
()
=>
{
const
component
=
new
CiIcon
({
vm
=
mountComponent
(
Component
,
{
propsData
:
{
status
:
{
status
:
{
icon
:
'
icon_status_warning
'
,
icon
:
'
icon_status_warning
'
,
group
:
'
warning
'
,
group
:
'
warning
'
,
},
},
},
});
}).
$mount
();
expect
(
component
.
$el
.
classList
.
contains
(
'
ci-status-icon-warning
'
)).
toEqual
(
true
);
expect
(
vm
.
$el
.
classList
.
contains
(
'
ci-status-icon-warning
'
)).
toEqual
(
true
);
});
});
it
(
'
should render pending status
'
,
()
=>
{
it
(
'
should render pending status
'
,
()
=>
{
const
component
=
new
CiIcon
({
vm
=
mountComponent
(
Component
,
{
propsData
:
{
status
:
{
status
:
{
icon
:
'
icon_status_pending
'
,
icon
:
'
icon_status_pending
'
,
group
:
'
pending
'
,
group
:
'
pending
'
,
},
},
},
});
}).
$mount
();
expect
(
component
.
$el
.
classList
.
contains
(
'
ci-status-icon-pending
'
)).
toEqual
(
true
);
expect
(
vm
.
$el
.
classList
.
contains
(
'
ci-status-icon-pending
'
)).
toEqual
(
true
);
});
});
it
(
'
should render running status
'
,
()
=>
{
it
(
'
should render running status
'
,
()
=>
{
const
component
=
new
CiIcon
({
vm
=
mountComponent
(
Component
,
{
propsData
:
{
status
:
{
status
:
{
icon
:
'
icon_status_running
'
,
icon
:
'
icon_status_running
'
,
group
:
'
running
'
,
group
:
'
running
'
,
},
},
},
});
}).
$mount
();
expect
(
component
.
$el
.
classList
.
contains
(
'
ci-status-icon-running
'
)).
toEqual
(
true
);
expect
(
vm
.
$el
.
classList
.
contains
(
'
ci-status-icon-running
'
)).
toEqual
(
true
);
});
});
it
(
'
should render created status
'
,
()
=>
{
it
(
'
should render created status
'
,
()
=>
{
const
component
=
new
CiIcon
({
vm
=
mountComponent
(
Component
,
{
propsData
:
{
status
:
{
status
:
{
icon
:
'
icon_status_created
'
,
icon
:
'
icon_status_created
'
,
group
:
'
created
'
,
group
:
'
created
'
,
},
},
},
});
}).
$mount
();
expect
(
component
.
$el
.
classList
.
contains
(
'
ci-status-icon-created
'
)).
toEqual
(
true
);
expect
(
vm
.
$el
.
classList
.
contains
(
'
ci-status-icon-created
'
)).
toEqual
(
true
);
});
});
it
(
'
should render skipped status
'
,
()
=>
{
it
(
'
should render skipped status
'
,
()
=>
{
const
component
=
new
CiIcon
({
vm
=
mountComponent
(
Component
,
{
propsData
:
{
status
:
{
status
:
{
icon
:
'
icon_status_skipped
'
,
icon
:
'
icon_status_skipped
'
,
group
:
'
skipped
'
,
group
:
'
skipped
'
,
},
},
},
});
}).
$mount
();
expect
(
component
.
$el
.
classList
.
contains
(
'
ci-status-icon-skipped
'
)).
toEqual
(
true
);
expect
(
vm
.
$el
.
classList
.
contains
(
'
ci-status-icon-skipped
'
)).
toEqual
(
true
);
});
});
it
(
'
should render canceled status
'
,
()
=>
{
it
(
'
should render canceled status
'
,
()
=>
{
const
component
=
new
CiIcon
({
vm
=
mountComponent
(
Component
,
{
propsData
:
{
status
:
{
status
:
{
icon
:
'
icon_status_canceled
'
,
icon
:
'
icon_status_canceled
'
,
group
:
'
canceled
'
,
group
:
'
canceled
'
,
},
},
},
});
}).
$mount
();
expect
(
component
.
$el
.
classList
.
contains
(
'
ci-status-icon-canceled
'
)).
toEqual
(
true
);
expect
(
vm
.
$el
.
classList
.
contains
(
'
ci-status-icon-canceled
'
)).
toEqual
(
true
);
});
});
it
(
'
should render status for manual action
'
,
()
=>
{
it
(
'
should render status for manual action
'
,
()
=>
{
const
component
=
new
CiIcon
({
vm
=
mountComponent
(
Component
,
{
propsData
:
{
status
:
{
status
:
{
icon
:
'
icon_status_manual
'
,
icon
:
'
icon_status_manual
'
,
group
:
'
manual
'
,
group
:
'
manual
'
,
},
},
},
});
}).
$mount
();
expect
(
component
.
$el
.
classList
.
contains
(
'
ci-status-icon-manual
'
)).
toEqual
(
true
);
expect
(
vm
.
$el
.
classList
.
contains
(
'
ci-status-icon-manual
'
)).
toEqual
(
true
);
});
});
});
});
spec/javascripts/vue_shared/components/clipboard_button_spec.js
View file @
12aab8ff
...
@@ -3,10 +3,10 @@ import clipboardButton from '~/vue_shared/components/clipboard_button.vue';
...
@@ -3,10 +3,10 @@ import clipboardButton from '~/vue_shared/components/clipboard_button.vue';
import
mountComponent
from
'
spec/helpers/vue_mount_component_helper
'
;
import
mountComponent
from
'
spec/helpers/vue_mount_component_helper
'
;
describe
(
'
clipboard button
'
,
()
=>
{
describe
(
'
clipboard button
'
,
()
=>
{
const
Component
=
Vue
.
extend
(
clipboardButton
);
let
vm
;
let
vm
;
beforeEach
(()
=>
{
beforeEach
(()
=>
{
const
Component
=
Vue
.
extend
(
clipboardButton
);
vm
=
mountComponent
(
Component
,
{
vm
=
mountComponent
(
Component
,
{
text
:
'
copy me
'
,
text
:
'
copy me
'
,
title
:
'
Copy this value into Clipboard!
'
,
title
:
'
Copy this value into Clipboard!
'
,
...
...
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