load 'test_helper/common' # Globals referenced from `test_helper/common`: # TEST_NAME # Can run tests in parallel?: No # Shared static container name: TEST_NAME # Test case # --------- # When SPAMASSASSIN_SPAM_TO_INBOX=0, spam messages must be bounced (rejected). # SPAMASSASSIN_SPAM_TO_INBOX=1 is covered in `mail_spam_junk_folder.bats`. # Original test PR: https://github.com/docker-mailserver/docker-mailserver/pull/1485 function setup() { run_setup_file_if_necessary } function teardown() { docker rm -f "${TEST_NAME}" run_teardown_file_if_necessary } function setup_file() { init_with_defaults } # Not used # function teardown_file() { # } @test "first" { skip 'this test must come first to reliably identify when to run setup_file' } @test "checking amavis: spam message is bounced (rejected)" { local TEST_DOCKER_ARGS=( --env ENABLE_SPAMASSASSIN=1 --env SPAMASSASSIN_SPAM_TO_INBOX=0 ) common_container_setup 'TEST_DOCKER_ARGS' run _should_emit_warning assert_failure _should_bounce_spam } @test "checking amavis: spam message is bounced (rejected), undefined SPAMASSASSIN_SPAM_TO_INBOX should raise a warning" { # SPAMASSASSIN_SPAM_TO_INBOX=0 is the default. If no explicit ENV value is set, it should log a warning at startup. # shellcheck disable=SC2034 local TEST_DOCKER_ARGS=( --env ENABLE_SPAMASSASSIN=1 ) common_container_setup 'TEST_DOCKER_ARGS' run _should_emit_warning assert_success _should_bounce_spam } @test "last" { skip 'this test is only there to reliably mark the end for the teardown_file' } # This warning should only be raised when the env SPAMASSASSIN_SPAM_TO_INBOX has no explicit value set function _should_emit_warning() { sh -c "docker logs ${TEST_NAME} | grep 'Spam messages WILL NOT BE DELIVERED'" } function _should_bounce_spam() { wait_for_smtp_port_in_container_to_respond "${TEST_NAME}" # send a spam message run docker exec "${TEST_NAME}" /bin/sh -c "nc 0.0.0.0 25 < /tmp/docker-mailserver-test/email-templates/amavis-spam.txt" assert_success run repeat_until_success_or_timeout 20 sh -c "docker logs ${TEST_NAME} | grep 'Blocked SPAM {NoBounceInbound,Quarantined}'" assert_success }