mirror of
https://github.com/mail-in-a-box/mailinabox.git
synced 2025-04-03 00:07:05 +00:00
Update QA tests for Nextcloud 28
This commit is contained in:
parent
b88845190f
commit
8cb2decb51
@ -22,8 +22,9 @@ D=$(dirname "$BASH_SOURCE")
|
|||||||
. "$D/rest.sh" || exit 4
|
. "$D/rest.sh" || exit 4
|
||||||
. "$D/system.sh" || exit 5
|
. "$D/system.sh" || exit 5
|
||||||
. "$D/carddav.sh" || exit 6
|
. "$D/carddav.sh" || exit 6
|
||||||
|
. "$D/webdav.sh" || exit 7
|
||||||
|
|
||||||
. "$D/populate.sh" || exit 7
|
. "$D/populate.sh" || exit 8
|
||||||
. "$D/installed-state.sh" || exit 8
|
. "$D/installed-state.sh" || exit 9
|
||||||
. "$D/totp.sh" || exit 9
|
. "$D/totp.sh" || exit 10
|
||||||
|
|
||||||
|
@ -31,7 +31,9 @@ class NcContactsAutomation(object):
|
|||||||
fullname = el.find_el('.line-one,.option__lineone').content().strip()
|
fullname = el.find_el('.line-one,.option__lineone').content().strip()
|
||||||
email = el.find_el('.line-two,.option__linetwo').content().strip()
|
email = el.find_el('.line-two,.option__linetwo').content().strip()
|
||||||
d.say_verbose('contact: "%s" <%s>', fullname, email)
|
d.say_verbose('contact: "%s" <%s>', fullname, email)
|
||||||
if fullname.lower() == "%s %s" % (contact['givenname'].lower(), contact['surname'].lower()) and email.lower() == contact['email'].lower():
|
# NC 28: email not present in html
|
||||||
|
ignore_email = True if email == '' else False
|
||||||
|
if fullname.lower() == "%s %s" % (contact['givenname'].lower(), contact['surname'].lower()) and ( ignore_email or email.lower() == contact['email'].lower() ):
|
||||||
found = True
|
found = True
|
||||||
el.click()
|
el.click()
|
||||||
break
|
break
|
||||||
|
@ -9,6 +9,8 @@
|
|||||||
|
|
||||||
from selenium.common.exceptions import (
|
from selenium.common.exceptions import (
|
||||||
NoSuchElementException,
|
NoSuchElementException,
|
||||||
|
ElementNotInteractableException,
|
||||||
|
ElementClickInterceptedException,
|
||||||
)
|
)
|
||||||
from .NcContactsAutomation import NcContactsAutomation
|
from .NcContactsAutomation import NcContactsAutomation
|
||||||
|
|
||||||
@ -32,18 +34,35 @@ class NextcloudAutomation(object):
|
|||||||
if not submit: submit = d.find_el('#submit-wrapper') # nc<25
|
if not submit: submit = d.find_el('#submit-wrapper') # nc<25
|
||||||
submit.click()
|
submit.click()
|
||||||
|
|
||||||
def logout(self):
|
def click_avatar(self):
|
||||||
d = self.d
|
d = self.d
|
||||||
d.say("Logout of Nextcloud")
|
d.say("click avatar")
|
||||||
el = d.find_el('#user-menu > a', throws=False)
|
el = d.find_el('#user-menu > a', throws=False)
|
||||||
|
if not el:
|
||||||
|
el = d.find_el('#user-menu > button', throws=False)
|
||||||
|
|
||||||
if not el:
|
if not el:
|
||||||
# nc < 26
|
# nc < 26
|
||||||
d.find_el('#settings .avatardiv').click()
|
d.find_el('#settings .avatardiv').click()
|
||||||
d.find_el('[data-id="logout"] a').click()
|
|
||||||
else:
|
else:
|
||||||
# nc >= 26
|
# nc >= 26
|
||||||
el.click()
|
el.click()
|
||||||
d.find_el('#logout > a').click()
|
d.wait_tick(1)
|
||||||
|
|
||||||
|
def logout(self):
|
||||||
|
d = self.d
|
||||||
|
d.say("Logout of Nextcloud")
|
||||||
|
self.click_avatar()
|
||||||
|
|
||||||
|
el = d.find_el('[data-id="logout"] a', throws=False) # nc < 26
|
||||||
|
if not el:
|
||||||
|
# nc >= 26
|
||||||
|
el = d.find_el('#logout > a', throws=False)
|
||||||
|
|
||||||
|
if el:
|
||||||
|
el.click()
|
||||||
|
else:
|
||||||
|
raise NoSuchElementException('could not find logout link')
|
||||||
|
|
||||||
def open_contacts(self):
|
def open_contacts(self):
|
||||||
d = self.d
|
d = self.d
|
||||||
@ -81,5 +100,8 @@ class NextcloudAutomation(object):
|
|||||||
firstrunwiz = d.find_el('#firstrunwizard', throws=False, quiet=True)
|
firstrunwiz = d.find_el('#firstrunwizard', throws=False, quiet=True)
|
||||||
if firstrunwiz and firstrunwiz.is_displayed():
|
if firstrunwiz and firstrunwiz.is_displayed():
|
||||||
d.say_verbose("closing first run wizard")
|
d.say_verbose("closing first run wizard")
|
||||||
d.find_el('#firstrunwizard span.close-icon').click()
|
# ElementNotInteractableException
|
||||||
|
# d.find_el('#firstrunwizard span.close-icon').click()
|
||||||
|
d.execute_script('document.querySelector("#firstrunwizard span.close-icon").click()')
|
||||||
|
|
||||||
d.wait_tick(1)
|
d.wait_tick(1)
|
||||||
|
133
tests/lib/webdav.sh
Normal file
133
tests/lib/webdav.sh
Normal file
@ -0,0 +1,133 @@
|
|||||||
|
#####
|
||||||
|
##### This file is part of Mail-in-a-Box-LDAP which is released under the
|
||||||
|
##### terms of the GNU Affero General Public License as published by the
|
||||||
|
##### Free Software Foundation, either version 3 of the License, or (at
|
||||||
|
##### your option) any later version. See file LICENSE or go to
|
||||||
|
##### https://github.com/downtownallday/mailinabox-ldap for full license
|
||||||
|
##### details.
|
||||||
|
#####
|
||||||
|
|
||||||
|
#
|
||||||
|
# requires:
|
||||||
|
# system packages: [ curl ]
|
||||||
|
# scripts: [ color-output.sh, misc.sh, locations.sh, carddav.sh ]
|
||||||
|
#
|
||||||
|
|
||||||
|
webdav_url() {
|
||||||
|
local user="$1"
|
||||||
|
local path="${2:-/}"
|
||||||
|
# nextcloud_url is defined in carddav.sh
|
||||||
|
local nc_url="$(nextcloud_url)"
|
||||||
|
echo "${nc_url%/}/remote.php/dav/files/$user${path%/}"
|
||||||
|
}
|
||||||
|
|
||||||
|
webdav_rest() {
|
||||||
|
# issue a WebDAV rest call to Nextcloud
|
||||||
|
#
|
||||||
|
# eg: webdav_rest PROPFIND / qa@abc.com Test_1234
|
||||||
|
#
|
||||||
|
# The function will set the following global variables regardless
|
||||||
|
# of exit code:
|
||||||
|
# REST_HTTP_CODE
|
||||||
|
# REST_OUTPUT
|
||||||
|
# REST_ERROR
|
||||||
|
# REST_ERROR_BRIEF
|
||||||
|
#
|
||||||
|
# Return values:
|
||||||
|
# 0 indicates success (curl returned 0 or a code deemed to be
|
||||||
|
# successful and HTTP status is >=200 but <300)
|
||||||
|
# 1 curl returned with non-zero code that indicates and error
|
||||||
|
# 2 the response status was <200 or >= 300
|
||||||
|
#
|
||||||
|
# Debug messages are sent to stderr
|
||||||
|
#
|
||||||
|
local verb="$1"
|
||||||
|
local uri="$2"
|
||||||
|
local auth_user="$3"
|
||||||
|
local auth_pass="$4"
|
||||||
|
shift; shift; shift; shift # remaining arguments are data
|
||||||
|
|
||||||
|
local url
|
||||||
|
case "$uri" in
|
||||||
|
http* )
|
||||||
|
url="$uri"
|
||||||
|
;;
|
||||||
|
* )
|
||||||
|
url="$(webdav_url "$auth_user")${uri#/}"
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
local data=()
|
||||||
|
local item output onlydata="false"
|
||||||
|
|
||||||
|
for item; do
|
||||||
|
case "$item" in
|
||||||
|
-- )
|
||||||
|
onlydata="true"
|
||||||
|
;;
|
||||||
|
--* )
|
||||||
|
# curl argument
|
||||||
|
if $onlydata; then
|
||||||
|
data+=("--data" "$item");
|
||||||
|
else
|
||||||
|
data+=("$item")
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
* )
|
||||||
|
onlydata="true"
|
||||||
|
data+=("--data" "$item");
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
|
||||||
|
local ct='text/xml; charset="utf-8"'
|
||||||
|
local tmp1="/tmp/curl.$$.tmp"
|
||||||
|
|
||||||
|
echo "spawn: curl -w \"%{http_code}\" -X $verb -H 'Content-Type: $ct' --user \"${auth_user}:xxx\" ${data[@]} \"$url\"" 1>&2
|
||||||
|
output=$(curl -s -S -w "%{http_code}" -X $verb -H "Content-Type: $ct" --user "${auth_user}:${auth_pass}" "${data[@]}" "$url" 2>$tmp1)
|
||||||
|
local code=$?
|
||||||
|
|
||||||
|
# http status is last 3 characters of output, extract it
|
||||||
|
REST_HTTP_CODE=$(awk '{S=substr($0,length($0)-2)} END {print S}' <<<"$output")
|
||||||
|
REST_OUTPUT=$(awk 'BEGIN{L=""}{ if(L!="") print L; L=$0 } END { print substr(L,1,length(L)-3) }' <<<"$output")
|
||||||
|
REST_ERROR=""
|
||||||
|
REST_ERROR_BRIEF=""
|
||||||
|
[ -z "$REST_HTTP_CODE" ] && REST_HTTP_CODE="000"
|
||||||
|
|
||||||
|
if [ $code -ne 0 -o \
|
||||||
|
$REST_HTTP_CODE -lt 200 -o \
|
||||||
|
$REST_HTTP_CODE -ge 300 ]
|
||||||
|
then
|
||||||
|
if [ $code -ne 0 -a "$REST_HTTP_CODE" == "000" ]; then
|
||||||
|
REST_ERROR="exit code $code"
|
||||||
|
REST_ERROR_BRIEF="$REST_ERROR"
|
||||||
|
else
|
||||||
|
REST_ERROR="REST status $REST_HTTP_CODE: $REST_OUTPUT"
|
||||||
|
REST_ERROR_BRIEF=$(python3 -c "import xml.etree.ElementTree as ET; print(ET.fromstring(r'''$REST_OUTPUT''').find('s:message',{'s':'http://sabredav.org/ns'}).text)" 2>/dev/null)
|
||||||
|
if [ -z "$REST_ERROR_BRIEF" ]; then
|
||||||
|
REST_ERROR_BRIEF="$REST_ERROR"
|
||||||
|
else
|
||||||
|
REST_ERROR_BRIEF="$REST_HTTP_CODE: $REST_ERROR_BRIEF"
|
||||||
|
fi
|
||||||
|
if [ $code -ne 0 ]; then
|
||||||
|
REST_ERROR_BRIEF="exit code $code: $REST_ERROR_BRIEF"
|
||||||
|
REST_ERROR="exit code $code: $REST_ERROR"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -s $tmp1 ]; then
|
||||||
|
REST_ERROR="$REST_ERROR: $(cat $tmp1)"
|
||||||
|
REST_ERROR_BRIEF="$REST_ERROR_BRIEF: $(cat $tmp1)"
|
||||||
|
fi
|
||||||
|
rm -f $tmp1
|
||||||
|
|
||||||
|
echo "${F_DANGER}$REST_ERROR${F_RESET}" 1>&2
|
||||||
|
[ $code -ne 0 ] && return 1
|
||||||
|
return 2
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "CURL succeded, HTTP status $REST_HTTP_CODE" 1>&2
|
||||||
|
echo "$output" 1>&2
|
||||||
|
rm -f $tmp1
|
||||||
|
return 0
|
||||||
|
}
|
@ -65,6 +65,9 @@ try:
|
|||||||
contacts.click_contact(contact)
|
contacts.click_contact(contact)
|
||||||
contacts.wait_contact_loaded()
|
contacts.wait_contact_loaded()
|
||||||
contacts.delete_current_contact()
|
contacts.delete_current_contact()
|
||||||
|
|
||||||
|
elif op=='nop':
|
||||||
|
pass
|
||||||
|
|
||||||
else:
|
else:
|
||||||
raise ValueError('Invalid operation: %s' % op)
|
raise ValueError('Invalid operation: %s' % op)
|
||||||
|
@ -86,7 +86,19 @@ test_nextcloud_contacts() {
|
|||||||
# create local user alice
|
# create local user alice
|
||||||
mgmt_assert_create_user "$alice" "$alice_pw"
|
mgmt_assert_create_user "$alice" "$alice_pw"
|
||||||
|
|
||||||
|
# NC 28: make sure user is initialized in nextcloud by logging
|
||||||
|
# them in and opening the contacts app using ui
|
||||||
|
# automation. otherwise, any access to contacts will fail with 404
|
||||||
|
# "Addressbook with name 'contacts' could not be found". logging
|
||||||
|
# in, by say, using a WebDAV PROPFIND does not work.
|
||||||
|
record "Initialize $alice in nextcloud"
|
||||||
|
assert_browser_test \
|
||||||
|
nextcloud/contacts.py \
|
||||||
|
"nop" \
|
||||||
|
"$alice" \
|
||||||
|
"$alice_pw" \
|
||||||
|
"" "" ""
|
||||||
|
|
||||||
#
|
#
|
||||||
# 1. create contact in Nextcloud - ensure it is available in Roundcube
|
# 1. create contact in Nextcloud - ensure it is available in Roundcube
|
||||||
#
|
#
|
||||||
|
@ -71,7 +71,21 @@ test_create_contact() {
|
|||||||
# generate an email address - the contact's email must be
|
# generate an email address - the contact's email must be
|
||||||
# unique or it can't be created
|
# unique or it can't be created
|
||||||
local contact_email="bob_bacon$(generate_uuid | awk -F- '{print $1 }')@example.com"
|
local contact_email="bob_bacon$(generate_uuid | awk -F- '{print $1 }')@example.com"
|
||||||
|
|
||||||
|
# NC 28: make sure user is initialized in nextcloud by logging
|
||||||
|
# them in and opening the contacts app using ui
|
||||||
|
# automation. otherwise, any access to contacts will fail with
|
||||||
|
# 404 "Addressbook with name 'contacts' could not be
|
||||||
|
# found". logging in, by say, using a WebDAV PROPFIND does not
|
||||||
|
# work.
|
||||||
|
record "Initialize $alice in nextcloud"
|
||||||
|
assert_browser_test \
|
||||||
|
nextcloud/contacts.py \
|
||||||
|
"nop" \
|
||||||
|
"$alice" \
|
||||||
|
"$alice_pw" \
|
||||||
|
"" "" ""
|
||||||
|
|
||||||
# create a contact using roundcube's ui
|
# create a contact using roundcube's ui
|
||||||
record "[create contact in Roundcube]"
|
record "[create contact in Roundcube]"
|
||||||
if assert_browser_test \
|
if assert_browser_test \
|
||||||
|
Loading…
Reference in New Issue
Block a user