f0746d06db
- 删除 novalon 前端 src/ 下所有文件 - 从 gym-manage 复制前端 src/ 完整目录树 - 替换 gym-manage-api → novalon-manage-api - 替换 gym_system → manage_system - 无 gym 残留引用
268 lines
6.6 KiB
TypeScript
268 lines
6.6 KiB
TypeScript
import { describe, it, expect, beforeEach, afterEach, vi } from 'vitest'
|
|
import { mount } from '@vue/test-utils'
|
|
import { createRouter, createMemoryHistory } from 'vue-router'
|
|
import ConfigManagement from '@/views/config/ConfigManagement.vue'
|
|
|
|
vi.mock('vue-router')
|
|
vi.mock('element-plus', () => ({
|
|
ElMessage: {
|
|
success: vi.fn(),
|
|
error: vi.fn(),
|
|
},
|
|
ElMessageBox: {
|
|
confirm: vi.fn(),
|
|
},
|
|
}))
|
|
|
|
vi.mock('@/utils/request', () => {
|
|
const mockRequest = {
|
|
get: vi.fn(),
|
|
post: vi.fn(),
|
|
put: vi.fn(),
|
|
delete: vi.fn(),
|
|
}
|
|
|
|
mockRequest.get.mockResolvedValue([])
|
|
mockRequest.post.mockResolvedValue({})
|
|
mockRequest.put.mockResolvedValue({})
|
|
mockRequest.delete.mockResolvedValue({})
|
|
|
|
return {
|
|
default: mockRequest,
|
|
}
|
|
})
|
|
|
|
describe('ConfigManagement Component', () => {
|
|
let router: any
|
|
let wrapper: any
|
|
|
|
beforeEach(() => {
|
|
router = createRouter({
|
|
history: createMemoryHistory(),
|
|
routes: [
|
|
{ path: '/', component: { template: '<div>Home</div>' } },
|
|
],
|
|
})
|
|
|
|
vi.clearAllMocks()
|
|
})
|
|
|
|
afterEach(() => {
|
|
if (wrapper) {
|
|
wrapper.unmount()
|
|
}
|
|
})
|
|
|
|
describe('component initialization', () => {
|
|
it('should render config management container', () => {
|
|
wrapper = mount(ConfigManagement, {
|
|
global: {
|
|
plugins: [router],
|
|
stubs: {
|
|
'el-card': true,
|
|
'el-button': true,
|
|
'el-table': true,
|
|
'el-table-column': true,
|
|
'el-tag': true,
|
|
'el-dialog': true,
|
|
'el-form': true,
|
|
'el-form-item': true,
|
|
'el-input': true,
|
|
'el-icon': true,
|
|
},
|
|
},
|
|
})
|
|
|
|
expect(wrapper.find('.config-management').exists()).toBe(true)
|
|
})
|
|
|
|
it('should initialize with empty data source', () => {
|
|
wrapper = mount(ConfigManagement, {
|
|
global: {
|
|
plugins: [router],
|
|
stubs: {
|
|
'el-card': true,
|
|
'el-button': true,
|
|
'el-table': true,
|
|
'el-table-column': true,
|
|
'el-tag': true,
|
|
'el-dialog': true,
|
|
'el-form': true,
|
|
'el-form-item': true,
|
|
'el-input': true,
|
|
'el-icon': true,
|
|
},
|
|
},
|
|
})
|
|
|
|
expect(wrapper.vm.dataSource).toBeDefined()
|
|
expect(Array.isArray(wrapper.vm.dataSource)).toBe(true)
|
|
})
|
|
|
|
it('should initialize with loading state false', () => {
|
|
wrapper = mount(ConfigManagement, {
|
|
global: {
|
|
plugins: [router],
|
|
stubs: {
|
|
'el-card': true,
|
|
'el-button': true,
|
|
'el-table': true,
|
|
'el-table-column': true,
|
|
'el-tag': true,
|
|
'el-dialog': true,
|
|
'el-form': true,
|
|
'el-form-item': true,
|
|
'el-input': true,
|
|
'el-icon': true,
|
|
},
|
|
},
|
|
})
|
|
|
|
expect(wrapper.vm.loading).toBeDefined()
|
|
expect(typeof wrapper.vm.loading).toBe('boolean')
|
|
})
|
|
|
|
it('should initialize with modal visible false', () => {
|
|
wrapper = mount(ConfigManagement, {
|
|
global: {
|
|
plugins: [router],
|
|
stubs: {
|
|
'el-card': true,
|
|
'el-button': true,
|
|
'el-table': true,
|
|
'el-table-column': true,
|
|
'el-tag': true,
|
|
'el-dialog': true,
|
|
'el-form': true,
|
|
'el-form-item': true,
|
|
'el-input': true,
|
|
'el-icon': true,
|
|
},
|
|
},
|
|
})
|
|
|
|
expect(wrapper.vm.modalVisible).toBe(false)
|
|
})
|
|
|
|
it('should initialize with empty form state', () => {
|
|
wrapper = mount(ConfigManagement, {
|
|
global: {
|
|
plugins: [router],
|
|
stubs: {
|
|
'el-card': true,
|
|
'el-button': true,
|
|
'el-table': true,
|
|
'el-table-column': true,
|
|
'el-tag': true,
|
|
'el-dialog': true,
|
|
'el-form': true,
|
|
'el-form-item': true,
|
|
'el-input': true,
|
|
'el-icon': true,
|
|
},
|
|
},
|
|
})
|
|
|
|
expect(wrapper.vm.formState.configName).toBe('')
|
|
expect(wrapper.vm.formState.configKey).toBe('')
|
|
expect(wrapper.vm.formState.configValue).toBe('')
|
|
})
|
|
})
|
|
|
|
describe('add config functionality', () => {
|
|
it('should have handleAdd method', () => {
|
|
wrapper = mount(ConfigManagement, {
|
|
global: {
|
|
plugins: [router],
|
|
stubs: {
|
|
'el-card': true,
|
|
'el-button': true,
|
|
'el-table': true,
|
|
'el-table-column': true,
|
|
'el-tag': true,
|
|
'el-dialog': true,
|
|
'el-form': true,
|
|
'el-form-item': true,
|
|
'el-input': true,
|
|
'el-icon': true,
|
|
},
|
|
},
|
|
})
|
|
|
|
expect(typeof wrapper.vm.handleAdd).toBe('function')
|
|
})
|
|
})
|
|
|
|
describe('edit config functionality', () => {
|
|
it('should have handleEdit method', () => {
|
|
wrapper = mount(ConfigManagement, {
|
|
global: {
|
|
plugins: [router],
|
|
stubs: {
|
|
'el-card': true,
|
|
'el-button': true,
|
|
'el-table': true,
|
|
'el-table-column': true,
|
|
'el-tag': true,
|
|
'el-dialog': true,
|
|
'el-form': true,
|
|
'el-form-item': true,
|
|
'el-input': true,
|
|
'el-icon': true,
|
|
},
|
|
},
|
|
})
|
|
|
|
expect(typeof wrapper.vm.handleEdit).toBe('function')
|
|
})
|
|
})
|
|
|
|
describe('delete config functionality', () => {
|
|
it('should have handleDelete method', () => {
|
|
wrapper = mount(ConfigManagement, {
|
|
global: {
|
|
plugins: [router],
|
|
stubs: {
|
|
'el-card': true,
|
|
'el-button': true,
|
|
'el-table': true,
|
|
'el-table-column': true,
|
|
'el-tag': true,
|
|
'el-dialog': true,
|
|
'el-form': true,
|
|
'el-form-item': true,
|
|
'el-input': true,
|
|
'el-icon': true,
|
|
},
|
|
},
|
|
})
|
|
|
|
expect(typeof wrapper.vm.handleDelete).toBe('function')
|
|
})
|
|
})
|
|
|
|
describe('form submission', () => {
|
|
it('should have handleModalOk method', () => {
|
|
wrapper = mount(ConfigManagement, {
|
|
global: {
|
|
plugins: [router],
|
|
stubs: {
|
|
'el-card': true,
|
|
'el-button': true,
|
|
'el-table': true,
|
|
'el-table-column': true,
|
|
'el-tag': true,
|
|
'el-dialog': true,
|
|
'el-form': true,
|
|
'el-form-item': true,
|
|
'el-input': true,
|
|
'el-icon': true,
|
|
},
|
|
},
|
|
})
|
|
|
|
expect(typeof wrapper.vm.handleModalOk).toBe('function')
|
|
})
|
|
})
|
|
})
|