summaryrefslogtreecommitdiff
path: root/tests/e2e/e2e-test-mail.sh
blob: 881aa627574c721ecae3e45792723954d63f01fa (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
#!/bin/bash

# Dependencies
# - swaks and uuid-runtime debian packages
#
#
# Usage
#
# In order to send authenticated mail to the tmp_user you need to
# export these environment variables before running this script:
#   - FROM_EXTERNAL_OPTS for sending mails from external mailservers to the tmp_user account
#
# as an example:
#   export FROM_EXTERNAL_OPTS='--tlsc --au user@example.or -ap MYPASSWORD -s smtp.example.org'
#
# then:
#
#   source venv/bin/activate
#   make dev-latest-backend
#   make test_e2e
#
#
# TODO:
#   - Timeout waiting for mail
#   - Decrease poll interval
#   - Make it less noisy (fix the vext warnings)
#   - move away from cdev.bm
#   - remove test user on success

# exit if any commands returns non-zero status
set -e

# DEBUG
# set -x

# Check if scipt is run in debug mode so we can hide secrets
if [[ "$-" =~ 'x' ]]
then
  echo 'Running with xtrace enabled!'
  xtrace=true
else
  echo 'Running with xtrace disabled!'
  xtrace=false
fi

#PROVIDER='ci.leap.se'
PROVIDER='mail.bitmask.net'
INVITE_CODE=${BITMASK_INVITE_CODE:?"Need to set BITMASK_INVITE_CODE non-empty"}

BCTL='bitmaskctl'
POLKIT='lxpolkit'
LEAP_HOME="$HOME/.config/leap"
MAIL_UUID=$(uuidgen)

username="tmp_user_$(date +%Y%m%d%H%M%S)"
user="${username}@${PROVIDER}"
pw="$(head -c 10 < /dev/urandom | base64)"
SWAKS="swaks --h-Subject $MAIL_UUID --silent 2 --helo ci.leap.se -f ci@leap.se -t $user"

# Stop any previously started bitmaskd
# and start a new instance
"$BCTL" stop

[ -d "$LEAP_HOME" ] && rm -rf "$LEAP_HOME"


# XXX skip certificate verification! -- self-signed cert in ci.leap.se
SKIP_TWISTED_SSL_CHECK=1 "$BCTL" start

# Register a new user
# Disable xtrace
set +x
"$BCTL" user create "$user" --pass "$pw" --invite "$INVITE_CODE"
# Enable xtrace again only if it was set at beginning of script
[[ $xtrace == true ]] && set -x

#tail ~/.config/leap/bitmaskd.log
echo "created user. authenticating..."

# Authenticate
"$BCTL" user auth "$user" --pass "$pw" > /dev/null

# Note that imap_pw is the same for smtp

imap_pw="None"

# FIXME -- this would be prettier if we had the auth command block on
# the first-time run, so that we just return when the key has been generated
# and explicitely raise any error found

while [[ $imap_pw == *"None"* ]]; do
  response=$("$BCTL" mail get_token)
  sleep 2
  imap_pw=$(echo "$response" | head -n 1 | sed 's/  */ /g' | cut -d' ' -f 2)
done

$SWAKS $FROM_EXTERNAL_OPTS


echo "IMAP/SMTP PASSWD: $imap_pw"

# Send testmail
$SWAKS $FROM_EXTERNAL_OPTS

# wait until we the get mail we just sent.
while ! ./tests/e2e/getmail --mailbox INBOX --subject "$MAIL_UUID" "$user" "$imap_pw" > /dev/null
do
  echo "Waiting for incoming test mail..."
  sleep 10
done

echo "Succeeded - mail arrived"