Dovecot 2.4 has a new configuration format, which is unfortunately backwards-incompatible with Dovecot 2.3. This patch adds a 2.4-compatible config, and selects which one to use based on the Dovecot version in the environment. In the future, once 2.4 becomes more common, we will drop the 2.3 config from the test. Note that we don't change the config used in the Docker image, because that is based on Debian **stable** which is still on 2.3.
102 lines
2.7 KiB
Bash
Executable File
102 lines
2.7 KiB
Bash
Executable File
#!/bin/bash
|
|
#
|
|
# This test checks that we can use dovecot as an authentication mechanism.
|
|
#
|
|
# Setup:
|
|
# - chasquid listening on :1025.
|
|
# - dovecot listening on unix sockets in .dovecot/
|
|
|
|
set -e
|
|
. "$(dirname "$0")/../util/lib.sh"
|
|
|
|
init
|
|
check_hostaliases
|
|
|
|
if ! dovecot --version > /dev/null; then
|
|
skip "dovecot not installed"
|
|
fi
|
|
|
|
# Create a temporary directory for dovecot to use, and generate the dovecot
|
|
# config based on the template.
|
|
# Note the length of the path must be < 100, because unix sockets have a low
|
|
# limitation, so we use a directory in /tmp, which is not ideal, as a
|
|
# workaround.
|
|
export ROOT="/tmp/chasquid-dovecot-test"
|
|
mkdir -p $ROOT $ROOT/run $ROOT/lib
|
|
rm -f $ROOT/dovecot.log
|
|
|
|
# Dovecot 2.4 config is not backwards compatible with 2.3.
|
|
# Since for now both are popular, we support testing against either.
|
|
# TODO: Remove 2.3 support once 2.4 becomes more common.
|
|
case "$(dovecot --version | cut -d . -f 1-2)" in
|
|
2.3)
|
|
DOVE_VER=2.3
|
|
;;
|
|
2.4)
|
|
DOVE_VER=2.4
|
|
;;
|
|
*)
|
|
skip "unknown dovecot version $(dovecot --version)"
|
|
;;
|
|
esac
|
|
|
|
|
|
GROUP=$(id -g -n) envsubst \
|
|
< config/dovecot.conf-$DOVE_VER.in > $ROOT/dovecot.conf
|
|
cp -f config/passwd $ROOT/passwd
|
|
|
|
dovecot -F -c $ROOT/dovecot.conf &
|
|
|
|
# Early tests: run dovecot-auth-cli for testing purposes. These fail early if
|
|
# there are obvious problems.
|
|
OUT=$(dovecot-auth-cli $ROOT/run/auth exists user@srv || true)
|
|
if [ "$OUT" != "yes" ]; then
|
|
fail "user does not exist: $OUT"
|
|
fi
|
|
|
|
OUT=$(dovecot-auth-cli $ROOT/run/auth auth user@srv password || true)
|
|
if [ "$OUT" != "yes" ]; then
|
|
fail "auth failed: $OUT"
|
|
fi
|
|
|
|
|
|
# Set up chasquid, using dovecot as authentication backend.
|
|
generate_certs_for srv
|
|
|
|
mkdir -p .logs
|
|
chasquid -v=2 --logfile=.logs/chasquid.log --config_dir=config &
|
|
wait_until_ready 1025
|
|
|
|
# Send an email as "user@srv" successfully.
|
|
smtpc user@srv < content
|
|
wait_for_file .mail/user@srv
|
|
mail_diff content .mail/user@srv
|
|
|
|
# Send an email as "naked" successfully.
|
|
rm .mail/user@srv
|
|
smtpc --user=naked --password=gun --from=naked@srv user@srv < content
|
|
wait_for_file .mail/user@srv
|
|
mail_diff content .mail/user@srv
|
|
|
|
# Send an email to the "naked" user successfully.
|
|
smtpc naked@srv < content
|
|
wait_for_file .mail/naked@srv
|
|
mail_diff content .mail/naked@srv
|
|
|
|
# Fail to send to nobody@srv (user does not exist).
|
|
if smtpc nobody@srv < content 2> /dev/null; then
|
|
fail "successfully sent an email to a non-existent user"
|
|
fi
|
|
|
|
# Fail to send from unknownuser@srv (user does not exist).
|
|
if smtpc --user=unknownuser@srv user@srv < content 2> /dev/null; then
|
|
fail "successfully sent an email with a bad user"
|
|
fi
|
|
|
|
# Fail to send with an incorrect password.
|
|
if smtpc --password=badpasswd user@srv < content 2> /dev/null; then
|
|
fail "successfully sent an email with a bad password"
|
|
fi
|
|
|
|
success
|