Can't catch events with ActiveMQ listener on Pytest












2















I'm trying to write a test case to see if my action is being transmitted into ActiveMQ topic.
I check my code outside of pytest, somehow code runs smoothly and I can see my message generated an event on ActiveMQ topic. But If I run it inside pytest case, I can't catch the events. I can't seem to find a reason. We are setting the receiver but we don't get header list if we use pytest. Outside pytest works fine.



Version without pytest:



import messenger
import client
import time
import amq_client as aq

lst=aq.MyListener(aq.conn)
aq.conn.set_listener('', lst)
aq.conn.start()
aq.conn.connect(login=aq.user, passcode=aq.password)
aq.conn.subscribe(destination=aq.destination, ack='auto', id=1234)
print("Waiting for messages...")

resp=messenger.Messenger().send_message()
print(resp)
lognum=resp[1].split("=")[1]
time.sleep(10)

actions = [x['ENTITY_ACTION'] for x in lst.header_list]
accounts = [x['ACCOUNT'] for x in lst.header_list]

print('actions ', actions)
print(' ')
print(' ')
print(' ')
print(' ')
print('ACCOUNTS', accounts)


if(str(lognum) in accounts and 'NEW_ACCOUNT' in actions ):
print('By this it WORKS')


Output:



actions ['NEW_ACCOUNT', 'ACCOUNT_GROUP_CHANGED']




ACCOUNTS ['720308353', '720308353']
By this it WORKS


Pytest version:



import pytest
import messenger
import amq_client as aq
import time

class Test_AmqTestCase(object):

def test_newaccount(self):
lst=aq.MyListener(aq.conn)
aq.conn.set_listener('', lst)
aq.conn.start()
aq.conn.connect(login=aq.user, passcode=aq.password)
aq.conn.subscribe(destination=aq.destination, ack='auto', id=1234)
print("Waiting for messages...")

resp=messenger.Messenger().send_message()
print(resp)
lognum=resp[1].split("=")[1]

t_end=time.time()+30
t_start=time.time()
while time.time() < t_end:
time.sleep(1)
t_total=time.time()-t_start

print('Total time for event occur :', t_total)
print(' ')

actions = [x['ENTITY_ACTION'] for x in lst.header_list]
accounts = [x['ACCOUNT'] for x in lst.header_list]

print('ACCOUNTS', accounts)
assert (str(lognum) in accounts and 'NEW_ACCOUNT' in actions)


pytest result:



assert (str(lognum) in accounts and 'NEW_ACCOUNT' in actions)
E AssertionError: assert ('720308351' in )
E + where '720308351' = str('720308351')

Test_AmqCase.py:33: AssertionError
---------------------------- Captured stdout call -----------------------------
Waiting for messages...
['OK', 'LOGIN=720308351', 'end', '']
Total time for event occur : 30.017589569091797

ACCOUNTS









share|improve this question























  • Did you try the Pytest version on a fresh topic? If not, can you try and check if you get the same issue?

    – Samarth
    Nov 26 '18 at 17:11











  • On fresh topic, pytest doesn't read as well. I can't get header or message body if I run it inside pytest.

    – AlperenK
    Nov 28 '18 at 6:29
















2















I'm trying to write a test case to see if my action is being transmitted into ActiveMQ topic.
I check my code outside of pytest, somehow code runs smoothly and I can see my message generated an event on ActiveMQ topic. But If I run it inside pytest case, I can't catch the events. I can't seem to find a reason. We are setting the receiver but we don't get header list if we use pytest. Outside pytest works fine.



Version without pytest:



import messenger
import client
import time
import amq_client as aq

lst=aq.MyListener(aq.conn)
aq.conn.set_listener('', lst)
aq.conn.start()
aq.conn.connect(login=aq.user, passcode=aq.password)
aq.conn.subscribe(destination=aq.destination, ack='auto', id=1234)
print("Waiting for messages...")

resp=messenger.Messenger().send_message()
print(resp)
lognum=resp[1].split("=")[1]
time.sleep(10)

actions = [x['ENTITY_ACTION'] for x in lst.header_list]
accounts = [x['ACCOUNT'] for x in lst.header_list]

print('actions ', actions)
print(' ')
print(' ')
print(' ')
print(' ')
print('ACCOUNTS', accounts)


if(str(lognum) in accounts and 'NEW_ACCOUNT' in actions ):
print('By this it WORKS')


Output:



actions ['NEW_ACCOUNT', 'ACCOUNT_GROUP_CHANGED']




ACCOUNTS ['720308353', '720308353']
By this it WORKS


Pytest version:



import pytest
import messenger
import amq_client as aq
import time

class Test_AmqTestCase(object):

