DR695H | ccff30b | 2017-02-17 18:44:24 -0500 | [diff] [blame] | 1 | *** Settings *** |
Brian Freeman | 19a4d2d | 2018-11-30 13:03:52 -0500 | [diff] [blame] | 2 | Documentation The main interface for interacting with Message router. It handles low level stuff like managing the http request library and message router required fields |
Brian Freeman | ed66ff9 | 2019-05-02 15:30:02 -0500 | [diff] [blame] | 3 | Library RequestsLibrary |
Brian Freeman | ed66ff9 | 2019-05-02 15:30:02 -0500 | [diff] [blame] | 4 | Library DateTime |
| 5 | Library Process |
DR695H | 7aca1a4 | 2019-06-03 17:08:34 -0400 | [diff] [blame] | 6 | Library ONAPLibrary.JSON |
DR695H | 18872bc | 2019-06-13 16:16:52 -0400 | [diff] [blame] | 7 | Library ONAPLibrary.Utilities |
DR695H | 3d12502 | 2019-06-19 20:45:38 -0400 | [diff] [blame] | 8 | Library ONAPLibrary.Templating |
DR695H | ccff30b | 2017-02-17 18:44:24 -0500 | [diff] [blame] | 9 | |
| 10 | Resource global_properties.robot |
| 11 | |
| 12 | *** Variables *** |
| 13 | ${MR_HEALTH_CHECK_PATH} /topics |
Brian Freeman | 19a4d2d | 2018-11-30 13:03:52 -0500 | [diff] [blame] | 14 | ${MR_PUB_HEALTH_CHECK_PATH} /events/TEST_TOPIC |
| 15 | ${MR_SUB_HEALTH_CHECK_PATH} /events/TEST_TOPIC/g1/c4?timeout=5000 |
Brian Freeman | ed66ff9 | 2019-05-02 15:30:02 -0500 | [diff] [blame] | 16 | ${MR_CREATE_TOPIC_PATH} /topics/create |
| 17 | ${MR_UPDATE_ACL_TOPIC_PATH} /topics/TEST_TOPIC_ACL/producers |
Jerry Flood | 8fd592b | 2017-07-29 07:31:50 -0400 | [diff] [blame] | 18 | ${MR_ENDPOINT} ${GLOBAL_MR_SERVER_PROTOCOL}://${GLOBAL_INJECTED_MR_IP_ADDR}:${GLOBAL_MR_SERVER_PORT} |
DR695H | 3d12502 | 2019-06-19 20:45:38 -0400 | [diff] [blame] | 19 | ${MR_PUBLISH_TEMPLATE} mr/mr_publish.jinja |
| 20 | ${MR_PUT_ACL_TEMPLATE} mr/mr_put_acl.jinja |
DR695H | bf5a3a3 | 2017-06-30 13:09:57 -0400 | [diff] [blame] | 21 | |
DR695H | ccff30b | 2017-02-17 18:44:24 -0500 | [diff] [blame] | 22 | |
| 23 | *** Keywords *** |
| 24 | Run MR Health Check |
| 25 | [Documentation] Runs MR Health check |
Jerry Flood | 8fd592b | 2017-07-29 07:31:50 -0400 | [diff] [blame] | 26 | ${resp}= Run MR Get Request ${MR_HEALTH_CHECK_PATH} |
Brian Freeman | 19a4d2d | 2018-11-30 13:03:52 -0500 | [diff] [blame] | 27 | Should Be Equal As Strings ${resp.status_code} 200 |
DR695H | ccff30b | 2017-02-17 18:44:24 -0500 | [diff] [blame] | 28 | Should Contain ${resp.json()} topics |
Jerry Flood | 8fd592b | 2017-07-29 07:31:50 -0400 | [diff] [blame] | 29 | |
Brian Freeman | 19a4d2d | 2018-11-30 13:03:52 -0500 | [diff] [blame] | 30 | Run MR PubSub Health Check |
| 31 | [Documentation] Runs MR PubSub Health check |
Brian Freeman | a8ceb69 | 2019-03-03 09:37:54 -0500 | [diff] [blame] | 32 | #${resp}= Run MR Get Request ${MR_SUB_HEALTH_CHECK_PATH} |
Brian Freeman | 19a4d2d | 2018-11-30 13:03:52 -0500 | [diff] [blame] | 33 | # topic may not be created which is a 400 error |
Brian Freeman | a8ceb69 | 2019-03-03 09:37:54 -0500 | [diff] [blame] | 34 | |
Brian Freeman | 19a4d2d | 2018-11-30 13:03:52 -0500 | [diff] [blame] | 35 | ${resp}= Run MR Post Request ${MR_PUB_HEALTH_CHECK_PATH} |
| 36 | Should Be Equal As Strings ${resp.status_code} 200 |
| 37 | Should Contain ${resp.json()} serverTimeMs Failed to Write Data |
| 38 | ${resp}= Run MR Get Request ${MR_SUB_HEALTH_CHECK_PATH} |
Brian Freeman | a8ceb69 | 2019-03-03 09:37:54 -0500 | [diff] [blame] | 39 | # Always Write twice to catch lost first message |
| 40 | ${resp}= Run MR Post Request ${MR_PUB_HEALTH_CHECK_PATH} |
| 41 | ${resp}= Run MR Get Request ${MR_SUB_HEALTH_CHECK_PATH} |
Brian Freeman | 19a4d2d | 2018-11-30 13:03:52 -0500 | [diff] [blame] | 42 | # ${resp} is an array |
| 43 | Should Be Equal As Strings ${resp.status_code} 200 |
| 44 | Should Contain ${resp.json()[0]} timestamp Failed to Read Data |
| 45 | |
Brian Freeman | ed66ff9 | 2019-05-02 15:30:02 -0500 | [diff] [blame] | 46 | |
| 47 | Run MR Update Topic Acl |
| 48 | [Documentation] Runs MR create topic and update producer credentials |
| 49 | # |
| 50 | # Testing to Delete a Topic: |
| 51 | # /opt/kafka/bin/kafka-topics.sh --zookeeper message-router-zookeeper:2181 --delete --topic <topic_name> |
| 52 | # /opt/kafka/bin/kafka-topics.sh --zookeeper message-router-zookeeper:2181 --delete --topic TEST_TOPIC_ACL |
| 53 | # |
| 54 | # Appears to not care if topic already exists with the POST / PUT method |
| 55 | # |
| 56 | ${dict}= Create Dictionary TOPIC_NAME=TEST_TOPIC_ACL |
DR695H | 3d12502 | 2019-06-19 20:45:38 -0400 | [diff] [blame] | 57 | Create Environment mr ${GLOBAL_TEMPLATE_FOLDER} |
| 58 | ${data}= Apply Template mr ${MR_PUT_ACL_TEMPLATE} ${dict} |
Brian Freeman | ed66ff9 | 2019-05-02 15:30:02 -0500 | [diff] [blame] | 59 | ${resp}= Run MR Auth Post Request ${MR_CREATE_TOPIC_PATH} iPIxkpAMI8qTcQj8 Ehq3WyT4bkif4zwgEbvshGal ${data} |
DR695H | 8e7028b | 2019-07-10 10:13:58 -0400 | [diff] [blame] | 60 | #Log Update Owner for TEST_TOPIC_ACL |
Brian Freeman | ed66ff9 | 2019-05-02 15:30:02 -0500 | [diff] [blame] | 61 | ${resp}= Run MR Auth Put Request ${MR_UPDATE_ACL_TOPIC_PATH}/iPIxkpAMI8qTcQj8 iPIxkpAMI8qTcQj8 Ehq3WyT4bkif4zwgEbvshGal ${data} |
| 62 | Should Be Equal As Strings ${resp.status_code} 200 |
| 63 | |
| 64 | Run MR Auth Post Request |
| 65 | [Documentation] Runs MR Authenticated Post Request |
| 66 | [Arguments] ${data_path} ${id_key} ${secret_key} ${data} |
| 67 | ${current_time}= Get Time |
| 68 | ${time}= Evaluate datetime.datetime.today().replace(tzinfo=pytz.UTC).replace(microsecond=0).isoformat() modules=datetime,pytz |
| 69 | ${command}= Set Variable /bin/echo -n "${time}" | /usr/bin/openssl sha1 -hmac "${secret_key}" -binary | /usr/bin/openssl base64 |
| 70 | ${result}= Run Process ${command} shell=True |
| 71 | ${signature}= Set Variable ${result.stdout} |
| 72 | ${xAuth}= Set Variable ${id_key}:${signature} |
| 73 | ${headers}= Create Dictionary Content-Type=application/json X-CambriaAuth=${xAuth} X-CambriaDate=${time} |
| 74 | ${session}= Create Session mr ${MR_ENDPOINT} |
| 75 | ${resp}= Post Request mr ${data_path} headers=${headers} data=${data} |
| 76 | ${status_string}= Convert To String ${resp.status_code} |
| 77 | Should Match Regexp ${status_string} ^(204|200)$ |
| 78 | Log Received response from message router ${resp.text} |
| 79 | [Return] ${resp} |
| 80 | |
| 81 | |
| 82 | Run MR Auth Put Request |
| 83 | [Documentation] Runs MR Authenticated Put Request |
| 84 | [Arguments] ${data_path} ${id_key} ${secret_key} ${data} |
| 85 | ${current_time}= Get Time |
| 86 | ${time}= Evaluate datetime.datetime.today().replace(tzinfo=pytz.UTC).replace(microsecond=0).isoformat() modules=datetime,pytz |
| 87 | ${command}= Set Variable /bin/echo -n "${time}" | /usr/bin/openssl sha1 -hmac "${secret_key}" -binary | /usr/bin/openssl base64 |
| 88 | ${result}= Run Process ${command} shell=True |
| 89 | ${signature}= Set Variable ${result.stdout} |
| 90 | ${xAuth}= Set Variable ${id_key}:${signature} |
| 91 | ${headers}= Create Dictionary Content-Type=application/json X-CambriaAuth=${xAuth} X-CambriaDate=${time} |
| 92 | ${session}= Create Session mr ${MR_ENDPOINT} |
| 93 | ${resp}= Put Request mr ${data_path} headers=${headers} data=${data} |
| 94 | Should Be Equal As Strings ${resp.status_code} 200 |
| 95 | Log Received response from message router ${resp.text} |
| 96 | [Return] ${resp} |
| 97 | |
DR695H | ccff30b | 2017-02-17 18:44:24 -0500 | [diff] [blame] | 98 | Run MR Get Request |
| 99 | [Documentation] Runs MR Get request |
| 100 | [Arguments] ${data_path} |
Brian Freeman | 19a4d2d | 2018-11-30 13:03:52 -0500 | [diff] [blame] | 101 | ${session}= Create Session mr ${MR_ENDPOINT} |
DR695H | 18872bc | 2019-06-13 16:16:52 -0400 | [diff] [blame] | 102 | ${uuid}= Generate UUID4 |
DR695H | ccff30b | 2017-02-17 18:44:24 -0500 | [diff] [blame] | 103 | ${headers}= Create Dictionary Accept=application/json Content-Type=application/json X-TransactionId=${GLOBAL_APPLICATION_ID}-${uuid} X-FromAppId=${GLOBAL_APPLICATION_ID} |
Brian Freeman | 19a4d2d | 2018-11-30 13:03:52 -0500 | [diff] [blame] | 104 | ${resp}= Get Request mr ${data_path} headers=${headers} |
| 105 | Log Received response from message router ${resp.text} |
| 106 | [Return] ${resp} |
| 107 | |
| 108 | Run MR Post Request |
| 109 | [Documentation] Runs MR Post request |
| 110 | [Arguments] ${data_path} |
| 111 | ${session}= Create Session mr ${MR_ENDPOINT} |
| 112 | ${timestamp}= Get Current Date |
| 113 | ${dict}= Create Dictionary timestamp=${timestamp} |
DR695H | 3d12502 | 2019-06-19 20:45:38 -0400 | [diff] [blame] | 114 | Create Environment mr ${GLOBAL_TEMPLATE_FOLDER} |
| 115 | ${data}= Apply Template mr ${MR_PUBLISH_TEMPLATE} ${dict} |
DR695H | 18872bc | 2019-06-13 16:16:52 -0400 | [diff] [blame] | 116 | ${uuid}= Generate UUID4 |
Brian Freeman | 19a4d2d | 2018-11-30 13:03:52 -0500 | [diff] [blame] | 117 | ${headers}= Create Dictionary Accept=application/json Content-Type=application/json X-TransactionId=${GLOBAL_APPLICATION_ID}-${uuid} X-FromAppId=${GLOBAL_APPLICATION_ID} |
| 118 | ${resp}= Post Request mr ${data_path} data=${data} headers=${headers} |
DR695H | ccff30b | 2017-02-17 18:44:24 -0500 | [diff] [blame] | 119 | Log Received response from message router ${resp.text} |
| 120 | [Return] ${resp} |
| 121 | |