[release]4.1.0 (#211)
This commit is contained in:
		
							
								
								
									
										5
									
								
								tests/unit/.eslintrc.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								tests/unit/.eslintrc.js
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,5 @@
 | 
			
		||||
module.exports = {
 | 
			
		||||
  env: {
 | 
			
		||||
    jest: true
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										98
									
								
								tests/unit/components/Breadcrumb.spec.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										98
									
								
								tests/unit/components/Breadcrumb.spec.js
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,98 @@
 | 
			
		||||
import { mount, createLocalVue } from '@vue/test-utils'
 | 
			
		||||
import VueRouter from 'vue-router'
 | 
			
		||||
import ElementUI from 'element-ui'
 | 
			
		||||
import Breadcrumb from '@/components/Breadcrumb/index.vue'
 | 
			
		||||
 | 
			
		||||
const localVue = createLocalVue()
 | 
			
		||||
localVue.use(VueRouter)
 | 
			
		||||
localVue.use(ElementUI)
 | 
			
		||||
 | 
			
		||||
const routes = [
 | 
			
		||||
  {
 | 
			
		||||
    path: '/',
 | 
			
		||||
    name: 'home',
 | 
			
		||||
    children: [{
 | 
			
		||||
      path: 'dashboard',
 | 
			
		||||
      name: 'dashboard'
 | 
			
		||||
    }]
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    path: '/menu',
 | 
			
		||||
    name: 'menu',
 | 
			
		||||
    children: [{
 | 
			
		||||
      path: 'menu1',
 | 
			
		||||
      name: 'menu1',
 | 
			
		||||
      meta: { title: 'menu1' },
 | 
			
		||||
      children: [{
 | 
			
		||||
        path: 'menu1-1',
 | 
			
		||||
        name: 'menu1-1',
 | 
			
		||||
        meta: { title: 'menu1-1' }
 | 
			
		||||
      },
 | 
			
		||||
      {
 | 
			
		||||
        path: 'menu1-2',
 | 
			
		||||
        name: 'menu1-2',
 | 
			
		||||
        redirect: 'noredirect',
 | 
			
		||||
        meta: { title: 'menu1-2' },
 | 
			
		||||
        children: [{
 | 
			
		||||
          path: 'menu1-2-1',
 | 
			
		||||
          name: 'menu1-2-1',
 | 
			
		||||
          meta: { title: 'menu1-2-1' }
 | 
			
		||||
        },
 | 
			
		||||
        {
 | 
			
		||||
          path: 'menu1-2-2',
 | 
			
		||||
          name: 'menu1-2-2'
 | 
			
		||||
        }]
 | 
			
		||||
      }]
 | 
			
		||||
    }]
 | 
			
		||||
  }]
 | 
			
		||||
 | 
			
		||||
const router = new VueRouter({
 | 
			
		||||
  routes
 | 
			
		||||
})
 | 
			
		||||
 | 
			
		||||
describe('Breadcrumb.vue', () => {
 | 
			
		||||
  const wrapper = mount(Breadcrumb, {
 | 
			
		||||
    localVue,
 | 
			
		||||
    router
 | 
			
		||||
  })
 | 
			
		||||
  it('dashboard', () => {
 | 
			
		||||
    router.push('/dashboard')
 | 
			
		||||
    const len = wrapper.findAll('.el-breadcrumb__inner').length
 | 
			
		||||
    expect(len).toBe(1)
 | 
			
		||||
  })
 | 
			
		||||
  it('normal route', () => {
 | 
			
		||||
    router.push('/menu/menu1')
 | 
			
		||||
    const len = wrapper.findAll('.el-breadcrumb__inner').length
 | 
			
		||||
    expect(len).toBe(2)
 | 
			
		||||
  })
 | 
			
		||||
  it('nested route', () => {
 | 
			
		||||
    router.push('/menu/menu1/menu1-2/menu1-2-1')
 | 
			
		||||
    const len = wrapper.findAll('.el-breadcrumb__inner').length
 | 
			
		||||
    expect(len).toBe(4)
 | 
			
		||||
  })
 | 
			
		||||
  it('no meta.title', () => {
 | 
			
		||||
    router.push('/menu/menu1/menu1-2/menu1-2-2')
 | 
			
		||||
    const len = wrapper.findAll('.el-breadcrumb__inner').length
 | 
			
		||||
    expect(len).toBe(3)
 | 
			
		||||
  })
 | 
			
		||||
  // it('click link', () => {
 | 
			
		||||
  //   router.push('/menu/menu1/menu1-2/menu1-2-2')
 | 
			
		||||
  //   const breadcrumbArray = wrapper.findAll('.el-breadcrumb__inner')
 | 
			
		||||
  //   const second = breadcrumbArray.at(1)
 | 
			
		||||
  //   console.log(breadcrumbArray)
 | 
			
		||||
  //   const href = second.find('a').attributes().href
 | 
			
		||||
  //   expect(href).toBe('#/menu/menu1')
 | 
			
		||||
  // })
 | 
			
		||||
  // it('noRedirect', () => {
 | 
			
		||||
  //   router.push('/menu/menu1/menu1-2/menu1-2-1')
 | 
			
		||||
  //   const breadcrumbArray = wrapper.findAll('.el-breadcrumb__inner')
 | 
			
		||||
  //   const redirectBreadcrumb = breadcrumbArray.at(2)
 | 
			
		||||
  //   expect(redirectBreadcrumb.contains('a')).toBe(false)
 | 
			
		||||
  // })
 | 
			
		||||
  it('last breadcrumb', () => {
 | 
			
		||||
    router.push('/menu/menu1/menu1-2/menu1-2-1')
 | 
			
		||||
    const breadcrumbArray = wrapper.findAll('.el-breadcrumb__inner')
 | 
			
		||||
    const redirectBreadcrumb = breadcrumbArray.at(3)
 | 
			
		||||
    expect(redirectBreadcrumb.contains('a')).toBe(false)
 | 
			
		||||
  })
 | 
			
		||||
})
 | 
			
		||||
							
								
								
									
										18
									
								
								tests/unit/components/Hamburger.spec.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								tests/unit/components/Hamburger.spec.js
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,18 @@
 | 
			
		||||
import { shallowMount } from '@vue/test-utils'
 | 
			
		||||
import Hamburger from '@/components/Hamburger/index.vue'
 | 
			
		||||
describe('Hamburger.vue', () => {
 | 
			
		||||
  it('toggle click', () => {
 | 
			
		||||
    const wrapper = shallowMount(Hamburger)
 | 
			
		||||
    const mockFn = jest.fn()
 | 
			
		||||
    wrapper.vm.$on('toggleClick', mockFn)
 | 
			
		||||
    wrapper.find('.hamburger').trigger('click')
 | 
			
		||||
    expect(mockFn).toBeCalled()
 | 
			
		||||
  })
 | 
			
		||||
  it('prop isActive', () => {
 | 
			
		||||
    const wrapper = shallowMount(Hamburger)
 | 
			
		||||
    wrapper.setProps({ isActive: true })
 | 
			
		||||
    expect(wrapper.contains('.is-active')).toBe(true)
 | 
			
		||||
    wrapper.setProps({ isActive: false })
 | 
			
		||||
    expect(wrapper.contains('.is-active')).toBe(false)
 | 
			
		||||
  })
 | 
			
		||||
})
 | 
			
		||||
							
								
								
									
										22
									
								
								tests/unit/components/SvgIcon.spec.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								tests/unit/components/SvgIcon.spec.js
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,22 @@
 | 
			
		||||
import { shallowMount } from '@vue/test-utils'
 | 
			
		||||
import SvgIcon from '@/components/SvgIcon/index.vue'
 | 
			
		||||
describe('SvgIcon.vue', () => {
 | 
			
		||||
  it('iconClass', () => {
 | 
			
		||||
    const wrapper = shallowMount(SvgIcon, {
 | 
			
		||||
      propsData: {
 | 
			
		||||
        iconClass: 'test'
 | 
			
		||||
      }
 | 
			
		||||
    })
 | 
			
		||||
    expect(wrapper.find('use').attributes().href).toBe('#icon-test')
 | 
			
		||||
  })
 | 
			
		||||
  it('className', () => {
 | 
			
		||||
    const wrapper = shallowMount(SvgIcon, {
 | 
			
		||||
      propsData: {
 | 
			
		||||
        iconClass: 'test'
 | 
			
		||||
      }
 | 
			
		||||
    })
 | 
			
		||||
    expect(wrapper.classes().length).toBe(1)
 | 
			
		||||
    wrapper.setProps({ className: 'test' })
 | 
			
		||||
    expect(wrapper.classes().includes('test')).toBe(true)
 | 
			
		||||
  })
 | 
			
		||||
})
 | 
			
		||||
							
								
								
									
										30
									
								
								tests/unit/utils/formatTime.spec.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										30
									
								
								tests/unit/utils/formatTime.spec.js
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,30 @@
 | 
			
		||||
import { formatTime } from '@/utils/index.js'
 | 
			
		||||
 | 
			
		||||
describe('Utils:formatTime', () => {
 | 
			
		||||
  const d = new Date('2018-07-13 17:54:01') // "2018-07-13 17:54:01"
 | 
			
		||||
  const retrofit = 5 * 1000
 | 
			
		||||
 | 
			
		||||
  it('ten digits timestamp', () => {
 | 
			
		||||
    expect(formatTime((d / 1000).toFixed(0))).toBe('7月13日17时54分')
 | 
			
		||||
  })
 | 
			
		||||
  it('test now', () => {
 | 
			
		||||
    expect(formatTime(+new Date() - 1)).toBe('刚刚')
 | 
			
		||||
  })
 | 
			
		||||
  it('less two minute', () => {
 | 
			
		||||
    expect(formatTime(+new Date() - 60 * 2 * 1000 + retrofit)).toBe('2分钟前')
 | 
			
		||||
  })
 | 
			
		||||
  it('less two hour', () => {
 | 
			
		||||
    expect(formatTime(+new Date() - 60 * 60 * 2 * 1000 + retrofit)).toBe('2小时前')
 | 
			
		||||
  })
 | 
			
		||||
  it('less one day', () => {
 | 
			
		||||
    expect(formatTime(+new Date() - 60 * 60 * 24 * 1 * 1000)).toBe('1天前')
 | 
			
		||||
  })
 | 
			
		||||
  it('more than one day', () => {
 | 
			
		||||
    expect(formatTime(d)).toBe('7月13日17时54分')
 | 
			
		||||
  })
 | 
			
		||||
  it('format', () => {
 | 
			
		||||
    expect(formatTime(d, '{y}-{m}-{d} {h}:{i}')).toBe('2018-07-13 17:54')
 | 
			
		||||
    expect(formatTime(d, '{y}-{m}-{d}')).toBe('2018-07-13')
 | 
			
		||||
    expect(formatTime(d, '{y}/{m}/{d} {h}-{i}')).toBe('2018/07/13 17-54')
 | 
			
		||||
  })
 | 
			
		||||
})
 | 
			
		||||
							
								
								
									
										28
									
								
								tests/unit/utils/parseTime.spec.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										28
									
								
								tests/unit/utils/parseTime.spec.js
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,28 @@
 | 
			
		||||
import { parseTime } from '@/utils/index.js'
 | 
			
		||||
 | 
			
		||||
describe('Utils:parseTime', () => {
 | 
			
		||||
  const d = new Date('2018-07-13 17:54:01') // "2018-07-13 17:54:01"
 | 
			
		||||
  it('timestamp', () => {
 | 
			
		||||
    expect(parseTime(d)).toBe('2018-07-13 17:54:01')
 | 
			
		||||
  })
 | 
			
		||||
  it('ten digits timestamp', () => {
 | 
			
		||||
    expect(parseTime((d / 1000).toFixed(0))).toBe('2018-07-13 17:54:01')
 | 
			
		||||
  })
 | 
			
		||||
  it('new Date', () => {
 | 
			
		||||
    expect(parseTime(new Date(d))).toBe('2018-07-13 17:54:01')
 | 
			
		||||
  })
 | 
			
		||||
  it('format', () => {
 | 
			
		||||
    expect(parseTime(d, '{y}-{m}-{d} {h}:{i}')).toBe('2018-07-13 17:54')
 | 
			
		||||
    expect(parseTime(d, '{y}-{m}-{d}')).toBe('2018-07-13')
 | 
			
		||||
    expect(parseTime(d, '{y}/{m}/{d} {h}-{i}')).toBe('2018/07/13 17-54')
 | 
			
		||||
  })
 | 
			
		||||
  it('get the day of the week', () => {
 | 
			
		||||
    expect(parseTime(d, '{a}')).toBe('五') // 星期五
 | 
			
		||||
  })
 | 
			
		||||
  it('get the day of the week', () => {
 | 
			
		||||
    expect(parseTime(+d + 1000 * 60 * 60 * 24 * 2, '{a}')).toBe('日') // 星期日
 | 
			
		||||
  })
 | 
			
		||||
  it('empty argument', () => {
 | 
			
		||||
    expect(parseTime()).toBeNull()
 | 
			
		||||
  })
 | 
			
		||||
})
 | 
			
		||||
							
								
								
									
										17
									
								
								tests/unit/utils/validate.spec.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								tests/unit/utils/validate.spec.js
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,17 @@
 | 
			
		||||
import { validUsername, isExternal } from '@/utils/validate.js'
 | 
			
		||||
 | 
			
		||||
describe('Utils:validate', () => {
 | 
			
		||||
  it('validUsername', () => {
 | 
			
		||||
    expect(validUsername('admin')).toBe(true)
 | 
			
		||||
    expect(validUsername('editor')).toBe(true)
 | 
			
		||||
    expect(validUsername('xxxx')).toBe(false)
 | 
			
		||||
  })
 | 
			
		||||
  it('isExternal', () => {
 | 
			
		||||
    expect(isExternal('https://github.com/PanJiaChen/vue-element-admin')).toBe(true)
 | 
			
		||||
    expect(isExternal('http://github.com/PanJiaChen/vue-element-admin')).toBe(true)
 | 
			
		||||
    expect(isExternal('github.com/PanJiaChen/vue-element-admin')).toBe(false)
 | 
			
		||||
    expect(isExternal('/dashboard')).toBe(false)
 | 
			
		||||
    expect(isExternal('./dashboard')).toBe(false)
 | 
			
		||||
    expect(isExternal('dashboard')).toBe(false)
 | 
			
		||||
  })
 | 
			
		||||
})
 | 
			
		||||
		Reference in New Issue
	
	Block a user