mirror of
https://github.com/Foundry376/Mailspring.git
synced 2025-01-19 06:29:03 +08:00
83 lines
3.4 KiB
CoffeeScript
Executable file
83 lines
3.4 KiB
CoffeeScript
Executable file
{React, ReactTestUtils, DraftStore, Message} = require 'nylas-exports'
|
|
pgp = require 'kbpgp'
|
|
|
|
DecryptMessageButton = require '../lib/decrypt-button'
|
|
PGPKeyStore = require '../lib/pgp-key-store'
|
|
|
|
describe "DecryptMessageButton", ->
|
|
beforeEach ->
|
|
@unencryptedMsg = new Message({clientId: 'test', subject: 'Subject', body: '<p>Body</p>'})
|
|
body = """-----BEGIN PGP MESSAGE-----
|
|
Version: Keybase OpenPGP v2.0.52 Comment: keybase.io/crypto
|
|
|
|
wcBMA5nwa6GWVDOUAQf+MjiVRIBWJyM6The6/h2MgSJTDyrN9teFFJTizOvgHNnD W4EpEmmhShNyERI67qXhC03lFczu2Zp2Qofgs8YePIEv7wwb27/cviODsE42YJvX 1zGir+jBp81s9ZiF4dex6Ir9XfiZJlypI2QV2dHjO+5pstW+XhKIc1R5vKvoFTGI 1XmZtL3EgtKfj/HkPUkq2N0G5kAoB2MTTQuurfXm+3TRkftqesyTKlek652sFjCv nSF+LQ1GYq5hI4YaUBiHnZd7wKUgDrIh2rzbuGq+AHjrHdVLMfRTbN0Xsy3OWRcC 9uWU8Nln00Ly6KbTqPXKcBDcMrOJuoxYcpmLlhRds9JoAY7MyIsj87M2mkTtAtMK hqK0PPvJKfepV+eljDhQ7y0TQ0IvNtO5/pcY2CozbFJncm/ToxxZPNJueKRcz+EH M9uBvrWNTwfHj26g405gpRDN1T8CsY5ZeiaDHduIKnBWd4za0ak0Xfw=
|
|
=1aPN
|
|
-----END PGP MESSAGE-----"""
|
|
@encryptedMsg = new Message({clientId: 'test2', subject: 'Subject', body: body})
|
|
|
|
@msg = new Message({subject: 'Subject', body: '<p>Body</p>'})
|
|
@component = ReactTestUtils.renderIntoDocument(
|
|
<DecryptMessageButton message={@msg} />
|
|
)
|
|
|
|
xit "should try to decrypt the message whenever a new key is unlocked", ->
|
|
spyOn(PGPKeyStore, "decrypt")
|
|
spyOn(PGPKeyStore, "isDecrypted").andCallFake((message) =>
|
|
return false
|
|
)
|
|
spyOn(PGPKeyStore, "hasEncryptedComponent").andCallFake((message) =>
|
|
return true
|
|
)
|
|
|
|
PGPKeyStore.trigger(PGPKeyStore)
|
|
expect(PGPKeyStore.decrypt).toHaveBeenCalled()
|
|
|
|
xit "should not try to decrypt the message whenever a new key is unlocked
|
|
if the message is already decrypted", ->
|
|
spyOn(PGPKeyStore, "decrypt")
|
|
spyOn(PGPKeyStore, "isDecrypted").andCallFake((message) =>
|
|
return true)
|
|
spyOn(PGPKeyStore, "hasEncryptedComponent").andCallFake((message) =>
|
|
return true)
|
|
|
|
# TODO for some reason the above spyOn calls aren't working and false is
|
|
# being returned from isDecrypted, causing this test to fail
|
|
PGPKeyStore.trigger(PGPKeyStore)
|
|
|
|
expect(PGPKeyStore.decrypt).not.toHaveBeenCalled()
|
|
|
|
it "should have a button to decrypt a message", ->
|
|
@component = ReactTestUtils.renderIntoDocument(
|
|
<DecryptMessageButton message=@encryptedMsg />
|
|
)
|
|
|
|
expect(@component.refs.button).toBeDefined()
|
|
|
|
it "should not allow for the unlocking of a message with no encrypted component", ->
|
|
@component = ReactTestUtils.renderIntoDocument(
|
|
<DecryptMessageButton message=@unencryptedMsg />
|
|
)
|
|
|
|
expect(@component.refs.button).not.toBeDefined()
|
|
|
|
it "should indicate when a message has been decrypted", ->
|
|
spyOn(PGPKeyStore, "isDecrypted").andCallFake((message) =>
|
|
return true)
|
|
|
|
@component = ReactTestUtils.renderIntoDocument(
|
|
<DecryptMessageButton message=@encryptedMsg />
|
|
)
|
|
|
|
expect(@component.refs.button).not.toBeDefined()
|
|
|
|
it "should open a popover when clicked", ->
|
|
spyOn(DecryptMessageButton.prototype, "_onClickDecrypt")
|
|
|
|
msg = @encryptedMsg
|
|
msg.to = [{email: "test@example.com"}]
|
|
@component = ReactTestUtils.renderIntoDocument(
|
|
<DecryptMessageButton message=msg />
|
|
)
|
|
expect(@component.refs.button).toBeDefined()
|
|
ReactTestUtils.Simulate.click(@component.refs.button)
|
|
expect(DecryptMessageButton.prototype._onClickDecrypt).toHaveBeenCalled()
|