mirror of
https://github.com/EKKOLearnAI/hermes-web-ui.git
synced 2026-05-25 21:40:13 +00:00
52 lines
1.5 KiB
TypeScript
52 lines
1.5 KiB
TypeScript
// @vitest-environment jsdom
|
|
import { describe, expect, it, vi } from 'vitest'
|
|
import { mount } from '@vue/test-utils'
|
|
import { defineComponent } from 'vue'
|
|
import SkillList from '@/components/hermes/skills/SkillList.vue'
|
|
|
|
vi.mock('vue-i18n', () => ({
|
|
useI18n: () => ({ t: (key: string) => key }),
|
|
}))
|
|
|
|
vi.mock('@/api/hermes/skills', () => ({
|
|
toggleSkill: vi.fn(),
|
|
}))
|
|
|
|
vi.mock('naive-ui', () => ({
|
|
NSwitch: defineComponent({
|
|
name: 'NSwitch',
|
|
props: ['value', 'loading'],
|
|
emits: ['update:value', 'click'],
|
|
template: '<button type="button" @click="$emit(\'click\')"></button>',
|
|
}),
|
|
useMessage: () => ({ error: vi.fn() }),
|
|
}))
|
|
|
|
describe('SkillList', () => {
|
|
it('supports filtering skills from external sources', () => {
|
|
const wrapper = mount(SkillList, {
|
|
props: {
|
|
categories: [
|
|
{
|
|
name: 'tools',
|
|
description: '',
|
|
skills: [
|
|
{ name: 'local-skill', description: 'Local skill', enabled: true, source: 'local' },
|
|
{ name: 'external-skill', description: 'External skill', enabled: true, source: 'external' },
|
|
],
|
|
},
|
|
],
|
|
archived: [],
|
|
selectedSkill: null,
|
|
searchQuery: '',
|
|
sourceFilter: 'external',
|
|
},
|
|
})
|
|
|
|
expect(wrapper.text()).toContain('external-skill')
|
|
expect(wrapper.text()).not.toContain('local-skill')
|
|
expect(wrapper.get('.source-dot').classes()).toContain('dot-external')
|
|
expect(wrapper.get('.source-dot').attributes('title')).toBe('skills.source.external')
|
|
})
|
|
})
|