Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
erp5
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Léo-Paul Géneau
erp5
Commits
f8e8eb86
Commit
f8e8eb86
authored
Jun 29, 2017
by
Jérome Perrin
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
tests: remove old way of running functional tests
parent
acba8dc0
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
0 additions
and
459 deletions
+0
-459
product/ERP5Type/tests/runFunctionalTest.py
product/ERP5Type/tests/runFunctionalTest.py
+0
-370
product/ERP5Type/tests/sendMail.py
product/ERP5Type/tests/sendMail.py
+0
-89
No files found.
product/ERP5Type/tests/runFunctionalTest.py
deleted
100644 → 0
View file @
acba8dc0
#!/usr/bin/env python2.7
import
os
import
re
import
signal
import
sys
import
shutil
import
getopt
from
time
import
sleep
import
urllib2
from
subprocess
import
Popen
,
PIPE
from
sendMail
import
sendMail
import
atexit
print
"DEPRECATION WARNING: This command 'runFunctionalTest' is Deprecated, "
+
\
"you should use ERP5TypeFunctionalTestCase and runUnitTest instead."
+
\
"You can take a look at testFunctionalCore.py"
__doc__
=
"""%(program)s: Zelenium functional test runner for the ERP5 Project
usage: %(program)s [options]
Options:
-h, --help this help screen
--email_to_address=STRING send results to this address by email (defaults to
erp5-report@erp5.org)
--smtp_host=hostname specify SMTP server
-s, --stdout print the results on stdout instead of sending
results by email (unless email_to_address is also
passed explicitly)
-d, --debug run firefox on current DISPLAY instead of on Xvfb
--host the hostname of this ERP5 instance
--port the port of this ERP5 instance
--portal_name the ID of the ERP5 site
URLs will start with:
http://${host}:${port}/${portal_name}/
--run_only=STRING run only specified test suite (should be only one)
--email_subject the email subject to be sent
--xvfb_display=STRING Define a xvfb display to be used.
Notes:
* You need to prepare first test environment by using following command:
./runUnitTest.py --save prepareFunctionalTest.py
"""
tests_framework_home
=
os
.
path
.
dirname
(
os
.
path
.
abspath
(
__file__
))
# handle 'system global' instance
if
tests_framework_home
.
startswith
(
'/usr/lib'
):
real_instance_home
=
'/var/lib/erp5'
else
:
real_instance_home
=
os
.
path
.
sep
.
join
(
tests_framework_home
.
split
(
os
.
path
.
sep
)[:
-
3
])
instance_home
=
os
.
path
.
join
(
real_instance_home
,
'unit_test'
)
bt5_dir_list
=
','
.
join
([
os
.
path
.
join
(
instance_home
,
'Products/ERP5/bootstrap'
),
os
.
path
.
join
(
instance_home
,
'bt5'
)])
class
FunctionalTestRunner
:
"""
Used to run Functional tests
"""
def
__init__
(
self
,
instance_home
):
self
.
instance_home
=
instance_home
self
.
xvfb_fbdir
=
instance_home
self
.
send_mail
=
0
self
.
stdout
=
0
self
.
debug
=
0
self
.
email_to_address
=
'erp5-report@erp5.org'
self
.
smtp_host
=
''
self
.
host
=
'localhost'
self
.
port
=
8080
self
.
user
=
'ERP5TypeTestCase'
self
.
password
=
''
self
.
portal_name
=
'erp5_portal'
self
.
run_only
=
''
self
.
email_subject
=
'ERP5'
self
.
xvfb_display
=
'123'
self
.
profile_dir
=
os
.
path
.
join
(
instance_home
,
'profile'
)
def
usage
(
self
,
stream
,
msg
=
None
):
if
msg
:
print
>>
stream
,
msg
print
>>
stream
program
=
os
.
path
.
basename
(
sys
.
argv
[
0
])
print
>>
stream
,
__doc__
%
{
"program"
:
program
}
def
parseArgs
(
self
,
arguments
=
None
):
if
arguments
is
None
:
arguments
=
sys
.
argv
[
1
:]
try
:
opts
,
args
=
getopt
.
getopt
(
arguments
,
"hsd"
,
[
"help"
,
"stdout"
,
"debug"
,
"email_to_address="
,
"host="
,
"port="
,
"portal_name="
,
"run_only="
,
"user="
,
"password="
,
"alarms="
,
"email_subject="
,
"smtp_host="
,
"xvfb_display="
]
)
except
getopt
.
GetoptError
,
msg
:
self
.
usage
(
sys
.
stderr
,
msg
)
sys
.
exit
(
2
)
for
opt
,
arg
in
opts
:
if
opt
in
(
"-s"
,
"--stdout"
):
self
.
stdout
=
1
elif
opt
in
(
"-d"
,
"--debug"
):
self
.
debug
=
1
elif
opt
==
'--email_to_address'
:
self
.
email_to_address
=
arg
self
.
send_mail
=
1
elif
opt
==
'--smtp_host'
:
self
.
smtp_host
=
arg
elif
opt
in
(
'-h'
,
'--help'
):
self
.
usage
(
sys
.
stdout
)
sys
.
exit
()
elif
opt
==
"--host"
:
self
.
host
=
arg
elif
opt
==
"--port"
:
self
.
port
=
int
(
arg
)
elif
opt
==
"--portal_name"
:
self
.
portal_name
=
arg
elif
opt
==
"--run_only"
:
self
.
run_only
=
arg
elif
opt
==
"--user"
:
user
=
arg
elif
opt
==
"--password"
:
password
=
arg
elif
opt
==
"--email_subject"
:
self
.
email_subject
=
arg
elif
opt
==
"--xvfb_display"
:
self
.
xvfb_display
=
arg
if
not
self
.
stdout
:
self
.
send_mail
=
1
self
.
portal_url
=
"http://%s:%d/%s"
%
(
self
.
host
,
self
.
port
,
self
.
portal_name
)
def
openUrl
(
self
,
url
):
# Send Accept-Charset headers to activate the UnicodeConflictResolver
# (imitating firefox 3.5.9 here)
headers
=
{
'Accept-Charset'
:
'ISO-8859-1,utf-8;q=0.7,*;q=0.7'
}
request
=
urllib2
.
Request
(
url
,
headers
=
headers
)
# Try to use long timeout, this is needed when there is many
# activities runing
try
:
f
=
urllib2
.
urlopen
(
request
,
timeout
=
3600
*
4
)
except
TypeError
:
f
=
urllib2
.
urlopen
(
request
)
file_content
=
f
.
read
()
f
.
close
()
return
file_content
def
main
(
self
):
self
.
setUp
()
self
.
launchFuntionalTest
()
def
launchFuntionalTest
(
self
):
status
=
self
.
getStatus
()
xvfb_pid
=
None
firefox_pid
=
None
try
:
if
not
self
.
debug
:
xvfb_pid
=
self
.
runXvfb
(
self
.
xvfb_display
)
firefox_pid
=
self
.
runFirefox
(
self
.
xvfb_display
)
while
True
:
sleep
(
10
)
cur_status
=
self
.
getStatus
()
if
status
!=
cur_status
:
break
finally
:
if
xvfb_pid
:
os
.
kill
(
xvfb_pid
,
signal
.
SIGTERM
)
if
firefox_pid
:
os
.
kill
(
firefox_pid
,
signal
.
SIGTERM
)
def
startZope
(
self
):
os
.
environ
[
'erp5_save_data_fs'
]
=
"1"
os
.
system
(
'%s/bin/zopectl start'
%
self
.
instance_home
)
sleep
(
2
)
# ad hoc
def
stopZope
(
self
):
os
.
system
(
'%s/bin/zopectl stop'
%
self
.
instance_home
)
def
runXvfb
(
self
,
xvfb_display
):
pid
=
os
.
spawnlp
(
os
.
P_NOWAIT
,
'Xvfb'
,
'Xvfb'
,
'-fbdir'
,
'%s'
%
self
.
xvfb_fbdir
,
':%s'
%
xvfb_display
)
display
=
os
.
environ
.
get
(
'DISPLAY'
)
if
display
:
auth
=
Popen
([
'xauth'
,
'list'
,
display
],
stdout
=
PIPE
).
communicate
()[
0
]
if
auth
:
(
displayname
,
protocolname
,
hexkey
)
=
auth
.
split
()
Popen
([
'xauth'
,
'add'
,
'localhost/unix:%s'
%
xvfb_display
,
protocolname
,
hexkey
])
print
'Xvfb : %d'
%
pid
print
'Take screenshots using xwud -in %s/Xvfb_screen0'
%
self
.
xvfb_fbdir
return
pid
def
getPrefJs
(
self
,
host
,
port
):
prefs_js
=
"""
// Don't ask if we want to switch default browsers
user_pref("browser.shell.checkDefaultBrowser", false);
// Disable pop-up blocking
user_pref("browser.allowpopups", true);
user_pref("dom.disable_open_during_load", false);
// Configure us as the local proxy
//user_pref("network.proxy.type", 2);
// Disable security warnings
user_pref("security.warn_submit_insecure", false);
user_pref("security.warn_submit_insecure.show_once", false);
user_pref("security.warn_entering_secure", false);
user_pref("security.warn_entering_secure.show_once", false);
user_pref("security.warn_entering_weak", false);
user_pref("security.warn_entering_weak.show_once", false);
user_pref("security.warn_leaving_secure", false);
user_pref("security.warn_leaving_secure.show_once", false);
user_pref("security.warn_viewing_mixed", false);
user_pref("security.warn_viewing_mixed.show_once", false);
// Disable "do you want to remember this password?"
user_pref("signon.rememberSignons", false);
// increase the timeout before warning of unresponsive script
user_pref("dom.max_script_run_time", 120);
// this is required to upload files
user_pref("capability.principal.codebase.p1.granted", "UniversalFileRead");
user_pref("signed.applets.codebase_principal_support", true);
user_pref("capability.principal.codebase.p1.id", "http://%s");
user_pref("capability.principal.codebase.p1.subjectName", "");"""
%
\
'%s:%s'
%
(
host
,
port
)
return
prefs_js
def
prepareFirefox
(
self
,
prefs_js
=
''
):
os
.
system
(
"rm -rf %s"
%
self
.
profile_dir
)
os
.
mkdir
(
self
.
profile_dir
)
pref_file
=
open
(
os
.
path
.
join
(
self
.
profile_dir
,
'prefs.js'
),
'w'
)
pref_file
.
write
(
prefs_js
)
pref_file
.
close
()
def
runFirefox
(
self
,
xvfb_display
):
prefs_js
=
self
.
getPrefJs
(
self
.
host
,
self
.
port
)
self
.
prepareFirefox
(
prefs_js
)
if
self
.
debug
:
try
:
shutil
.
copy2
(
os
.
path
.
expanduser
(
'~/.Xauthority'
),
'%s/.Xauthority'
%
self
.
profile_dir
)
except
IOError
:
pass
else
:
os
.
environ
[
'DISPLAY'
]
=
':%s'
%
xvfb_display
os
.
environ
[
'MOZ_NO_REMOTE'
]
=
'1'
os
.
environ
[
'HOME'
]
=
self
.
profile_dir
os
.
environ
[
'LC_ALL'
]
=
'C'
# check if old zelenium or new zelenium
try
:
urllib2
.
urlopen
(
"%s/portal_tests/core/scripts/selenium-version.js"
%
self
.
portal_url
)
except
urllib2
.
HTTPError
:
# Zelenium 0.8
url_string
=
"%s/portal_tests/?auto=true&__ac_name=%s&__ac_password=%s"
%
(
self
.
portal_url
,
self
.
user
,
self
.
password
)
else
:
# Zelenium 0.8+ or later
url_string
=
"%s/portal_tests/core/TestRunner.html?test=../test_suite_html&auto=on&resultsUrl=%s/portal_tests/postResults&__ac_name=%s&__ac_password=%s"
%
(
self
.
portal_url
,
self
.
portal_url
,
self
.
user
,
self
.
password
)
if
self
.
run_only
:
url_string
=
url_string
.
replace
(
'/portal_tests/'
,
'/portal_tests/%s/'
%
self
.
run_only
,
1
)
pid
=
os
.
spawnlp
(
os
.
P_NOWAIT
,
"firefox"
,
"firefox"
,
"-no-remote"
,
"-profile"
,
self
.
profile_dir
,
url_string
)
os
.
environ
[
'MOZ_NO_REMOTE'
]
=
'0'
print
'firefox : %d'
%
pid
return
pid
def
getStatus
(
self
):
try
:
status
=
self
.
openUrl
(
'%s/portal_tests/TestTool_getResults'
%
(
self
.
portal_url
))
except
urllib2
.
HTTPError
,
e
:
if
e
.
msg
==
"No Content"
:
status
=
""
else
:
raise
return
status
def
setPreference
(
self
):
conversion_server_url
=
os
.
environ
.
get
(
'conversion_server_url'
,
''
)
conversion_server_hostname
=
os
.
environ
.
get
(
'conversion_server_hostname'
,
'localhost'
)
conversion_server_port
=
os
.
environ
.
get
(
'conversion_server_port'
,
'8008'
)
urllib2
.
urlopen
(
'%s/Zuite_setPreference?__ac_name='
'%s&__ac_password=%s&working_copy_list=%s'
'&conversion_server_url=%s'
%
(
self
.
portal_url
,
self
.
user
,
self
.
password
,
bt5_dir_list
,
conversion_server_url
,))
def
unsubscribeFromTimerService
(
self
):
urllib2
.
urlopen
(
'%s/portal_activities/?unsubscribe:method='
'&__ac_name=%s&__ac_password=%s'
%
(
self
.
portal_url
,
self
.
user
,
self
.
password
))
def
setUp
(
self
):
self
.
setPreference
()
self
.
unsubscribeFromTimerService
()
def
getSvnRevision
(
self
):
"""Get svn revision used."""
import
pysvn
return
pysvn
.
Client
().
info
(
os
.
path
.
dirname
(
__file__
)).
revision
.
number
def
sendResult
(
self
):
file_content
=
self
.
openUrl
(
'%s/portal_tests/TestTool_getResults'
%
self
.
portal_url
)
passes_re
=
re
.
compile
(
'<th[^>]*>Tests passed</th>
\
n
\
s*<
t
d[^>]*>([^<]*)'
)
failures_re
=
re
.
compile
(
'<th[^>]*>Tests failed</th>
\
n
\
s*<
t
d[^>]*>([^<]*)'
)
image_re
=
re
.
compile
(
'<img[^>]*?>'
)
error_title_re
=
re
.
compile
(
'(?:error.gif.*?>|title status_failed"><td[^>]*>)([^>]*?)</td></tr>'
,
re
.
S
)
result_re
=
re
.
compile
(
'<div style="padding-top: 10px;">
\
s*<p>
\
s*'
'<img.*?</div>
\
s.*?</di
v
>
\
s*
'
, re.S)
error_result_re = re.compile('
.
*
(
?
:
error
.
gif
|
title
status_failed
).
*
', re.S)
passes = passes_re.search(file_content).group(1)
failures = failures_re.search(file_content).group(1)
error_titles = [re.compile('
\
s
+
').sub('
', x).strip()
for x in error_title_re.findall(file_content)]
revision = self.getSvnRevision()
subject = "%s r%s: Functional Tests, %s Passes, %s Failures"
\
% (self.email_subject, revision, passes, failures)
summary = """
Test Summary
Tests passed: %4s
Tests failed: %4s
Following tests failed:
%s""" % (passes, failures, "
\
n
".join(error_titles))
detail = ''
for e in result_re.findall(file_content):
if error_result_re.match(e):
detail += e
detail = image_re.sub('', detail)
if detail:
detail = '''<html>
<head>
<style type="text/css">tr.status_failed { background-color:red };</style>
</head>
<body>%s</body>
</html>''' % detail
status = (not failures)
if self.send_mail:
sendMail(subject=subject,
body=summary,
status=status,
attachments=[detail],
from_mail='
nobody
@
svn
.
erp5
.
org
',
to_mail=[self.email_to_address],
smtp_host=self.smtp_host)
if self.stdout:
print '
-
' * 79
print subject
print '
-
' * 79
print summary
print '
-
' * 79
print detail
return int(failures)
if __name__ == "__main__":
test_runner = FunctionalTestRunner(instance_home)
test_runner.parseArgs()
test_runner.startZope()
atexit.register(test_runner.stopZope)
test_runner.main()
sys.exit(test_runner.sendResult())
product/ERP5Type/tests/sendMail.py
deleted
100644 → 0
View file @
acba8dc0
##############################################################################
#
# Copyright (c) 2007 Nexedi SARL and Contributors. All Rights Reserved.
# Kazuhiko <kazuhiko@nexedi.com>
#
# WARNING: This program as such is intended to be used by professional
# programmers who take the whole responsability of assessing all potential
# consequences resulting from its eventual inadequacies and bugs
# End users who are looking for a ready-to-use solution with commercial
# garantees and support are strongly adviced to contract a Free Software
# Service Company
#
# This program is Free Software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License
# as published by the Free Software Foundation; either version 2
# of the License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
#
##############################################################################
"""Send a mail with attachments.
"""
import
smtplib
import
re
from
email.mime.text
import
MIMEText
from
email.mime.multipart
import
MIMEMultipart
from
email.message
import
Message
def
sendMail
(
subject
,
body
,
attachments
=
[],
status
=
False
,
from_mail
=
'nobody@erp5.org'
,
to_mail
=
[
'erp5-report@erp5.org'
],
smtp_host
=
''
):
if
attachments
:
msg
=
MIMEMultipart
()
else
:
msg
=
Message
()
msg
[
'Subject'
]
=
subject
msg
[
'From'
]
=
from_mail
msg
[
'To'
]
=
', '
.
join
(
to_mail
)
msg
[
'X-ERP5-Tests'
]
=
'ERP5'
if
status
:
msg
[
'X-ERP5-Tests-Status'
]
=
'OK'
# Guarantees the message ends in a newline
msg
.
preamble
=
subject
msg
.
epilogue
=
''
if
attachments
:
mime_text
=
MIMEText
(
body
)
mime_text
.
add_header
(
'Content-Disposition'
,
'attachment'
,
filename
=
'body'
)
msg
.
attach
(
mime_text
)
html_re
=
re
.
compile
(
'<html>'
,
re
.
I
)
for
item
in
attachments
:
mime_text
=
MIMEText
(
item
)
if
html_re
.
match
(
item
):
mime_text
.
set_type
(
'text/html'
)
mime_text
.
add_header
(
'Content-Disposition'
,
'attachment'
,
filename
=
'attachment.html'
)
else
:
mime_text
.
add_header
(
'Content-Disposition'
,
'attachment'
,
filename
=
'attachment.txt'
)
msg
.
attach
(
mime_text
)
else
:
msg
.
set_payload
(
body
)
# Send the email via SMTP server.
if
smtp_host
:
s
=
smtplib
.
SMTP
(
smtp_host
)
else
:
s
=
smtplib
.
SMTP
()
s
.
connect
()
s
.
sendmail
(
from_mail
,
to_mail
,
msg
.
as_string
())
s
.
close
()
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment