44 lines
1.1 KiB
JavaScript
44 lines
1.1 KiB
JavaScript
import Vue from 'vue';
|
|
import timeagoTooltip from '~/vue_shared/components/time_ago_tooltip.vue';
|
|
import { formatDate, getTimeago } from '~/lib/utils/datetime_utility';
|
|
|
|
describe('Time ago with tooltip component', () => {
|
|
let TimeagoTooltip;
|
|
let vm;
|
|
|
|
beforeEach(() => {
|
|
TimeagoTooltip = Vue.extend(timeagoTooltip);
|
|
});
|
|
|
|
afterEach(() => {
|
|
vm.$destroy();
|
|
});
|
|
|
|
it('should render timeago with a bootstrap tooltip', () => {
|
|
vm = new TimeagoTooltip({
|
|
propsData: {
|
|
time: '2017-05-08T14:57:39.781Z',
|
|
},
|
|
}).$mount();
|
|
|
|
expect(vm.$el.tagName).toEqual('TIME');
|
|
expect(vm.$el.getAttribute('data-original-title')).toEqual(
|
|
formatDate('2017-05-08T14:57:39.781Z'),
|
|
);
|
|
|
|
const timeago = getTimeago();
|
|
|
|
expect(vm.$el.textContent.trim()).toEqual(timeago.format('2017-05-08T14:57:39.781Z'));
|
|
});
|
|
|
|
it('should render provided html class', () => {
|
|
vm = new TimeagoTooltip({
|
|
propsData: {
|
|
time: '2017-05-08T14:57:39.781Z',
|
|
cssClass: 'foo',
|
|
},
|
|
}).$mount();
|
|
|
|
expect(vm.$el.classList.contains('foo')).toEqual(true);
|
|
});
|
|
});
|