Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
S
slapos.toolbox
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
Nicolas Wavrant
slapos.toolbox
Commits
9199b64d
Commit
9199b64d
authored
Dec 12, 2014
by
Cédric de Saint Martin
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
add erp5 resiliency test suite.
parent
918130a2
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
238 additions
and
5 deletions
+238
-5
setup.py
setup.py
+1
-1
slapos/resiliencytest/suites/erp5.py
slapos/resiliencytest/suites/erp5.py
+231
-0
slapos/resiliencytest/suites/resiliencytestsuite.py
slapos/resiliencytest/suites/resiliencytestsuite.py
+5
-4
slapos/resiliencytest/suites/slaprunner.py
slapos/resiliencytest/suites/slaprunner.py
+1
-0
No files found.
setup.py
View file @
9199b64d
...
@@ -42,7 +42,7 @@ setup(name=name,
...
@@ -42,7 +42,7 @@ setup(name=name,
'slapos.core'
,
# as it provides library for slap
'slapos.core'
,
# as it provides library for slap
'xml_marshaller'
,
# needed to dump information
'xml_marshaller'
,
# needed to dump information
'GitPython'
,
#needed for git manipulation into slaprunner
'GitPython'
,
#needed for git manipulation into slaprunner
'netifaces'
'netifaces'
,
'rpdb'
]
+
additional_install_requires
,
]
+
additional_install_requires
,
extras_require
=
{
extras_require
=
{
'lampconfigure'
:
[
"mysql-python"
],
#needed for MySQL Database access
'lampconfigure'
:
[
"mysql-python"
],
#needed for MySQL Database access
...
...
slapos/resiliencytest/suites/erp5.py
0 → 100644
View file @
9199b64d
# -*- coding: utf-8 -*-
##############################################################################
#
# Copyright (c) 2014 Vifib SARL and Contributors. All Rights Reserved.
#
# WARNING: This program as such is intended to be used by professional
# programmers who take the whole responsibility 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
# guarantees 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 3
# 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.
#
##############################################################################
from
.slaprunner
import
SlaprunnerTestSuite
import
json
import
random
import
ssl
import
string
import
time
import
urllib
import
urllib2
class
NotHttpOkException
(
Exception
):
pass
class
ERP5TestSuite
(
SlaprunnerTestSuite
):
"""
Run ERP5 inside Slaprunner Resiliency Test.
Note: requires specific kernel allowing long shebang paths.
"""
def
_setERP5InstanceParameter
(
self
):
"""
Set inside of slaprunner the instance parameter to use to deploy erp5 instance.
"""
self
.
_connectToSlaprunner
(
resource
=
'saveParameterXml'
,
data
=
'software_type=production¶meter=%3C%3Fxml+version%3D%221.0%22+encoding%3D%22utf-8%22%3F%3E%0A%3Cinstance%3E%0A%3Cparameter+id%3D%22json%22%3E%7B%0A++%22backup-periodicity%22%3A+%22*%2F5+*+*+*+*%22%2C%0A++%22site-id%22%3A+%22erp5%22%2C%0A++%22erp5-ca%22%3A+%7B%0A++++%22country-code%22%3A+%22FR%22%2C%0A++++%22city%22%3A+%22Lille%22%2C%0A++++%22state%22%3A+%22Nord-Pas-de-Calais%22%2C%0A++++%22company%22%3A+%22ViFiB+SARL%22%2C%0A++++%22email%22%3A+%22admin%40vifib.org%22%0A++%7D%2C%0A++%22zeo%22%3A+%7B%0A++++%22Zeo-Server-1%22%3A+%5B%7B%0A++++++%22zodb-name%22%3A+%22main%22%2C%0A++++++%22serialize-path%22%3A+%22%2F%25(site-id)s%2Faccount_module%2F%22%2C%0A++++++%22mount-point%22%3A+%22%2F%22%2C%0A++++++%22zope-cache-size%22%3A+%222000%22%2C%0A++++++%22storage-name%22%3A+%22main%22%2C%0A++++++%22zeo-cache-size%22%3A+%22400MB%22%0A++++%7D%5D%0A++%7D%2C%0A++%22activity%22%3A+%7B%0A++++%22zopecount%22%3A+1%2C%0A++++%22timerservice%22%3A+true%0A++%7D%2C%0A++%22timezone%22%3A+%22Europe%2FParis%22%2C%0A++%22backend%22%3A+%7B%0A++++%22login%22%3A+%7B%0A++++++%22zopecount%22%3A+1%2C%0A++++++%22access-control-string%22%3A+%22all%22%2C%0A++++++%22scheme%22%3A+%5B%22https%22%5D%2C%0A++++++%22maxconn%22%3A+1%2C%0A++++++%22thread-amount%22%3A+1%0A++++%7D%2C%0A++++%22erp5%22%3A+%7B%0A++++++%22zopecount%22%3A+1%2C%0A++++++%22access-control-string%22%3A+%22all%22%2C%0A++++++%22scheme%22%3A+%5B%22https%22%5D%2C%0A++++++%22maxconn%22%3A+1%2C%0A++++++%22thread-amount%22%3A+1%0A++++%7D%0A++%7D%0A%7D%3C%2Fparameter%3E%0A%3Cparameter+id%3D%22mariadb-json%22%3E%7B%22backup-periodicity%22%3A+%22*%2F5+*+*+*+*%22%7D%3C%2Fparameter%3E%0A%3C%2Finstance%3E%0A'
)
def
_getERP5Url
(
self
):
"""
Return the backend url of erp5 instance.
Note: it is not connection parameter of slaprunner,
but connection parameter of what is inside of webrunner.
"""
data
=
self
.
_connectToSlaprunner
(
resource
=
'getConnectionParameter/slappart5'
)
url
=
json
.
loads
(
data
)[
'url-erp5'
]
self
.
logger
.
info
(
'Retrieved erp5 url is:
\
n
%s'
%
url
)
return
url
def
_connectToERP5
(
self
,
url
,
data
=
None
):
auth_handler
=
urllib2
.
HTTPBasicAuthHandler
()
auth_handler
.
add_password
(
realm
=
'Zope'
,
uri
=
url
,
user
=
'zope'
,
passwd
=
'insecure'
)
ssl_context
=
ssl
.
_create_unverified_context
()
opener_director
=
urllib2
.
build_opener
(
auth_handler
,
urllib2
.
HTTPSHandler
(
context
=
ssl_context
)
)
self
.
logger
.
info
(
'Calling ERP5 url %s'
%
url
)
if
data
:
result
=
opener_director
.
open
(
url
,
data
=
data
)
else
:
result
=
opener_director
.
open
(
url
)
if
result
.
getcode
()
is
not
200
:
raise
NotHttpOkException
(
result
.
getcode
())
return
result
.
read
()
def
_createRandomERP5Document
(
self
):
""" Create a document with random content in erp5 site."""
# XXX currently only sets erp5 site title.
# XXX could be simplified to /erp5/setTitle?title=slapos
erp5_site_title
=
self
.
slaprunner_user
url
=
"%s/erp5?__ac_name=zope&__ac_password=insecure"
%
self
.
_getERP5Url
()
form
=
'title%%3AUTF-8:string=%s&manage_editProperties%%3Amethod=Save+Changes'
%
erp5_site_title
self
.
_connectToERP5
(
url
,
form
)
return
erp5_site_title
def
_getCreatedERP5Document
(
self
):
""" Fetch and return content of ERP5 document created above."""
url
=
"%s/erp5/getTitle"
%
self
.
_getERP5Url
()
return
self
.
_connectToERP5
(
url
)
def
_editHAProxyconfiguration
(
self
):
"""
XXX pure hack.
haproxy processes don't support long path for sockets.
Edit haproxy configuration file of erp5 to make it compatible with long paths
Then restart haproxy.
"""
self
.
logger
.
info
(
'Editing HAProxy configuration...'
)
result
=
self
.
_connectToSlaprunner
(
resource
=
'/getFileContent'
,
data
=
'file=runner_workdir%2Finstance%2Fslappart5%2Fetc%2Fhaproxy-erp5.cfg'
)
file_content
=
json
.
loads
(
result
)[
'result'
]
file_content
=
file_content
.
replace
(
'var/run/haproxy-erp5.sock'
,
'ha-erp5.sock'
)
self
.
_connectToSlaprunner
(
resource
=
'/saveFileContent'
,
data
=
'file=runner_workdir%%2Finstance%%2Fslappart5%%2Fetc%%2Fhaproxy-erp5.cfg&content=%s'
%
urllib
.
quote
(
file_content
)
)
# Restart HAProxy
self
.
_connectToSlaprunner
(
resource
=
'/startStopProccess/name/slappart5:haproxy-erp5/cmd/STOPPED'
)
time
.
sleep
(
15
)
def
generateData
(
self
):
self
.
slaprunner_password
=
''
.
join
(
random
.
SystemRandom
().
sample
(
string
.
ascii_lowercase
,
8
)
)
self
.
slaprunner_user
=
'slapos'
self
.
logger
.
info
(
'Generated slaprunner user is: %s'
%
self
.
slaprunner_user
)
self
.
logger
.
info
(
'Generated slaprunner password is: %s'
%
self
.
slaprunner_password
)
def
pushDataOnMainInstance
(
self
):
"""
Create a dummy Software Release,
Build it,
Wait for build to be successful,
Deploy instance,
Wait for instance to be started.
Store the main IP of the slaprunner for future use.
"""
self
.
logger
.
debug
(
'Getting the backend URL and recovery code...'
)
parameter_dict
=
self
.
_getPartitionParameterDict
()
self
.
slaprunner_backend_url
=
parameter_dict
[
'backend_url'
]
self
.
logger
.
info
(
'backend_url is %s.'
%
self
.
slaprunner_backend_url
)
self
.
monitor_url
=
parameter_dict
[
'monitor_backend_url'
]
slaprunner_recovery_code
=
self
.
_getRcode
()
self
.
logger
.
debug
(
'Creating the slaprunner account...'
)
self
.
_connectToSlaprunner
(
resource
=
'configAccount'
,
data
=
'name=slapos&username=%s&email=slapos@slapos.org&password=%s&rcode=%s'
%
(
self
.
slaprunner_user
,
self
.
slaprunner_password
,
slaprunner_recovery_code
)
)
self
.
_login
()
self
.
_gitClone
()
self
.
_openSoftwareRelease
(
'erp5'
)
self
.
_setERP5InstanceParameter
()
# Debug, remove me.
time
.
sleep
(
600
)
self
.
_buildSoftwareRelease
()
self
.
_deployInstance
()
self
.
_deployInstance
()
self
.
_deployInstance
()
self
.
_editHAProxyconfiguration
()
self
.
logger
.
info
(
'Waiting 5 minutes so that erp5 can be bootstrapped...'
)
time
.
sleep
(
300
)
self
.
data
=
self
.
_createRandomERP5Document
()
self
.
logger
.
info
(
'Wait half an hour for main instance to have backup of erp5...'
)
time
.
sleep
(
3600
/
2
)
# in erp5testnode, we have only one IP, so we can't run at the same time
# erp5 in webrunner of main instance, and mariadb/zope/etc in import script of clone instance
# So we stop main instance processes.
self
.
_connectToSlaprunner
(
'/stopAllPartition'
)
self
.
logger
.
info
(
'Wait half an hour for clone to have compiled ERP5 SR...'
)
time
.
sleep
(
3600
/
2
)
def
checkDataOnCloneInstance
(
self
):
"""
Check that:
* backend_url is different
* Software Release profile is the same,
* Software Release is built and is the same,
* Instance is deployed and is the same (contains same new data).
"""
old_slaprunner_backend_url
=
self
.
slaprunner_backend_url
self
.
slaprunner_backend_url
=
self
.
_returnNewInstanceParameter
(
parameter_key
=
'backend_url'
,
old_parameter_value
=
old_slaprunner_backend_url
)
self
.
_login
()
self
.
_waitForSoftwareBuild
()
self
.
_deployInstance
()
time
.
sleep
(
60
)
self
.
_editHAProxyconfiguration
()
new_data
=
self
.
_getCreatedERP5Document
()
if
new_data
==
self
.
data
:
self
.
logger
.
info
(
'Data are the same: success.'
)
return
True
else
:
self
.
logger
.
info
(
'Data are different: failure.'
)
return
False
def
runTestSuite
(
*
args
,
**
kwargs
):
"""
Run Slaprunner Resiliency Test.
"""
return
ERP5TestSuite
(
*
args
,
**
kwargs
).
runTestSuite
()
slapos/resiliencytest/suites/resiliencytestsuite.py
View file @
9199b64d
...
@@ -211,10 +211,11 @@ class ResiliencyTestSuite(object):
...
@@ -211,10 +211,11 @@ class ResiliencyTestSuite(object):
# In case we have only one clone: test the takeover twice
# In case we have only one clone: test the takeover twice
# so that we test the reconstruction of a new clone.
# so that we test the reconstruction of a new clone.
if
clone_count
==
1
:
if
clone_count
==
1
:
for
i
in
range
(
2
):
return
self
.
_testClone
(
1
)
success
=
self
.
_testClone
(
1
)
#for i in range(2):
if
not
success
:
# success = self._testClone(1)
return
False
# if not success:
# return False
else
:
else
:
# Test each clone
# Test each clone
...
...
slapos/resiliencytest/suites/slaprunner.py
View file @
9199b64d
...
@@ -158,6 +158,7 @@ class SlaprunnerTestSuite(ResiliencyTestSuite):
...
@@ -158,6 +158,7 @@ class SlaprunnerTestSuite(ResiliencyTestSuite):
except
(
NotHttpOkException
,
urllib2
.
HTTPError
):
except
(
NotHttpOkException
,
urllib2
.
HTTPError
):
# The nginx frontend might timeout before software release is finished.
# The nginx frontend might timeout before software release is finished.
pass
pass
self
.
_waitForSoftwareBuild
()
self
.
_waitForSoftwareBuild
()
def
_deployInstance
(
self
):
def
_deployInstance
(
self
):
...
...
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