Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
caucase
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
Vincent Pelletier
caucase
Commits
44a29702
Commit
44a29702
authored
Jun 26, 2020
by
Vincent Pelletier
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
caucase.test: Reuse caucased datadir when running multiple tests.
parent
208bb644
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
44 additions
and
15 deletions
+44
-15
caucase/test.py
caucase/test.py
+44
-15
No files found.
caucase/test.py
View file @
44a29702
...
@@ -46,6 +46,7 @@ import sqlite3
...
@@ -46,6 +46,7 @@ import sqlite3
import
ssl
import
ssl
import
subprocess
import
subprocess
import
sys
import
sys
import
tarfile
import
tempfile
import
tempfile
import
threading
import
threading
import
time
import
time
...
@@ -317,6 +318,7 @@ def print_buffer_on_error(func):
...
@@ -317,6 +318,7 @@ def print_buffer_on_error(func):
raise
raise
return
wrapper
return
wrapper
_clean_caucased_snapshot
=
None
class
CaucaseTest
(
unittest
.
TestCase
):
class
CaucaseTest
(
unittest
.
TestCase
):
"""
"""
Test a complete caucase setup: spawn a caucase-http server on CAUCASE_NETLOC
Test a complete caucase setup: spawn a caucase-http server on CAUCASE_NETLOC
...
@@ -329,6 +331,7 @@ class CaucaseTest(unittest.TestCase):
...
@@ -329,6 +331,7 @@ class CaucaseTest(unittest.TestCase):
Prepare test data directory and file paths, and start caucased as most
Prepare test data directory and file paths, and start caucased as most
tests will need to interact with it.
tests will need to interact with it.
"""
"""
global
_clean_caucased_snapshot
self
.
_data_dir
=
data_dir
=
tempfile
.
mkdtemp
(
prefix
=
'caucase_test_'
)
self
.
_data_dir
=
data_dir
=
tempfile
.
mkdtemp
(
prefix
=
'caucase_test_'
)
self
.
_client_dir
=
client_dir
=
os
.
path
.
join
(
data_dir
,
'client'
)
self
.
_client_dir
=
client_dir
=
os
.
path
.
join
(
data_dir
,
'client'
)
...
@@ -366,6 +369,30 @@ class CaucaseTest(unittest.TestCase):
...
@@ -366,6 +369,30 @@ class CaucaseTest(unittest.TestCase):
'Something else is already listening on %r, define CAUCASE_NETLOC '
'Something else is already listening on %r, define CAUCASE_NETLOC '
'environment variable with a different ip/port'
%
(
netloc
,
),
'environment variable with a different ip/port'
%
(
netloc
,
),
)
)
# Starting caucased the first time is expensive: it needs to create at
# least 4 asymetric key pairs (CAU, CAS, HTTP CA, HTTP cert). This can
# take over 40 seconds on a Raspberry Pi 1 (which is the low-end platform
# which should reliably pass these tests).
# So backup the database after the first start, and restore it on further
# starts. Save it as an in-memory uncompressed tarball (should be under a
# megabyte).
# This is intentionally independent from caucased own backup mechanism.
if
_clean_caucased_snapshot
is
None
:
self
.
_startServer
(
timeout
=
60
)
self
.
_stopServer
()
server_raw
=
BytesIO
()
with
tarfile
.
TarFile
(
mode
=
'w'
,
fileobj
=
server_raw
)
as
server_tarball
:
server_tarball
.
add
(
self
.
_server_dir
,
arcname
=
os
.
path
.
basename
(
self
.
_server_dir
),
)
_clean_caucased_snapshot
=
server_raw
.
getvalue
()
else
:
with
tarfile
.
TarFile
(
mode
=
'r'
,
fileobj
=
BytesIO
(
_clean_caucased_snapshot
),
)
as
server_tarball
:
server_tarball
.
extractall
(
path
=
self
.
_data_dir
)
self
.
_startServer
()
self
.
_startServer
()
@
print_buffer_on_error
@
print_buffer_on_error
...
@@ -556,7 +583,7 @@ class CaucaseTest(unittest.TestCase):
...
@@ -556,7 +583,7 @@ class CaucaseTest(unittest.TestCase):
return
1
return
1
return
0
return
0
def
_startServer
(
self
,
*
argv
):
def
_startServer
(
self
,
argv
=
(),
timeout
=
10
):
"""
"""
Start caucased server
Start caucased server
"""
"""
...
@@ -585,10 +612,12 @@ class CaucaseTest(unittest.TestCase):
...
@@ -585,10 +612,12 @@ class CaucaseTest(unittest.TestCase):
self
.
assertTrue
(
server
.
is_alive
(),
'caucased crashed on startup'
)
or
self
.
assertTrue
(
server
.
is_alive
(),
'caucased crashed on startup'
)
or
canConnect
((
parsed_url
.
hostname
,
parsed_url
.
port
))
canConnect
((
parsed_url
.
hostname
,
parsed_url
.
port
))
),
),
try_count
=
timeout
*
10
,
):
# pragma: no cover
):
# pragma: no cover
self
.
_stopServer
()
self
.
_stopServer
()
raise
AssertionError
(
'Could not connect to %r after
1 second
'
%
(
raise
AssertionError
(
'Could not connect to %r after
%i seconds
'
%
(
self
.
_caucase_url
,
self
.
_caucase_url
,
timeout
,
))
))
def
_stopServer
(
self
):
def
_stopServer
(
self
):
...
@@ -1189,9 +1218,9 @@ class CaucaseTest(unittest.TestCase):
...
@@ -1189,9 +1218,9 @@ class CaucaseTest(unittest.TestCase):
user_key_path
=
self
.
_createFirstUser
()
user_key_path
=
self
.
_createFirstUser
()
self
.
_stopServer
()
self
.
_stopServer
()
self
.
_startServer
(
self
.
_startServer
(
(
'--service-max-csr'
,
'5'
,
'--service-max-csr'
,
'5'
,
)
)
)
assertCanSend
(
5
)
assertCanSend
(
5
)
# But resubmitting one of the accepted ones is still fine
# But resubmitting one of the accepted ones is still fine
_
,
csr_path
=
csr_list
[
0
]
_
,
csr_path
=
csr_list
[
0
]
...
@@ -1219,22 +1248,22 @@ class CaucaseTest(unittest.TestCase):
...
@@ -1219,22 +1248,22 @@ class CaucaseTest(unittest.TestCase):
Verify that auto-approve limit freezing works.
Verify that auto-approve limit freezing works.
"""
"""
self
.
_stopServer
()
self
.
_stopServer
()
self
.
_startServer
(
self
.
_startServer
(
(
'--user-auto-approve-count'
,
'2'
,
'--user-auto-approve-count'
,
'2'
,
'--lock-auto-approve-count'
,
'--lock-auto-approve-count'
,
)
)
)
self
.
_stopServer
()
self
.
_stopServer
()
self
.
_startServer
(
self
.
_startServer
(
(
'--user-auto-approve-count'
,
'3'
,
'--user-auto-approve-count'
,
'3'
,
)
)
)
self
.
_createFirstUser
()
self
.
_createFirstUser
()
self
.
_createFirstUser
()
self
.
_createFirstUser
()
self
.
assertRaises
(
TypeError
,
self
.
_createFirstUser
)
self
.
assertRaises
(
TypeError
,
self
.
_createFirstUser
)
self
.
_stopServer
()
self
.
_stopServer
()
self
.
_startServer
(
self
.
_startServer
(
(
'--user-auto-approve-count'
,
'3'
,
'--user-auto-approve-count'
,
'3'
,
'--lock-auto-approve-count'
,
'--lock-auto-approve-count'
,
)
)
)
self
.
assertRaises
(
TypeError
,
self
.
_createFirstUser
)
self
.
assertRaises
(
TypeError
,
self
.
_createFirstUser
)
def
testCSRFiltering
(
self
):
def
testCSRFiltering
(
self
):
...
@@ -2249,7 +2278,7 @@ class CaucaseTest(unittest.TestCase):
...
@@ -2249,7 +2278,7 @@ class CaucaseTest(unittest.TestCase):
backup_glob
=
os
.
path
.
join
(
self
.
_server_backup_path
,
'*.sql.caucased'
)
backup_glob
=
os
.
path
.
join
(
self
.
_server_backup_path
,
'*.sql.caucased'
)
self
.
_stopServer
()
self
.
_stopServer
()
self
.
_startServer
(
'--backup-directory'
,
self
.
_server_backup_path
)
self
.
_startServer
(
(
'--backup-directory'
,
self
.
_server_backup_path
)
)
# XXX: waiting for nothing to happen
# XXX: waiting for nothing to happen
time
.
sleep
(
1
)
time
.
sleep
(
1
)
# No backup must have been created, as no user exists.
# No backup must have been created, as no user exists.
...
@@ -2276,7 +2305,7 @@ class CaucaseTest(unittest.TestCase):
...
@@ -2276,7 +2305,7 @@ class CaucaseTest(unittest.TestCase):
self
.
_server_db
,
self
.
_server_db
,
table_prefix
=
'cau'
,
table_prefix
=
'cau'
,
).
dumpIterator
())
).
dumpIterator
())
self
.
_startServer
(
'--backup-directory'
,
self
.
_server_backup_path
)
self
.
_startServer
(
(
'--backup-directory'
,
self
.
_server_backup_path
)
)
backup_path_list
=
retry
(
lambda
:
glob
.
glob
(
backup_glob
))
backup_path_list
=
retry
(
lambda
:
glob
.
glob
(
backup_glob
))
if
not
backup_path_list
:
# pragma: no cover
if
not
backup_path_list
:
# pragma: no cover
raise
AssertionError
(
'Backup file not created after 1 second'
)
raise
AssertionError
(
'Backup file not created after 1 second'
)
...
@@ -2391,7 +2420,7 @@ class CaucaseTest(unittest.TestCase):
...
@@ -2391,7 +2420,7 @@ class CaucaseTest(unittest.TestCase):
)
)
try
:
try
:
caucase
.
ca
.
DEFAULT_BACKUP_SYMETRIC_CIPHER
=
'TESTS_INTERNAL_USE_ONLY'
caucase
.
ca
.
DEFAULT_BACKUP_SYMETRIC_CIPHER
=
'TESTS_INTERNAL_USE_ONLY'
self
.
_startServer
(
'--backup-directory'
,
self
.
_server_backup_path
)
self
.
_startServer
(
(
'--backup-directory'
,
self
.
_server_backup_path
)
)
finally
:
finally
:
caucase
.
ca
.
DEFAULT_BACKUP_SYMETRIC_CIPHER
=
(
caucase
.
ca
.
DEFAULT_BACKUP_SYMETRIC_CIPHER
=
(
DEFAULT_BACKUP_SYMETRIC_CIPHER_orig
DEFAULT_BACKUP_SYMETRIC_CIPHER_orig
...
@@ -2410,7 +2439,7 @@ class CaucaseTest(unittest.TestCase):
...
@@ -2410,7 +2439,7 @@ class CaucaseTest(unittest.TestCase):
self
.
_stopServer
()
self
.
_stopServer
()
for
backup_path
in
glob
.
glob
(
backup_glob
):
for
backup_path
in
glob
.
glob
(
backup_glob
):
os
.
unlink
(
backup_path
)
os
.
unlink
(
backup_path
)
self
.
_startServer
(
'--backup-directory'
,
self
.
_server_backup_path
)
self
.
_startServer
(
(
'--backup-directory'
,
self
.
_server_backup_path
)
)
backup_path_list
=
retry
(
lambda
:
glob
.
glob
(
backup_glob
))
backup_path_list
=
retry
(
lambda
:
glob
.
glob
(
backup_glob
))
if
not
backup_path_list
:
# pragma: no cover
if
not
backup_path_list
:
# pragma: no cover
raise
AssertionError
(
'Backup file not created after 1 second'
)
raise
AssertionError
(
'Backup file not created after 1 second'
)
...
@@ -2445,7 +2474,7 @@ class CaucaseTest(unittest.TestCase):
...
@@ -2445,7 +2474,7 @@ class CaucaseTest(unittest.TestCase):
c
.
execute
(
bloat_query
,
bloat_value
)
c
.
execute
(
bloat_query
,
bloat_value
)
db
.
close
()
db
.
close
()
del
db
del
db
self
.
_startServer
(
'--backup-directory'
,
self
.
_server_backup_path
)
self
.
_startServer
(
(
'--backup-directory'
,
self
.
_server_backup_path
)
)
backup_path_list
=
retry
(
lambda
:
glob
.
glob
(
backup_glob
),
try_count
=
300
)
backup_path_list
=
retry
(
lambda
:
glob
.
glob
(
backup_glob
),
try_count
=
300
)
if
not
backup_path_list
:
# pragma: no cover
if
not
backup_path_list
:
# pragma: no cover
raise
AssertionError
(
'Backup file took too long to be created'
)
raise
AssertionError
(
'Backup file took too long to be created'
)
...
...
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