From dc23f3e5b50ed76c3bfaffbe91bce044b9c64a4b Mon Sep 17 00:00:00 2001 From: danidfra Date: Sun, 12 Jan 2025 14:13:15 -0300 Subject: [PATCH] Remove "statuses.test" --- src/reducers/statuses.test.ts | 252 ---------------------------------- 1 file changed, 252 deletions(-) delete mode 100644 src/reducers/statuses.test.ts diff --git a/src/reducers/statuses.test.ts b/src/reducers/statuses.test.ts deleted file mode 100644 index 70f464e70..000000000 --- a/src/reducers/statuses.test.ts +++ /dev/null @@ -1,252 +0,0 @@ -import { - Map as ImmutableMap, - Record as ImmutableRecord, -} from 'immutable'; -import { describe, expect, it } from 'vitest'; - -import { STATUS_IMPORT } from 'soapbox/actions/importer/index.ts'; -import { - STATUS_CREATE_REQUEST, - STATUS_CREATE_FAIL, - STATUS_DELETE_REQUEST, - STATUS_DELETE_FAIL, -} from 'soapbox/actions/statuses.ts'; -import { normalizeStatus } from 'soapbox/normalizers/index.ts'; - -import reducer, { ReducerStatus } from './statuses.ts'; - -describe('statuses reducer', () => { - it('should return the initial state', () => { - expect(reducer(undefined, {} as any)).toEqual(ImmutableMap()); - }); - - describe('STATUS_IMPORT', () => { - it('parses the status as a Record', async () => { - const status = await import('soapbox/__fixtures__/pleroma-quote-post.json'); - const action = { type: STATUS_IMPORT, status }; - const result = reducer(undefined, action).get('AFmFMSpITT9xcOJKcK'); - - expect(ImmutableRecord.isRecord(result)).toBe(true); - }); - - it('fixes the order of mentions', async () => { - const status = await import('soapbox/__fixtures__/status-unordered-mentions.json'); - const action = { type: STATUS_IMPORT, status }; - - const expected = ['NEETzsche', 'alex', 'Lumeinshin', 'sneeden']; - - const result = reducer(undefined, action) - .get('AFChectaqZjmOVkXZ2')?.mentions - .map(mention => mention.get('username')) - .toJS(); - - expect(result).toEqual(expected); - }); - - it('preserves the quote', async () => { - const quotePost = await import('soapbox/__fixtures__/pleroma-quote-post.json'); - const quotedQuotePost = await import('soapbox/__fixtures__/pleroma-quote-of-quote-post.json'); - - let state = undefined; - state = reducer(state, { type: STATUS_IMPORT, status: quotePost }); - state = reducer(state, { type: STATUS_IMPORT, status: quotedQuotePost.pleroma.quote }); - - expect(state.getIn(['AFmFMSpITT9xcOJKcK', 'quote'])).toEqual('AFmFLcd6XYVdjWCrOS'); - }); - - it('normalizes Mitra attachments', async () => { - const status = await import('soapbox/__fixtures__/mitra-status-with-attachments.json'); - - const state = reducer(undefined, { type: STATUS_IMPORT, status }); - - const expected = [{ - id: '017eeb0e-e5df-30a4-77a7-a929145cb836', - type: 'image', - url: 'https://mitra.social/media/8e04e6091bbbac79641b5812508683ce72c38693661c18d16040553f2371e18d.png', - preview_url: 'https://mitra.social/media/8e04e6091bbbac79641b5812508683ce72c38693661c18d16040553f2371e18d.png', - remote_url: null, - }, { - id: '017eeb0e-e5e4-2a48-2889-afdebf368a54', - type: 'unknown', - url: 'https://mitra.social/media/8f72dc2e98572eb4ba7c3a902bca5f69c448fc4391837e5f8f0d4556280440ac', - preview_url: 'https://mitra.social/media/8f72dc2e98572eb4ba7c3a902bca5f69c448fc4391837e5f8f0d4556280440ac', - remote_url: null, - }, { - id: '017eeb0e-e5e5-79fd-6054-8b6869b1db49', - type: 'unknown', - url: 'https://mitra.social/media/55a81a090247cc4fc127e5716bcf7964f6e0df9b584f85f4696c0b994747a4d0.oga', - preview_url: 'https://mitra.social/media/55a81a090247cc4fc127e5716bcf7964f6e0df9b584f85f4696c0b994747a4d0.oga', - remote_url: null, - }, { - id: '017eeb0e-e5e6-c416-a444-21e560c47839', - type: 'unknown', - url: 'https://mitra.social/media/0d96a4ff68ad6d4b6f1f30f713b18d5184912ba8dd389f86aa7710db079abcb0', - preview_url: 'https://mitra.social/media/0d96a4ff68ad6d4b6f1f30f713b18d5184912ba8dd389f86aa7710db079abcb0', - remote_url: null, - }]; - - expect(state.get('017eeb0e-e5e7-98fe-6b2b-ad02349251fb')?.media_attachments.toJS()).toMatchObject(expected); - }); - - it('fixes Pleroma attachments', async () => { - const status = await import('soapbox/__fixtures__/pleroma-status-with-attachments.json'); - const action = { type: STATUS_IMPORT, status }; - const state = reducer(undefined, action); - const result = state.get('AGNkA21auFR5lnEAHw')?.media_attachments; - - expect(result?.size).toBe(4); - expect(result?.get(1)?.meta).toEqual(ImmutableMap()); - expect(result?.getIn([1, 'pleroma', 'mime_type'])).toBe('application/x-nes-rom'); - }); - - it('hides CWs', async () => { - const status = await import('soapbox/__fixtures__/status-cw.json'); - const action = { type: STATUS_IMPORT, status }; - - const hidden = reducer(undefined, action).getIn(['107831528995252317', 'hidden']); - expect(hidden).toBe(true); - }); - - it('expands CWs when expandSpoilers is enabled', async () => { - const status = await import('soapbox/__fixtures__/status-cw.json'); - const action = { type: STATUS_IMPORT, status, expandSpoilers: true }; - - const hidden = reducer(undefined, action).getIn(['107831528995252317', 'hidden']); - expect(hidden).toBe(false); - }); - - it('parses custom emojis', async () => { - const status = await import('soapbox/__fixtures__/status-custom-emoji.json'); - const action = { type: STATUS_IMPORT, status }; - - const expected = 'Hello :ablobcathyper: :ageblobcat: 😂 world 😋 test :blobcatphoto:'; - - const result = reducer(undefined, action).getIn(['AGm7uC9DaAIGUa4KYK', 'contentHtml']); - expect(result).toBe(expected); - }); - - it('builds search_index', async () => { - const status = await import('soapbox/__fixtures__/status-with-poll.json'); - const action = { type: STATUS_IMPORT, status }; - - const expected = `What is tolerance? - -Banning, censoring, and deplatforming anyone you disagree with - -Promoting free speech, even for people and ideas you dislike`; - - const result = reducer(undefined, action).getIn(['103874034847713213', 'search_index']); - expect(result).toEqual(expected); - }); - - it('builds search_index with mentions', async () => { - const status = await import('soapbox/__fixtures__/pleroma-status-reply-with-mentions.json'); - const action = { type: STATUS_IMPORT, status }; - - const expected = `DMs are definitely only federated to the servers of the recipients tho. So if I DM a kfcc user, the kfcc admins can see it, but no other instance admins can. - -@crunklord420@kiwifarms.cc - -@becassine@kiwifarms.cc - -@King_Porgi@poa.st - -@ademan@thebag.social`; - - const result = reducer(undefined, action).getIn(['AHcweewcCh0iPUtMdk', 'search_index']); - expect(result).toEqual(expected); - }); - }); - - describe('STATUS_CREATE_REQUEST', () => { - it('increments the replies_count of its parent', () => { - const state = ImmutableMap({ - '123': normalizeStatus({ replies_count: 4 }) as ReducerStatus, - }); - - const action = { - type: STATUS_CREATE_REQUEST, - params: { in_reply_to_id: '123' }, - }; - - const result = reducer(state, action).getIn(['123', 'replies_count']); - expect(result).toEqual(5); - }); - }); - - describe('STATUS_CREATE_FAIL', () => { - it('decrements the replies_count of its parent', () => { - const state = ImmutableMap({ - '123': normalizeStatus({ replies_count: 5 }) as ReducerStatus, - }); - - const action = { - type: STATUS_CREATE_FAIL, - params: { in_reply_to_id: '123' }, - }; - - const result = reducer(state, action).getIn(['123', 'replies_count']); - expect(result).toEqual(4); - }); - }); - - describe('STATUS_DELETE_REQUEST', () => { - it('decrements the replies_count of its parent', () => { - const state = ImmutableMap({ - '123': normalizeStatus({ replies_count: 4 }) as ReducerStatus, - }); - - const action = { - type: STATUS_DELETE_REQUEST, - params: { in_reply_to_id: '123' }, - }; - - const result = reducer(state, action).getIn(['123', 'replies_count']); - expect(result).toEqual(3); - }); - - it('gracefully does nothing if no parent', () => { - const state = ImmutableMap({ - '123': normalizeStatus({ replies_count: 4 }) as ReducerStatus, - }); - - const action = { - type: STATUS_DELETE_REQUEST, - params: { id: '1' }, - }; - - const result = reducer(state, action).getIn(['123', 'replies_count']); - expect(result).toEqual(4); - }); - }); - - describe('STATUS_DELETE_FAIL', () => { - it('decrements the replies_count of its parent', () => { - const state = ImmutableMap({ - '123': normalizeStatus({ replies_count: 4 }) as ReducerStatus, - }); - - const action = { - type: STATUS_DELETE_FAIL, - params: { in_reply_to_id: '123' }, - }; - - const result = reducer(state, action).getIn(['123', 'replies_count']); - expect(result).toEqual(5); - }); - - it('gracefully does nothing if no parent', () => { - const state = ImmutableMap({ - '123': normalizeStatus({ replies_count: 4 }) as ReducerStatus, - }); - - const action = { - type: STATUS_DELETE_FAIL, - params: { id: '1' }, - }; - - const result = reducer(state, action).getIn(['123', 'replies_count']); - expect(result).toEqual(4); - }); - }); -});