diff options
author | Robin Houston <robin@lenny.robin> | 2011-09-08 00:58:31 +0100 |
---|---|---|
committer | Robin Houston <robin@lenny.robin> | 2011-09-08 00:58:31 +0100 |
commit | 0b35486809a9a5ef8ba371549b05390682427392 (patch) | |
tree | 019d6dd61f30b6639eb0585b6db9a618f4e1854e /spec/script/handle-mail-replies_spec.rb | |
parent | 6e0e5e5bed89ff2093e1cca3fa50310f678565fd (diff) | |
parent | e35a213a5550382c6aeeeadf29abdd178c87ea32 (diff) |
Merge branch 'wdtk' into develop
Conflicts:
config/general.yml-example
spec/models/track_mailer_spec.rb
Diffstat (limited to 'spec/script/handle-mail-replies_spec.rb')
-rw-r--r-- | spec/script/handle-mail-replies_spec.rb | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/spec/script/handle-mail-replies_spec.rb b/spec/script/handle-mail-replies_spec.rb new file mode 100644 index 000000000..856476c3f --- /dev/null +++ b/spec/script/handle-mail-replies_spec.rb @@ -0,0 +1,33 @@ +require File.expand_path(File.dirname(__FILE__) + '/../spec_helper') +require "external_command" + +def mail_reply_test(email_filename) + Dir.chdir RAILS_ROOT do + xc = ExternalCommand.new("script/handle-mail-replies", "--test") + xc.run(load_file_fixture(email_filename)) + + xc.err.should == "" + return xc + end +end + +describe "When filtering" do + it "should detect an Exim bounce" do + r = mail_reply_test("track-response-exim-bounce.email") + r.status.should == 1 + r.out.should == "user@example.com\n" + end + + it "should pass on a non-bounce message" do + r = mail_reply_test("incoming-request-bad-uuencoding.email") + r.status.should == 0 + r.out.should == "" + end + + it "should detect a multipart bounce" do + r = mail_reply_test("track-response-multipart-report.email") + r.status.should == 1 + r.out.should == "FailedUser@example.com\n" + end +end + |