From d1466746de4eca3920f10103b814d3d95f4bfd46 Mon Sep 17 00:00:00 2001 From: provira Date: Fri, 3 Jan 2025 08:33:38 +0100 Subject: [PATCH] feat: refs #7078 created test for VnJsonValue --- .../common/__tests__/VnJsonValue.spec.js | 87 +++++++++++++++++++ 1 file changed, 87 insertions(+) create mode 100644 src/components/common/__tests__/VnJsonValue.spec.js diff --git a/src/components/common/__tests__/VnJsonValue.spec.js b/src/components/common/__tests__/VnJsonValue.spec.js new file mode 100644 index 000000000..19e563a1f --- /dev/null +++ b/src/components/common/__tests__/VnJsonValue.spec.js @@ -0,0 +1,87 @@ +import { mount } from '@vue/test-utils'; +import { describe, it, expect } from 'vitest'; +import VnJsonValue from 'src/components/common/VnJsonValue.vue'; + +const createWrapper = (props) => { + return mount(VnJsonValue, { + props, + }); +}; + +describe('VnJsonValue', () => { + it('renders null value correctly', async () => { + const wrapper = createWrapper({ value: null }); + const span = wrapper.find('span'); + expect(span.text()).toBe('∅'); + expect(span.classes()).toContain('json-null'); + }); + + it('renders boolean true correctly', async () => { + const wrapper = createWrapper({ value: true }); + const span = wrapper.find('span'); + expect(span.text()).toBe('✓'); + expect(span.classes()).toContain('json-true'); + }); + + it('renders boolean false correctly', async () => { + const wrapper = createWrapper({ value: false }); + const span = wrapper.find('span'); + expect(span.text()).toBe('✗'); + expect(span.classes()).toContain('json-false'); + }); + + it('renders a short string correctly', async () => { + const wrapper = createWrapper({ value: 'Hello' }); + const span = wrapper.find('span'); + expect(span.text()).toBe('Hello'); + expect(span.classes()).toContain('json-string'); + }); + + it('renders a long string correctly with ellipsis', async () => { + const longString = 'a'.repeat(600); + const wrapper = createWrapper({ value: longString }); + const span = wrapper.find('span'); + expect(span.text()).toContain('...'); + expect(span.text().length).toBeLessThanOrEqual(515); + expect(span.attributes('title')).toBe(longString); + expect(span.classes()).toContain('json-string'); + }); + + it('renders a number correctly', async () => { + const wrapper = createWrapper({ value: 123.4567 }); + const span = wrapper.find('span'); + expect(span.text()).toBe('123.457'); + expect(span.classes()).toContain('json-number'); + }); + + it('renders an integer correctly', async () => { + const wrapper = createWrapper({ value: 42 }); + const span = wrapper.find('span'); + expect(span.text()).toBe('42'); + expect(span.classes()).toContain('json-number'); + }); + + it('renders a date correctly', async () => { + const date = new Date('2023-01-01'); + const wrapper = createWrapper({ value: date }); + const span = wrapper.find('span'); + expect(span.text()).toBe('2023-01-01'); + expect(span.classes()).toContain('json-object'); + }); + + it('renders an object correctly', async () => { + const obj = { key: 'value' }; + const wrapper = createWrapper({ value: obj }); + const span = wrapper.find('span'); + expect(span.text()).toBe(obj.toString()); + expect(span.classes()).toContain('json-object'); + }); + + it('updates value when prop changes', async () => { + const wrapper = createWrapper({ value: true }); + await wrapper.setProps({ value: 123 }); + const span = wrapper.find('span'); + expect(span.text()).toBe('123'); + expect(span.classes()).toContain('json-number'); + }); +});