2017-09-07 07:19:48 +08:00
|
|
|
import React from 'react';
|
|
|
|
import ReactDOM from 'react-dom';
|
|
|
|
|
2017-09-27 02:33:08 +08:00
|
|
|
import { Message, NylasTestUtils } from 'nylas-exports';
|
|
|
|
import OpenTrackingMessageStatus from '../lib/open-tracking-message-status';
|
|
|
|
import { PLUGIN_ID } from '../lib/open-tracking-constants';
|
2017-09-07 07:19:48 +08:00
|
|
|
|
2017-09-27 02:33:08 +08:00
|
|
|
const { renderIntoDocument } = NylasTestUtils;
|
2017-09-07 07:19:48 +08:00
|
|
|
|
|
|
|
function makeIcon(message, props = {}) {
|
2017-09-27 02:33:08 +08:00
|
|
|
return renderIntoDocument(
|
|
|
|
<div className="temp">
|
|
|
|
<OpenTrackingMessageStatus {...props} message={message} />
|
|
|
|
</div>
|
|
|
|
);
|
2017-09-07 07:19:48 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
function addOpenMetadata(obj, openCount) {
|
2017-09-27 02:33:08 +08:00
|
|
|
obj.directlyAttachMetadata(PLUGIN_ID, { open_count: openCount });
|
2017-09-07 07:19:48 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
describe('Open tracking message status', function openTrackingMessageStatus() {
|
|
|
|
beforeEach(() => {
|
|
|
|
this.message = new Message();
|
|
|
|
});
|
|
|
|
|
2017-09-27 02:33:08 +08:00
|
|
|
it('shows nothing if the message has no metadata', () => {
|
2017-09-07 07:19:48 +08:00
|
|
|
const icon = ReactDOM.findDOMNode(makeIcon(this.message));
|
2017-09-27 02:33:08 +08:00
|
|
|
expect(icon.querySelector('.open-tracking-message-status')).toBeNull();
|
2017-09-07 07:19:48 +08:00
|
|
|
});
|
|
|
|
|
2017-09-27 02:33:08 +08:00
|
|
|
it('shows nothing if metadata is malformed', () => {
|
|
|
|
this.message.directlyAttachMetadata(PLUGIN_ID, { gar: 'bage' });
|
2017-09-07 07:19:48 +08:00
|
|
|
const icon = ReactDOM.findDOMNode(makeIcon(this.message));
|
2017-09-27 02:33:08 +08:00
|
|
|
expect(icon.querySelector('.open-tracking-message-status')).toBeNull();
|
2017-09-07 07:19:48 +08:00
|
|
|
});
|
|
|
|
|
2017-09-27 02:33:08 +08:00
|
|
|
it('shows an unopened icon if the message has metadata and is unopened', () => {
|
2017-09-07 07:19:48 +08:00
|
|
|
addOpenMetadata(this.message, 0);
|
|
|
|
const icon = ReactDOM.findDOMNode(makeIcon(this.message));
|
2017-09-27 02:33:08 +08:00
|
|
|
expect(icon.querySelector('img.unopened')).not.toBeNull();
|
|
|
|
expect(icon.querySelector('img.opened')).toBeNull();
|
2017-09-07 07:19:48 +08:00
|
|
|
});
|
|
|
|
|
2017-09-27 02:33:08 +08:00
|
|
|
it('shows an opened icon if the message has metadata and is opened', () => {
|
2017-09-07 07:19:48 +08:00
|
|
|
addOpenMetadata(this.message, 1);
|
|
|
|
const icon = ReactDOM.findDOMNode(makeIcon(this.message));
|
2017-09-27 02:33:08 +08:00
|
|
|
expect(icon.querySelector('img.unopened')).toBeNull();
|
|
|
|
expect(icon.querySelector('img.opened')).not.toBeNull();
|
2017-09-07 07:19:48 +08:00
|
|
|
});
|
|
|
|
});
|