StackGenVis: Alignment of Data, Algorithms, and Models for Stacking Ensemble Learning Using Performance Metrics https://doi.org/10.1109/TVCG.2020.3030352
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
StackGenVis/frontend/node_modules/bootstrap-vue/src/components/link/link.spec.js

385 lines
11 KiB

import VueRouter from 'vue-router'
import { mount, createLocalVue as CreateLocalVue } from '@vue/test-utils'
import { BLink } from './link'
describe('b-link', () => {
it('has expected default structure', async () => {
const wrapper = mount(BLink)
expect(wrapper.is('a')).toBe(true)
expect(wrapper.attributes('href')).toEqual('#')
expect(wrapper.attributes('target')).toEqual('_self')
expect(wrapper.attributes('rel')).not.toBeDefined()
expect(wrapper.attributes('aria-disabled')).not.toBeDefined()
expect(wrapper.classes().length).toBe(0)
expect(wrapper.text()).toEqual('')
wrapper.destroy()
})
it('renders content from default slot', async () => {
const wrapper = mount(BLink, {
slots: {
default: 'foobar'
}
})
expect(wrapper.is('a')).toBe(true)
expect(wrapper.attributes('href')).toEqual('#')
expect(wrapper.attributes('target')).toEqual('_self')
expect(wrapper.attributes('rel')).not.toBeDefined()
expect(wrapper.attributes('aria-disabled')).not.toBeDefined()
expect(wrapper.classes().length).toBe(0)
expect(wrapper.text()).toEqual('foobar')
wrapper.destroy()
})
it('sets attribute href to user supplied value', async () => {
const wrapper = mount(BLink, {
propsData: {
href: '/foobar'
}
})
expect(wrapper.is('a')).toBe(true)
expect(wrapper.attributes('href')).toEqual('/foobar')
expect(wrapper.attributes('target')).toEqual('_self')
expect(wrapper.attributes('rel')).not.toBeDefined()
expect(wrapper.attributes('aria-disabled')).not.toBeDefined()
expect(wrapper.classes().length).toBe(0)
expect(wrapper.text()).toEqual('')
wrapper.destroy()
})
it('sets attribute href when user supplied href is hash target', async () => {
const wrapper = mount(BLink, {
propsData: {
href: '#foobar'
}
})
expect(wrapper.is('a')).toBe(true)
expect(wrapper.attributes('href')).toEqual('#foobar')
expect(wrapper.attributes('target')).toEqual('_self')
expect(wrapper.attributes('rel')).not.toBeDefined()
expect(wrapper.attributes('aria-disabled')).not.toBeDefined()
expect(wrapper.classes().length).toBe(0)
expect(wrapper.text()).toEqual('')
wrapper.destroy()
})
it('should set href to string `to` prop', async () => {
const wrapper = mount(BLink, {
propsData: {
to: '/foobar'
}
})
expect(wrapper.is('a')).toBe(true)
expect(wrapper.attributes('href')).toEqual('/foobar')
expect(wrapper.attributes('target')).toEqual('_self')
expect(wrapper.attributes('rel')).not.toBeDefined()
expect(wrapper.attributes('aria-disabled')).not.toBeDefined()
expect(wrapper.classes().length).toBe(0)
expect(wrapper.text()).toEqual('')
wrapper.destroy()
})
it('should set href to path from `to` prop', async () => {
const wrapper = mount(BLink, {
propsData: {
to: { path: '/foobar' }
}
})
expect(wrapper.is('a')).toBe(true)
expect(wrapper.attributes('href')).toEqual('/foobar')
expect(wrapper.attributes('target')).toEqual('_self')
expect(wrapper.attributes('rel')).not.toBeDefined()
expect(wrapper.attributes('aria-disabled')).not.toBeDefined()
expect(wrapper.classes().length).toBe(0)
expect(wrapper.text()).toEqual('')
wrapper.destroy()
})
it('should default rel to `noopener` when target==="_blank"', async () => {
const wrapper = mount(BLink, {
propsData: {
href: '/foobar',
target: '_blank'
}
})
expect(wrapper.is('a')).toBe(true)
expect(wrapper.attributes('href')).toEqual('/foobar')
expect(wrapper.attributes('target')).toEqual('_blank')
expect(wrapper.attributes('rel')).toEqual('noopener')
expect(wrapper.classes().length).toBe(0)
wrapper.destroy()
})
it('should render the given rel to when target==="_blank"', async () => {
const wrapper = mount(BLink, {
propsData: {
href: '/foobar',
target: '_blank',
rel: 'alternate'
}
})
expect(wrapper.is('a')).toBe(true)
expect(wrapper.attributes('href')).toEqual('/foobar')
expect(wrapper.attributes('target')).toEqual('_blank')
expect(wrapper.attributes('rel')).toEqual('alternate')
expect(wrapper.classes().length).toBe(0)
wrapper.destroy()
})
it('should add "active" class when prop active=true', async () => {
const wrapper = mount(BLink, {
propsData: {
active: true
}
})
expect(wrapper.is('a')).toBe(true)
expect(wrapper.classes()).toContain('active')
expect(wrapper.classes().length).toBe(1)
wrapper.destroy()
})
it('should add aria-disabled="true" when disabled', async () => {
const wrapper = mount(BLink, {
propsData: {
disabled: true
}
})
expect(wrapper.attributes('aria-disabled')).toBeDefined()
expect(wrapper.attributes('aria-disabled')).toEqual('true')
wrapper.destroy()
})
it("should add '.disabled' class when prop disabled=true", async () => {
const wrapper = mount(BLink, {
propsData: {
disabled: true
}
})
expect(wrapper.classes()).toContain('disabled')
wrapper.destroy()
})
it('focus and blur methods work', async () => {
const wrapper = mount(BLink, {
attachToDocument: true,
propsData: {
href: '#foobar'
}
})
expect(wrapper.is('a')).toBe(true)
expect(document.activeElement).not.toBe(wrapper.element)
wrapper.vm.focus()
expect(document.activeElement).toBe(wrapper.element)
wrapper.vm.blur()
expect(document.activeElement).not.toBe(wrapper.element)
wrapper.destroy()
})
describe('click handling', () => {
const localVue = new CreateLocalVue()
it('should invoke click handler bound by Vue when clicked on', async () => {
let called = 0
let evt = null
const wrapper = mount(BLink, {
listeners: {
click: e => {
evt = e
called++
}
}
})
expect(wrapper.is('a')).toBe(true)
expect(called).toBe(0)
expect(evt).toEqual(null)
wrapper.find('a').trigger('click')
expect(called).toBe(1)
expect(evt).toBeInstanceOf(MouseEvent)
wrapper.destroy()
})
it('should invoke multiple click handlers bound by Vue when clicked on', async () => {
const spy1 = jest.fn()
const spy2 = jest.fn()
const wrapper = mount(BLink, {
listeners: {
click: [spy1, spy2]
}
})
expect(wrapper.is('a')).toBe(true)
expect(spy1).not.toHaveBeenCalled()
expect(spy2).not.toHaveBeenCalled()
wrapper.find('a').trigger('click')
expect(spy1).toHaveBeenCalled()
expect(spy2).toHaveBeenCalled()
wrapper.destroy()
})
it('should NOT invoke click handler bound by Vue when disabled and clicked', async () => {
let called = 0
let evt = null
const wrapper = mount(BLink, {
propsData: {
disabled: true
},
listeners: {
click: e => {
evt = e
called++
}
}
})
expect(wrapper.is('a')).toBe(true)
expect(called).toBe(0)
expect(evt).toEqual(null)
wrapper.find('a').trigger('click')
expect(called).toBe(0)
expect(evt).toEqual(null)
wrapper.destroy()
})
it('should NOT invoke click handler bound via "addEventListener" when disabled and clicked', async () => {
const wrapper = mount(BLink, {
propsData: {
disabled: true
}
})
const spy = jest.fn()
expect(wrapper.is('a')).toBe(true)
wrapper.find('a').element.addEventListener('click', spy)
wrapper.find('a').trigger('click')
expect(spy).not.toHaveBeenCalled()
wrapper.destroy()
})
it('should emit "clicked::link" on $root when clicked on', async () => {
const App = localVue.extend({
render(h) {
return h('div', [h(BLink, { props: { href: '/foo' } }, 'link')])
}
})
const spy = jest.fn()
const wrapper = mount(App, {
localVue: localVue
})
wrapper.vm.$root.$on('clicked::link', spy)
wrapper.find('a').trigger('click')
expect(spy).toHaveBeenCalled()
wrapper.destroy()
})
it('should NOT emit "clicked::link" on $root when clicked on when disabled', async () => {
const App = localVue.extend({
render(h) {
return h('div', [h(BLink, { props: { href: '/foo', disabled: true } }, 'link')])
}
})
const spy = jest.fn()
const wrapper = mount(App, {
localVue: localVue
})
expect(wrapper.isVueInstance()).toBe(true)
wrapper.vm.$root.$on('clicked::link', spy)
wrapper.find('a').trigger('click')
expect(spy).not.toHaveBeenCalled()
wrapper.destroy()
})
})
describe('router-link support', () => {
it('works', async () => {
const localVue = new CreateLocalVue()
localVue.use(VueRouter)
const router = new VueRouter({
mode: 'abstract',
routes: [
{ path: '/', component: { name: 'R', template: '<div class="r">ROOT</div>' } },
{ path: '/a', component: { name: 'A', template: '<div class="a">A</div>' } },
{ path: '/b', component: { name: 'B', template: '<div class="a">B</div>' } }
]
})
const App = localVue.extend({
router,
components: { BLink },
render(h) {
return h('main', [
// router-link
h('b-link', { props: { to: '/a' } }, ['to-a']),
// regular link
h('b-link', { props: { href: '/a' } }, ['href-a']),
// router-link
h('b-link', { props: { to: { path: '/b' } } }, ['to-path-b']),
// regular link
h('b-link', { props: { href: '/b' } }, ['href-a']),
h('router-view')
])
}
})
const wrapper = mount(App, {
localVue: localVue,
attachToDocument: true
})
expect(wrapper.isVueInstance()).toBe(true)
expect(wrapper.is('main')).toBe(true)
expect(wrapper.findAll('a').length).toBe(4)
const $links = wrapper.findAll('a')
expect($links.at(0).isVueInstance()).toBe(true)
expect($links.at(0).vm.$options.name).toBe('BLink')
expect($links.at(0).vm.$children.length).toBe(1)
expect($links.at(0).vm.$children[0].$options.name).toBe('RouterLink')
expect($links.at(1).isVueInstance()).toBe(true)
expect($links.at(1).vm.$options.name).toBe('BLink')
expect($links.at(1).vm.$children.length).toBe(0)
expect($links.at(2).isVueInstance()).toBe(true)
expect($links.at(2).vm.$options.name).toBe('BLink')
expect($links.at(2).vm.$children.length).toBe(1)
expect($links.at(2).vm.$children[0].$options.name).toBe('RouterLink')
expect($links.at(3).isVueInstance()).toBe(true)
expect($links.at(3).vm.$options.name).toBe('BLink')
expect($links.at(3).vm.$children.length).toBe(0)
wrapper.destroy()
})
})
})