本文整理匯總了Python中twisted.python.monkey.MonkeyPatcher.patch方法的典型用法代碼示例。如果您正苦於以下問題:Python MonkeyPatcher.patch方法的具體用法?Python MonkeyPatcher.patch怎麽用?Python MonkeyPatcher.patch使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類twisted.python.monkey.MonkeyPatcher
的用法示例。
在下文中一共展示了MonkeyPatcher.patch方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: test_error_logging
# 需要導入模塊: from twisted.python.monkey import MonkeyPatcher [as 別名]
# 或者: from twisted.python.monkey.MonkeyPatcher import patch [as 別名]
def test_error_logging(self, logger):
"""
Failures while applying a diff emit a log message containing the full
diff.
"""
o1 = DiffTestObjInvariant(
a=1,
b=2,
)
patcher = MonkeyPatcher()
patcher.addPatch(
DiffTestObjInvariant,
'_perform_invariant_check',
False
)
patcher.patch()
try:
o2 = o1.set('b', 1)
finally:
patcher.restore()
diff = create_diff(o1, o2)
self.assertRaises(
InvariantException,
diff.apply,
o1,
)
示例2: test_delete_works_on_valid_credentials
# 需要導入模塊: from twisted.python.monkey import MonkeyPatcher [as 別名]
# 或者: from twisted.python.monkey.MonkeyPatcher import patch [as 別名]
def test_delete_works_on_valid_credentials(self):
from hashlib import sha512
ctuple = namedtuple('named_user', 'email key')
user_tuple = ctuple('[email protected]', sha512('key').hexdigest())
def delete(fles, user):
self.assertEqual(user.email, '[email protected]')
self.assertEqual(user, user_tuple)
monkey_patcher = MonkeyPatcher((user.User, 'delete', delete))
monkey_patcher.patch()
url = '/delete/key'
request = self.generate_request_and_session(
url, auth=lambda: True, uuid='73s7b33f'
)
request.session.user = user_tuple
request.session.expire = lambda: True
result = yield self.account.render(request)
self.assertEqual(result.code, http.OK)
self.assertEqual(result.subject['success'], True)
示例3: test_put_verifyProperRemoval
# 需要導入模塊: from twisted.python.monkey import MonkeyPatcher [as 別名]
# 或者: from twisted.python.monkey.MonkeyPatcher import patch [as 別名]
def test_put_verifyProperRemoval(self):
# Replace the time function of the datastore module
# so that we can artificially speed up time
monkey_patcher = MonkeyPatcher()
c = clock()
c.set(0)
monkey_patcher.addPatch(datastore, "time", c)
# Replace the peer_timeout to 5 seconds
monkey_patcher.addPatch(constants, "peer_timeout", 5)
monkey_patcher.patch()
# Insert a node and verify it is within the datastore
m = self.datastore(self.reactor)
infohash = 5
expected_peer = ("127.0.0.1", 5151)
m.put(infohash, expected_peer)
peers = m.get(infohash)
# Iterate over a 1 element list
for peer in peers:
self.assertEqual(expected_peer, peer)
self.assertEquals(1, len(peers))
# Change the time and verify that the cleaning function
# actually removes the peer
c.set(5)
# TODO hackish, shouldnt reach into object
m._cleanup(infohash, peer)
peers = m.get(infohash)
self.assertEqual(0, len(peers))
monkey_patcher.restore()
示例4: __init__
# 需要導入模塊: from twisted.python.monkey import MonkeyPatcher [as 別名]
# 或者: from twisted.python.monkey.MonkeyPatcher import patch [as 別名]
def __init__(self, model):
if '__pypy__' in sys.modules:
# try to use psycopg2ct if we are on PyPy
try:
from psycopg2ct import compat
compat.register()
# monkey patch to dont let Storm crash on register type
import psycopg2
psycopg2._psycopg = object
class _psycopg:
UNICODEARRAY = psycopg2.extensions.UNICODEARRAY
from twisted.python.monkey import MonkeyPatcher
monkey_patcher = MonkeyPatcher(
(psycopg2, '_psycopg', _psycopg))
monkey_patcher.patch()
except ImportError:
raise RuntimeError(
'You are trying to use PostgreSQL with PyPy. Regular '
'psycopg2 module don\'t work with PyPy, you may install '
'psycopg2ct in order to can use psycopg2 with PyPy'
)
self.model = model
示例5: TestingBase
# 需要導入模塊: from twisted.python.monkey import MonkeyPatcher [as 別名]
# 或者: from twisted.python.monkey.MonkeyPatcher import patch [as 別名]
class TestingBase(object):
def setUp(self):
self.clock = Clock()
self.monkey_patcher = MonkeyPatcher()
self.monkey_patcher.addPatch(rate_limiter.time, "time", self.clock)
self.monkey_patcher.patch()
def tearDown(self):
self.monkey_patcher.restore()
示例6: test_constructWithPatches
# 需要導入模塊: from twisted.python.monkey import MonkeyPatcher [as 別名]
# 或者: from twisted.python.monkey.MonkeyPatcher import patch [as 別名]
def test_constructWithPatches(self):
"""
Constructing a L{MonkeyPatcher} with patches should add all of the
given patches to the patch list.
"""
patcher = MonkeyPatcher((self.testObject, "foo", "haha"), (self.testObject, "bar", "hehe"))
patcher.patch()
self.assertEqual("haha", self.testObject.foo)
self.assertEqual("hehe", self.testObject.bar)
self.assertEqual(self.originalObject.baz, self.testObject.baz)
示例7: test_constructWithPatches
# 需要導入模塊: from twisted.python.monkey import MonkeyPatcher [as 別名]
# 或者: from twisted.python.monkey.MonkeyPatcher import patch [as 別名]
def test_constructWithPatches(self):
"""
Constructing a L{MonkeyPatcher} with patches should add all of the
given patches to the patch list.
"""
patcher = MonkeyPatcher((self.testObject, 'foo', 'haha'),
(self.testObject, 'bar', 'hehe'))
patcher.patch()
self.assertEqual('haha', self.testObject.foo)
self.assertEqual('hehe', self.testObject.bar)
self.assertEqual(self.originalObject.baz, self.testObject.baz)
示例8: __init__
# 需要導入模塊: from twisted.python.monkey import MonkeyPatcher [as 別名]
# 或者: from twisted.python.monkey.MonkeyPatcher import patch [as 別名]
def __init__(self, model):
if '__pypy__' in sys.modules:
# try to use psycopg2ct if we are on PyPy
try:
from psycopg2ct import compat
compat.register()
# monkey patch to dont let Storm crash on register type
import psycopg2
psycopg2._psycopg = object
class _psycopg:
UNICODEARRAY = psycopg2.extensions.UNICODEARRAY
from twisted.python.monkey import MonkeyPatcher
monkey_patcher = MonkeyPatcher(
(psycopg2, '_psycopg', _psycopg))
monkey_patcher.patch()
except ImportError:
raise RuntimeError(
'You are trying to use PostgreSQL with PyPy. Regular '
'psycopg2 module don\'t work with PyPy, you may install '
'psycopg2ct in order to can use psycopg2 with PyPy'
)
self.model = model
self._columns_mapping = {
properties.Bool: 'bool',
properties.UUID: 'uuid',
properties.RawStr: 'bytea',
properties.Pickle: 'bytea',
properties.JSON: 'json',
properties.DateTime: 'timestamp',
properties.Date: 'date',
properties.Time: 'time',
properties.TimeDelta: 'interval',
properties.Enum: 'integer',
properties.Decimal: 'decimal'
}
self.parse = singledispatch(self.parse)
self.parse.register(properties.Int, self._parse_int)
self.parse.register(properties.Unicode, self._parse_unicode)
self.parse.register(properties.Float, self._parse_float)
self.parse.register(properties.List, self._parse_list)
self.parse.register(NativeEnum, self._parse_enum)
示例9: _monkey_patch
# 需要導入模塊: from twisted.python.monkey import MonkeyPatcher [as 別名]
# 或者: from twisted.python.monkey.MonkeyPatcher import patch [as 別名]
def _monkey_patch(self):
"""
Monkeypatch some parts of the twisted library that are waiting
for bugfix inclussion in the trunk
"""
if not self.monkey_patched:
# add new method
setattr(http.Request, 'getClientProxyIP', getClientProxyIP)
# patch getClientIP
monkey_patcher = MonkeyPatcher(
(http.Request, 'getClientIP', getClientIPPatch)
)
monkey_patcher.patch()
self.monkey_patched = True
示例10: test_regsiter_works_when_provided_information_is_valid
# 需要導入模塊: from twisted.python.monkey import MonkeyPatcher [as 別名]
# 或者: from twisted.python.monkey.MonkeyPatcher import patch [as 別名]
def test_regsiter_works_when_provided_information_is_valid(self):
def create(fles):
self.assertEqual(fles.name, 'Someone')
self.assertEqual(fles.email, '[email protected]')
monkey_patcher = MonkeyPatcher((user.User, 'create', create))
monkey_patcher.patch()
request = self.generate_request(['/register'], '''{
"name": "Someone",
"email": "[email protected]"
}''')
result = yield self.account.render(request)
self.assertEqual(result.code, http.OK)
self.assertEqual(type(result.subject), dict)
self.assertEqual(result.headers['content-type'], 'application/json')
self.assertTrue(result.subject['success'])
示例11: test_regsiter_works_when_provided_information_is_valid
# 需要導入模塊: from twisted.python.monkey import MonkeyPatcher [as 別名]
# 或者: from twisted.python.monkey.MonkeyPatcher import patch [as 別名]
def test_regsiter_works_when_provided_information_is_valid(self):
def create(fles):
self.assertEqual(fles.name, "Someone")
self.assertEqual(fles.email, "[email protected]")
monkey_patcher = MonkeyPatcher((user.User, "create", create))
monkey_patcher.patch()
request = self.generate_request(
["/register"],
"""{
"name": "Someone",
"email": "[email protected]"
}""",
)
result = yield self.account.render(request)
self.assertEqual(result.code, http.OK)
self.assertEqual(type(result.subject), dict)
self.assertEqual(result.headers["content-type"], "application/json")
self.assertTrue(result.subject["success"])
示例12: test_unknown_instance_id
# 需要導入模塊: from twisted.python.monkey import MonkeyPatcher [as 別名]
# 或者: from twisted.python.monkey.MonkeyPatcher import patch [as 別名]
def test_unknown_instance_id(self):
"""
``UnknownInstanceID`` is raised if all node UUID lookup mechanisms
fail.
"""
patch = MonkeyPatcher()
# Use non-existent config drive label.
# Mount will fail.
patch.addPatch(
self.api,
'_config_drive_label',
filesystem_label_for_test(self)
)
# Use an unreachable metadata service endpoint address.
# TCP connections will fail.
patch.addPatch(
self.api,
'_metadata_service_endpoint',
find_free_port()
)
self.addCleanup(patch.restore)
patch.patch()
self.assertRaises(UnknownInstanceID, self.api.compute_instance_id)
示例13: test_delete_works_on_valid_credentials
# 需要導入模塊: from twisted.python.monkey import MonkeyPatcher [as 別名]
# 或者: from twisted.python.monkey.MonkeyPatcher import patch [as 別名]
def test_delete_works_on_valid_credentials(self):
from hashlib import sha512
ctuple = namedtuple("named_user", "email key")
user_tuple = ctuple("[email protected]", sha512("key").hexdigest())
def delete(fles, user):
self.assertEqual(user.email, "[email protected]")
self.assertEqual(user, user_tuple)
monkey_patcher = MonkeyPatcher((user.User, "delete", delete))
monkey_patcher.patch()
url = "/delete/key"
request = self.generate_request_and_session(url, auth=lambda: True, uid="73s7b33f")
request.session.user = user_tuple
request.session.expire = lambda: True
result = yield self.account.render(request)
self.assertEqual(result.code, http.OK)
self.assertEqual(result.subject["success"], True)
示例14: __init__
# 需要導入模塊: from twisted.python.monkey import MonkeyPatcher [as 別名]
# 或者: from twisted.python.monkey.MonkeyPatcher import patch [as 別名]
def __init__(self, pool=None, testing=False):
if pool is not None:
self.pool = pool
self.started = False
self.__testing = testing
if not self.zstorm_configured:
provideUtility(global_zstorm, IZStorm)
zstorm = getUtility(IZStorm)
zstorm.set_default_uri('mamba', config.Database().uri)
SQLite.register()
MySQL.register()
PostgreSQL.register()
# MonkeyPatch Storm
if not self.monkey_patched:
monkey_patcher = MonkeyPatcher(
(properties, 'PropertyColumn', PropertyColumnMambaPatch)
)
monkey_patcher.patch()
self.monkey_patched = True
示例15: test_put_reannounceResetsTimer
# 需要導入模塊: from twisted.python.monkey import MonkeyPatcher [as 別名]
# 或者: from twisted.python.monkey.MonkeyPatcher import patch [as 別名]
def test_put_reannounceResetsTimer(self):
# Replace the time function of the datastore module
# so that we can artificially speed up time
monkey_patcher = MonkeyPatcher()
c = clock()
c.set(0)
monkey_patcher.addPatch(datastore, "time", c)
# Replace the peer_timeout to 5 seconds
monkey_patcher.addPatch(constants, "peer_timeout", 5)
monkey_patcher.patch()
# Insert a node and verify it is within the datastore
m = self.datastore(self.reactor)
infohash = 5
expected_peer = ("127.0.0.1", 5151)
m.put(infohash, expected_peer)
peers = m.get(infohash)
# Iterate over a 1 element list
self.assertEquals(1, len(peers))
for peer in peers:
self.assertEqual(expected_peer, peer)
# Change the time and reannounce the peer
# (make sure the cleanup function doesnt
# remove the peer yet)
c.set(4)
m.put(infohash, expected_peer)
peers = m.get(infohash)
self.assertEqual(1, len(peers))
m._cleanup(infohash, expected_peer)
c.set(8)
m._cleanup(infohash, expected_peer)
peers = m.get(infohash)
self.assertEqual(1, len(peers))
c.set(9)
m._cleanup(infohash, expected_peer)
peers = m.get(infohash)
self.assertEqual(0, len(peers))
monkey_patcher.restore()