def test_newaccount(self):
lst=aq.MyListener(aq.conn)
aq.conn.set_listener('', lst)
aq.conn.start()
aq.conn.connect(login=aq.user, passcode=aq.password)
aq.conn.subscribe(destination=aq.destination, ack='auto', id=1234)
print("Waiting for messages...")

resp=messenger.Messenger().send_message()
print(resp)
lognum=resp[1].split("=")[1]

t_end=time.time()+30
t_start=time.time()
while time.time() < t_end:
time.sleep(1)
t_total=time.time()-t_start

print('Total time for event occur :', t_total)
print(' ')

actions = [x['ENTITY_ACTION'] for x in lst.header_list]
accounts = [x['ACCOUNT'] for x in lst.header_list]

print('ACCOUNTS', accounts)
assert (str(lognum) in accounts and 'NEW_ACCOUNT' in actions)


pytest result:



assert (str(lognum) in accounts and 'NEW_ACCOUNT' in actions)
E AssertionError: assert ('720308351' in )
E + where '720308351' = str('720308351')

Test_AmqCase.py:33: AssertionError
---------------------------- Captured stdout call -----------------------------
Waiting for messages...
['OK', 'LOGIN=720308351', 'end', '']
Total time for event occur : 30.017589569091797

ACCOUNTS









share|improve this question























  • Did you try the Pytest version on a fresh topic? If not, can you try and check if you get the same issue?

    – Samarth
    Nov 26 '18 at 17:11











  • On fresh topic, pytest doesn't read as well. I can't get header or message body if I run it inside pytest.

    – AlperenK
    Nov 28 '18 at 6:29














2












2








2








I'm trying to write a test case to see if my action is being transmitted into ActiveMQ topic.
I check my code outside of pytest, somehow code runs smoothly and I can see my message generated an event on ActiveMQ topic. But If I run it inside pytest case, I can't catch the events. I can't seem to find a reason. We are setting the receiver but we don't get header list if we use pytest. Outside pytest works fine.



Version without pytest:



import messenger
import client
import time
import amq_client as aq

lst=aq.MyListener(aq.conn)
aq.conn.set_listener('', lst)
aq.conn.start()
aq.conn.connect(login=aq.user, passcode=aq.password)
aq.conn.subscribe(destination=aq.destination, ack='auto', id=1234)
print("Waiting for messages...")

resp=messenger.Messenger().send_message()
print(resp)
lognum=resp[1].split("=")[1]
time.sleep(10)

actions = [x['ENTITY_ACTION'] for x in lst.header_list]
accounts = [x['ACCOUNT'] for x in lst.header_list]

print('actions ', actions)
print(' ')
print(' ')
print(' ')
print(' ')
print('ACCOUNTS', accounts)


if(str(lognum) in accounts and 'NEW_ACCOUNT' in actions ):
print('By this it WORKS')


Output:



actions ['NEW_ACCOUNT', 'ACCOUNT_GROUP_CHANGED']




ACCOUNTS ['720308353', '720308353']
By this it WORKS


Pytest version:



import pytest
import messenger
import amq_client as aq
import time

class Test_AmqTestCase(object):

def test_newaccount(self):
lst=aq.MyListener(aq.conn)
aq.conn.set_listener('', lst)
aq.conn.start()
aq.conn.connect(login=aq.user, passcode=aq.password)
aq.conn.subscribe(destination=aq.destination, ack='auto', id=1234)
print("Waiting for messages...")

resp=messenger.Messenger().send_message()
print(resp)
lognum=resp[1].split("=")[1]

t_end=time.time()+30
t_start=time.time()
while time.time() < t_end:
time.sleep(1)
t_total=time.time()-t_start

print('Total time for event occur :', t_total)
print(' ')

actions = [x['ENTITY_ACTION'] for x in lst.header_list]
accounts = [x['ACCOUNT'] for x in lst.header_list]

print('ACCOUNTS', accounts)
assert (str(lognum) in accounts and 'NEW_ACCOUNT' in actions)


pytest result:



assert (str(lognum) in accounts and 'NEW_ACCOUNT' in actions)
E AssertionError: assert ('720308351' in )
E + where '720308351' = str('720308351')

Test_AmqCase.py:33: AssertionError
---------------------------- Captured stdout call -----------------------------
Waiting for messages...
['OK', 'LOGIN=720308351', 'end', '']
Total time for event occur : 30.017589569091797

ACCOUNTS









share|improve this question














I'm trying to write a test case to see if my action is being transmitted into ActiveMQ topic.
I check my code outside of pytest, somehow code runs smoothly and I can see my message generated an event on ActiveMQ topic. But If I run it inside pytest case, I can't catch the events. I can't seem to find a reason. We are setting the receiver but we don't get header list if we use pytest. Outside pytest works fine.



Version without pytest:



import messenger
import client
import time
import amq_client as aq

