當前位置: 首頁>>代碼示例>>Python>>正文


Python xmlrpclib.ServerProxy方法代碼示例

本文整理匯總了Python中xmlrpclib.ServerProxy方法的典型用法代碼示例。如果您正苦於以下問題:Python xmlrpclib.ServerProxy方法的具體用法?Python xmlrpclib.ServerProxy怎麽用?Python xmlrpclib.ServerProxy使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在xmlrpclib的用法示例。


在下文中一共展示了xmlrpclib.ServerProxy方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: test_distribute

# 需要導入模塊: import xmlrpclib [as 別名]
# 或者: from xmlrpclib import ServerProxy [as 別名]
def test_distribute(self):
        real_urlopen = urllib.urlopen
        real_server_proxy = xmlrpclib.ServerProxy
        try:
            xmlrpclib.ServerProxy = ProxyStub(
                "distributedata.py", xmlrpclib.ServerProxy, False
            )
            urllib.urlopen = urlopenstub
            data = pypidata.get_data("distribute")
            rating = rate(data)

            self.assertEqual(
                rating,
                (
                    9,
                    [
                        "The classifiers should specify what minor versions of Python "
                        "you support as well as what major version.",
                        "You should have three or more owners of the project on PyPI.",
                    ],
                ),
            )
        finally:
            xmlrpclib.ServerProxy = real_server_proxy
            urllib.urlopen = real_urlopen 
開發者ID:regebro,項目名稱:pyroma,代碼行數:27,代碼來源:tests.py

示例2: setUpClass

# 需要導入模塊: import xmlrpclib [as 別名]
# 或者: from xmlrpclib import ServerProxy [as 別名]
def setUpClass(self):
        import tests.data_test_webpage
        import httpbin

        self.httpbin_thread = utils.run_in_subprocess(httpbin.app.run, host='0.0.0.0', port=14887, passthrough_errors=False)
        self.httpbin = 'http://' + socket.gethostbyname(socket.gethostname()) + ':14887'

        self.inqueue = Queue(10)
        self.outqueue = Queue(10)
        self.fetcher = Fetcher(self.inqueue, self.outqueue)
        self.fetcher.splash_endpoint = 'http://127.0.0.1:8050/execute'
        self.rpc = xmlrpc_client.ServerProxy('http://localhost:%d' % 24444)
        self.xmlrpc_thread = utils.run_in_thread(self.fetcher.xmlrpc_run, port=24444)
        self.thread = utils.run_in_thread(self.fetcher.run)
        self.proxy_thread = subprocess.Popen(['pyproxy', '--username=binux', '--bind=0.0.0.0',
                                              '--password=123456', '--port=14830',
                                              '--debug'], close_fds=True)
        self.proxy = socket.gethostbyname(socket.gethostname()) + ':14830' 
開發者ID:binux,項目名稱:pyspider,代碼行數:20,代碼來源:test_fetcher.py

示例3: attach_volume

# 需要導入模塊: import xmlrpclib [as 別名]
# 或者: from xmlrpclib import ServerProxy [as 別名]
def attach_volume(self, vm, disk_size, disk_device, disk_fstype, session_id):
        server = ServerProxy(self.server_url, allow_none=True)

        disk_temp = '''
            DISK = [
                TYPE = fs ,
                FORMAT = %s,
                SIZE = %d,
                TARGET = %s,
                SAVE = no
                ]
        ''' % (disk_fstype, disk_size, disk_device)

        success, res_info = server.one.vm.attach(session_id, int(vm.id), disk_temp, False)[0:2]
        if success:
            return (True, "")
        else:
            return (False, res_info) 
開發者ID:grycap,項目名稱:im,代碼行數:20,代碼來源:OpenNebula.py

示例4: delete_image

