forked from mirrors/misskey
* add channel_muting table and entities * add channel_muting services * タイムライン取得処理への組み込み * misskey-jsの型とインターフェース生成 * Channelスキーマにミュート情報を追加 * フロントエンドの実装 * 条件が逆だったのを修正 * 期限切れミュートを掃除する機能を実装 * TLの抽出条件調節 * 名前の変更と変更不要の差分をロールバック * 修正漏れ * isChannelRelatedの条件に誤りがあった * [wip] テスト追加 * テストの追加と検出した不備の修正 * fix test * fix CHANGELOG.md * 通常はFTTにしておく * 実装忘れ対応 * fix merge * fix merge * add channel tl test * fix CHANGELOG.md * remove unused import * fix lint * fix test * fix favorite -> favorited * exclude -> include * fix CHANGELOG.md * fix CHANGELOG.md * maintenance * fix CHANGELOG.md * fix * fix ci * regenerate * fix * Revert "fix" This reverts commit 699d50c6ec798777d8e9667cb5d45a26b06bfc93. * fixed --------- Co-authored-by: syuilo <4439005+syuilo@users.noreply.github.com>
91 lines
2.4 KiB
TypeScript
91 lines
2.4 KiB
TypeScript
/*
|
|
* SPDX-FileCopyrightText: syuilo and misskey-project
|
|
* SPDX-License-Identifier: AGPL-3.0-only
|
|
*/
|
|
|
|
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);
|
|
});
|
|
});
|