1
0
mirror of https://github.com/kremalicious/metamask-extension.git synced 2024-12-23 09:52:26 +01:00
metamask-extension/app/scripts/controllers/decrypt-message.test.ts

223 lines
6.9 KiB
TypeScript

import { DecryptMessageManager } from '@metamask/message-manager';
import { AbstractMessage } from '@metamask/message-manager/dist/AbstractMessageManager';
import { MetaMetricsEventCategory } from '../../../shared/constants/metametrics';
import DecryptMessageController, {
DecryptMessageControllerMessenger,
DecryptMessageControllerOptions,
getDefaultState,
} from './decrypt-message';
const messageIdMock = '12345';
const messageMock = {
metamaskId: messageIdMock,
time: 123,
status: 'unapproved',
type: 'testType',
rawSig: undefined,
} as any as AbstractMessage;
const mockExtState = {};
jest.mock('@metamask/message-manager', () => ({
DecryptMessageManager: jest.fn(),
}));
const createKeyringControllerMock = () => ({
decryptMessage: jest.fn(),
});
const createMessengerMock = () =>
({
registerActionHandler: jest.fn(),
publish: jest.fn(),
call: jest.fn(),
} as any as jest.Mocked<DecryptMessageControllerMessenger>);
const createDecryptMessageManagerMock = <T>() =>
({
getUnapprovedMessages: jest.fn(),
getUnapprovedMessagesCount: jest.fn(),
getMessage: jest.fn(),
addUnapprovedMessageAsync: jest.fn(),
approveMessage: jest.fn(),
setMessageStatusAndResult: jest.fn(),
rejectMessage: jest.fn(),
update: jest.fn(),
subscribe: jest.fn(),
updateMessage: jest.fn(),
updateMessageErrorInline: jest.fn(),
setResult: jest.fn(),
hub: {
on: jest.fn(),
},
} as any as jest.Mocked<T>);
describe('EncryptionPublicKeyController', () => {
let decryptMessageController: DecryptMessageController;
const decryptMessageManagerConstructorMock =
DecryptMessageManager as jest.MockedClass<typeof DecryptMessageManager>;
const getStateMock = jest.fn();
const keyringControllerMock = createKeyringControllerMock();
const messengerMock = createMessengerMock();
const metricsEventMock = jest.fn();
const decryptMessageManagerMock =
createDecryptMessageManagerMock<DecryptMessageManager>();
beforeEach(() => {
jest.resetAllMocks();
decryptMessageManagerConstructorMock.mockReturnValue(
decryptMessageManagerMock,
);
decryptMessageController = new DecryptMessageController({
getState: getStateMock as any,
keyringController: keyringControllerMock as any,
messenger: messengerMock as any,
metricsEvent: metricsEventMock as any,
} as DecryptMessageControllerOptions);
});
it('should return unapprovedMsgCount', () => {
decryptMessageManagerMock.getUnapprovedMessagesCount.mockReturnValue(5);
expect(decryptMessageController.unapprovedDecryptMsgCount).toBe(5);
});
it('should reset state', () => {
decryptMessageController.update(() => ({
unapprovedDecryptMsgs: {
[messageIdMock]: messageMock,
} as any,
unapprovedDecryptMsgCount: 1,
}));
decryptMessageController.resetState();
expect(decryptMessageController.state).toStrictEqual(getDefaultState());
});
it('should clear unapproved messages', () => {
decryptMessageController.clearUnapproved();
expect(decryptMessageController.state).toStrictEqual(getDefaultState());
expect(decryptMessageManagerMock.update).toBeCalledTimes(1);
});
it('should add unapproved messages', async () => {
await decryptMessageController.newRequestDecryptMessage(messageMock);
expect(decryptMessageManagerMock.addUnapprovedMessageAsync).toBeCalledTimes(
1,
);
expect(decryptMessageManagerMock.addUnapprovedMessageAsync).toBeCalledWith(
messageMock,
undefined,
);
});
it('should decrypt message', async () => {
const messageToDecrypt = {
...messageMock,
data: '0x7b22666f6f223a22626172227d',
};
decryptMessageManagerMock.approveMessage.mockResolvedValue(
messageToDecrypt,
);
keyringControllerMock.decryptMessage.mockResolvedValue('decryptedMessage');
getStateMock.mockReturnValue(mockExtState);
const result = await decryptMessageController.decryptMessage(
messageToDecrypt,
);
expect(decryptMessageManagerMock.approveMessage).toBeCalledTimes(1);
expect(decryptMessageManagerMock.approveMessage).toBeCalledWith(
messageToDecrypt,
);
expect(keyringControllerMock.decryptMessage).toBeCalledTimes(1);
expect(keyringControllerMock.decryptMessage).toBeCalledWith(
messageToDecrypt,
);
expect(decryptMessageManagerMock.setMessageStatusAndResult).toBeCalledTimes(
1,
);
expect(decryptMessageManagerMock.setMessageStatusAndResult).toBeCalledWith(
messageIdMock,
'decryptedMessage',
'decrypted',
);
expect(result).toBe(mockExtState);
});
it('should cancel decrypt request', async () => {
const messageToDecrypt = {
...messageMock,
data: '0x7b22666f6f223a22626172227d',
};
decryptMessageManagerMock.approveMessage.mockResolvedValue(
messageToDecrypt,
);
keyringControllerMock.decryptMessage.mockRejectedValue(new Error('error'));
getStateMock.mockReturnValue(mockExtState);
return expect(
decryptMessageController.decryptMessage(messageToDecrypt),
).rejects.toThrow('error');
});
it('should decrypt message inline', async () => {
const messageToDecrypt = {
...messageMock,
data: '0x7b22666f6f223a22626172227d',
};
decryptMessageManagerMock.getMessage.mockReturnValue(messageToDecrypt);
keyringControllerMock.decryptMessage.mockResolvedValue('decryptedMessage');
getStateMock.mockReturnValue(mockExtState);
const result = await decryptMessageController.decryptMessageInline(
messageToDecrypt,
);
expect(decryptMessageManagerMock.setResult).toBeCalledTimes(1);
expect(decryptMessageManagerMock.setResult).toBeCalledWith(
messageMock.metamaskId,
'decryptedMessage',
);
expect(result).toBe(mockExtState);
});
it('should be able to cancel decrypt message', async () => {
decryptMessageManagerMock.rejectMessage.mockResolvedValue(messageMock);
getStateMock.mockReturnValue(mockExtState);
const result = await decryptMessageController.cancelDecryptMessage(
messageIdMock,
);
expect(decryptMessageManagerMock.rejectMessage).toBeCalledTimes(1);
expect(decryptMessageManagerMock.rejectMessage).toBeCalledWith(
messageIdMock,
);
expect(result).toBe(mockExtState);
});
it('should be able to reject all unapproved messages', async () => {
decryptMessageManagerMock.getUnapprovedMessages.mockReturnValue({
[messageIdMock]: messageMock,
});
await decryptMessageController.rejectUnapproved('reason to cancel');
expect(decryptMessageManagerMock.rejectMessage).toBeCalledTimes(1);
expect(decryptMessageManagerMock.rejectMessage).toBeCalledWith(
messageIdMock,
);
expect(metricsEventMock).toBeCalledTimes(1);
expect(metricsEventMock).toBeCalledWith({
event: 'reason to cancel',
category: MetaMetricsEventCategory.Messages,
properties: {
action: 'Decrypt Message Request',
},
});
});
});