# 需要導入模塊: import xmlrpclib [as 別名]
# 或者: from xmlrpclib import ServerProxy [as 別名]
def delete_image(self, image_url, auth_data):
        server = ServerProxy(self.server_url, allow_none=True)

        session_id = self.getSessionID(auth_data)
        if session_id is None:
            return (False, "Incorrect auth data, username and password must be specified for OpenNebula provider.")

        image_id = self.get_image_id(image_url, session_id)
        if image_id is None:
            return (False, "Incorrect image name or id specified.")

        # Wait the image to be READY (not USED)
        success, msg = self.wait_image(image_id, auth_data)
        if not success:
            self.logger.warn("Error waiting image to be READY: " + msg)

        success, res_info = server.one.image.delete(session_id, image_id)[0:2]
        if success:
            return (True, "")
        else:
            return (False, res_info) 
開發者ID:grycap,項目名稱:im,代碼行數:23,代碼來源:OpenNebula.py

示例5: get_image_id

# 需要導入模塊: import xmlrpclib [as 別名]
# 或者: from xmlrpclib import ServerProxy [as 別名]
def get_image_id(self, image_url, session_id):
        url = urlparse(image_url)
        image_id = url[2][1:]
        if image_id.isdigit():
            return int(image_id)
        else:
            # We have to find the ID of the image name
            server = ServerProxy(self.server_url, allow_none=True)
            success, res_info = server.one.imagepool.info(session_id, -2, -1, -1)[0:2]
            if success:
                pool_info = IMAGE_POOL(res_info)
            else:
                self.logger.error("Error in the function one.imagepool.info: " + res_info)
                return None

            for image in pool_info.IMAGE:
                if image.NAME == image_id:
                    return image.ID

            return None 
開發者ID:grycap,項目名稱:im,代碼行數:22,代碼來源:OpenNebula.py

示例6: alter_xmlrpc

# 需要導入模塊: import xmlrpclib [as 別名]
# 或者: from xmlrpclib import ServerProxy [as 別名]
def alter_xmlrpc(request):
    """Replaces the ServerProxy class in the xmlrpclib library with a fake class.

    Class is restored after testing.
    """
    old_method = xmlrpclib.ServerProxy
    xmlrpclib.ServerProxy = FakeServerProxy

    def func(value):
        FakeServerProxy.VALUE = value

    def fin():
        xmlrpclib.ServerProxy = old_method
    request.addfinalizer(fin)

    return func


# Initialize the application and sets the app context to avoid needing 'with app.app_context():'.
# This must happen before any Celery tasks are imported automatically by py.test during test discovery. 
開發者ID:Robpol86,項目名稱:Flask-Large-Application-Example,代碼行數:22,代碼來源:conftest.py

示例7: test_multicall

