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
21
Merge Requests
21
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
5385ba4e
Commit
5385ba4e
authored
Jun 25, 2013
by
Marco Mariani
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
removed obsolete entry points for 'request', 'supply', 'remove'
also removed related tests
parent
eed56ee9
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
0 additions
and
516 deletions
+0
-516
slapos/cli_legacy/entry.py
slapos/cli_legacy/entry.py
+0
-226
slapos/cli_legacy/remove.py
slapos/cli_legacy/remove.py
+0
-22
slapos/cli_legacy/request.py
slapos/cli_legacy/request.py
+0
-56
slapos/cli_legacy/supply.py
slapos/cli_legacy/supply.py
+0
-25
slapos/tests/entry.py
slapos/tests/entry.py
+0
-187
No files found.
slapos/cli_legacy/entry.py
deleted
100644 → 0
View file @
eed56ee9
# -*- coding: utf-8 -*-
##############################################################################
#
# Copyright (c) 2012 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 advised 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.
#
##############################################################################
import
argparse
import
ConfigParser
import
os
import
sys
from
slapos.cli_legacy.bang
import
main
as
bang
from
slapos.cli_legacy.console
import
console
from
slapos.cli_legacy.request
import
request
from
slapos.cli_legacy.remove
import
remove
from
slapos.cli_legacy.supply
import
supply
from
slapos.cli_legacy.format
import
main
as
format
from
slapos.cli_legacy.slapgrid
import
runComputerPartition
as
instance
from
slapos.cli_legacy.slapgrid
import
runSoftwareRelease
as
software
from
slapos.cli_legacy.slapgrid
import
runUsageReport
as
report
from
slapos.cli_legacy.svcbackend
import
supervisord
from
slapos.cli_legacy.svcbackend
import
supervisorctl
from
slapos.version
import
version
# Note: this whole file is a hack. We should better try dedicated library
# like https://github.com/dhellmann/cliff or https://github.com/docopt/docopt.
GLOBAL_SLAPOS_CONFIGURATION
=
os
.
environ
.
get
(
'SLAPOS_CONFIGURATION'
,
'/etc/opt/slapos/slapos.cfg'
)
USER_SLAPOS_CONFIGURATION
=
os
.
environ
.
get
(
'SLAPOS_CLIENT_CONFIGURATION'
,
os
.
environ
.
get
(
'SLAPOS_CONFIGURATION'
,
'~/.slapos/slapos.cfg'
))
class
EntryPointNotImplementedError
(
NotImplementedError
):
def
__init__
(
self
,
*
args
,
**
kw_args
):
NotImplementedError
.
__init__
(
self
,
*
args
,
**
kw_args
)
def
checkSlaposCfg
():
"""
Check if a slapos configuration file was given as a argument.
If a slapos configuration file is given it return True else False
"""
# XXX-Cedric: dangerous but quick way to achieve way to not provide
# configuration file for each command without changing underlying code.
# It the long term, it should be done in a better way (no guessing).
for
element
in
sys
.
argv
:
if
'.cfg'
in
element
:
if
os
.
path
.
exists
(
element
):
configp
=
ConfigParser
.
SafeConfigParser
()
configp
.
read
(
element
)
if
configp
.
has_section
(
'slapos'
):
return
True
return
False
def
checkOption
(
option
):
"""
Check if a given option is already in call line
Add it and its values if missing
"""
option
=
option
.
split
()
key
=
option
[
0
]
for
element
in
sys
.
argv
:
if
key
in
element
:
return
True
sys
.
argv
.
append
(
key
)
if
len
(
option
)
>
1
:
sys
.
argv
=
sys
.
argv
+
option
[
1
:]
return
True
def
call
(
fun
,
config_path
=
False
,
option
=
None
):
"""
Add missing options to sys.argv
Add config if asked and it is missing
Call function fun
"""
if
option
is
None
:
option
=
[]
for
element
in
option
:
checkOption
(
element
)
if
config_path
:
if
not
checkSlaposCfg
():
sys
.
argv
=
[
sys
.
argv
[
0
]]
+
[
os
.
path
.
expanduser
(
config_path
)]
+
sys
.
argv
[
1
:]
fun
()
sys
.
exit
(
0
)
def
dispatch
(
command
,
is_node_command
):
""" Dispatch to correct SlapOS module.
Here we could use introspection to get rid of the big "if" statements,
but we want to control every input.
Here we give default option and configuration file if they are needed, i.e
If configuration file is not given: define it arbitrarily, and so on.
"""
if
is_node_command
:
if
os
.
getuid
()
!=
0
:
sys
.
stderr
.
write
(
'This command must be run as root.
\
n
'
)
sys
.
exit
()
if
command
==
'software'
:
call
(
software
,
config_path
=
GLOBAL_SLAPOS_CONFIGURATION
,
option
=
[
'--pidfile /opt/slapos/slapgrid-sr.pid'
])
elif
command
==
'instance'
:
call
(
instance
,
config_path
=
GLOBAL_SLAPOS_CONFIGURATION
,
option
=
[
'--pidfile /opt/slapos/slapgrid-cp.pid'
])
elif
command
==
'report'
:
call
(
report
,
config_path
=
GLOBAL_SLAPOS_CONFIGURATION
,
option
=
[
'--pidfile /opt/slapos/slapgrid-ur.pid'
])
elif
command
==
'bang'
:
call
(
bang
,
config_path
=
GLOBAL_SLAPOS_CONFIGURATION
)
elif
command
==
'format'
:
call
(
format
,
config_path
=
GLOBAL_SLAPOS_CONFIGURATION
,
option
=
[
'-c'
,
'-v'
])
elif
command
==
'supervisord'
:
call
(
supervisord
,
config_path
=
GLOBAL_SLAPOS_CONFIGURATION
)
elif
command
==
'supervisorctl'
:
call
(
supervisorctl
,
config_path
=
GLOBAL_SLAPOS_CONFIGURATION
)
elif
command
in
[
'start'
,
'stop'
,
'restart'
,
'status'
,
'tail'
]:
# Again, too hackish
sys
.
argv
[
-
2
:
-
2
]
=
[
command
]
call
(
supervisorctl
,
config_path
=
GLOBAL_SLAPOS_CONFIGURATION
)
else
:
return
False
elif
command
==
'request'
:
call
(
request
,
config_path
=
USER_SLAPOS_CONFIGURATION
)
elif
command
==
'supply'
:
call
(
supply
,
config_path
=
USER_SLAPOS_CONFIGURATION
)
elif
command
==
'remove'
:
call
(
remove
,
config_path
=
USER_SLAPOS_CONFIGURATION
)
elif
command
==
'start'
:
raise
EntryPointNotImplementedError
(
command
)
elif
command
==
'stop'
:
raise
EntryPointNotImplementedError
(
command
)
elif
command
==
'destroy'
:
raise
EntryPointNotImplementedError
(
command
)
elif
command
==
'console'
:
call
(
console
,
config_path
=
USER_SLAPOS_CONFIGURATION
)
else
:
return
False
def
main
():
"""
Main entry point of SlapOS Node. Used to dispatch commands to python
module responsible of the operation.
"""
# If "node" arg is the first: we strip it and set a switch
if
len
(
sys
.
argv
)
>
1
and
sys
.
argv
[
1
]
==
"node"
:
sys
.
argv
.
pop
(
1
)
# Hackish way to show status if no argument is specified
if
len
(
sys
.
argv
)
is
1
:
sys
.
argv
.
append
(
'status'
)
is_node
=
True
else
:
is_node
=
False
usage
=
"""SlapOS %s command line interface.
For more informations, refer to SlapOS documentation.
Client subcommands usage:
slapos request <instance-name> <software-url> [--configuration arg1=value1 arg2=value2 ... argN=valueN]
slapos supply <software-url> <node-id>
slapos console
Node subcommands usage:
slapos node
slapos node software
slapos node instance
slapos node report
slapos node format
slapos node start <process>
slapos node stop <process>
slapos node restart <process>
slapos node tail [process]
slapos node status <process>
slapos node supervisorctl
slapos node supervisord
"""
%
version
# Parse arguments
# XXX remove the "positional arguments" from help message
ap
=
argparse
.
ArgumentParser
(
usage
=
usage
)
ap
.
add_argument
(
'command'
)
ap
.
add_argument
(
'argument_list'
,
nargs
=
argparse
.
REMAINDER
)
args
=
ap
.
parse_args
()
# Set sys.argv for the sub-entry point that we will call
command_line
=
[
args
.
command
]
command_line
.
extend
(
args
.
argument_list
)
sys
.
argv
=
command_line
try
:
if
not
dispatch
(
args
.
command
,
is_node
):
ap
.
print_help
()
sys
.
exit
(
1
)
except
EntryPointNotImplementedError
,
exception
:
print
(
'The command %s does not exist or is not yet implemented. Please '
'have a look at http://community.slapos.org to read documentation or '
'forum. Please also make sure that SlapOS Node is up to '
'date.'
%
exception
)
sys
.
exit
(
1
)
slapos/cli_legacy/remove.py
deleted
100644 → 0
View file @
eed56ee9
# -*- coding: utf-8 -*-
import
argparse
from
slapos.client
import
ClientConfig
,
init
,
do_remove
from
slapos.cli_legacy.util
import
get_config_parser
def
remove
():
ap
=
argparse
.
ArgumentParser
()
ap
.
add_argument
(
'configuration_file'
,
help
=
'SlapOS configuration file'
)
ap
.
add_argument
(
'software_url'
,
help
=
'Your software url'
)
ap
.
add_argument
(
'node'
,
help
=
'Target node'
)
args
=
ap
.
parse_args
()
configp
=
get_config_parser
(
args
.
configuration_file
)
conf
=
ClientConfig
(
args
,
configp
)
local
=
init
(
conf
)
do_remove
(
args
.
software_url
,
args
.
node
,
local
)
slapos/cli_legacy/request.py
deleted
100644 → 0
View file @
eed56ee9
# -*- coding: utf-8 -*-
import
argparse
from
slapos.client
import
ClientConfig
,
init
,
do_request
from
slapos.cli_legacy.util
import
get_config_parser
def
argToDict
(
element
):
"""
convert a table of string 'key=value' to dict
"""
if
element
is
not
None
:
element_dict
=
dict
([
arg
.
split
(
'='
)
for
arg
in
element
])
return
element_dict
def
request
():
"""Run when invoking slapos request. Request an instance."""
# Parse arguments and inititate needed parameters
# XXX-Cedric: move argument parsing to main entry point
ap
=
argparse
.
ArgumentParser
()
ap
.
add_argument
(
'configuration_file'
,
help
=
'SlapOS configuration file.'
)
ap
.
add_argument
(
'reference'
,
help
=
'Your instance reference'
)
ap
.
add_argument
(
'software_url'
,
help
=
'Your software url'
)
ap
.
add_argument
(
'--node'
,
nargs
=
'*'
,
help
=
'Node request option '
"'option1=value1 option2=value2'"
)
ap
.
add_argument
(
'--type'
,
type
=
str
,
help
=
'Define software type to be requested'
)
ap
.
add_argument
(
'--slave'
,
action
=
'store_true'
,
default
=
False
,
help
=
'Ask for a slave instance'
)
ap
.
add_argument
(
'--configuration'
,
nargs
=
'*'
,
help
=
'Give your configuration '
"'option1=value1 option2=value2'"
)
args
=
ap
.
parse_args
()
if
args
.
configuration
:
args
.
parameters
=
argToDict
(
args
.
configuration
)
if
args
.
node
:
args
.
node
=
argToDict
(
args
.
node
)
configp
=
get_config_parser
(
args
.
configuration_file
)
conf
=
ClientConfig
(
args
,
configp
)
local
=
init
(
conf
)
do_request
(
conf
,
local
)
slapos/cli_legacy/supply.py
deleted
100644 → 0
View file @
eed56ee9
# -*- coding: utf-8 -*-
import
argparse
from
slapos.client
import
ClientConfig
,
init
,
do_supply
from
slapos.cli_legacy.util
import
get_config_parser
def
supply
():
"""
Run when invoking slapos supply. Mostly argument parsing.
"""
ap
=
argparse
.
ArgumentParser
()
ap
.
add_argument
(
'configuration_file'
,
help
=
'SlapOS configuration file'
)
ap
.
add_argument
(
'software_url'
,
help
=
'Your software url'
)
ap
.
add_argument
(
'node'
,
help
=
'Target node'
)
args
=
ap
.
parse_args
()
configp
=
get_config_parser
(
args
.
configuration_file
)
conf
=
ClientConfig
(
args
,
configp
)
local
=
init
(
conf
)
do_supply
(
args
.
software_url
,
args
.
node
,
local
)
slapos/tests/entry.py
deleted
100644 → 0
View file @
eed56ee9
# -*- coding: utf-8 -*-
##############################################################################
#
# Copyright (c) 2012 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 advised 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.
#
##############################################################################
import
os
import
shutil
from
slapos.cli_legacy
import
entry
import
sys
import
tempfile
import
unittest
class
BasicMixin
:
def
setUp
(
self
):
self
.
_tempdir
=
tempfile
.
mkdtemp
()
self
.
_original_sys_argv
=
sys
.
argv
sys
.
argv
=
[
'entry'
]
def
tearDown
(
self
):
shutil
.
rmtree
(
self
.
_tempdir
,
True
)
sys
.
argv
=
self
.
_original_sys_argv
class
TestcheckSlaposCfg
(
BasicMixin
,
unittest
.
TestCase
):
"""
Tests on checkSlaposCfg function
"""
def
test_slapos_cfg_detection_when_no_configuration_given
(
self
):
"""
If no configuration file is given then False is return
"""
sys
.
argv
=
[
'entry'
,
'--logfile'
,
'/log/file'
]
self
.
assertFalse
(
entry
.
checkSlaposCfg
())
def
test_slapos_cfg_detection_when_file_does_not_exists
(
self
):
"""
If given configuration file does not exists then False is return
"""
slapos_cfg
=
os
.
path
.
join
(
self
.
_tempdir
,
'slapos.cfg'
)
sys
.
argv
=
[
'entry'
,
slapos_cfg
]
self
.
assertFalse
(
entry
.
checkSlaposCfg
())
def
test_slapos_cfg_detection_when_no_slapos_section
(
self
):
"""
If given configuration file does not have slapos section
then False is return
"""
slapos_cfg
=
os
.
path
.
join
(
self
.
_tempdir
,
'slapos.cfg'
)
open
(
slapos_cfg
,
'w'
).
write
(
'[slapformat]'
)
sys
.
argv
=
[
'entry'
,
slapos_cfg
]
self
.
assertFalse
(
entry
.
checkSlaposCfg
())
def
test_slapos_cfg_detection_when_correct
(
self
):
"""
If given configuration file have slapos section
then True is return
"""
slapos_cfg
=
os
.
path
.
join
(
self
.
_tempdir
,
'slapos.cfg'
)
open
(
slapos_cfg
,
'w'
).
write
(
'[slapos]'
)
sys
.
argv
.
append
(
slapos_cfg
)
self
.
assertTrue
(
entry
.
checkSlaposCfg
())
class
TestcheckOption
(
BasicMixin
,
unittest
.
TestCase
):
def
test_present_option_is_not_added
(
self
):
"""
If the option is already there do not add it
"""
sys
.
argv
+=
[
'-vc'
,
'--logfile'
,
'/opt/slapos/slapos.log'
]
original_sysargv
=
sys
.
argv
entry
.
checkOption
(
"--logfile /opt/slapos/format.log"
)
self
.
assertEqual
(
original_sysargv
,
sys
.
argv
)
def
test_missing_option_is_added
(
self
):
"""
If the option is not there add it
"""
sys
.
argv
+=
[
'-vc'
,
'--pidfile'
,
'/opt/slapos/slapos.pid'
]
original_sysargv
=
sys
.
argv
option
=
"--logfile /opt/slapgrid/slapformat.log"
entry
.
checkOption
(
option
)
self
.
assertNotEqual
(
original_sysargv
,
sys
.
argv
)
self
.
assertIn
(
option
,
' '
.
join
(
sys
.
argv
))
class
TestCall
(
BasicMixin
,
unittest
.
TestCase
):
"""
Testing call function
"""
def
test_config_and_option_are_added
(
self
):
"""
Test missing options and config are added
"""
sys
.
argv
+=
[
'-vc'
]
original_sysargv
=
sys
.
argv
def
fun
():
return
0
options
=
[
"--logfile /opt/slapos/logfile"
,
"--pidfile /opt/slapos/pidfile"
]
config_path
=
'/etc/opt/slapos/slapos.cfg'
try
:
entry
.
call
(
fun
,
config_path
=
config_path
,
option
=
options
)
except
SystemExit
,
e
:
self
.
assertEqual
(
e
[
0
],
0
)
self
.
assertNotEqual
(
original_sysargv
,
sys
.
argv
)
for
x
in
options
:
self
.
assertIn
(
x
,
' '
.
join
(
sys
.
argv
))
self
.
assertEqual
(
config_path
,
sys
.
argv
[
1
])
def
test_config_and_missing_option_are_added
(
self
):
"""
Test missing options and config are added but do not replace
already present option
"""
missing_option
=
"--logfile /opt/slapos/logfile"
present_option
=
"--pidfile /opt/slapos/pidfile"
default_present_option
=
"--pidfile /opt/slapos/pidfile.default"
sys
.
argv
+=
[
'-vc'
,
present_option
]
original_sysargv
=
sys
.
argv
def
fun
():
return
0
options
=
[
default_present_option
,
missing_option
]
config_path
=
'/etc/opt/slapos/slapos.cfg'
try
:
entry
.
call
(
fun
,
config_path
=
config_path
,
option
=
options
)
except
SystemExit
,
e
:
self
.
assertEqual
(
e
[
0
],
0
)
self
.
assertNotEqual
(
original_sysargv
,
sys
.
argv
)
for
x
in
(
missing_option
,
present_option
):
self
.
assertIn
(
x
,
' '
.
join
(
sys
.
argv
))
self
.
assertFalse
(
default_present_option
in
" "
.
join
(
sys
.
argv
))
self
.
assertEqual
(
config_path
,
sys
.
argv
[
1
])
def
test_present_config_and_option_are_not_added
(
self
):
"""
Test already present options and config are not added
"""
present_option
=
"--pidfile /opt/slapos/pidfile"
default_present_option
=
"--pidfile /opt/slapos/pidfile.default"
slapos_cfg
=
os
.
path
.
join
(
self
.
_tempdir
,
'slapos.cfg'
)
open
(
slapos_cfg
,
'w'
).
write
(
'[slapos]'
)
sys
.
argv
+=
[
'-vc'
,
slapos_cfg
,
present_option
.
split
()[
0
],
present_option
.
split
()[
1
]]
original_sysargv
=
sys
.
argv
def
fun
():
return
0
options
=
[
default_present_option
]
config_path
=
'/etc/opt/slapos/slapos.cfg'
try
:
entry
.
call
(
fun
,
config_path
=
config_path
,
option
=
options
)
except
SystemExit
,
e
:
self
.
assertEqual
(
e
[
0
],
0
)
self
.
assertEqual
(
original_sysargv
,
sys
.
argv
)
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