// Copyright 2020-2022 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import { assert } from 'chai'; import { getAreWeASubscriber, getEmojiSkinTone, getPinnedConversationIds, getPreferredLeftPaneWidth, getPreferredReactionEmoji, getUsernamesEnabled, } from '../../../state/selectors/items'; import type { StateType } from '../../../state/reducer'; import type { ItemsStateType } from '../../../state/ducks/items'; describe('both/state/selectors/items', () => { // Note: we would like to use the full reducer here, to get a real empty state object // but we cannot load the full reducer inside of electron-mocha. function getRootState(items: ItemsStateType): StateType { return { items, // eslint-disable-next-line @typescript-eslint/no-explicit-any } as any; } describe('#getAreWeASubscriber', () => { it('returns false if the value is not in storage', () => { assert.isFalse(getAreWeASubscriber(getRootState({}))); }); it('returns the value in storage', () => { assert.isFalse( getAreWeASubscriber(getRootState({ areWeASubscriber: false })) ); assert.isTrue( getAreWeASubscriber(getRootState({ areWeASubscriber: true })) ); }); }); describe('#getEmojiSkinTone', () => { it('returns 0 if passed anything invalid', () => { [ // Invalid types undefined, null, '2', [2], // Numbers out of range -1, 6, Infinity, // Invalid numbers 0.1, 1.2, NaN, ].forEach(skinTone => { const state = getRootState({ skinTone }); assert.strictEqual(getEmojiSkinTone(state), 0); }); }); it('returns all valid skin tones', () => { [0, 1, 2, 3, 4, 5].forEach(skinTone => { const state = getRootState({ skinTone }); assert.strictEqual(getEmojiSkinTone(state), skinTone); }); }); }); describe('#getPreferredLeftPaneWidth', () => { it('returns a default if no value is present', () => { const state = getRootState({}); assert.strictEqual(getPreferredLeftPaneWidth(state), 320); }); it('returns a default value if passed something invalid', () => { [undefined, null, '250', [250], 250.123].forEach( preferredLeftPaneWidth => { const state = getRootState({ // eslint-disable-next-line @typescript-eslint/no-explicit-any preferredLeftPaneWidth: preferredLeftPaneWidth as any, }); assert.strictEqual(getPreferredLeftPaneWidth(state), 320); } ); }); it('returns the value in storage if it is valid', () => { const state = getRootState({ preferredLeftPaneWidth: 345, }); assert.strictEqual(getPreferredLeftPaneWidth(state), 345); }); }); describe('#getPinnedConversationIds', () => { it('returns pinnedConversationIds key from items', () => { const expected = ['one', 'two']; const state: StateType = getRootState({ pinnedConversationIds: expected, }); const actual = getPinnedConversationIds(state); assert.deepEqual(actual, expected); }); it('returns empty array if no saved data', () => { const expected: Array = []; const state = getRootState({}); const actual = getPinnedConversationIds(state); assert.deepEqual(actual, expected); }); }); describe('#getPreferredReactionEmoji', () => { // See also: the tests for the `getPreferredReactionEmoji` helper. const expectedDefault = ['❤️', '👍🏿', '👎🏿', '😂', '😮', '😢']; it('returns the default set if no value is stored', () => { const state = getRootState({ skinTone: 5 }); const actual = getPreferredReactionEmoji(state); assert.deepStrictEqual(actual, expectedDefault); }); it('returns the default set if the stored value is invalid', () => { const state = getRootState({ skinTone: 5, preferredReactionEmoji: ['garbage!!'], }); const actual = getPreferredReactionEmoji(state); assert.deepStrictEqual(actual, expectedDefault); }); it('returns a custom set of emoji', () => { const preferredReactionEmoji = ['✨', '❇️', '🤙🏻', '🦈', '💖', '🅿️']; const state = getRootState({ skinTone: 5, preferredReactionEmoji }); const actual = getPreferredReactionEmoji(state); assert.deepStrictEqual(actual, preferredReactionEmoji); }); }); describe('#getUsernamesEnabled', () => { it('returns false if the flag is missing or disabled', () => { [ {}, { remoteConfig: {} }, { remoteConfig: { 'desktop.usernames': { name: 'desktop.usernames' as const, enabled: false, }, }, }, ].forEach(itemsState => { const state = getRootState(itemsState); assert.isFalse(getUsernamesEnabled(state)); }); }); it('returns true if the flag is enabled', () => { const state = getRootState({ remoteConfig: { 'desktop.usernames': { name: 'desktop.usernames' as const, enabled: true, }, }, }); assert.isTrue(getUsernamesEnabled(state)); }); }); });