 6798effbab
			
		
	
	6798effbab
	
	
	
		
			
			* .formラッパーを削除 * fix type of MkPostFormAttaches * 🚀 * 🎨 * 🎨 * 🎨 * 🎨 * specifiedの時は連合なしをdisabledに * ✌️ * set select default * gap: 2px (max-width: 500px) / 4px * wip * ✌️ * 🎨 * fix maxTextLength * 今後表示しない * 🎨 * cache channel * 🎨 * 連合なしにする * use i18n.ts.neverShow * ✌️ * refactor * fix indent * tweak --------- Co-authored-by: syuilo <Syuilotan@yahoo.co.jp>
		
			
				
	
	
		
			99 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			99 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import { describe, test, assert, afterEach } from 'vitest';
 | |
| import { render, cleanup, type RenderResult } from '@testing-library/vue';
 | |
| import './init';
 | |
| import type { DriveFile } from 'misskey-js/built/entities';
 | |
| import { components } from '@/components';
 | |
| import { directives } from '@/directives';
 | |
| import MkMediaImage from '@/components/MkMediaImage.vue';
 | |
| 
 | |
| describe('MkMediaImage', () => {
 | |
| 	const renderMediaImage = (image: Partial<DriveFile>): RenderResult => {
 | |
| 		return render(MkMediaImage, {
 | |
| 			props: {
 | |
| 				image: {
 | |
| 					id: 'xxxxxxxx',
 | |
| 					createdAt: (new Date()).toJSON(),
 | |
| 					isSensitive: false,
 | |
| 					name: 'example.png',
 | |
| 					thumbnailUrl: null,
 | |
| 					url: '',
 | |
| 					type: 'application/octet-stream',
 | |
| 					size: 1,
 | |
| 					md5: '15eca7fba0480996e2245f5185bf39f2',
 | |
| 					blurhash: null,
 | |
| 					comment: null,
 | |
| 					properties: {},
 | |
| 					...image,
 | |
| 				} as DriveFile,
 | |
| 			},
 | |
| 			global: { directives, components },
 | |
| 		});
 | |
| 	};
 | |
| 
 | |
| 	afterEach(() => {
 | |
| 		cleanup();
 | |
| 	});
 | |
| 
 | |
| 	test('Attaching JPG should show no indicator', async () => {
 | |
| 		const mkMediaImage = renderMediaImage({
 | |
| 			type: 'image/jpeg',
 | |
| 		});
 | |
| 		const [gif, alt] = await Promise.all([
 | |
| 			mkMediaImage.queryByText('GIF'),
 | |
| 			mkMediaImage.queryByText('ALT'),
 | |
| 		]);
 | |
| 		assert.ok(!gif);
 | |
| 		assert.ok(!alt);
 | |
| 	});
 | |
| 
 | |
| 	test('Attaching GIF should show a GIF indicator', async () => {
 | |
| 		const mkMediaImage = renderMediaImage({
 | |
| 			type: 'image/gif',
 | |
| 		});
 | |
| 		const [gif, alt] = await Promise.all([
 | |
| 			mkMediaImage.queryByText('GIF'),
 | |
| 			mkMediaImage.queryByText('ALT'),
 | |
| 		]);
 | |
| 		assert.ok(gif);
 | |
| 		assert.ok(!alt);
 | |
| 	});
 | |
| 
 | |
| 	test('Attaching APNG should show a GIF indicator', async () => {
 | |
| 		const mkMediaImage = renderMediaImage({
 | |
| 			type: 'image/apng',
 | |
| 		});
 | |
| 		const [gif, alt] = await Promise.all([
 | |
| 			mkMediaImage.queryByText('GIF'),
 | |
| 			mkMediaImage.queryByText('ALT'),
 | |
| 		]);
 | |
| 		assert.ok(gif);
 | |
| 		assert.ok(!alt);
 | |
| 	});
 | |
| 
 | |
| 	test('Attaching image with an alt message should show an ALT indicator', async () => {
 | |
| 		const mkMediaImage = renderMediaImage({
 | |
| 			type: 'image/png',
 | |
| 			comment: 'Misskeyのロゴです',
 | |
| 		});
 | |
| 		const [gif, alt] = await Promise.all([
 | |
| 			mkMediaImage.queryByText('GIF'),
 | |
| 			mkMediaImage.queryByText('ALT'),
 | |
| 		]);
 | |
| 		assert.ok(!gif);
 | |
| 		assert.ok(alt);
 | |
| 	});
 | |
| 
 | |
| 	test('Attaching GIF image with an alt message should show a GIF and an ALT indicator', async () => {
 | |
| 		const mkMediaImage = renderMediaImage({
 | |
| 			type: 'image/gif',
 | |
| 			comment: 'Misskeyのロゴです',
 | |
| 		});
 | |
| 		const [gif, alt] = await Promise.all([
 | |
| 			mkMediaImage.queryByText('GIF'),
 | |
| 			mkMediaImage.queryByText('ALT'),
 | |
| 		]);
 | |
| 		assert.ok(gif);
 | |
| 		assert.ok(alt);
 | |
| 	});
 | |
| });
 |