Development of an internal social media platform with personalised dashboards for students
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

test_entities.py 12KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374
  1. from __future__ import absolute_import
  2. import pickle
  3. from kombu import Connection, Exchange, Producer, Queue, binding
  4. from kombu.exceptions import NotBoundError
  5. from kombu.serialization import registry
  6. from .case import Case, Mock, call
  7. from .mocks import Transport
  8. def get_conn():
  9. return Connection(transport=Transport)
  10. class test_binding(Case):
  11. def test_constructor(self):
  12. x = binding(
  13. Exchange('foo'), 'rkey',
  14. arguments={'barg': 'bval'},
  15. unbind_arguments={'uarg': 'uval'},
  16. )
  17. self.assertEqual(x.exchange, Exchange('foo'))
  18. self.assertEqual(x.routing_key, 'rkey')
  19. self.assertDictEqual(x.arguments, {'barg': 'bval'})
  20. self.assertDictEqual(x.unbind_arguments, {'uarg': 'uval'})
  21. def test_declare(self):
  22. chan = get_conn().channel()
  23. x = binding(Exchange('foo'), 'rkey')
  24. x.declare(chan)
  25. self.assertIn('exchange_declare', chan)
  26. def test_declare_no_exchange(self):
  27. chan = get_conn().channel()
  28. x = binding()
  29. x.declare(chan)
  30. self.assertNotIn('exchange_declare', chan)
  31. def test_bind(self):
  32. chan = get_conn().channel()
  33. x = binding(Exchange('foo'))
  34. x.bind(Exchange('bar')(chan))
  35. self.assertIn('exchange_bind', chan)
  36. def test_unbind(self):
  37. chan = get_conn().channel()
  38. x = binding(Exchange('foo'))
  39. x.unbind(Exchange('bar')(chan))
  40. self.assertIn('exchange_unbind', chan)
  41. def test_repr(self):
  42. b = binding(Exchange('foo'), 'rkey')
  43. self.assertIn('foo', repr(b))
  44. self.assertIn('rkey', repr(b))
  45. class test_Exchange(Case):
  46. def test_bound(self):
  47. exchange = Exchange('foo', 'direct')
  48. self.assertFalse(exchange.is_bound)
  49. self.assertIn('<unbound', repr(exchange))
  50. chan = get_conn().channel()
  51. bound = exchange.bind(chan)
  52. self.assertTrue(bound.is_bound)
  53. self.assertIs(bound.channel, chan)
  54. self.assertIn('bound to chan:%r' % (chan.channel_id, ),
  55. repr(bound))
  56. def test_hash(self):
  57. self.assertEqual(hash(Exchange('a')), hash(Exchange('a')))
  58. self.assertNotEqual(hash(Exchange('a')), hash(Exchange('b')))
  59. def test_can_cache_declaration(self):
  60. self.assertTrue(Exchange('a', durable=True).can_cache_declaration)
  61. self.assertTrue(Exchange('a', durable=False).can_cache_declaration)
  62. def test_pickle(self):
  63. e1 = Exchange('foo', 'direct')
  64. e2 = pickle.loads(pickle.dumps(e1))
  65. self.assertEqual(e1, e2)
  66. def test_eq(self):
  67. e1 = Exchange('foo', 'direct')
  68. e2 = Exchange('foo', 'direct')
  69. self.assertEqual(e1, e2)
  70. e3 = Exchange('foo', 'topic')
  71. self.assertNotEqual(e1, e3)
  72. self.assertEqual(e1.__eq__(True), NotImplemented)
  73. def test_revive(self):
  74. exchange = Exchange('foo', 'direct')
  75. conn = get_conn()
  76. chan = conn.channel()
  77. # reviving unbound channel is a noop.
  78. exchange.revive(chan)
  79. self.assertFalse(exchange.is_bound)
  80. self.assertIsNone(exchange._channel)
  81. bound = exchange.bind(chan)
  82. self.assertTrue(bound.is_bound)
  83. self.assertIs(bound.channel, chan)
  84. chan2 = conn.channel()
  85. bound.revive(chan2)
  86. self.assertTrue(bound.is_bound)
  87. self.assertIs(bound._channel, chan2)
  88. def test_assert_is_bound(self):
  89. exchange = Exchange('foo', 'direct')
  90. with self.assertRaises(NotBoundError):
  91. exchange.declare()
  92. conn = get_conn()
  93. chan = conn.channel()
  94. exchange.bind(chan).declare()
  95. self.assertIn('exchange_declare', chan)
  96. def test_set_transient_delivery_mode(self):
  97. exc = Exchange('foo', 'direct', delivery_mode='transient')
  98. self.assertEqual(exc.delivery_mode, Exchange.TRANSIENT_DELIVERY_MODE)
  99. def test_set_passive_mode(self):
  100. exc = Exchange('foo', 'direct', passive=True)
  101. self.assertTrue(exc.passive)
  102. def test_set_persistent_delivery_mode(self):
  103. exc = Exchange('foo', 'direct', delivery_mode='persistent')
  104. self.assertEqual(exc.delivery_mode, Exchange.PERSISTENT_DELIVERY_MODE)
  105. def test_bind_at_instantiation(self):
  106. self.assertTrue(Exchange('foo', channel=get_conn().channel()).is_bound)
  107. def test_create_message(self):
  108. chan = get_conn().channel()
  109. Exchange('foo', channel=chan).Message({'foo': 'bar'})
  110. self.assertIn('prepare_message', chan)
  111. def test_publish(self):
  112. chan = get_conn().channel()
  113. Exchange('foo', channel=chan).publish('the quick brown fox')
  114. self.assertIn('basic_publish', chan)
  115. def test_delete(self):
  116. chan = get_conn().channel()
  117. Exchange('foo', channel=chan).delete()
  118. self.assertIn('exchange_delete', chan)
  119. def test__repr__(self):
  120. b = Exchange('foo', 'topic')
  121. self.assertIn('foo(topic)', repr(b))
  122. self.assertIn('Exchange', repr(b))
  123. def test_bind_to(self):
  124. chan = get_conn().channel()
  125. foo = Exchange('foo', 'topic')
  126. bar = Exchange('bar', 'topic')
  127. foo(chan).bind_to(bar)
  128. self.assertIn('exchange_bind', chan)
  129. def test_bind_to_by_name(self):
  130. chan = get_conn().channel()
  131. foo = Exchange('foo', 'topic')
  132. foo(chan).bind_to('bar')
  133. self.assertIn('exchange_bind', chan)
  134. def test_unbind_from(self):
  135. chan = get_conn().channel()
  136. foo = Exchange('foo', 'topic')
  137. bar = Exchange('bar', 'topic')
  138. foo(chan).unbind_from(bar)
  139. self.assertIn('exchange_unbind', chan)
  140. def test_unbind_from_by_name(self):
  141. chan = get_conn().channel()
  142. foo = Exchange('foo', 'topic')
  143. foo(chan).unbind_from('bar')
  144. self.assertIn('exchange_unbind', chan)
  145. class test_Queue(Case):
  146. def setUp(self):
  147. self.exchange = Exchange('foo', 'direct')
  148. def test_hash(self):
  149. self.assertEqual(hash(Queue('a')), hash(Queue('a')))
  150. self.assertNotEqual(hash(Queue('a')), hash(Queue('b')))
  151. def test_repr_with_bindings(self):
  152. ex = Exchange('foo')
  153. x = Queue('foo', bindings=[ex.binding('A'), ex.binding('B')])
  154. self.assertTrue(repr(x))
  155. def test_anonymous(self):
  156. chan = Mock()
  157. x = Queue(bindings=[binding(Exchange('foo'), 'rkey')])
  158. chan.queue_declare.return_value = 'generated', 0, 0
  159. xx = x(chan)
  160. xx.declare()
  161. self.assertEqual(xx.name, 'generated')
  162. def test_basic_get__accept_disallowed(self):
  163. conn = Connection('memory://')
  164. q = Queue('foo', exchange=self.exchange)
  165. p = Producer(conn)
  166. p.publish(
  167. {'complex': object()},
  168. declare=[q], exchange=self.exchange, serializer='pickle',
  169. )
  170. message = q(conn).get(no_ack=True)
  171. self.assertIsNotNone(message)
  172. with self.assertRaises(q.ContentDisallowed):
  173. message.decode()
  174. def test_basic_get__accept_allowed(self):
  175. conn = Connection('memory://')
  176. q = Queue('foo', exchange=self.exchange)
  177. p = Producer(conn)
  178. p.publish(
  179. {'complex': object()},
  180. declare=[q], exchange=self.exchange, serializer='pickle',
  181. )
  182. message = q(conn).get(accept=['pickle'], no_ack=True)
  183. self.assertIsNotNone(message)
  184. payload = message.decode()
  185. self.assertTrue(payload['complex'])
  186. def test_when_bound_but_no_exchange(self):
  187. q = Queue('a')
  188. q.exchange = None
  189. self.assertIsNone(q.when_bound())
  190. def test_declare_but_no_exchange(self):
  191. q = Queue('a')
  192. q.queue_declare = Mock()
  193. q.queue_bind = Mock()
  194. q.exchange = None
  195. q.declare()
  196. q.queue_declare.assert_called_with(False, passive=False)
  197. def test_bind_to_when_name(self):
  198. chan = Mock()
  199. q = Queue('a')
  200. q(chan).bind_to('ex')
  201. self.assertTrue(chan.queue_bind.called)
  202. def test_get_when_no_m2p(self):
  203. chan = Mock()
  204. q = Queue('a')(chan)
  205. chan.message_to_python = None
  206. self.assertTrue(q.get())
  207. def test_multiple_bindings(self):
  208. chan = Mock()
  209. q = Queue('mul', [
  210. binding(Exchange('mul1'), 'rkey1'),
  211. binding(Exchange('mul2'), 'rkey2'),
  212. binding(Exchange('mul3'), 'rkey3'),
  213. ])
  214. q(chan).declare()
  215. self.assertIn(
  216. call(
  217. nowait=False,
  218. exchange='mul1',
  219. auto_delete=False,
  220. passive=False,
  221. arguments=None,
  222. type='direct',
  223. durable=True,
  224. ),
  225. chan.exchange_declare.call_args_list,
  226. )
  227. def test_can_cache_declaration(self):
  228. self.assertTrue(Queue('a', durable=True).can_cache_declaration)
  229. self.assertTrue(Queue('a', durable=False).can_cache_declaration)
  230. def test_eq(self):
  231. q1 = Queue('xxx', Exchange('xxx', 'direct'), 'xxx')
  232. q2 = Queue('xxx', Exchange('xxx', 'direct'), 'xxx')
  233. self.assertEqual(q1, q2)
  234. self.assertEqual(q1.__eq__(True), NotImplemented)
  235. q3 = Queue('yyy', Exchange('xxx', 'direct'), 'xxx')
  236. self.assertNotEqual(q1, q3)
  237. def test_exclusive_implies_auto_delete(self):
  238. self.assertTrue(
  239. Queue('foo', self.exchange, exclusive=True).auto_delete,
  240. )
  241. def test_binds_at_instantiation(self):
  242. self.assertTrue(Queue('foo', self.exchange,
  243. channel=get_conn().channel()).is_bound)
  244. def test_also_binds_exchange(self):
  245. chan = get_conn().channel()
  246. b = Queue('foo', self.exchange)
  247. self.assertFalse(b.is_bound)
  248. self.assertFalse(b.exchange.is_bound)
  249. b = b.bind(chan)
  250. self.assertTrue(b.is_bound)
  251. self.assertTrue(b.exchange.is_bound)
  252. self.assertIs(b.channel, b.exchange.channel)
  253. self.assertIsNot(b.exchange, self.exchange)
  254. def test_declare(self):
  255. chan = get_conn().channel()
  256. b = Queue('foo', self.exchange, 'foo', channel=chan)
  257. self.assertTrue(b.is_bound)
  258. b.declare()
  259. self.assertIn('exchange_declare', chan)
  260. self.assertIn('queue_declare', chan)
  261. self.assertIn('queue_bind', chan)
  262. def test_get(self):
  263. b = Queue('foo', self.exchange, 'foo', channel=get_conn().channel())
  264. b.get()
  265. self.assertIn('basic_get', b.channel)
  266. def test_purge(self):
  267. b = Queue('foo', self.exchange, 'foo', channel=get_conn().channel())
  268. b.purge()
  269. self.assertIn('queue_purge', b.channel)
  270. def test_consume(self):
  271. b = Queue('foo', self.exchange, 'foo', channel=get_conn().channel())
  272. b.consume('fifafo', None)
  273. self.assertIn('basic_consume', b.channel)
  274. def test_cancel(self):
  275. b = Queue('foo', self.exchange, 'foo', channel=get_conn().channel())
  276. b.cancel('fifafo')
  277. self.assertIn('basic_cancel', b.channel)
  278. def test_delete(self):
  279. b = Queue('foo', self.exchange, 'foo', channel=get_conn().channel())
  280. b.delete()
  281. self.assertIn('queue_delete', b.channel)
  282. def test_queue_unbind(self):
  283. b = Queue('foo', self.exchange, 'foo', channel=get_conn().channel())
  284. b.queue_unbind()
  285. self.assertIn('queue_unbind', b.channel)
  286. def test_as_dict(self):
  287. q = Queue('foo', self.exchange, 'rk')
  288. d = q.as_dict(recurse=True)
  289. self.assertEqual(d['exchange']['name'], self.exchange.name)
  290. def test_queue_dump(self):
  291. b = binding(self.exchange, 'rk')
  292. q = Queue('foo', self.exchange, 'rk', bindings=[b])
  293. d = q.as_dict(recurse=True)
  294. self.assertEqual(d['bindings'][0]['routing_key'], 'rk')
  295. registry.dumps(d)
  296. def test__repr__(self):
  297. b = Queue('foo', self.exchange, 'foo')
  298. self.assertIn('foo', repr(b))
  299. self.assertIn('Queue', repr(b))