lst=aq.MyListener(aq.conn)
aq.conn.set_listener('', lst)
aq.conn.start()
aq.conn.connect(login=aq.user, passcode=aq.password)
aq.conn.subscribe(destination=aq.destination, ack='auto', id=1234)
print("Waiting for messages...")

resp=messenger.Messenger().send_message()
print(resp)
lognum=resp[1].split("=")[1]
time.sleep(10)

actions = [x['ENTITY_ACTION'] for x in lst.header_list]
accounts = [x['ACCOUNT'] for x in lst.header_list]

print('actions ', actions)
print(' ')
print(' ')
print(' ')
print(' ')
print('ACCOUNTS', accounts)


if(str(lognum) in accounts and 'NEW_ACCOUNT' in actions ):
print('By this it WORKS')


Output:



actions ['NEW_ACCOUNT', 'ACCOUNT_GROUP_CHANGED']




ACCOUNTS ['720308353', '720308353']
By this it WORKS


Pytest version:



import pytest
import messenger
import amq_client as aq
import time

class Test_AmqTestCase(object):

def test_newaccount(self):
lst=aq.MyListener(aq.conn)
aq.conn.set_listener('', lst)
aq.conn.start()
aq.conn.connect(login=aq.user, passcode=aq.password)
aq.conn.subscribe(destination=aq.destination, ack='auto', id=1234)
print("Waiting for messages...")

resp=messenger.Messenger().send_message()
print(resp)
lognum=resp[1].split("=")[1]

t_end=time.time()+30
t_start=time.time()
while time.time() < t_end:
time.sleep(1)
t_total=time.time()-t_start

print('Total time for event occur :', t_total)
print(' ')

actions = [x['ENTITY_ACTION'] for x in lst.header_list]
accounts = [x['ACCOUNT'] for x in lst.header_list]

print('ACCOUNTS', accounts)
assert (str(lognum) in accounts and 'NEW_ACCOUNT' in actions)


pytest result:



assert (str(lognum) in accounts and 'NEW_ACCOUNT' in actions)
E AssertionError: assert ('720308351' in )
E + where '720308351' = str('720308351')

Test_AmqCase.py:33: AssertionError
---------------------------- Captured stdout call -----------------------------
Waiting for messages...
['OK', 'LOGIN=720308351', 'end', '']
Total time for event occur : 30.017589569091797

ACCOUNTS






python activemq pytest






share|improve this question













share|improve this question











share|improve this question




share|improve this question










asked Nov 26 '18 at 13:35









AlperenKAlperenK

111




111













  • Did you try the Pytest version on a fresh topic? If not, can you try and check if you get the same issue?

    – Samarth
    Nov 26 '18 at 17:11











  • On fresh topic, pytest doesn't read as well. I can't get header or message body if I run it inside pytest.

    – AlperenK
    Nov 28 '18 at 6:29



















  • Did you try the Pytest version on a fresh topic? If not, can you try and check if you get the same issue?

    – Samarth
    Nov 26 '18 at 17:11











  • On fresh topic, pytest doesn't read as well. I can't get header or message body if I run it inside pytest.

    – AlperenK
    Nov 28 '18 at 6:29

















Did you try the Pytest version on a fresh topic? If not, can you try and check if you get the same issue?

– Samarth
Nov 26 '18 at 17:11





Did you try the Pytest version on a fresh topic? If not, can you try and check if you get the same issue?

– Samarth
Nov 26 '18 at 17:11













On fresh topic, pytest doesn't read as well. I can't get header or message body if I run it inside pytest.

– AlperenK
Nov 28 '18 at 6:29





On fresh topic, pytest doesn't read as well. I can't get header or message body if I run it inside pytest.

– AlperenK
Nov 28 '18 at 6:29












0






active

oldest

votes











Your Answer






StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");

StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "1"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);

StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});

function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});


}
});














draft saved

draft discarded


















StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53482307%2fcant-catch-events-with-activemq-listener-on-pytest%23new-answer', 'question_page');
}
);

Post as a guest















Required, but never shown

























0






active

oldest

votes








0






active

oldest

votes









active

oldest

votes






active

oldest

votes
















draft saved

draft discarded




















































Thanks for contributing an answer to Stack Overflow!


  • Please be sure to answer the question. Provide details and share your research!

But avoid



  • Asking for help, clarification, or responding to other answers.

  • Making statements based on opinion; back them up with references or personal experience.


To learn more, see our tips on writing great answers.




draft saved


draft discarded














StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53482307%2fcant-catch-events-with-activemq-listener-on-pytest%23new-answer', 'question_page');
}
);

Post as a guest















Required, but never shown





















































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown

































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown







Popular posts from this blog

A CLEAN and SIMPLE way to add appendices to Table of Contents and bookmarks

Calculate evaluation metrics using cross_val_predict sklearn

Insert data from modal to MySQL (multiple modal on website)