Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
S
slapos.core
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Labels
Merge Requests
19
Merge Requests
19
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Jobs
Commits
Open sidebar
nexedi
slapos.core
Commits
f24a2ecc
Commit
f24a2ecc
authored
Sep 25, 2018
by
Bryton Lacquement
🚪
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
wip
parent
fa583d3f
Changes
25
Show whitespace changes
Inline
Side-by-side
Showing
25 changed files
with
93 additions
and
84 deletions
+93
-84
slapos/cli/config.py
slapos/cli/config.py
+2
-2
slapos/cli/configure_local/__init__.py
slapos/cli/configure_local/__init__.py
+3
-3
slapos/client.py
slapos/client.py
+2
-2
slapos/collect/__init__.py
slapos/collect/__init__.py
+2
-1
slapos/collect/snapshot.py
slapos/collect/snapshot.py
+2
-1
slapos/grid/SlapObject.py
slapos/grid/SlapObject.py
+4
-4
slapos/grid/networkcache.py
slapos/grid/networkcache.py
+8
-7
slapos/grid/promise/__init__.py
slapos/grid/promise/__init__.py
+5
-5
slapos/grid/promise/generic.py
slapos/grid/promise/generic.py
+4
-4
slapos/grid/promise/wrapper.py
slapos/grid/promise/wrapper.py
+2
-3
slapos/grid/slapgrid.py
slapos/grid/slapgrid.py
+4
-4
slapos/grid/svcbackend.py
slapos/grid/svcbackend.py
+1
-1
slapos/grid/utils.py
slapos/grid/utils.py
+7
-5
slapos/manager/cpuset.py
slapos/manager/cpuset.py
+2
-4
slapos/proxy/db_version.py
slapos/proxy/db_version.py
+1
-1
slapos/proxy/views.py
slapos/proxy/views.py
+6
-2
slapos/tests/configure_local.py
slapos/tests/configure_local.py
+1
-1
slapos/tests/grid_utils.py
slapos/tests/grid_utils.py
+1
-1
slapos/tests/interface.py
slapos/tests/interface.py
+2
-2
slapos/tests/promise.py
slapos/tests/promise.py
+8
-8
slapos/tests/slap.py
slapos/tests/slap.py
+5
-3
slapos/tests/slapformat.py
slapos/tests/slapformat.py
+3
-1
slapos/tests/slapgrid.py
slapos/tests/slapgrid.py
+12
-13
slapos/tests/slapproxy/__init__.py
slapos/tests/slapproxy/__init__.py
+3
-3
slapos/tests/util.py
slapos/tests/util.py
+3
-3
No files found.
slapos/cli/config.py
View file @
f24a2ecc
...
@@ -27,7 +27,7 @@
...
@@ -27,7 +27,7 @@
#
#
##############################################################################
##############################################################################
import
ConfigP
arser
from
six.moves
import
configp
arser
import
os
import
os
from
slapos.cli.command
import
Command
from
slapos.cli.command
import
Command
...
@@ -77,7 +77,7 @@ class ConfigCommand(Command):
...
@@ -77,7 +77,7 @@ class ConfigCommand(Command):
if
not
os
.
path
.
exists
(
cfg_path
):
if
not
os
.
path
.
exists
(
cfg_path
):
raise
ConfigError
(
'Configuration file does not exist: %s'
%
cfg_path
)
raise
ConfigError
(
'Configuration file does not exist: %s'
%
cfg_path
)
configp
=
ConfigP
arser
.
SafeConfigParser
()
configp
=
configp
arser
.
SafeConfigParser
()
if
configp
.
read
(
cfg_path
)
!=
[
cfg_path
]:
if
configp
.
read
(
cfg_path
)
!=
[
cfg_path
]:
# bad permission, etc.
# bad permission, etc.
raise
ConfigError
(
'Cannot parse configuration file: %s'
%
cfg_path
)
raise
ConfigError
(
'Cannot parse configuration file: %s'
%
cfg_path
)
...
...
slapos/cli/configure_local/__init__.py
View file @
f24a2ecc
...
@@ -121,7 +121,7 @@ def _replaceParameterValue(original_content, to_replace):
...
@@ -121,7 +121,7 @@ def _replaceParameterValue(original_content, to_replace):
"""
"""
for
key
,
value
in
to_replace
:
for
key
,
value
in
to_replace
:
original_content
=
re
.
sub
(
'%s
\
s+=.*
'
% key, '
%
s
=
%
s
' % (key, value),
original_content
=
re
.
sub
(
'%s
\
s+=.*
'
% key, '
%
s
=
%
s
' % (key, value),
original_content
)
str(original_content)
)
return original_content
return original_content
def _generateSlaposNodeConfigurationFile(slapos_node_config_path, args):
def _generateSlaposNodeConfigurationFile(slapos_node_config_path, args):
...
@@ -148,7 +148,7 @@ def _generateSlaposNodeConfigurationFile(slapos_node_config_path, args):
...
@@ -148,7 +148,7 @@ def _generateSlaposNodeConfigurationFile(slapos_node_config_path, args):
slapos_node_configuration_content = re.sub(
slapos_node_configuration_content = re.sub(
'
(
key_file
|
cert_file
|
certificate_repository_path
).
*=
.
*
\
n
',
'
(
key_file
|
cert_file
|
certificate_repository_path
).
*=
.
*
\
n
',
'', slapos_node_configuration_content)
'', slapos_node_configuration_content)
with open(slapos_node_config_path, '
w
') as fout:
with open(slapos_node_config_path, '
w
b
') as fout:
fout.write(slapos_node_configuration_content.encode('
utf8
'))
fout.write(slapos_node_configuration_content.encode('
utf8
'))
def _generateSlaposProxyConfigurationFile(conf):
def _generateSlaposProxyConfigurationFile(conf):
...
@@ -171,7 +171,7 @@ def _generateSlaposProxyConfigurationFile(conf):
...
@@ -171,7 +171,7 @@ def _generateSlaposProxyConfigurationFile(conf):
slapos_proxy_configuration_content = _replaceParameterValue(
slapos_proxy_configuration_content = _replaceParameterValue(
slapos_proxy_configuration_template, to_replace)
slapos_proxy_configuration_template, to_replace)
with open(slapos_proxy_configuration_path, '
w
') as fout:
with open(slapos_proxy_configuration_path, '
w
b
') as fout:
fout.write(slapos_proxy_configuration_content.encode('
utf8
'))
fout.write(slapos_proxy_configuration_content.encode('
utf8
'))
return slapos_proxy_configuration_path
return slapos_proxy_configuration_path
...
...
slapos/client.py
View file @
f24a2ecc
...
@@ -28,7 +28,7 @@
...
@@ -28,7 +28,7 @@
##############################################################################
##############################################################################
import
atexit
import
atexit
import
ConfigP
arser
import
six.moves.configp
arser
import
os
import
os
import
sys
import
sys
...
@@ -119,7 +119,7 @@ def _getSoftwareReleaseFromSoftwareString(logger, software_string, product):
...
@@ -119,7 +119,7 @@ def _getSoftwareReleaseFromSoftwareString(logger, software_string, product):
try
:
try
:
return
product
.
__getattr__
(
software_string
[
len
(
SOFTWARE_PRODUCT_NAMESPACE
):])
return
product
.
__getattr__
(
software_string
[
len
(
SOFTWARE_PRODUCT_NAMESPACE
):])
except
AttributeError
as
e
:
except
AttributeError
as
e
:
logger
.
error
(
'Error: %s Exiting now.'
%
e
.
message
)
logger
.
error
(
'Error: %s Exiting now.'
%
e
)
sys
.
exit
(
1
)
sys
.
exit
(
1
)
def
do_console
(
local
):
def
do_console
(
local
):
...
...
slapos/collect/__init__.py
View file @
f24a2ecc
...
@@ -27,6 +27,7 @@
...
@@ -27,6 +27,7 @@
#
#
##############################################################################
##############################################################################
from
__future__
import
print_function
from
psutil
import
process_iter
,
NoSuchProcess
,
AccessDenied
from
psutil
import
process_iter
,
NoSuchProcess
,
AccessDenied
from
time
import
strftime
from
time
import
strftime
import
shutil
import
shutil
...
@@ -157,5 +158,5 @@ def do_collect(conf):
...
@@ -157,5 +158,5 @@ def do_collect(conf):
database
.
garbageCollect
()
database
.
garbageCollect
()
except
AccessDenied
:
except
AccessDenied
:
print
"You HAVE TO execute this script with root permission."
print
(
"You HAVE TO execute this script with root permission."
)
slapos/collect/snapshot.py
View file @
f24a2ecc
...
@@ -27,6 +27,7 @@
...
@@ -27,6 +27,7 @@
#
#
##############################################################################
##############################################################################
from
__future__
import
print_function
import
psutil
import
psutil
import
os
import
os
import
subprocess
import
subprocess
...
@@ -159,7 +160,7 @@ class HeatingContributionSnapshot(_Snapshot):
...
@@ -159,7 +160,7 @@ class HeatingContributionSnapshot(_Snapshot):
result
=
launchTemperatureTest
(
sensor_id
)
result
=
launchTemperatureTest
(
sensor_id
)
if
result
is
None
:
if
result
is
None
:
print
"Impossible to test sensor: %s "
%
sensor_id
print
(
"Impossible to test sensor: %s "
%
sensor_id
)
initial_temperature
,
final_temperature
,
duration
=
result
initial_temperature
,
final_temperature
,
duration
=
result
...
...
slapos/grid/SlapObject.py
View file @
f24a2ecc
...
@@ -38,7 +38,7 @@ import subprocess
...
@@ -38,7 +38,7 @@ import subprocess
import
tarfile
import
tarfile
import
tempfile
import
tempfile
import
time
import
time
import
xmlrpclib
from
six.moves
import
xmlrpc_client
as
xmlrpclib
from
supervisor
import
xmlrpc
from
supervisor
import
xmlrpc
...
@@ -150,7 +150,7 @@ class Software(object):
...
@@ -150,7 +150,7 @@ class Software(object):
self
.
software_min_free_space
=
software_min_free_space
self
.
software_min_free_space
=
software_min_free_space
def
check_free_space
(
self
):
def
check_free_space
(
self
):
required
=
self
.
software_min_free_space
required
=
self
.
software_min_free_space
or
0
available
=
free_space_nonroot
(
self
.
software_path
)
available
=
free_space_nonroot
(
self
.
software_path
)
if
available
<
required
:
if
available
<
required
:
...
@@ -293,7 +293,7 @@ class Software(object):
...
@@ -293,7 +293,7 @@ class Software(object):
def
_create_buildout_profile
(
self
,
buildout_cfg
,
url
):
def
_create_buildout_profile
(
self
,
buildout_cfg
,
url
):
with
open
(
buildout_cfg
,
'wb'
)
as
fout
:
with
open
(
buildout_cfg
,
'wb'
)
as
fout
:
fout
.
write
(
'[buildout]
\
n
extends = '
+
url
+
'
\
n
'
)
fout
.
write
(
(
'[buildout]
\
n
extends = '
+
url
+
'
\
n
'
).
encode
(
'utf-8'
)
)
self
.
_set_ownership
(
buildout_cfg
)
self
.
_set_ownership
(
buildout_cfg
)
def
uploadSoftwareRelease
(
self
,
tarpath
):
def
uploadSoftwareRelease
(
self
,
tarpath
):
...
@@ -419,7 +419,7 @@ class Partition(object):
...
@@ -419,7 +419,7 @@ class Partition(object):
def
check_free_space
(
self
):
def
check_free_space
(
self
):
required
=
self
.
instance_min_free_space
required
=
self
.
instance_min_free_space
or
0
available
=
free_space_nonroot
(
self
.
instance_path
)
available
=
free_space_nonroot
(
self
.
instance_path
)
if
available
<
required
:
if
available
<
required
:
...
...
slapos/grid/networkcache.py
View file @
f24a2ecc
...
@@ -11,6 +11,7 @@
...
@@ -11,6 +11,7 @@
# FOR A PARTICULAR PURPOSE.
# FOR A PARTICULAR PURPOSE.
#
#
##############################################################################
##############################################################################
from
__future__
import
print_function
import
ast
import
ast
import
json
import
json
...
@@ -29,10 +30,10 @@ try:
...
@@ -29,10 +30,10 @@ try:
else
:
else
:
LIBNETWORKCACHE_ENABLED
=
True
LIBNETWORKCACHE_ENABLED
=
True
except
:
except
:
print
'There was problem while trying to import slapos.libnetworkcache:'
\
print
(
'There was problem while trying to import slapos.libnetworkcache:'
\
'
\
n
%s'
%
traceback
.
format_exc
()
'
\
n
%s'
%
traceback
.
format_exc
()
)
LIBNETWORKCACHE_ENABLED
=
False
LIBNETWORKCACHE_ENABLED
=
False
print
'Networkcache forced to be disabled.'
print
(
'Networkcache forced to be disabled.'
)
...
@@ -45,8 +46,8 @@ def fallback_call(function):
...
@@ -45,8 +46,8 @@ def fallback_call(function):
try
:
try
:
return
function
(
self
,
*
args
,
**
kwd
)
return
function
(
self
,
*
args
,
**
kwd
)
except
:
# indeed, *any* exception is swallowed
except
:
# indeed, *any* exception is swallowed
print
'There was problem while calling method %r:
\
n
%s'
%
(
print
(
'There was problem while calling method %r:
\
n
%s'
%
(
function
.
__name__
,
traceback
.
format_exc
())
function
.
__name__
,
traceback
.
format_exc
())
)
return
False
return
False
wrapper
.
__doc__
=
function
.
__doc__
wrapper
.
__doc__
=
function
.
__doc__
return
wrapper
return
wrapper
...
@@ -107,7 +108,7 @@ def download_network_cached(cache_url, dir_url, software_url, software_root,
...
@@ -107,7 +108,7 @@ def download_network_cached(cache_url, dir_url, software_url, software_root,
f
.
close
()
f
.
close
()
file_descriptor
.
close
()
file_descriptor
.
close
()
return
True
return
True
except
(
IOError
,
DirectoryNotFound
)
,
e
:
except
(
IOError
,
DirectoryNotFound
)
as
e
:
logger
.
info
(
'Failed to download from network cache %s: %s'
%
\
logger
.
info
(
'Failed to download from network cache %s: %s'
%
\
(
software_url
,
str
(
e
)))
(
software_url
,
str
(
e
)))
return
False
return
False
...
@@ -169,7 +170,7 @@ def upload_network_cached(software_root, software_url, cached_key,
...
@@ -169,7 +170,7 @@ def upload_network_cached(software_root, software_url, cached_key,
try
:
try
:
return
nc
.
upload_generic
(
f
,
cached_key
,
**
kw
)
return
nc
.
upload_generic
(
f
,
cached_key
,
**
kw
)
except
(
IOError
,
UploadError
)
,
e
:
except
(
IOError
,
UploadError
)
as
e
:
logger
.
info
(
'Failed to upload file. %s'
%
(
str
(
e
)))
logger
.
info
(
'Failed to upload file. %s'
%
(
str
(
e
)))
return
False
return
False
finally
:
finally
:
...
...
slapos/grid/promise/__init__.py
View file @
f24a2ecc
...
@@ -38,7 +38,7 @@ import importlib
...
@@ -38,7 +38,7 @@ import importlib
import
traceback
import
traceback
import
psutil
import
psutil
from
multiprocessing
import
Process
,
Queue
as
MQueue
from
multiprocessing
import
Process
,
Queue
as
MQueue
import
Q
ueue
from
six.moves
import
q
ueue
from
slapos.util
import
mkdir_p
,
chownDirectory
from
slapos.util
import
mkdir_p
,
chownDirectory
from
slapos.grid.utils
import
dropPrivileges
,
killProcessTree
from
slapos.grid.utils
import
dropPrivileges
,
killProcessTree
from
slapos.grid.promise
import
interface
from
slapos.grid.promise
import
interface
...
@@ -168,7 +168,7 @@ class PromiseProcess(Process):
...
@@ -168,7 +168,7 @@ class PromiseProcess(Process):
if
not
os
.
path
.
exists
(
init_file
):
if
not
os
.
path
.
exists
(
init_file
):
with
open
(
init_file
,
'w'
)
as
f
:
with
open
(
init_file
,
'w'
)
as
f
:
f
.
write
(
""
)
f
.
write
(
""
)
os
.
chmod
(
init_file
,
0644
)
os
.
chmod
(
init_file
,
0
o
644
)
# add promise folder to sys.path so we can import promise script
# add promise folder to sys.path so we can import promise script
if
sys
.
path
[
0
]
!=
promise_folder
:
if
sys
.
path
[
0
]
!=
promise_folder
:
sys
.
path
[
0
:
0
]
=
[
promise_folder
]
sys
.
path
[
0
:
0
]
=
[
promise_folder
]
...
@@ -362,7 +362,7 @@ class PromiseLauncher(object):
...
@@ -362,7 +362,7 @@ class PromiseLauncher(object):
try
:
try
:
result
=
PromiseQueueResult
()
result
=
PromiseQueueResult
()
result
.
load
(
json
.
loads
(
f
.
read
()))
result
.
load
(
json
.
loads
(
f
.
read
()))
except
ValueError
,
e
:
except
ValueError
as
e
:
result
=
None
result
=
None
self
.
logger
.
warn
(
'Bad promise JSON result at %r: %s'
%
(
self
.
logger
.
warn
(
'Bad promise JSON result at %r: %s'
%
(
promise_output_file
,
promise_output_file
,
...
@@ -375,7 +375,7 @@ class PromiseLauncher(object):
...
@@ -375,7 +375,7 @@ class PromiseLauncher(object):
while
True
:
while
True
:
try
:
try
:
self
.
queue_result
.
get_nowait
()
self
.
queue_result
.
get_nowait
()
except
Q
ueue
.
Empty
:
except
q
ueue
.
Empty
:
return
return
def
_updateFolderOwner
(
self
,
folder_path
=
None
):
def
_updateFolderOwner
(
self
,
folder_path
=
None
):
...
@@ -443,7 +443,7 @@ class PromiseLauncher(object):
...
@@ -443,7 +443,7 @@ class PromiseLauncher(object):
if
not
promise_process
.
is_alive
():
if
not
promise_process
.
is_alive
():
try
:
try
:
queue_item
=
self
.
queue_result
.
get
(
True
,
1
)
queue_item
=
self
.
queue_result
.
get
(
True
,
1
)
except
Q
ueue
.
Empty
:
except
q
ueue
.
Empty
:
# no result found in process result Queue
# no result found in process result Queue
pass
pass
else
:
else
:
...
...
slapos/grid/promise/generic.py
View file @
f24a2ecc
...
@@ -410,7 +410,7 @@ class GenericPromise(object):
...
@@ -410,7 +410,7 @@ class GenericPromise(object):
try:
try:
self.__queue.put_nowait(result_item)
self.__queue.put_nowait(result_item)
break
break
except Queue.Full
,
e:
except Queue.Full
as
e:
error = e
error = e
time.sleep(0.5)
time.sleep(0.5)
if error:
if error:
...
@@ -459,7 +459,7 @@ class GenericPromise(object):
...
@@ -459,7 +459,7 @@ class GenericPromise(object):
"""
"""
try:
try:
self.sense()
self.sense()
except Exception
,
e:
except Exception
as
e:
# log the result
# log the result
self.logger.error(str(e))
self.logger.error(str(e))
if check_anomaly:
if check_anomaly:
...
@@ -468,7 +468,7 @@ class GenericPromise(object):
...
@@ -468,7 +468,7 @@ class GenericPromise(object):
result = self.anomaly()
result = self.anomaly()
if result is None:
if result is None:
raise ValueError("
Promise
anomaly
method
returned
'None'")
raise ValueError("
Promise
anomaly
method
returned
'None'")
except Exception
,
e:
except Exception
as
e:
result = AnomalyResult(problem=True, message=str(e))
result = AnomalyResult(problem=True, message=str(e))
else:
else:
if isinstance(result, AnomalyResult) and result.hasFailed() and can_bang:
if isinstance(result, AnomalyResult) and result.hasFailed() and can_bang:
...
@@ -482,7 +482,7 @@ class GenericPromise(object):
...
@@ -482,7 +482,7 @@ class GenericPromise(object):
result = self.test()
result = self.test()
if result is None:
if result is None:
raise ValueError("
Promise
test
method
returned
'None'")
raise ValueError("
Promise
test
method
returned
'None'")
except Exception
,
e:
except Exception
as
e:
result = TestResult(problem=True, message=str(e))
result = TestResult(problem=True, message=str(e))
if self.__logger_buffer is not None:
if self.__logger_buffer is not None:
...
...
slapos/grid/promise/wrapper.py
View file @
f24a2ecc
...
@@ -32,17 +32,16 @@ import subprocess
...
@@ -32,17 +32,16 @@ import subprocess
import
functools
import
functools
import
signal
import
signal
import
traceback
import
traceback
from
zope
import
interface
as
zope_interface
from
zope
.interface
import
implementer
from
slapos.grid.promise
import
interface
from
slapos.grid.promise
import
interface
from
slapos.grid.promise.generic
import
GenericPromise
from
slapos.grid.promise.generic
import
GenericPromise
@
implementer
(
interface
.
IPromise
)
class
WrapPromise
(
GenericPromise
):
class
WrapPromise
(
GenericPromise
):
"""
"""
A wrapper promise used to run old promises style and bash promises
A wrapper promise used to run old promises style and bash promises
"""
"""
zope_interface
.
implements
(
interface
.
IPromise
)
def
__init__
(
self
,
config
):
def
__init__
(
self
,
config
):
GenericPromise
.
__init__
(
self
,
config
)
GenericPromise
.
__init__
(
self
,
config
)
self
.
setPeriodicity
(
minute
=
2
)
self
.
setPeriodicity
(
minute
=
2
)
...
...
slapos/grid/slapgrid.py
View file @
f24a2ecc
...
@@ -32,7 +32,7 @@ import os
...
@@ -32,7 +32,7 @@ import os
import
pkg_resources
import
pkg_resources
import
random
import
random
import
socket
import
socket
import
StringIO
from
six
import
StringIO
import
subprocess
import
subprocess
import
sys
import
sys
import
tempfile
import
tempfile
...
@@ -672,7 +672,7 @@ stderr_logfile_backups=1
...
@@ -672,7 +672,7 @@ stderr_logfile_backups=1
computer_partition
.
setComputerPartitionRelatedInstanceList
(
computer_partition
.
setComputerPartitionRelatedInstanceList
(
[
reference
for
reference
in
tf
.
read
().
split
(
'
\
n
'
)
if
reference
]
[
reference
for
reference
in
tf
.
read
().
split
(
'
\
n
'
)
if
reference
]
)
)
except
NotFoundError
,
e
:
except
NotFoundError
as
e
:
# Master doesn't implement this feature ?
# Master doesn't implement this feature ?
self
.
logger
.
warning
(
"NotFoundError: %s.
\
n
Cannot send requested instance "
\
self
.
logger
.
warning
(
"NotFoundError: %s.
\
n
Cannot send requested instance "
\
"list to master. Please check if this feature is"
\
"list to master. Please check if this feature is"
\
...
@@ -922,7 +922,7 @@ stderr_logfile_backups=1
...
@@ -922,7 +922,7 @@ stderr_logfile_backups=1
self
.
_checkPromiseList
(
local_partition
,
self
.
_checkPromiseList
(
local_partition
,
check_anomaly
=
True
,
check_anomaly
=
True
,
force
=
False
)
force
=
False
)
except
PromiseError
,
e
:
except
PromiseError
as
e
:
self
.
logger
.
error
(
e
)
self
.
logger
.
error
(
e
)
if
partition_access_status
is
None
or
not
status_error
:
if
partition_access_status
is
None
or
not
status_error
:
computer_partition
.
error
(
e
,
logger
=
self
.
logger
)
computer_partition
.
error
(
e
,
logger
=
self
.
logger
)
...
@@ -1140,7 +1140,7 @@ stderr_logfile_backups=1
...
@@ -1140,7 +1140,7 @@ stderr_logfile_backups=1
(
computer_partition_id
,
computer_partition_state
)
(
computer_partition_id
,
computer_partition_state
)
computer_partition
.
error
(
error_string
,
logger
=
self
.
logger
)
computer_partition
.
error
(
error_string
,
logger
=
self
.
logger
)
raise
NotImplementedError
(
error_string
)
raise
NotImplementedError
(
error_string
)
except
Exception
,
e
:
except
Exception
as
e
:
if
not
isinstance
(
e
,
PromiseError
):
if
not
isinstance
(
e
,
PromiseError
):
with
open
(
error_output_file
,
'w'
)
as
error_file
:
with
open
(
error_output_file
,
'w'
)
as
error_file
:
# Write error message in a log file assible to computer partition user
# Write error message in a log file assible to computer partition user
...
...
slapos/grid/svcbackend.py
View file @
f24a2ecc
...
@@ -35,7 +35,7 @@ import subprocess
...
@@ -35,7 +35,7 @@ import subprocess
import
stat
import
stat
import
sys
import
sys
import
time
import
time
import
xmlrpclib
from
six.moves
import
xmlrpc_client
as
xmlrpclib
from
slapos.grid.utils
import
(
createPrivateDirectory
,
SlapPopen
,
updateFile
)
from
slapos.grid.utils
import
(
createPrivateDirectory
,
SlapPopen
,
updateFile
)
...
...
slapos/grid/utils.py
View file @
f24a2ecc
...
@@ -40,6 +40,8 @@ import logging
...
@@ -40,6 +40,8 @@ import logging
import
psutil
import
psutil
import
time
import
time
import
six
from
slapos.grid.exception
import
BuildoutFailedError
,
WrongPermissionError
from
slapos.grid.exception
import
BuildoutFailedError
,
WrongPermissionError
# Such umask by default will create paths with full permission
# Such umask by default will create paths with full permission
...
@@ -131,12 +133,12 @@ class SlapPopen(subprocess.Popen):
...
@@ -131,12 +133,12 @@ class SlapPopen(subprocess.Popen):
break
break
if
line
:
if
line
:
output_lines
.
append
(
line
)
output_lines
.
append
(
line
)
logger
.
info
(
line
.
rstrip
(
'
\
n
'
))
logger
.
info
(
line
.
rstrip
(
b
'
\
n
'
))
self
.
output
=
''
.
join
(
output_lines
)
self
.
output
=
''
.
join
(
output_lines
)
def
md5digest
(
url
):
def
md5digest
(
url
):
return
hashlib
.
md5
(
url
).
hexdigest
()
return
hashlib
.
md5
(
url
.
encode
(
'utf-8'
)
).
hexdigest
()
def
getCleanEnvironment
(
logger
,
home_path
=
'/tmp'
):
def
getCleanEnvironment
(
logger
,
home_path
=
'/tmp'
):
...
@@ -150,7 +152,7 @@ def getCleanEnvironment(logger, home_path='/tmp'):
...
@@ -150,7 +152,7 @@ def getCleanEnvironment(logger, home_path='/tmp'):
if
old
is
not
None
:
if
old
is
not
None
:
removed_env
.
append
(
k
)
removed_env
.
append
(
k
)
changed_env
[
'HOME'
]
=
env
[
'HOME'
]
=
home_path
changed_env
[
'HOME'
]
=
env
[
'HOME'
]
=
home_path
for
k
in
sorted
(
changed_env
.
iterkeys
(
)):
for
k
in
sorted
(
six
.
iterkeys
(
changed_env
)):
logger
.
debug
(
'Overridden %s = %r'
%
(
k
,
changed_env
[
k
]))
logger
.
debug
(
'Overridden %s = %r'
%
(
k
,
changed_env
[
k
]))
if
removed_env
:
if
removed_env
:
logger
.
debug
(
'Removed from environment: %s'
%
', '
.
join
(
sorted
(
removed_env
)))
logger
.
debug
(
'Removed from environment: %s'
%
', '
.
join
(
sorted
(
removed_env
)))
...
@@ -399,7 +401,7 @@ def killProcessTree(pid, logger):
...
@@ -399,7 +401,7 @@ def killProcessTree(pid, logger):
for
child
in
running_process_list
:
for
child
in
running_process_list
:
try
:
try
:
child
.
suspend
()
child
.
suspend
()
except
psutil
.
Error
,
e
:
except
psutil
.
Error
as
e
:
logger
.
debug
(
str
(
e
))
logger
.
debug
(
str
(
e
))
time
.
sleep
(
0.2
)
time
.
sleep
(
0.2
)
...
@@ -408,5 +410,5 @@ def killProcessTree(pid, logger):
...
@@ -408,5 +410,5 @@ def killProcessTree(pid, logger):
for
process
in
process_list
:
for
process
in
process_list
:
try
:
try
:
process
.
kill
()
process
.
kill
()
except
psutil
.
Error
,
e
:
except
psutil
.
Error
as
e
:
logger
.
debug
(
"Process kill: %s"
%
e
)
logger
.
debug
(
"Process kill: %s"
%
e
)
slapos/manager/cpuset.py
View file @
f24a2ecc
...
@@ -5,12 +5,12 @@ import os.path
...
@@ -5,12 +5,12 @@ import os.path
import
pwd
import
pwd
import
time
import
time
from
zope
import
interface
as
zope_interface
from
zope
.interface
import
implementer
from
slapos.manager
import
interface
from
slapos.manager
import
interface
logger
=
logging
.
getLogger
(
__name__
)
logger
=
logging
.
getLogger
(
__name__
)
@
implementer
(
interface
.
IManager
)
class
Manager
(
object
):
class
Manager
(
object
):
"""Manage cgroup's cpuset in terms on initializing and runtime operations.
"""Manage cgroup's cpuset in terms on initializing and runtime operations.
...
@@ -21,8 +21,6 @@ class Manager(object):
...
@@ -21,8 +21,6 @@ class Manager(object):
TODO: there is no limit on number of reserved cores per user.
TODO: there is no limit on number of reserved cores per user.
"""
"""
zope_interface
.
implements
(
interface
.
IManager
)
cpu_exclusive_file
=
".slapos-cpu-exclusive"
cpu_exclusive_file
=
".slapos-cpu-exclusive"
cpuset_path
=
"/sys/fs/cgroup/cpuset/"
cpuset_path
=
"/sys/fs/cgroup/cpuset/"
task_write_mode
=
"wt"
task_write_mode
=
"wt"
...
...
slapos/proxy/db_version.py
View file @
f24a2ecc
...
@@ -2,5 +2,5 @@
...
@@ -2,5 +2,5 @@
import
pkg_resources
import
pkg_resources
DB_VERSION
=
pkg_resources
.
resource_stream
(
'slapos.proxy'
,
'schema.sql'
).
readline
().
strip
().
split
(
':'
)[
1
]
DB_VERSION
=
pkg_resources
.
resource_stream
(
'slapos.proxy'
,
'schema.sql'
).
readline
().
strip
().
split
(
b
':'
)[
1
]
slapos/proxy/views.py
View file @
f24a2ecc
...
@@ -28,6 +28,8 @@
...
@@ -28,6 +28,8 @@
#
#
##############################################################################
##############################################################################
from
__future__
import
print_function
from
lxml
import
etree
from
lxml
import
etree
import
random
import
random
import
string
import
string
...
@@ -42,6 +44,8 @@ import xml_marshaller
...
@@ -42,6 +44,8 @@ import xml_marshaller
from
xml_marshaller.xml_marshaller
import
loads
from
xml_marshaller.xml_marshaller
import
loads
from
xml_marshaller.xml_marshaller
import
dumps
from
xml_marshaller.xml_marshaller
import
dumps
from
six.moves
import
range
app
=
Flask
(
__name__
)
app
=
Flask
(
__name__
)
EMPTY_DICT_XML
=
dumps
({})
EMPTY_DICT_XML
=
dumps
({})
...
@@ -139,7 +143,7 @@ def execute_db(table, query, args=(), one=False, db_version=None, log=False, db=
...
@@ -139,7 +143,7 @@ def execute_db(table, query, args=(), one=False, db_version=None, log=False, db=
db_version
=
DB_VERSION
db_version
=
DB_VERSION
query
=
query
%
(
table
+
db_version
,)
query
=
query
%
(
table
+
db_version
,)
if
log
:
if
log
:
print
query
print
(
query
)
try
:
try
:
cur
=
db
.
execute
(
query
,
args
)
cur
=
db
.
execute
(
query
,
args
)
except
:
except
:
...
@@ -404,7 +408,7 @@ def parseRequestComputerPartitionForm(form):
...
@@ -404,7 +408,7 @@ def parseRequestComputerPartitionForm(form):
return
parsed_dict
return
parsed_dict
run_id
=
''
.
join
([
random
.
choice
(
string
.
ascii_letters
+
string
.
digits
)
for
n
in
x
range
(
32
)])
run_id
=
''
.
join
([
random
.
choice
(
string
.
ascii_letters
+
string
.
digits
)
for
n
in
range
(
32
)])
def
checkIfMasterIsCurrentMaster
(
master_url
):
def
checkIfMasterIsCurrentMaster
(
master_url
):
"""
"""
Because there are several ways to contact this server, we can't easily check
Because there are several ways to contact this server, we can't easily check
...
...
slapos/tests/configure_local.py
View file @
f24a2ecc
...
@@ -34,7 +34,7 @@ import slapos.cli.configure_local
...
@@ -34,7 +34,7 @@ import slapos.cli.configure_local
from
slapos.cli.configure_local
import
ConfigureLocalCommand
,
_createConfigurationDirectory
from
slapos.cli.configure_local
import
ConfigureLocalCommand
,
_createConfigurationDirectory
from
slapos.cli.entry
import
SlapOSApp
from
slapos.cli.entry
import
SlapOSApp
from
argparse
import
Namespace
from
argparse
import
Namespace
from
ConfigP
arser
import
ConfigParser
from
six.moves.configp
arser
import
ConfigParser
# Disable any command to launch slapformat and supervisor
# Disable any command to launch slapformat and supervisor
slapos
.
cli
.
configure_local
.
_runFormat
=
lambda
x
:
"Do nothing"
slapos
.
cli
.
configure_local
.
_runFormat
=
lambda
x
:
"Do nothing"
...
...
slapos/tests/grid_utils.py
View file @
f24a2ecc
...
@@ -47,7 +47,7 @@ class SlapPopenTestCase(unittest.TestCase):
...
@@ -47,7 +47,7 @@ class SlapPopenTestCase(unittest.TestCase):
def
test_exec
(
self
):
def
test_exec
(
self
):
"""Test command execution with SlapPopen.
"""Test command execution with SlapPopen.
"""
"""
self
.
script
.
write
(
'#!/bin/sh
\
n
echo "hello"
\
n
exit 123'
)
self
.
script
.
write
(
b
'#!/bin/sh
\
n
echo "hello"
\
n
exit 123'
)
self
.
script
.
close
()
self
.
script
.
close
()
logger
=
mock
.
MagicMock
()
logger
=
mock
.
MagicMock
()
...
...
slapos/tests/interface.py
View file @
f24a2ecc
...
@@ -28,7 +28,7 @@ import unittest
...
@@ -28,7 +28,7 @@ import unittest
from
zope.interface.verify
import
verifyClass
from
zope.interface.verify
import
verifyClass
import
zope.interface
import
zope.interface
import
types
from
six
import
class_
types
from
slapos
import
slap
from
slapos
import
slap
def
getOnlyImplementationAssertionMethod
(
klass
,
method_list
):
def
getOnlyImplementationAssertionMethod
(
klass
,
method_list
):
...
@@ -61,7 +61,7 @@ def generateTestMethodListOnClass(klass, module):
...
@@ -61,7 +61,7 @@ def generateTestMethodListOnClass(klass, module):
"""Generate test method on klass"""
"""Generate test method on klass"""
for
class_id
in
dir
(
module
):
for
class_id
in
dir
(
module
):
implementing_class
=
getattr
(
module
,
class_id
)
implementing_class
=
getattr
(
module
,
class_id
)
if
type
(
implementing_class
)
not
in
(
types
.
ClassType
,
types
.
TypeType
):
if
not
isinstance
(
implementing_class
,
class_types
):
continue
continue
# add methods to assert that publicly available classes are defining
# add methods to assert that publicly available classes are defining
# interfaces
# interfaces
...
...
slapos/tests/promise.py
View file @
f24a2ecc
...
@@ -59,7 +59,7 @@ class TestSlapOSPromiseMixin(unittest.TestCase):
...
@@ -59,7 +59,7 @@ class TestSlapOSPromiseMixin(unittest.TestCase):
def
writeInit
(
self
):
def
writeInit
(
self
):
with
open
(
os
.
path
.
join
(
self
.
plugin_dir
,
'__init__'
),
'w'
)
as
f
:
with
open
(
os
.
path
.
join
(
self
.
plugin_dir
,
'__init__'
),
'w'
)
as
f
:
f
.
write
(
''
)
f
.
write
(
''
)
os
.
chmod
(
os
.
path
.
join
(
self
.
plugin_dir
,
'__init__'
),
0644
)
os
.
chmod
(
os
.
path
.
join
(
self
.
plugin_dir
,
'__init__'
),
0
o
644
)
if
sys
.
path
[
0
]
!=
self
.
plugin_dir
:
if
sys
.
path
[
0
]
!=
self
.
plugin_dir
:
sys
.
path
[
0
:
0
]
=
[
self
.
plugin_dir
]
sys
.
path
[
0
:
0
]
=
[
self
.
plugin_dir
]
...
@@ -128,7 +128,7 @@ class TestSlapOSPromiseMixin(unittest.TestCase):
...
@@ -128,7 +128,7 @@ class TestSlapOSPromiseMixin(unittest.TestCase):
wrap
=
wrap
,
wrap
=
wrap
,
)
)
def
writeFile
(
self
,
path
,
content
,
mode
=
0644
):
def
writeFile
(
self
,
path
,
content
,
mode
=
0
o
644
):
with
open
(
path
,
'w'
)
as
f
:
with
open
(
path
,
'w'
)
as
f
:
f
.
write
(
content
)
f
.
write
(
content
)
os
.
chmod
(
path
,
mode
)
os
.
chmod
(
path
,
mode
)
...
@@ -781,7 +781,7 @@ class RunPromise(GenericPromise):
...
@@ -781,7 +781,7 @@ class RunPromise(GenericPromise):
f
.
write
(
"""#!/bin/bash
f
.
write
(
"""#!/bin/bash
echo "success"
echo "success"
"""
)
"""
)
os
.
chmod
(
promise_path
,
0744
)
os
.
chmod
(
promise_path
,
0
o
744
)
def
test_method
(
result
):
def
test_method
(
result
):
self
.
called
=
True
self
.
called
=
True
...
@@ -810,7 +810,7 @@ echo "success"
...
@@ -810,7 +810,7 @@ echo "success"
echo "This promise failed"
echo "This promise failed"
exit 1
exit 1
"""
)
"""
)
os
.
chmod
(
promise_path
,
0744
)
os
.
chmod
(
promise_path
,
0
o
744
)
self
.
configureLauncher
()
self
.
configureLauncher
()
state_file
=
os
.
path
.
join
(
self
.
partition_dir
,
PROMISE_STATE_FOLDER_NAME
)
state_file
=
os
.
path
.
join
(
self
.
partition_dir
,
PROMISE_STATE_FOLDER_NAME
)
...
@@ -841,13 +841,13 @@ exit 1
...
@@ -841,13 +841,13 @@ exit 1
echo "promise 1 succeeded"
echo "promise 1 succeeded"
exit 0
exit 0
"""
)
"""
)
os
.
chmod
(
promise_path
,
0744
)
os
.
chmod
(
promise_path
,
0
o
744
)
with
open
(
promise_path2
,
'w'
)
as
f
:
with
open
(
promise_path2
,
'w'
)
as
f
:
f
.
write
(
"""#!/bin/bash
f
.
write
(
"""#!/bin/bash
echo "promise 2 succeeded"
echo "promise 2 succeeded"
exit 0
exit 0
"""
)
"""
)
os
.
chmod
(
promise_path2
,
0744
)
os
.
chmod
(
promise_path2
,
0
o
744
)
self
.
generatePromiseScript
(
"first_promise.py"
,
success
=
True
)
self
.
generatePromiseScript
(
"first_promise.py"
,
success
=
True
)
self
.
generatePromiseScript
(
"second_promise.py"
,
success
=
True
)
self
.
generatePromiseScript
(
"second_promise.py"
,
success
=
True
)
...
@@ -989,7 +989,7 @@ exit 0
...
@@ -989,7 +989,7 @@ exit 0
sleep 20
sleep 20
echo "success"
echo "success"
"""
)
"""
)
os
.
chmod
(
promise_path
,
0744
)
os
.
chmod
(
promise_path
,
0
o
744
)
def
test_method
(
result
):
def
test_method
(
result
):
self
.
called
=
True
self
.
called
=
True
...
@@ -1025,7 +1025,7 @@ sleep 20
...
@@ -1025,7 +1025,7 @@ sleep 20
echo "success"
echo "success"
exit 1
exit 1
"""
)
"""
)
os
.
chmod
(
promise_path
,
0744
)
os
.
chmod
(
promise_path
,
0
o
744
)
createPromise
(
first_promise_path
)
createPromise
(
first_promise_path
)
createPromise
(
second_promise_path
)
createPromise
(
second_promise_path
)
...
...
slapos/tests/slap.py
View file @
f24a2ecc
...
@@ -25,6 +25,8 @@
...
@@ -25,6 +25,8 @@
#
#
##############################################################################
##############################################################################
from
__future__
import
print_function
import
logging
import
logging
import
os
import
os
import
unittest
import
unittest
...
@@ -51,7 +53,7 @@ class SlapMixin(unittest.TestCase):
...
@@ -51,7 +53,7 @@ class SlapMixin(unittest.TestCase):
self
.
server_url
=
'http://localhost/'
self
.
server_url
=
'http://localhost/'
else
:
else
:
self
.
server_url
=
self
.
_server_url
self
.
server_url
=
self
.
_server_url
print
'Testing against SLAP server %r'
%
self
.
server_url
print
(
'Testing against SLAP server %r'
%
self
.
server_url
)
self
.
slap
=
slapos
.
slap
.
slap
()
self
.
slap
=
slapos
.
slap
.
slap
()
self
.
partition_id
=
'PARTITION_01'
self
.
partition_id
=
'PARTITION_01'
if
os
.
environ
.
has_key
(
'SLAPGRID_INSTANCE_ROOT'
):
if
os
.
environ
.
has_key
(
'SLAPGRID_INSTANCE_ROOT'
):
...
@@ -1205,7 +1207,7 @@ class TestSoftwareProductCollection(SlapMixin):
...
@@ -1205,7 +1207,7 @@ class TestSoftwareProductCollection(SlapMixin):
self
.
assertEqual
(
self
.
product_collection
.
foo
,
'0'
)
self
.
assertEqual
(
self
.
product_collection
.
foo
,
'0'
)
if
__name__
==
'__main__'
:
if
__name__
==
'__main__'
:
print
'You can point to any SLAP server by setting TEST_SLAP_SERVER_URL '
\
print
(
'You can point to any SLAP server by setting TEST_SLAP_SERVER_URL '
\
'environment variable'
'environment variable'
)
unittest
.
main
()
unittest
.
main
()
slapos/tests/slapformat.py
View file @
f24a2ecc
...
@@ -26,6 +26,8 @@
...
@@ -26,6 +26,8 @@
# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
#
#
##############################################################################
##############################################################################
from
__future__
import
print_function
import
glob
import
glob
import
logging
import
logging
import
slapos.format
import
slapos.format
...
@@ -86,7 +88,7 @@ class FakeCallAndRead:
...
@@ -86,7 +88,7 @@ class FakeCallAndRead:
retval
=
0
,
'UP'
retval
=
0
,
'UP'
global
INTERFACE_DICT
global
INTERFACE_DICT
if
'useradd'
in
argument_list
:
if
'useradd'
in
argument_list
:
print
argument_list
print
(
argument_list
)
global
USER_LIST
global
USER_LIST
username
=
argument_list
[
-
1
]
username
=
argument_list
[
-
1
]
if
username
==
'-r'
:
if
username
==
'-r'
:
...
...
slapos/tests/slapgrid.py
View file @
f24a2ecc
...
@@ -38,13 +38,13 @@ import tempfile
...
@@ -38,13 +38,13 @@ import tempfile
import
textwrap
import
textwrap
import
time
import
time
import
unittest
import
unittest
import
url
parse
from
six.moves.urllib
import
parse
import
json
import
json
import
re
import
re
import
xml_marshaller
import
xml_marshaller
from
mock
import
patch
from
mock
import
patch
from
zope
import
interface
from
zope
.interface
import
implementer
import
slapos.slap.slap
import
slapos.slap.slap
import
slapos.grid.utils
import
slapos.grid.utils
...
@@ -113,7 +113,7 @@ class BasicMixin(object):
...
@@ -113,7 +113,7 @@ class BasicMixin(object):
self
.
manager_list
=
[]
self
.
manager_list
=
[]
self
.
software_root
=
os
.
path
.
join
(
self
.
_tempdir
,
'software'
)
self
.
software_root
=
os
.
path
.
join
(
self
.
_tempdir
,
'software'
)
self
.
instance_root
=
os
.
path
.
join
(
self
.
_tempdir
,
'instance'
)
self
.
instance_root
=
os
.
path
.
join
(
self
.
_tempdir
,
'instance'
)
if
os
.
environ
.
has_key
(
'SLAPGRID_INSTANCE_ROOT'
)
:
if
'SLAPGRID_INSTANCE_ROOT'
in
os
.
environ
:
del
os
.
environ
[
'SLAPGRID_INSTANCE_ROOT'
]
del
os
.
environ
[
'SLAPGRID_INSTANCE_ROOT'
]
logging
.
basicConfig
(
level
=
logging
.
DEBUG
)
logging
.
basicConfig
(
level
=
logging
.
DEBUG
)
self
.
setSlapgrid
()
self
.
setSlapgrid
()
...
@@ -314,9 +314,9 @@ class ComputerForTest(object):
...
@@ -314,9 +314,9 @@ class ComputerForTest(object):
"""
"""
self
.
sequence
.
append
(
url
.
path
)
self
.
sequence
.
append
(
url
.
path
)
if
req
.
method
==
'GET'
:
if
req
.
method
==
'GET'
:
qs
=
url
parse
.
parse_qs
(
url
.
query
)
qs
=
parse
.
parse_qs
(
url
.
query
)
else
:
else
:
qs
=
url
parse
.
parse_qs
(
req
.
body
)
qs
=
parse
.
parse_qs
(
req
.
body
)
if
(
url
.
path
==
'/getFullComputerInformation'
if
(
url
.
path
==
'/getFullComputerInformation'
and
'computer_id'
in
qs
):
and
'computer_id'
in
qs
):
slap_computer
=
self
.
getComputer
(
qs
[
'computer_id'
][
0
])
slap_computer
=
self
.
getComputer
(
qs
[
'computer_id'
][
0
])
...
@@ -549,9 +549,8 @@ touch worked"""):
...
@@ -549,9 +549,8 @@ touch worked"""):
fout
.
write
(
str
(
periodicity
))
fout
.
write
(
str
(
periodicity
))
@
implementer
(
IManager
)
class
DummyManager
(
object
):
class
DummyManager
(
object
):
interface
.
implements
(
IManager
)
def
__init__
(
self
):
def
__init__
(
self
):
self
.
sequence
=
[]
self
.
sequence
=
[]
...
@@ -2151,8 +2150,8 @@ echo "ERROR: $var"
...
@@ -2151,8 +2150,8 @@ echo "ERROR: $var"
exit 1
exit 1
"""
)
"""
)
os
.
chmod
(
self
.
firewall_cmd_add
,
0755
)
os
.
chmod
(
self
.
firewall_cmd_add
,
0
o
755
)
os
.
chmod
(
self
.
firewall_cmd_remove
,
0755
)
os
.
chmod
(
self
.
firewall_cmd_remove
,
0
o
755
)
firewall_conf
=
dict
(
firewall_conf
=
dict
(
authorized_sources
=
source_ip
,
authorized_sources
=
source_ip
,
...
@@ -2543,7 +2542,7 @@ exit 0
...
@@ -2543,7 +2542,7 @@ exit 0
os
.
makedirs
(
pre_delete_dir
,
0o700
)
os
.
makedirs
(
pre_delete_dir
,
0o700
)
with
open
(
pre_delete_script
,
'w'
)
as
f
:
with
open
(
pre_delete_script
,
'w'
)
as
f
:
f
.
write
(
self
.
prerm_script_content
)
f
.
write
(
self
.
prerm_script_content
)
os
.
chmod
(
pre_delete_script
,
0754
)
os
.
chmod
(
pre_delete_script
,
0
o
754
)
self
.
assertInstanceDirectoryListEqual
([
'0'
])
self
.
assertInstanceDirectoryListEqual
([
'0'
])
self
.
assertItemsEqual
(
os
.
listdir
(
partition
.
partition_path
),
self
.
assertItemsEqual
(
os
.
listdir
(
partition
.
partition_path
),
[
'.slapgrid'
,
'.0_wrapper.log'
,
'buildout.cfg'
,
[
'.slapgrid'
,
'.0_wrapper.log'
,
'buildout.cfg'
,
...
@@ -2593,7 +2592,7 @@ exit 0
...
@@ -2593,7 +2592,7 @@ exit 0
os
.
makedirs
(
pre_delete_dir
,
0o700
)
os
.
makedirs
(
pre_delete_dir
,
0o700
)
with
open
(
pre_delete_script
,
'w'
)
as
f
:
with
open
(
pre_delete_script
,
'w'
)
as
f
:
f
.
write
(
self
.
prerm_script_content
)
f
.
write
(
self
.
prerm_script_content
)
os
.
chmod
(
pre_delete_script
,
0754
)
os
.
chmod
(
pre_delete_script
,
0
o
754
)
self
.
assertTrue
(
os
.
path
.
exists
(
pre_delete_script
))
self
.
assertTrue
(
os
.
path
.
exists
(
pre_delete_script
))
manager_list
=
slapmanager
.
from_config
({
'manager_list'
:
'prerm'
})
manager_list
=
slapmanager
.
from_config
({
'manager_list'
:
'prerm'
})
...
@@ -2640,7 +2639,7 @@ exit 0
...
@@ -2640,7 +2639,7 @@ exit 0
os
.
makedirs
(
pre_delete_dir
,
0o700
)
os
.
makedirs
(
pre_delete_dir
,
0o700
)
with
open
(
pre_delete_script
,
'w'
)
as
f
:
with
open
(
pre_delete_script
,
'w'
)
as
f
:
f
.
write
(
self
.
prerm_script_content
)
f
.
write
(
self
.
prerm_script_content
)
os
.
chmod
(
pre_delete_script
,
0754
)
os
.
chmod
(
pre_delete_script
,
0
o
754
)
self
.
assertEqual
(
partition
.
state
,
'started'
)
self
.
assertEqual
(
partition
.
state
,
'started'
)
manager_list
=
slapmanager
.
from_config
({
'manager_list'
:
'prerm'
})
manager_list
=
slapmanager
.
from_config
({
'manager_list'
:
'prerm'
})
self
.
grid
.
_manager_list
=
manager_list
self
.
grid
.
_manager_list
=
manager_list
...
@@ -2675,7 +2674,7 @@ exit 0
...
@@ -2675,7 +2674,7 @@ exit 0
os
.
makedirs
(
pre_delete_dir
,
0o700
)
os
.
makedirs
(
pre_delete_dir
,
0o700
)
with
open
(
pre_delete_script
,
'w'
)
as
f
:
with
open
(
pre_delete_script
,
'w'
)
as
f
:
f
.
write
(
self
.
prerm_script_content
)
f
.
write
(
self
.
prerm_script_content
)
os
.
chmod
(
pre_delete_script
,
0754
)
os
.
chmod
(
pre_delete_script
,
0
o
754
)
manager_list
=
slapmanager
.
from_config
({
'manager_list'
:
'prerm'
})
manager_list
=
slapmanager
.
from_config
({
'manager_list'
:
'prerm'
})
self
.
grid
.
_manager_list
=
manager_list
self
.
grid
.
_manager_list
=
manager_list
...
...
slapos/tests/slapproxy/__init__.py
View file @
f24a2ecc
...
@@ -28,7 +28,7 @@
...
@@ -28,7 +28,7 @@
#
#
##############################################################################
##############################################################################
import
ConfigP
arser
from
six.moves
import
configp
arser
import
os
import
os
import
logging
import
logging
import
shutil
import
shutil
...
@@ -106,7 +106,7 @@ database_uri = %(tempdir)s/lib/proxy.db
...
@@ -106,7 +106,7 @@ database_uri = %(tempdir)s/lib/proxy.db
Set config for slapproxy and start it
Set config for slapproxy and start it
"""
"""
conf
=
slapos
.
proxy
.
ProxyConfig
(
logger
=
logging
.
getLogger
())
conf
=
slapos
.
proxy
.
ProxyConfig
(
logger
=
logging
.
getLogger
())
configp
=
ConfigP
arser
.
SafeConfigParser
()
configp
=
configp
arser
.
SafeConfigParser
()
configp
.
read
(
self
.
slapos_cfg
)
configp
.
read
(
self
.
slapos_cfg
)
conf
.
mergeConfig
(
ProxyOption
(
self
.
proxy_db
),
configp
)
conf
.
mergeConfig
(
ProxyOption
(
self
.
proxy_db
),
configp
)
conf
.
setConfig
()
conf
.
setConfig
()
...
@@ -1040,7 +1040,7 @@ database_uri = %(tempdir)s/lib/external_proxy.db
...
@@ -1040,7 +1040,7 @@ database_uri = %(tempdir)s/lib/external_proxy.db
self
.
external_proxy_slap
.
_connection_helper
.
GET
(
'/'
)
self
.
external_proxy_slap
.
_connection_helper
.
GET
(
'/'
)
except
slapos
.
slap
.
NotFoundError
:
except
slapos
.
slap
.
NotFoundError
:
break
break
except
slapos
.
slap
.
ConnectionError
,
socket
.
error
:
except
(
slapos
.
slap
.
ConnectionError
,
socket
.
error
)
:
attempts
=
attempts
+
1
attempts
=
attempts
+
1
time
.
sleep
(
0.1
)
time
.
sleep
(
0.1
)
else
:
else
:
...
...
slapos/tests/util.py
View file @
f24a2ecc
...
@@ -65,9 +65,9 @@ class TestUtil(unittest.TestCase):
...
@@ -65,9 +65,9 @@ class TestUtil(unittest.TestCase):
wanted_directory0
=
os
.
path
.
join
(
root_slaptest
,
'slap-write0'
)
wanted_directory0
=
os
.
path
.
join
(
root_slaptest
,
'slap-write0'
)
wanted_directory1
=
os
.
path
.
join
(
root_slaptest
,
'slap-write0'
,
'write-slap1'
)
wanted_directory1
=
os
.
path
.
join
(
root_slaptest
,
'slap-write0'
,
'write-slap1'
)
wanted_directory2
=
os
.
path
.
join
(
root_slaptest
,
'slap-write0'
,
'write-slap1'
,
'write-teste2'
)
wanted_directory2
=
os
.
path
.
join
(
root_slaptest
,
'slap-write0'
,
'write-slap1'
,
'write-teste2'
)
wanted_directory_mkdir0
=
os
.
makedirs
(
wanted_directory0
,
mode
=
0777
)
wanted_directory_mkdir0
=
os
.
makedirs
(
wanted_directory0
,
mode
=
0
o
777
)
wanted_directory_mkdir1
=
os
.
makedirs
(
wanted_directory1
,
mode
=
0777
)
wanted_directory_mkdir1
=
os
.
makedirs
(
wanted_directory1
,
mode
=
0
o
777
)
wanted_directory_mkdir2
=
os
.
makedirs
(
wanted_directory2
,
mode
=
0777
)
wanted_directory_mkdir2
=
os
.
makedirs
(
wanted_directory2
,
mode
=
0
o
777
)
create_file_txt
=
tempfile
.
mkstemp
(
suffix
=
'.txt'
,
prefix
=
'tmp'
,
dir
=
wanted_directory2
,
text
=
True
)
create_file_txt
=
tempfile
.
mkstemp
(
suffix
=
'.txt'
,
prefix
=
'tmp'
,
dir
=
wanted_directory2
,
text
=
True
)
user
=
'nobody'
user
=
'nobody'
try
:
try
:
...
...
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