Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
K
kedifa
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
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Łukasz Nowak
kedifa
Commits
2dbbf2d7
Commit
2dbbf2d7
authored
Oct 06, 2021
by
Łukasz Nowak
Browse files
Options
Browse Files
Download
Plain Diff
kedifa: Test stabilizing fixup, wait a bit longer on the cauase first start
See merge request
!11
parents
bf6754fe
a5ea5ecb
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
93 additions
and
31 deletions
+93
-31
.gitignore
.gitignore
+1
-0
kedifa/test.py
kedifa/test.py
+92
-31
No files found.
.gitignore
0 → 100644
View file @
2dbbf2d7
*.pyc
kedifa/test.py
View file @
2dbbf2d7
...
...
@@ -17,7 +17,7 @@
# See COPYING file for full licensing terms.
# See https://www.nexedi.com/licensing for rationale and options.
from
six
import
StringIO
from
six
import
StringIO
,
BytesIO
import
contextlib
import
datetime
from
six.moves
import
http_client
as
httplib
...
...
@@ -31,6 +31,7 @@ import requests.exceptions
import
shutil
import
signal
import
sys
import
tarfile
import
tempfile
import
time
import
unittest
...
...
@@ -60,6 +61,30 @@ def findFreeTCPPort(ip=''):
s
.
bind
((
ip
,
0
))
return
str
(
s
.
getsockname
()[
1
])
def
retry
(
callback
,
try_count
=
10
,
try_delay
=
0.1
):
"""
Poll <callback> every <try_delay> for <try_count> times or until it returns
a true value.
Always returns the value returned by latest callback invocation.
"""
for
_
in
xrange
(
try_count
):
result
=
callback
()
if
result
:
break
time
.
sleep
(
try_delay
)
return
result
def
canConnect
(
caucase_url
):
"""
Returns True if a connection can be established to given address, False
otherwise.
"""
try
:
requests
.
get
(
caucase_url
)
except
BaseException
:
return
False
return
True
class
KedifaMixin
(
object
):
def
setUp
(
self
):
...
...
@@ -70,7 +95,52 @@ class KedifaMixin(object):
self
.
addCleanup
(
cleanTestDir
)
_clean_caucased_snapshot
=
None
class
KedifaMixinCaucase
(
KedifaMixin
):
def
_startCaucaseServer
(
self
,
argv
=
(),
timeout
=
10
):
"""
Start caucased server
"""
ip
,
port
=
os
.
environ
[
'SLAPOS_TEST_IPV6'
],
\
findFreeTCPPort
(
os
.
environ
[
'SLAPOS_TEST_IPV6'
])
self
.
caucase_runtime
=
caucase_runtime
=
multiprocessing
.
Process
(
target
=
caucase
.
http
.
main
,
kwargs
=
dict
(
argv
=
[
'--db'
,
self
.
caucase_db
,
'--server-key'
,
os
.
path
.
join
(
self
.
caucased
,
'server.key.pem'
),
'--netloc'
,
'[%s]:%s'
%
(
ip
,
port
),
'--service-auto-approve-count'
,
'50'
]
)
)
self
.
caucase_runtime
.
start
()
self
.
caucase_url
=
'http://[%s]:%s'
%
(
ip
,
port
)
if
not
retry
(
lambda
:
(
self
.
assertTrue
(
caucase_runtime
.
is_alive
())
or
canConnect
(
self
.
caucase_url
)
),
try_count
=
timeout
*
10
,
):
self
.
_stopCaucaseServer
()
raise
AssertionError
(
'Could not connect to %r after %i seconds'
%
(
self
.
caucase_url
,
timeout
,
))
def
_stopCaucaseServer
(
self
):
"""
Stop a running caucased server
"""
caucase_runtime
=
self
.
caucase_runtime
caucase_runtime
.
terminate
()
caucase_runtime
.
join
()
if
caucase_runtime
.
is_alive
():
raise
ValueError
(
'%r does not wish to die'
%
(
caucase_runtime
,
))
def
createKey
(
self
):
key
=
rsa
.
generate_private_key
(
public_exponent
=
65537
,
key_size
=
2048
,
backend
=
default_backend
())
...
...
@@ -136,40 +206,31 @@ class KedifaMixinCaucase(KedifaMixin):
self
.
pem
=
certificate_pem
+
key_pem
def
setUpCaucase
(
self
):
ip
,
port
=
os
.
environ
[
'SLAPOS_TEST_IPV6'
],
\
findFreeTCPPort
(
os
.
environ
[
'SLAPOS_TEST_IPV6'
])
global
_clean_caucased_snapshot
# pylint: disable=global-statement
self
.
caucased
=
os
.
path
.
join
(
self
.
testdir
,
'caucased'
)
caucase_db
=
os
.
path
.
join
(
self
.
caucased
,
'caucase.sqlite'
)
self
.
caucase_db
=
os
.
path
.
join
(
self
.
caucased
,
'caucase.sqlite'
)
self
.
caucase_service
=
os
.
path
.
join
(
self
.
testdir
,
'service'
)
os
.
mkdir
(
self
.
caucased
)
os
.
mkdir
(
self
.
caucase_service
)
self
.
caucase_runtime
=
multiprocessing
.
Process
(
target
=
caucase
.
http
.
main
,
kwargs
=
dict
(
argv
=
[
'--db'
,
caucase_db
,
'--server-key'
,
os
.
path
.
join
(
self
.
caucased
,
'server.key.pem'
),
'--netloc'
,
'[%s]:%s'
%
(
ip
,
port
),
'--service-auto-approve-count'
,
'50'
]
)
)
self
.
addCleanup
(
self
.
caucase_runtime
.
terminate
)
self
.
caucase_runtime
.
start
()
self
.
assertTrue
(
self
.
caucase_runtime
.
is_alive
())
self
.
caucase_url
=
'http://[%s]:%s'
%
(
ip
,
port
)
# give 5s for caucase to be available
b
=
time
.
time
()
for
i
in
range
(
50
):
try
:
requests
.
get
(
self
.
caucase_url
)
except
BaseException
:
time
.
sleep
(
0.1
)
else
:
break
if
_clean_caucased_snapshot
is
None
:
self
.
_startCaucaseServer
(
timeout
=
60
)
self
.
_stopCaucaseServer
()
server_raw
=
BytesIO
()
with
tarfile
.
TarFile
(
mode
=
'w'
,
fileobj
=
server_raw
)
as
server_tarball
:
server_tarball
.
add
(
self
.
caucased
,
arcname
=
os
.
path
.
basename
(
self
.
caucased
),
)
_clean_caucased_snapshot
=
server_raw
.
getvalue
()
else
:
self
.
fail
(
'Caucase not available after %.2fs seconds'
%
(
time
.
time
()
-
b
))
with
tarfile
.
TarFile
(
mode
=
'r'
,
fileobj
=
BytesIO
(
_clean_caucased_snapshot
),
)
as
server_tarball
:
server_tarball
.
extractall
(
path
=
self
.
testdir
)
self
.
_startCaucaseServer
()
self
.
addCleanup
(
self
.
caucase_runtime
.
terminate
)
def
setUpKey
(
self
,
common_name
):
# create key for the service and keep its downloaded ca_crt
...
...
@@ -266,7 +327,7 @@ ez+ONyvetfvjD8cxyQ==
# give 5s for KeDiFa to be available
b
=
time
.
time
()
for
i
in
range
(
5
0
):
for
i
in
range
(
10
0
):
try
:
self
.
requests_get
(
self
.
kedifa_url
+
'ping'
)
except
BaseException
:
...
...
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