mirror of
https://github.com/misskey-dev/misskey.git
synced 2026-05-05 04:15:55 +02:00
* wip * update fake-timers and migrate * fix * remove jest-mock * fix * fix * fix * fix * attempt to fix unit tests * attempt to fix e2e tests * fix federation test [ci skip] * attempt to fix e2e tests * fix typecheck * fix unit tests * fix * attempt to fix e2e * fix * Revert "attempt to fix e2e" This reverts commitb7b7b05d85. * attempt to fix e2e * revert attempt to fix e2e * update deps * update vitest * migrate * attempt to fix e2e * update * fix * remove vite swc plugin as oxc parser can handle decorators * attempt to fix drive/files/create test * Revert "attempt to fix drive/files/create test" This reverts commit4715153375. * fix: エンドポイントにまつわるテストをunitからe2eに移動 * attempt to fix e2e * remove swc * attempt to fix e2e * Revert "attempt to fix e2e" This reverts commit9fb86a4076. * add logs for debug * attempt to fix e2e * Partially revert "attempt to fix e2e" This reverts commitfb0008c85a. * attempt to fix test * fix: attempt to fix test * Revert "fix: attempt to fix test" This reverts commited2f5c40e8. * Revert "attempt to fix test" This reverts commitd7329c46f1. * attempt to fix e2e * fix: surpass eventemitter warning by increasing defaultMaxListeners * attempt to fix e2e * fix * fix e2e not ending properly * exp: add hanging-process reporter for investigation * Revert "exp: add hanging-process reporter for investigation" This reverts commit26851f8282. * update changelog
92 lines
2.4 KiB
TypeScript
92 lines
2.4 KiB
TypeScript
/*
|
|
* SPDX-FileCopyrightText: syuilo and misskey-project
|
|
* SPDX-License-Identifier: AGPL-3.0-only
|
|
*/
|
|
|
|
import { describe, expect, test } from 'vitest';
|
|
import { isQuote, isRenote } from '@/misc/is-renote.js';
|
|
import { MiNote } from '@/models/Note.js';
|
|
|
|
const base: MiNote = {
|
|
id: 'some-note-id',
|
|
replyId: null,
|
|
reply: null,
|
|
renoteId: null,
|
|
renote: null,
|
|
threadId: null,
|
|
text: null,
|
|
name: null,
|
|
cw: null,
|
|
userId: 'some-user-id',
|
|
user: null,
|
|
localOnly: false,
|
|
reactionAcceptance: null,
|
|
renoteCount: 0,
|
|
repliesCount: 0,
|
|
clippedCount: 0,
|
|
pageCount: 0,
|
|
reactions: {},
|
|
visibility: 'public',
|
|
uri: null,
|
|
url: null,
|
|
fileIds: [],
|
|
attachedFileTypes: [],
|
|
visibleUserIds: [],
|
|
mentions: [],
|
|
mentionedRemoteUsers: '',
|
|
reactionAndUserPairCache: [],
|
|
emojis: [],
|
|
tags: [],
|
|
hasPoll: false,
|
|
channelId: null,
|
|
channel: null,
|
|
userHost: null,
|
|
replyUserId: null,
|
|
replyUserHost: null,
|
|
renoteUserId: null,
|
|
renoteUserHost: null,
|
|
renoteChannelId: null,
|
|
};
|
|
|
|
describe('misc:is-renote', () => {
|
|
test('note without renoteId should not be Renote', () => {
|
|
expect(isRenote(base)).toBe(false);
|
|
});
|
|
|
|
test('note with renoteId should be Renote and not be Quote', () => {
|
|
const note: MiNote = { ...base, renoteId: 'some-renote-id' };
|
|
expect(isRenote(note)).toBe(true);
|
|
expect(isQuote(note as any)).toBe(false);
|
|
});
|
|
|
|
test('note with renoteId and text should be Quote', () => {
|
|
const note: MiNote = { ...base, renoteId: 'some-renote-id', text: 'some-text' };
|
|
expect(isRenote(note)).toBe(true);
|
|
expect(isQuote(note as any)).toBe(true);
|
|
});
|
|
|
|
test('note with renoteId and cw should be Quote', () => {
|
|
const note: MiNote = { ...base, renoteId: 'some-renote-id', cw: 'some-cw' };
|
|
expect(isRenote(note)).toBe(true);
|
|
expect(isQuote(note as any)).toBe(true);
|
|
});
|
|
|
|
test('note with renoteId and replyId should be Quote', () => {
|
|
const note: MiNote = { ...base, renoteId: 'some-renote-id', replyId: 'some-reply-id' };
|
|
expect(isRenote(note)).toBe(true);
|
|
expect(isQuote(note as any)).toBe(true);
|
|
});
|
|
|
|
test('note with renoteId and poll should be Quote', () => {
|
|
const note: MiNote = { ...base, renoteId: 'some-renote-id', hasPoll: true };
|
|
expect(isRenote(note)).toBe(true);
|
|
expect(isQuote(note as any)).toBe(true);
|
|
});
|
|
|
|
test('note with renoteId and non-empty fileIds should be Quote', () => {
|
|
const note: MiNote = { ...base, renoteId: 'some-renote-id', fileIds: ['some-file-id'] };
|
|
expect(isRenote(note)).toBe(true);
|
|
expect(isQuote(note as any)).toBe(true);
|
|
});
|
|
});
|