Skip to content

Commit

Permalink
Merge pull request xapi-project#5453 from xcp-ng/storage-api-py3
Browse files Browse the repository at this point in the history
Python3 fixes for storage api
  • Loading branch information
liulinC authored May 22, 2024
2 parents 2a2e962 + af3a3e4 commit 6226bbd
Show file tree
Hide file tree
Showing 10 changed files with 41 additions and 26 deletions.
2 changes: 0 additions & 2 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -62,9 +62,7 @@ test:
trap "kill $${PSTREE_SLEEP_PID}" SIGINT SIGTERM EXIT; \
timeout --foreground $(TEST_TIMEOUT2) \
dune runtest --profile=$(PROFILE) --error-reporting=twice -j $(JOBS)
ifneq ($(PY_TEST), NO)
dune build @runtest-python --profile=$(PROFILE)
endif

stresstest:
dune build @stresstest --profile=$(PROFILE) --no-buffer -j $(JOBS)
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
#!/usr/bin/env python2
#!/usr/bin/env python3

"""
Copyright (C) Citrix Systems, Inc.
Expand Down
Original file line number Diff line number Diff line change
@@ -1,12 +1,12 @@
#!/usr/bin/env python2
#!/usr/bin/env python3

"""
Copyright (C) Citrix Systems, Inc.
"""

import os
import sys
import urlparse
import urllib.parse
import xapi.storage.api.volume

import plugin
Expand All @@ -21,11 +21,11 @@ def create(self, dbg, uri, name, description, configuration):
return

def detach(self, dbg, sr):
urlparse.urlparse(sr)
urllib.parse.urlparse(sr)
return

def ls(self, dbg, sr):
urlparse.urlparse(sr)
urllib.parse.urlparse(sr)
qr = plugin.Implementation().query(dbg)
return [{
"name": qr['name'],
Expand All @@ -40,7 +40,7 @@ def ls(self, dbg, sr):
}]

def stat(self, dbg, sr):
urlparse.urlparse(sr)
urllib.parse.urlparse(sr)
qr = plugin.Implementation().query(dbg)
return {
"sr": sr,
Expand Down
Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@
#!/usr/bin/env python2
#!/usr/bin/env python3

"""
Copyright (C) Citrix Systems, Inc.
"""

import uuid
import urlparse
import urllib.parse
import os
import sys
import xapi.storage.api.volume
Expand All @@ -17,7 +17,7 @@
class Implementation(xapi.storage.api.volume.Volume_skeleton):

def create(self, dbg, sr, name, description, size):
urlparse.urlparse(sr)
urllib.parse.urlparse(sr)
voluuid = str(uuid.uuid4())
return {
"name": name,
Expand All @@ -32,11 +32,11 @@ def create(self, dbg, sr, name, description, size):
}

def destroy(self, dbg, sr, key):
urlparse.urlparse(sr)
urllib.parse.urlparse(sr)
return

def stat(self, dbg, sr, key):
urlparse.urlparse(sr)
urllib.parse.urlparse(sr)
qr = plugin.Implementation().query(dbg)
return {
"name": qr['name'],
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
#!/usr/bin/env python2
#!/usr/bin/env python3

"""
Copyright (C) Citrix Systems, Inc.
Expand Down
Original file line number Diff line number Diff line change
@@ -1,12 +1,12 @@
#!/usr/bin/env python2
#!/usr/bin/env python3

"""
Copyright (C) Citrix Systems, Inc.
"""

import os
import sys
import urlparse
import urllib.parse
import xapi.storage.api.v5.volume

import plugin
Expand All @@ -22,11 +22,11 @@ def create(self, dbg, uuid, configuration, name, description):
return configuration

def detach(self, dbg, sr):
urlparse.urlparse(sr)
urllib.parse.urlparse(sr)
return

def ls(self, dbg, sr):
urlparse.urlparse(sr)
urllib.parse.urlparse(sr)
qr = plugin.Implementation().query(dbg)
return [{
"name": qr['name'],
Expand All @@ -42,7 +42,7 @@ def ls(self, dbg, sr):
}]

def stat(self, dbg, sr):
urlparse.urlparse(sr)
urllib.parse.urlparse(sr)
qr = plugin.Implementation().query(dbg)
return {
"sr": sr,
Expand Down
Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@
#!/usr/bin/env python2
#!/usr/bin/env python3

"""
Copyright (C) Citrix Systems, Inc.
"""

import uuid
import urlparse
import urllib.parse
import os
import sys
import xapi.storage.api.v5.volume
Expand All @@ -17,7 +17,7 @@
class Implementation(xapi.storage.api.v5.volume.Volume_skeleton):

def create(self, dbg, sr, name, description, size, sharable):
urlparse.urlparse(sr)
urllib.parse.urlparse(sr)
voluuid = str(uuid.uuid4())
return {
"name": name,
Expand All @@ -33,11 +33,11 @@ def create(self, dbg, sr, name, description, size, sharable):
}

def destroy(self, dbg, sr, key):
urlparse.urlparse(sr)
urllib.parse.urlparse(sr)
return

def stat(self, dbg, sr, key):
urlparse.urlparse(sr)
urllib.parse.urlparse(sr)
qr = plugin.Implementation().query(dbg)
return {
"name": qr['name'],
Expand Down
5 changes: 5 additions & 0 deletions ocaml/xapi-storage/python/xapi/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,11 @@
import json
import argparse

# pylint: disable=invalid-name,redefined-builtin,undefined-variable
# pyright: reportUndefinedVariable=false
if sys.version_info[0] > 2:
long = int
unicode = str

def success(result):
return {"Status": "Success", "Value": result}
Expand Down
8 changes: 7 additions & 1 deletion ocaml/xapi-storage/python/xapi/storage/api/datapath.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,12 @@
import argparse
import traceback
import logging

# pylint: disable=invalid-name,redefined-builtin,undefined-variable
# pyright: reportUndefinedVariable=false
if sys.version_info[0] > 2:
unicode = str

class Unimplemented(Rpc_light_failure):
def __init__(self, arg_0):
Rpc_light_failure.__init__(self, "Unimplemented", [ arg_0 ])
Expand Down Expand Up @@ -398,4 +404,4 @@ def _dispatch(self, method, params):
class datapath_server_test(datapath_server_dispatcher):
"""Create a server which will respond to all calls, returning arbitrary values. This is intended as a marshal/unmarshal test."""
def __init__(self):
datapath_server_dispatcher.__init__(self, Datapath_server_dispatcher(Datapath_test()))
datapath_server_dispatcher.__init__(self, Datapath_server_dispatcher(Datapath_test()))
8 changes: 7 additions & 1 deletion ocaml/xapi-storage/python/xapi/storage/api/plugin.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,12 @@
import argparse
import traceback
import logging

# pylint: disable=invalid-name,redefined-builtin,undefined-variable
# pyright: reportUndefinedVariable=false
if sys.version_info[0] > 2:
unicode = str

class Unimplemented(Rpc_light_failure):
def __init__(self, arg_0):
Rpc_light_failure.__init__(self, "Unimplemented", [ arg_0 ])
Expand Down Expand Up @@ -230,4 +236,4 @@ def _dispatch(self, method, params):
class plugin_server_test(plugin_server_dispatcher):
"""Create a server which will respond to all calls, returning arbitrary values. This is intended as a marshal/unmarshal test."""
def __init__(self):
plugin_server_dispatcher.__init__(self, Plugin_server_dispatcher(Plugin_test()))
plugin_server_dispatcher.__init__(self, Plugin_server_dispatcher(Plugin_test()))

0 comments on commit 6226bbd

Please sign in to comment.