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
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
Léo-Paul Géneau
slapos.core
Commits
909bc0ff
Commit
909bc0ff
authored
Jan 06, 2015
by
Rafael Monnerat
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
slapos: Add new command to query if source cache is inside shacache
parent
b6aa843a
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
158 additions
and
0 deletions
+158
-0
setup.py
setup.py
+1
-0
slapos/cli/cache_source.py
slapos/cli/cache_source.py
+101
-0
slapos/tests/test_cli.py
slapos/tests/test_cli.py
+56
-0
No files found.
setup.py
View file @
909bc0ff
...
@@ -85,6 +85,7 @@ setup(name=name,
...
@@ -85,6 +85,7 @@ setup(name=name,
'slapos.cli'
:
[
'slapos.cli'
:
[
# Utilities
# Utilities
'cache lookup = slapos.cli.cache:CacheLookupCommand'
,
'cache lookup = slapos.cli.cache:CacheLookupCommand'
,
'cache source = slapos.cli.cache_source:CacheLookupCommand'
,
# SlapOS Node commands
# SlapOS Node commands
'node bang = slapos.cli.bang:BangCommand'
,
'node bang = slapos.cli.bang:BangCommand'
,
'node format = slapos.cli.format:FormatCommand'
,
'node format = slapos.cli.format:FormatCommand'
,
...
...
slapos/cli/cache_source.py
0 → 100644
View file @
909bc0ff
# -*- coding: utf-8 -*-
##############################################################################
#
# Copyright (c) 2010-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 Lesser General Public License
# as published by the Free Software Foundation; either version 2.1
# 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 Lesser 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
ast
import
hashlib
import
json
import
re
import
requests
import
sys
import
prettytable
from
slapos.grid
import
networkcache
from
slapos.cli.config
import
ConfigCommand
from
slapos.cli.list
import
resetLogger
class
CacheLookupCommand
(
ConfigCommand
):
"""
perform a query to the networkcache
You can provide either a complete URL to the software release,
or a corresponding MD5 hash value.
The command will report which OS distribution/version have a binary
cache of the software release, and which ones are compatible
with the OS you are currently running.
"""
def
get_parser
(
self
,
prog_name
):
ap
=
super
(
CacheLookupCommand
,
self
).
get_parser
(
prog_name
)
ap
.
add_argument
(
'url'
,
help
=
'Wanted url for testing'
)
return
ap
def
take_action
(
self
,
args
):
configp
=
self
.
fetch_config
(
args
)
cache_dir
=
configp
.
get
(
'networkcache'
,
'download-binary-dir-url'
)
sys
.
exit
(
do_lookup
(
self
.
app
.
log
,
cache_dir
,
args
.
url
))
def
do_lookup
(
logger
,
cache_dir
,
url
):
md5
=
hashlib
.
md5
(
url
).
hexdigest
()
try
:
cached_url
=
'%s/slapos-buildout-%s'
%
(
cache_dir
,
md5
)
logger
.
debug
(
'Connecting to %s'
,
url
)
req
=
requests
.
get
(
cached_url
,
timeout
=
5
)
except
(
requests
.
Timeout
,
requests
.
ConnectionError
):
logger
.
critical
(
'Cannot connect to cache server at %s'
,
cached_url
)
return
10
if
not
req
.
ok
:
if
req
.
status_code
==
404
:
logger
.
critical
(
'Object not in cache: %s'
,
url
)
else
:
logger
.
critical
(
'Error while looking object %s: %s'
,
url
,
req
.
reason
)
return
10
entries
=
req
.
json
()
if
not
entries
:
logger
.
info
(
'Object found in cache, but has no entries.'
)
return
0
pt
=
prettytable
.
PrettyTable
([
'file'
,
'sha512'
])
entry_list
=
sorted
(
json
.
loads
(
entry
[
0
])
for
entry
in
entries
)
for
entry
in
entry_list
:
pt
.
add_row
([
entry
[
"file"
],
entry
[
"sha512"
]])
meta
=
json
.
loads
(
entries
[
0
][
0
])
logger
.
info
(
'Software source URL: %s'
,
url
)
logger
.
info
(
'SHADIR URL: %s'
,
cached_url
)
resetLogger
(
logger
)
for
line
in
pt
.
get_string
(
border
=
True
,
padding_width
=
0
,
vrules
=
prettytable
.
NONE
).
split
(
'
\
n
'
):
logger
.
info
(
line
)
return
0
slapos/tests/test_cli.py
View file @
909bc0ff
...
@@ -45,6 +45,7 @@ import slapos.cli.list
...
@@ -45,6 +45,7 @@ import slapos.cli.list
import
slapos.cli.supervisorctl
import
slapos.cli.supervisorctl
from
slapos.cli.proxy_show
import
do_show
,
StringIO
from
slapos.cli.proxy_show
import
do_show
,
StringIO
from
slapos.cli.cache
import
do_lookup
as
cache_do_lookup
from
slapos.cli.cache
import
do_lookup
as
cache_do_lookup
from
slapos.cli.cache_source
import
do_lookup
as
cache_source_do_lookup
from
slapos.client
import
ClientConfig
from
slapos.client
import
ClientConfig
import
slapos.grid.svcbackend
import
slapos.grid.svcbackend
import
slapos.proxy
import
slapos.proxy
...
@@ -101,6 +102,61 @@ class TestCliCache(CliMixin):
...
@@ -101,6 +102,61 @@ class TestCliCache(CliMixin):
'http://xxx.shacache.org/cccdc51a07e8c575c880f2d70dd4d458'
)
'http://xxx.shacache.org/cccdc51a07e8c575c880f2d70dd4d458'
)
class
TestCliCacheSource
(
CliMixin
):
test_url
=
"https://mirrors.edge.kernel.org/pub/software/scm/git/git-2.17.1.tar.xz"
def
test_cached_source
(
self
):
self
.
assertEquals
(
0
,
cache_source_do_lookup
(
self
.
logger
,
cache_dir
=
"http://dir.shacache.org"
,
url
=
self
.
test_url
))
self
.
logger
.
info
.
assert_any_call
(
'Software source URL: %s'
,
'https://mirrors.edge.kernel.org/pub/software/scm/git/git-2.17.1.tar.xz'
)
self
.
logger
.
info
.
assert_any_call
(
'SHADIR URL: %s'
,
'http://dir.shacache.org/slapos-buildout-9183e80d808e7dd49affd0d8977edd4f'
)
self
.
logger
.
info
.
assert_any_call
(
u'--------------------------------------------------------------------'
\
'--------------------------------------------------------------------'
\
'------------'
),
self
.
logger
.
info
.
assert_any_call
(
u' file '
\
' sha512 '
\
' '
),
self
.
logger
.
info
.
assert_any_call
(
u'--------------------------------------------------------------------'
\
'--------------------------------------------------------------------'
\
'------------'
)
self
.
logger
.
info
.
assert_any_call
(
u' git-2.17.1.tar.xz 77c27569d40fbae1842130baa0cdda674a02e384631bd8fb1'
\
'f2ddf67ce372dd4903b2ce6b4283a4ae506cdedd5daa55baa2afe6a6689528511e24'
\
'e4beb864960 '
),
self
.
logger
.
info
.
assert_any_call
(
u'--------------------------------------------------------------------'
\
'--------------------------------------------------------------------'
\
'------------'
)
def
test_uncached_binary
(
self
):
self
.
assertEquals
(
10
,
cache_source_do_lookup
(
self
.
logger
,
cache_dir
=
"http://dir.shacache.org"
,
url
=
"this_is_uncached_url"
))
self
.
logger
.
critical
.
assert_any_call
(
'Object not in cache: %s'
,
'this_is_uncached_url'
)
def
test_bad_cache_dir
(
self
):
self
.
assertEquals
(
10
,
cache_source_do_lookup
(
self
.
logger
,
cache_dir
=
"http://xxx.shacache.org"
,
url
=
self
.
test_url
))
self
.
logger
.
critical
.
assert_any_call
(
'Cannot connect to cache server at %s'
,
'http://xxx.shacache.org/slapos-buildout-9183e80d808e7dd49affd0d8977edd4f'
)
class
TestCliProxy
(
CliMixin
):
class
TestCliProxy
(
CliMixin
):
def
test_generateSoftwareProductListFromString
(
self
):
def
test_generateSoftwareProductListFromString
(
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