diff options
author | Gareth Rees <gareth@mysociety.org> | 2015-06-04 14:52:56 +0100 |
---|---|---|
committer | Gareth Rees <gareth@mysociety.org> | 2015-06-04 14:52:56 +0100 |
commit | e5963622d92cb3c901ad9d5f2c4d7aed254a5687 (patch) | |
tree | 19cb80040b57e9824a362af07850107e04b23efc /spec/models/incoming_message_spec.rb | |
parent | d6a1f042d64be5c8906aa4af0e0a4c9c6dd08bfb (diff) | |
parent | 305aab8701d9a398ad9dc9150e296c3badc0ee92 (diff) |
Merge branch 'hotfix/0.21.0.36' into develop
Diffstat (limited to 'spec/models/incoming_message_spec.rb')
-rw-r--r-- | spec/models/incoming_message_spec.rb | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/spec/models/incoming_message_spec.rb b/spec/models/incoming_message_spec.rb index 10bb3de62..8fb57e36c 100644 --- a/spec/models/incoming_message_spec.rb +++ b/spec/models/incoming_message_spec.rb @@ -503,6 +503,20 @@ end describe IncomingMessage, " when uudecoding bad messages" do + it "decodes a valid uuencoded attachment" do + mail = get_fixture_mail('simple-uuencoded-attachment.email') + im = incoming_messages(:useless_incoming_message) + im.stub!(:mail).and_return(mail) + im.extract_attachments! + + im.reload + attachments = im.foi_attachments + attachments.size.should == 2 + attachments[1].filename.should == 'Happy.txt' + attachments[1].body.should == "Happy today for to be one of peace and serene time.\n" + im.get_attachments_for_display.size.should == 1 + end + it "should be able to do it at all" do mail = get_fixture_mail('incoming-request-bad-uuencoding.email') im = incoming_messages(:useless_incoming_message) @@ -516,6 +530,21 @@ describe IncomingMessage, " when uudecoding bad messages" do im.get_attachments_for_display.size.should == 1 end + it "decodes an attachment where the uudecode program reports a 'No end line' error" do + # See https://github.com/mysociety/alaveteli/issues/2508 + mail = get_fixture_mail('incoming-request-bad-uuencoding-2.email') + im = incoming_messages(:useless_incoming_message) + im.stub!(:mail).and_return(mail) + im.extract_attachments! + + im.reload + attachments = im.foi_attachments + attachments.size.should == 2 + attachments[1].filename.should == 'ResponseT5741 15.doc' + attachments[1].display_size.should == '123K' + im.get_attachments_for_display.size.should == 1 + end + it "should still work when parsed from the raw email" do raw_email = load_file_fixture 'inline-uuencode.email' mail = MailHandler.mail_from_raw_email(raw_email) |