# 需要導入模塊: import xmlrpclib [as 別名]
# 或者: from xmlrpclib import ServerProxy [as 別名]
def test_multicall(self):
        try:
            p = xmlrpclib.ServerProxy(URL)
            multicall = xmlrpclib.MultiCall(p)
            multicall.add(2,3)
            multicall.pow(6,8)
            multicall.div(127,42)
            add_result, pow_result, div_result = multicall()
            self.assertEqual(add_result, 2+3)
            self.assertEqual(pow_result, 6**8)
            self.assertEqual(div_result, 127//42)
        except (xmlrpclib.ProtocolError, socket.error), e:
            # ignore failures due to non-blocking socket 'unavailable' errors
            if not is_unavailable_exception(e):
                # protocol error; provide additional information in test output
                self.fail("%s\n%s" % (e, getattr(e, "headers", ""))) 
開發者ID:IronLanguages,項目名稱:ironpython2,代碼行數:18,代碼來源:test_xmlrpc.py

示例8: test_non_existing_multicall

# 需要導入模塊: import xmlrpclib [as 別名]
# 或者: from xmlrpclib import ServerProxy [as 別名]
def test_non_existing_multicall(self):
        try:
            p = xmlrpclib.ServerProxy(URL)
            multicall = xmlrpclib.MultiCall(p)
            multicall.this_is_not_exists()
            result = multicall()

            # result.results contains;
            # [{'faultCode': 1, 'faultString': '<type \'exceptions.Exception\'>:'
            #   'method "this_is_not_exists" is not supported'>}]

            self.assertEqual(result.results[0]['faultCode'], 1)
            self.assertEqual(result.results[0]['faultString'],
                '<type \'exceptions.Exception\'>:method "this_is_not_exists" '
                'is not supported')
        except (xmlrpclib.ProtocolError, socket.error), e:
            # ignore failures due to non-blocking socket 'unavailable' errors
            if not is_unavailable_exception(e):
                # protocol error; provide additional information in test output
                self.fail("%s\n%s" % (e, getattr(e, "headers", ""))) 
開發者ID:IronLanguages,項目名稱:ironpython2,代碼行數:22,代碼來源:test_xmlrpc.py

示例9: test_two

# 需要導入模塊: import xmlrpclib [as 別名]
# 或者: from xmlrpclib import ServerProxy [as 別名]
def test_two(self):
        p = xmlrpclib.ServerProxy(URL)
        #do three requests.
        self.assertEqual(p.pow(6,8), 6**8)
        self.assertEqual(p.pow(6,8), 6**8)
        self.assertEqual(p.pow(6,8), 6**8)

        #they should have all been handled by a single request handler
        self.assertEqual(len(self.RequestHandler.myRequests), 1)

        #check that we did at least two (the third may be pending append
        #due to thread scheduling)
        self.assertGreaterEqual(len(self.RequestHandler.myRequests[-1]), 2)

#test special attribute access on the serverproxy, through the __call__
#function. 
開發者ID:IronLanguages,項目名稱:ironpython2,代碼行數:18,代碼來源:test_xmlrpc.py

示例10: test_close

# 需要導入模塊: import xmlrpclib [as 別名]
# 或者: from xmlrpclib import ServerProxy [as 別名]
def test_close(self):
        p = xmlrpclib.ServerProxy(URL)
        #do some requests with close.
        self.assertEqual(p.pow(6,8), 6**8)
        self.assertEqual(p.pow(6,8), 6**8)
        self.assertEqual(p.pow(6,8), 6**8)
        p("close")() #this should trigger a new keep-alive request
        self.assertEqual(p.pow(6,8), 6**8)
        self.assertEqual(p.pow(6,8), 6**8)
        self.assertEqual(p.pow(6,8), 6**8)

        #they should have all been two request handlers, each having logged at least
        #two complete requests
        self.assertEqual(len(self.RequestHandler.myRequests), 2)
        self.assertGreaterEqual(len(self.RequestHandler.myRequests[-1]), 2)
        self.assertGreaterEqual(len(self.RequestHandler.myRequests[-2]), 2) 
開發者ID:IronLanguages,項目名稱:ironpython2,代碼行數:18,代碼來源:test_xmlrpc.py

示例11: test_gzip_decode_limit

# 需要導入模塊: import xmlrpclib [as 別名]
# 或者: from xmlrpclib import ServerProxy [as 別名]
def test_gzip_decode_limit(self):
        max_gzip_decode = 20 * 1024 * 1024
        data = '\0' * max_gzip_decode
        encoded = xmlrpclib.gzip_encode(data)
        decoded = xmlrpclib.gzip_decode(encoded)
        self.assertEqual(len(decoded), max_gzip_decode)

        data = '\0' * (max_gzip_decode + 1)
        encoded = xmlrpclib.gzip_encode(data)

        with self.assertRaisesRegexp(ValueError,
                                     "max gzipped payload length exceeded"):
            xmlrpclib.gzip_decode(encoded)

        xmlrpclib.gzip_decode(encoded, max_decode=-1)


#Test special attributes of the ServerProxy object 
開發者ID:IronLanguages,項目名稱:ironpython2,代碼行數:20,代碼來源:test_xmlrpc.py

示例12: test_fail_with_info

# 需要導入模塊: import xmlrpclib [as 別名]
# 或者: from xmlrpclib import ServerProxy [as 別名]
def test_fail_with_info(self):
        # use the broken message class
        SimpleXMLRPCServer.SimpleXMLRPCRequestHandler.MessageClass = FailingMessageClass

        # Check that errors in the server send back exception/traceback
        # info when flag is set
        SimpleXMLRPCServer.SimpleXMLRPCServer._send_traceback_header = True

        try:
            p = xmlrpclib.ServerProxy(URL)
            p.pow(6,8)
        except (xmlrpclib.ProtocolError, socket.error), e:
            # ignore failures due to non-blocking socket 'unavailable' errors
            if not is_unavailable_exception(e) and hasattr(e, "headers"):
                # We should get error info in the response
                expected_err = "invalid literal for int() with base 10: 'I am broken'"
                self.assertEqual(e.headers.get("x-exception"), expected_err)
                self.assertTrue(e.headers.get("x-traceback") is not None) 
開發者ID:IronLanguages,項目名稱:ironpython2,代碼行數:20,代碼來源:test_xmlrpc.py

示例13: get_Supervisor

# 需要導入模塊: import xmlrpclib [as 別名]
# 或者: from xmlrpclib import ServerProxy [as 別名]
def get_Supervisor():
    sserver = getattr(g, '_supervisor', None)
    if sserver is None:
        supervisorurl = config.get('SUPERVISOR_URL',
                                   'unix:///var/run/supervisor.sock')
        sserver = xmlrpclib.ServerProxy(
            'http://127.0.0.1',
            transport=supervisor.xmlrpc.SupervisorTransport(
                None,
                None,
                supervisorurl
            )
        )
        g._supervisor = sserver

    return sserver 
開發者ID:PaloAltoNetworks,項目名稱:minemeld-core,代碼行數:18,代碼來源:supervisorclient.py

示例14: get_available_pip_pkgs

# 需要導入模塊: import xmlrpclib [as 別名]
# 或者: from xmlrpclib import ServerProxy [as 別名]
def get_available_pip_pkgs(version):
    try:
        for _ in range(100):
            pip_pkgs = dict()
            client = xmlrpclib.ServerProxy('https://pypi.python.org/pypi')
            raw_pkgs = client.browse(["Programming Language :: Python :: " + version + ""])
            all_pkgs = [i[0] for i in raw_pkgs]
            if len(all_pkgs) != 0:
                for pkg in all_pkgs:
                    pip_pkgs[pkg] = "N/A"
                return pip_pkgs
            else:
                local('sleep 5')
                continue
    except Exception as err:
        print('Error: {0}'.format(err))
        sys.exit(1) 
開發者ID:apache,項目名稱:incubator-dlab,代碼行數:19,代碼來源:get_list_available_pkgs.py

示例15: test_basic

# 需要導入模塊: import xmlrpclib [as 別名]
# 或者: from xmlrpclib import ServerProxy [as 別名]
def test_basic(self):
        # check that flag is false by default
        flagval = SimpleXMLRPCServer.SimpleXMLRPCServer._send_traceback_header
        self.assertEqual(flagval, False)

        # enable traceback reporting
        SimpleXMLRPCServer.SimpleXMLRPCServer._send_traceback_header = True

        # test a call that shouldn't fail just as a smoke test
        try:
            p = xmlrpclib.ServerProxy(URL)
            self.assertEqual(p.pow(6,8), 6**8)
        except (xmlrpclib.ProtocolError, socket.error), e:
            # ignore failures due to non-blocking socket 'unavailable' errors
            if not is_unavailable_exception(e):
                # protocol error; provide additional information in test output
                self.fail("%s\n%s" % (e, getattr(e, "headers", ""))) 
開發者ID:dxwu,項目名稱:BinderFilter,代碼行數:19,代碼來源:test_xmlrpc.py


注:本文中的xmlrpclib.ServerProxy方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。