116 lines
3.8 KiB
TypeScript
116 lines
3.8 KiB
TypeScript
import { describe, it, expect } from 'vitest';
|
|
import { CategoryIconViewDataBuilder } from './CategoryIconViewDataBuilder';
|
|
import type { MediaBinaryDTO } from '@/lib/types/MediaBinaryDTO';
|
|
|
|
describe('CategoryIconViewDataBuilder', () => {
|
|
describe('happy paths', () => {
|
|
it('should transform MediaBinaryDTO to CategoryIconViewData correctly', () => {
|
|
const buffer = new Uint8Array([0x89, 0x50, 0x4e, 0x47, 0x0d, 0x0a, 0x1a, 0x0a]);
|
|
const mediaDto: MediaBinaryDTO = {
|
|
buffer: buffer.buffer,
|
|
contentType: 'image/png',
|
|
};
|
|
|
|
const result = CategoryIconViewDataBuilder.build(mediaDto);
|
|
|
|
expect(result.buffer).toBe(Buffer.from(buffer).toString('base64'));
|
|
expect(result.contentType).toBe('image/png');
|
|
});
|
|
|
|
it('should handle SVG icons', () => {
|
|
const buffer = new TextEncoder().encode('<svg xmlns="http://www.w3.org/2000/svg"><circle cx="10" cy="10" r="5"/></svg>');
|
|
const mediaDto: MediaBinaryDTO = {
|
|
buffer: buffer.buffer,
|
|
contentType: 'image/svg+xml',
|
|
};
|
|
|
|
const result = CategoryIconViewDataBuilder.build(mediaDto);
|
|
|
|
expect(result.buffer).toBe(Buffer.from(buffer).toString('base64'));
|
|
expect(result.contentType).toBe('image/svg+xml');
|
|
});
|
|
|
|
it('should handle small icon files', () => {
|
|
const buffer = new Uint8Array([0x89, 0x50, 0x4e, 0x47]);
|
|
const mediaDto: MediaBinaryDTO = {
|
|
buffer: buffer.buffer,
|
|
contentType: 'image/png',
|
|
};
|
|
|
|
const result = CategoryIconViewDataBuilder.build(mediaDto);
|
|
|
|
expect(result.buffer).toBe(Buffer.from(buffer).toString('base64'));
|
|
expect(result.contentType).toBe('image/png');
|
|
});
|
|
});
|
|
|
|
describe('data transformation', () => {
|
|
it('should preserve all DTO fields in the output', () => {
|
|
const buffer = new Uint8Array([0x89, 0x50, 0x4e, 0x47]);
|
|
const mediaDto: MediaBinaryDTO = {
|
|
buffer: buffer.buffer,
|
|
contentType: 'image/png',
|
|
};
|
|
|
|
const result = CategoryIconViewDataBuilder.build(mediaDto);
|
|
|
|
expect(result.buffer).toBeDefined();
|
|
expect(result.contentType).toBe(mediaDto.contentType);
|
|
});
|
|
|
|
it('should not modify the input DTO', () => {
|
|
const buffer = new Uint8Array([0x89, 0x50, 0x4e, 0x47]);
|
|
const mediaDto: MediaBinaryDTO = {
|
|
buffer: buffer.buffer,
|
|
contentType: 'image/png',
|
|
};
|
|
|
|
const originalDto = { ...mediaDto };
|
|
CategoryIconViewDataBuilder.build(mediaDto);
|
|
|
|
expect(mediaDto).toEqual(originalDto);
|
|
});
|
|
|
|
it('should convert buffer to base64 string', () => {
|
|
const buffer = new Uint8Array([0x89, 0x50, 0x4e, 0x47, 0x0d, 0x0a, 0x1a, 0x0a]);
|
|
const mediaDto: MediaBinaryDTO = {
|
|
buffer: buffer.buffer,
|
|
contentType: 'image/png',
|
|
};
|
|
|
|
const result = CategoryIconViewDataBuilder.build(mediaDto);
|
|
|
|
expect(typeof result.buffer).toBe('string');
|
|
expect(result.buffer).toBe(Buffer.from(buffer).toString('base64'));
|
|
});
|
|
});
|
|
|
|
describe('edge cases', () => {
|
|
it('should handle empty buffer', () => {
|
|
const buffer = new Uint8Array([]);
|
|
const mediaDto: MediaBinaryDTO = {
|
|
buffer: buffer.buffer,
|
|
contentType: 'image/png',
|
|
};
|
|
|
|
const result = CategoryIconViewDataBuilder.build(mediaDto);
|
|
|
|
expect(result.buffer).toBe('');
|
|
expect(result.contentType).toBe('image/png');
|
|
});
|
|
|
|
it('should handle buffer with special characters', () => {
|
|
const buffer = new Uint8Array([0x00, 0x01, 0x02, 0x03, 0xff, 0xfe, 0xfd, 0xfc]);
|
|
const mediaDto: MediaBinaryDTO = {
|
|
buffer: buffer.buffer,
|
|
contentType: 'image/png',
|
|
};
|
|
|
|
const result = CategoryIconViewDataBuilder.build(mediaDto);
|
|
|
|
expect(result.buffer).toBe(Buffer.from(buffer).toString('base64'));
|
|
expect(result.contentType).toBe('image/png');
|
|
});
|
|
});
|
|
});
|