Mailspring/app/internal_packages/send-later/specs/send-later-button-spec.jsx

99 lines
3.3 KiB
React
Raw Normal View History

/* eslint react/no-render-return-value: 0 */
import React from 'react';
import ReactDOM from 'react-dom';
import { findRenderedDOMComponentWithClass } from 'react-dom/test-utils';
import { DateUtils, Actions } from 'mailspring-exports';
import SendLaterButton from '../lib/send-later-button';
import { PLUGIN_ID } from '../lib/send-later-constants';
const node = document.createElement('div');
const makeButton = (initialState, metadataValue) => {
const draft = {
accountId: 'accountId',
metadataForPluginId: () => metadataValue,
2017-09-27 02:33:08 +08:00
};
const session = {
changes: {
add: jasmine.createSpy('add'),
addPluginMetadata: jasmine.createSpy('addPluginMetadata'),
},
2017-09-27 02:33:08 +08:00
};
const button = ReactDOM.render(
<SendLaterButton draft={draft} session={session} isValidDraft={() => true} />,
node
);
if (initialState) {
2017-09-27 02:33:08 +08:00
button.setState(initialState);
}
2017-09-27 02:33:08 +08:00
return button;
};
xdescribe('SendLaterButton', function sendLaterButton() {
beforeEach(() => {
2017-09-27 02:33:08 +08:00
spyOn(DateUtils, 'format').andReturn('formatted');
});
describe('onSendLater', () => {
it('sets scheduled date to "saving" and adds plugin metadata to the session', () => {
2017-09-27 02:33:08 +08:00
const button = makeButton(null, { sendLaterDate: 'date' });
spyOn(button, 'setState');
spyOn(Actions, 'finalizeDraftAndSyncbackMetadata');
2017-09-27 02:33:08 +08:00
const sendLaterDate = { utc: () => 'utc' };
button.onSendLater(sendLaterDate);
advanceClock();
2017-09-27 02:33:08 +08:00
expect(button.setState).toHaveBeenCalledWith({ saving: true });
expect(button.props.session.changes.addPluginMetadata).toHaveBeenCalledWith(PLUGIN_ID, {
sendLaterDate,
});
});
it('displays dialog if an auth error occurs', () => {
2017-09-27 02:33:08 +08:00
const button = makeButton(null, { sendLaterDate: 'date' });
spyOn(button, 'setState');
2017-09-27 02:36:58 +08:00
spyOn(AppEnv, 'reportError');
spyOn(AppEnv, 'showErrorDialog');
2017-09-27 02:33:08 +08:00
spyOn(Actions, 'finalizeDraftAndSyncbackMetadata');
button.onSendLater({ utc: () => 'utc' });
advanceClock();
2017-09-27 02:36:58 +08:00
expect(AppEnv.reportError).toHaveBeenCalled();
expect(AppEnv.showErrorDialog).toHaveBeenCalled();
});
it('closes the composer window if a sendLaterDate has been set', () => {
2017-09-27 02:33:08 +08:00
const button = makeButton(null, { sendLaterDate: 'date' });
spyOn(button, 'setState');
2017-09-27 02:36:58 +08:00
spyOn(AppEnv, 'close');
spyOn(AppEnv, 'isComposerWindow').andReturn(true);
2017-09-27 02:33:08 +08:00
spyOn(Actions, 'finalizeDraftAndSyncbackMetadata');
button.onSendLater({ utc: () => 'utc' });
advanceClock();
2017-09-27 02:36:58 +08:00
expect(AppEnv.close).toHaveBeenCalled();
});
});
describe('render', () => {
it('renders spinner if saving', () => {
2017-09-27 02:33:08 +08:00
const button = ReactDOM.findDOMNode(makeButton({ saving: true }, null));
expect(button.title).toEqual('Saving send date...');
});
it('renders date if message is scheduled', () => {
2017-09-27 02:33:08 +08:00
spyOn(DateUtils, 'futureDateFromString').andReturn({ fromNow: () => '5 minutes' });
const button = makeButton({ saving: false }, { sendLaterDate: 'date' });
const span = ReactDOM.findDOMNode(findRenderedDOMComponentWithClass(button, 'at'));
expect(span.textContent).toEqual('Sending in 5 minutes');
});
it('does not render date if message is not scheduled', () => {
2017-09-27 02:33:08 +08:00
const button = makeButton(null, null);
expect(() => {
2017-09-27 02:33:08 +08:00
findRenderedDOMComponentWithClass(button, 'at');
}).toThrow();
});
});
});