You Wang | aabb283 | 2017-11-16 17:24:09 -0800 | [diff] [blame] | 1 | # Copyright 2017-present Radisys Corporation |
| 2 | # |
| 3 | # Licensed under the Apache License, Version 2.0 (the "License"); |
| 4 | # you may not use this file except in compliance with the License. |
| 5 | # You may obtain a copy of the License at |
| 6 | # |
| 7 | # http://www.apache.org/licenses/LICENSE-2.0 |
| 8 | # |
| 9 | # Unless required by applicable law or agreed to in writing, software |
| 10 | # distributed under the License is distributed on an "AS IS" BASIS, |
| 11 | # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 12 | # See the License for the specific language governing permissions and |
| 13 | # limitations under the License. |
| 14 | |
You Wang | 0991196 | 2018-02-09 15:34:06 -0800 | [diff] [blame] | 15 | # NOTE: `make collect-diag` command needs to be executed on the head-node |
| 16 | # before running this test |
You Wang | aabb283 | 2017-11-16 17:24:09 -0800 | [diff] [blame] | 17 | |
| 18 | *** Settings *** |
| 19 | Documentation Test suite for checking results collected by `make collect-diag` command |
| 20 | Library OperatingSystem |
| 21 | Library ../cord-api/Framework/utils/onosUtils.py |
| 22 | Library ../cord-api/Framework/utils/utils.py |
| 23 | Resource ../cord-api/Framework/utils/utils.robot |
| 24 | |
| 25 | *** Variables *** |
| 26 | ${DOCKER_CONTAINERS_FILE} ${CURDIR}/dockerContainers.json |
| 27 | ${ONOS_APPS_FILE} ${CURDIR}/onosApps.json |
| 28 | ${CORD_PROFILE} rcord |
| 29 | ${CORD_SCENARIO} cord |
| 30 | |
| 31 | *** Test Cases *** |
| 32 | Verify Docker Containers |
| 33 | [Documentation] Verify expected containers are up and running |
| 34 | ${dockerContainersExpected} utils.jsonToList ${DOCKER_CONTAINERS_FILE} docker-containers-${CORD_PROFILE} |
| 35 | : FOR ${container} IN @{dockerContainersExpected} |
You Wang | 046fa86 | 2017-11-21 13:13:26 -0800 | [diff] [blame] | 36 | \ Run Keyword And Continue On Failure Verify Docker Container ${container} |
You Wang | aabb283 | 2017-11-16 17:24:09 -0800 | [diff] [blame] | 37 | |
| 38 | Verify Synchronizer Logs |
| 39 | [Documentation] Verify synchronizer logs are correct |
You Wang | dc60493 | 2018-02-09 17:21:29 -0800 | [diff] [blame] | 40 | ${latestDiag}= Run ls -1t /home/cord | head -1 |
| 41 | ${synchronizerLogs} utils.readFiles /home/cord/${latestDiag}/docker/*synchronizer*.logs |
You Wang | aabb283 | 2017-11-16 17:24:09 -0800 | [diff] [blame] | 42 | : FOR ${key} IN @{synchronizerLogs.keys()} |
You Wang | 0894ffa | 2017-11-30 23:00:59 -0800 | [diff] [blame] | 43 | \ @{name}= Split String ${key} -synchronizer |
| 44 | \ @{name}= Split String From Right @{name}[0] _ 1 |
You Wang | 046fa86 | 2017-11-21 13:13:26 -0800 | [diff] [blame] | 45 | \ ${synchronizerLog}= Get From Dictionary ${synchronizerLogs} ${key} |
You Wang | f89c8e7 | 2017-12-05 13:06:46 -0800 | [diff] [blame] | 46 | \ Run Keyword And Continue On Failure Verify Synchronizer Log ${name} ${synchronizerLog} |
You Wang | aabb283 | 2017-11-16 17:24:09 -0800 | [diff] [blame] | 47 | |
| 48 | Verify ONOS |
| 49 | [Documentation] Verify ONOS status, applications and logs |
You Wang | d65eb85 | 2017-11-20 15:04:32 -0800 | [diff] [blame] | 50 | Run Keyword If '${CORD_PROFILE}' != 'ecord-global' Verify ONOS-Fabric ${CORD_PROFILE} |
| 51 | Verify ONOS-CORD ${CORD_PROFILE} |
You Wang | aabb283 | 2017-11-16 17:24:09 -0800 | [diff] [blame] | 52 | |
| 53 | *** Keywords *** |
You Wang | 046fa86 | 2017-11-21 13:13:26 -0800 | [diff] [blame] | 54 | Verify Docker Container |
| 55 | [Arguments] ${container} |
Kailash Khalasi | 71ee323 | 2018-01-16 15:20:45 -0800 | [diff] [blame] | 56 | OperatingSystem.File Should Exist /home/cord/diag-*/docker/${container}.logs |
You Wang | 046fa86 | 2017-11-21 13:13:26 -0800 | [diff] [blame] | 57 | |
| 58 | Verify Synchronizer Log |
You Wang | f89c8e7 | 2017-12-05 13:06:46 -0800 | [diff] [blame] | 59 | [Arguments] ${name} ${log} |
You Wang | f35df4a | 2018-01-24 11:00:58 -0800 | [diff] [blame] | 60 | ${config} utils.readFile /opt/cord/orchestration/*/*/xos/synchronizer/@{name}[1]_config.yaml |
You Wang | 4c09fae | 2017-12-06 13:30:34 -0800 | [diff] [blame] | 61 | ${match1}= Get Lines Matching Regexp ${config} ^steps_dir: ".*"$ |
| 62 | ${match2}= Get Lines Matching Regexp ${config} ^model_policies_dir: ".*"$ |
| 63 | Run Keyword If '${match1}' != '${EMPTY}' Should Contain ${log} Waiting for event or timeout msg= "Waiting for event or timeout" not found in @{name}[1] synchronizer log |
| 64 | ... ELSE IF '${match2}' != '${EMPTY}' Should Contain ${log} Loaded model policies msg= "Loaded model policies" not found in @{name}[1] synchronizer log |
You Wang | 046fa86 | 2017-11-21 13:13:26 -0800 | [diff] [blame] | 65 | |
You Wang | d65eb85 | 2017-11-20 15:04:32 -0800 | [diff] [blame] | 66 | Verify ONOS-Fabric |
| 67 | [Arguments] ${cord_profile} |
You Wang | 046fa86 | 2017-11-21 13:13:26 -0800 | [diff] [blame] | 68 | Run Keyword And Continue On Failure Verify ONOS Status onos-fabric |
| 69 | Run Keyword And Continue On Failure Verify ONOS Applications onos-fabric ${cord_profile} |
| 70 | Run Keyword And Continue On Failure Verify ONOS Log onos-fabric |
You Wang | d65eb85 | 2017-11-20 15:04:32 -0800 | [diff] [blame] | 71 | |
| 72 | Verify ONOS-CORD |
| 73 | [Arguments] ${cord_profile} |
You Wang | 046fa86 | 2017-11-21 13:13:26 -0800 | [diff] [blame] | 74 | Run Keyword And Continue On Failure Verify ONOS Status onos-cord |
| 75 | Run Keyword And Continue On Failure Verify ONOS Applications onos-cord ${cord_profile} |
| 76 | Run Keyword And Continue On Failure Verify ONOS Log onos-cord |
You Wang | d65eb85 | 2017-11-20 15:04:32 -0800 | [diff] [blame] | 77 | |
You Wang | aabb283 | 2017-11-16 17:24:09 -0800 | [diff] [blame] | 78 | Verify ONOS Status |
| 79 | [Arguments] ${onosName} |
| 80 | ${onosStatus} utils.readFile /home/cord/diag-*/${onosName}/nodes |
| 81 | Should Contain ${onosStatus} READY |
| 82 | |
| 83 | Verify ONOS Applications |
| 84 | [Arguments] ${onosName} ${cordProfile} |
| 85 | ${onosAppsExpected} utils.jsonToList ${ONOS_APPS_FILE} ${onosName}-${cordProfile} |
| 86 | ${onosApps} utils.readFile /home/cord/diag-*/${onosName}/apps_-s_-a |
| 87 | : FOR ${app} IN @{onosAppsExpected} |
| 88 | \ Should Contain ${onosApps} ${app} |
| 89 | |
You Wang | 046fa86 | 2017-11-21 13:13:26 -0800 | [diff] [blame] | 90 | Verify ONOS Log |
You Wang | aabb283 | 2017-11-16 17:24:09 -0800 | [diff] [blame] | 91 | [Arguments] ${onosName} |
| 92 | ${onosLog} utils.readFile /home/cord/diag-*/${onosName}/log_display |
| 93 | Should Not Contain ${onosLog} ERROR |