1 # ==================================================================================
2 # Copyright (c) 2019 Nokia
3 # Copyright (c) 2018-2019 AT&T Intellectual Property.
5 # Licensed under the Apache License, Version 2.0 (the "License");
6 # you may not use this file except in compliance with the License.
7 # You may obtain a copy of the License at
9 # http://www.apache.org/licenses/LICENSE-2.0
11 # Unless required by applicable law or agreed to in writing, software
12 # distributed under the License is distributed on an "AS IS" BASIS,
13 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 # See the License for the specific language governing permissions and
15 # limitations under the License.
16 # ==================================================================================
26 PORT = os.environ.get("TEST_RCV_PORT", "4560")
27 DELAY = int(os.environ.get("TEST_RCV_SEC_DELAY", 0))
28 HANDLER_ID = os.environ.get("HANDLER_ID", "test_receiver")
30 mrc = rmr.rmr_init(PORT.encode("utf-8"), rmr.RMR_MAX_RCV_BYTES, rmr.RMRFL_MTCALL)
32 while rmr.rmr_ready(mrc) == 0:
34 print("not yet ready")
36 print("listening ON {}".format(PORT))
38 sbuf = rmr.rmr_alloc_msg(mrc, 10)
39 sbuf = rmr.rmr_torcv_msg(mrc, sbuf, 1000)
40 summary = rmr.message_summary(sbuf)
41 if summary["message state"] == 12 and summary["message status"] == "RMR_ERR_TIMEOUT":
42 # print("Nothing received yet")
45 print("Message received!: {}".format(summary))
47 received_payload = json.loads(summary["payload"])
49 op = received_payload["operation"]
50 send_payload_status = "ERROR"
52 send_payload_status = "OK"
54 send_payload_status = "DELETED"
57 "policy_type_id": received_payload["policy_type_id"],
58 "policy_instance_id": received_payload["policy_instance_id"],
59 "handler_id": HANDLER_ID,
60 "status": send_payload_status,
63 val = json.dumps(payload).encode("utf-8")
64 rmr.set_payload_and_length(val, sbuf)
65 sbuf.contents.mtype = 20011
66 print("Pre reply summary: {}".format(rmr.message_summary(sbuf)))
69 # try up to 5 times to send back the ack
71 sbuf = rmr.rmr_rts_msg(mrc, sbuf)
72 post_reply_summary = rmr.message_summary(sbuf)
73 print("Post reply summary: {}".format(post_reply_summary))
74 if post_reply_summary["message state"] == 10 and post_reply_summary["message status"] == "RMR_ERR_RETRY":