Commit 1d9e5c85a853592e96fb89d4e901ccc71e91ce49
1 parent
0ef2974b
Modify Отримати останній індекс keyword
Showing
4 changed files
with
1072 additions
and
24 deletions
| @@ -46,7 +46,7 @@ ${MOZ_INTEGRATION} ${False} | @@ -46,7 +46,7 @@ ${MOZ_INTEGRATION} ${False} | ||
| 46 | ... ${USERS.users['${viewer}'].broker} | 46 | ... ${USERS.users['${viewer}'].broker} |
| 47 | ... lot_cancellation | 47 | ... lot_cancellation |
| 48 | [Setup] Дочекатись синхронізації з майданчиком ${viewer} | 48 | [Setup] Дочекатись синхронізації з майданчиком ${viewer} |
| 49 | - ${cancellation_index}= Отримати останній індекс cancellations ${viewer} | 49 | + ${cancellation_index}= Отримати останній індекс cancellations ${tender_owner} ${viewer} |
| 50 | Звірити поле тендера із значенням ${viewer} ${TENDER['TENDER_UAID']} | 50 | Звірити поле тендера із значенням ${viewer} ${TENDER['TENDER_UAID']} |
| 51 | ... active | 51 | ... active |
| 52 | ... cancellations[${cancellation_index}].status | 52 | ... cancellations[${cancellation_index}].status |
| @@ -57,7 +57,7 @@ ${MOZ_INTEGRATION} ${False} | @@ -57,7 +57,7 @@ ${MOZ_INTEGRATION} ${False} | ||
| 57 | ... viewer | 57 | ... viewer |
| 58 | ... ${USERS.users['${viewer}'].broker} | 58 | ... ${USERS.users['${viewer}'].broker} |
| 59 | ... lot_cancellation | 59 | ... lot_cancellation |
| 60 | - ${cancellation_index}= Отримати останній індекс cancellations ${viewer} | 60 | + ${cancellation_index}= Отримати останній індекс cancellations ${tender_owner} ${viewer} |
| 61 | Звірити поле тендера із значенням ${viewer} ${TENDER['TENDER_UAID']} | 61 | Звірити поле тендера із значенням ${viewer} ${TENDER['TENDER_UAID']} |
| 62 | ... ${USERS.users['${tender_owner}']['lot_cancellation_data']['cancellation_reason']} | 62 | ... ${USERS.users['${tender_owner}']['lot_cancellation_data']['cancellation_reason']} |
| 63 | ... cancellations[${cancellation_index}].reason | 63 | ... cancellations[${cancellation_index}].reason |
| @@ -105,7 +105,7 @@ ${MOZ_INTEGRATION} ${False} | @@ -105,7 +105,7 @@ ${MOZ_INTEGRATION} ${False} | ||
| 105 | ... ${USERS.users['${viewer}'].broker} | 105 | ... ${USERS.users['${viewer}'].broker} |
| 106 | ... tender_cancellation | 106 | ... tender_cancellation |
| 107 | [Setup] Дочекатись синхронізації з майданчиком ${viewer} | 107 | [Setup] Дочекатись синхронізації з майданчиком ${viewer} |
| 108 | - ${cancellation_index}= Отримати останній індекс cancellations ${viewer} | 108 | + ${cancellation_index}= Отримати останній індекс cancellations ${tender_owner} ${viewer} |
| 109 | Звірити поле тендера із значенням ${viewer} ${TENDER['TENDER_UAID']} | 109 | Звірити поле тендера із значенням ${viewer} ${TENDER['TENDER_UAID']} |
| 110 | ... active | 110 | ... active |
| 111 | ... cancellations[${cancellation_index}].status | 111 | ... cancellations[${cancellation_index}].status |
| @@ -116,7 +116,7 @@ ${MOZ_INTEGRATION} ${False} | @@ -116,7 +116,7 @@ ${MOZ_INTEGRATION} ${False} | ||
| 116 | ... viewer | 116 | ... viewer |
| 117 | ... ${USERS.users['${viewer}'].broker} | 117 | ... ${USERS.users['${viewer}'].broker} |
| 118 | ... tender_cancellation | 118 | ... tender_cancellation |
| 119 | - ${cancellation_index}= Отримати останній індекс cancellations ${viewer} | 119 | + ${cancellation_index}= Отримати останній індекс cancellations ${tender_owner} ${viewer} |
| 120 | Звірити поле тендера із значенням ${viewer} ${TENDER['TENDER_UAID']} | 120 | Звірити поле тендера із значенням ${viewer} ${TENDER['TENDER_UAID']} |
| 121 | ... ${USERS.users['${tender_owner}']['tender_cancellation_data']['cancellation_reason']} | 121 | ... ${USERS.users['${tender_owner}']['tender_cancellation_data']['cancellation_reason']} |
| 122 | ... cancellations[${cancellation_index}].reason | 122 | ... cancellations[${cancellation_index}].reason |
| @@ -27,7 +27,8 @@ Suite Teardown Test Suite Teardown | @@ -27,7 +27,8 @@ Suite Teardown Test Suite Teardown | ||
| 27 | ... tender_owner | 27 | ... tender_owner |
| 28 | ... ${USERS.users['${tender_owner}'].broker} | 28 | ... ${USERS.users['${tender_owner}'].broker} |
| 29 | ... tender_view | 29 | ... tender_view |
| 30 | - ${award_index}= Отримати останній індекс awards ${viewer} | 30 | + ... critical |
| 31 | + ${award_index}= Отримати останній індекс awards ${tender_owner} ${viewer} | ||
| 31 | :FOR ${username} IN ${viewer} ${tender_owner} | 32 | :FOR ${username} IN ${viewer} ${tender_owner} |
| 32 | \ Отримати дані із тендера ${username} ${TENDER['TENDER_UAID']} awards[${award_index}].complaintPeriod.endDate | 33 | \ Отримати дані із тендера ${username} ${TENDER['TENDER_UAID']} awards[${award_index}].complaintPeriod.endDate |
| 33 | 34 | ||
| @@ -37,7 +38,8 @@ Suite Teardown Test Suite Teardown | @@ -37,7 +38,8 @@ Suite Teardown Test Suite Teardown | ||
| 37 | ... tender_owner | 38 | ... tender_owner |
| 38 | ... ${USERS.users['${tender_owner}'].broker} | 39 | ... ${USERS.users['${tender_owner}'].broker} |
| 39 | ... contract_sign | 40 | ... contract_sign |
| 40 | - ${award_index}= Отримати останній індекс awards ${viewer} | 41 | + ... critical |
| 42 | + ${award_index}= Отримати останній індекс awards ${tender_owner} ${viewer} | ||
| 41 | ${standstillEnd}= Get Variable Value ${USERS.users['${tender_owner}'].tender_data.data.awards[${award_index}].complaintPeriod.endDate} | 43 | ${standstillEnd}= Get Variable Value ${USERS.users['${tender_owner}'].tender_data.data.awards[${award_index}].complaintPeriod.endDate} |
| 42 | Дочекатись дати ${standstillEnd} | 44 | Дочекатись дати ${standstillEnd} |
| 43 | 45 | ||
| @@ -48,7 +50,7 @@ Suite Teardown Test Suite Teardown | @@ -48,7 +50,7 @@ Suite Teardown Test Suite Teardown | ||
| 48 | ... ${USERS.users['${viewer}'].broker} | 50 | ... ${USERS.users['${viewer}'].broker} |
| 49 | ... contract_view | 51 | ... contract_view |
| 50 | [Setup] Дочекатись синхронізації з майданчиком ${viewer} | 52 | [Setup] Дочекатись синхронізації з майданчиком ${viewer} |
| 51 | - ${award_index}= Отримати останній індекс awards ${viewer} | 53 | + ${award_index}= Отримати останній індекс awards ${tender_owner} ${viewer} |
| 52 | Отримати дані із поля awards[${award_index}].value.amount тендера для користувача ${viewer} | 54 | Отримати дані із поля awards[${award_index}].value.amount тендера для користувача ${viewer} |
| 53 | 55 | ||
| 54 | 56 | ||
| @@ -59,8 +61,8 @@ Suite Teardown Test Suite Teardown | @@ -59,8 +61,8 @@ Suite Teardown Test Suite Teardown | ||
| 59 | ... modify_contract | 61 | ... modify_contract |
| 60 | [Setup] Дочекатись синхронізації з майданчиком ${tender_owner} | 62 | [Setup] Дочекатись синхронізації з майданчиком ${tender_owner} |
| 61 | [Teardown] Оновити LAST_MODIFICATION_DATE | 63 | [Teardown] Оновити LAST_MODIFICATION_DATE |
| 62 | - ${award_index}= Отримати останній індекс awards ${viewer} | ||
| 63 | - ${contract_index}= Отримати останній індекс contracts ${viewer} | 64 | + ${award_index}= Отримати останній індекс awards ${tender_owner} ${viewer} |
| 65 | + ${contract_index}= Отримати останній індекс contracts ${tender_owner} ${viewer} | ||
| 64 | ${award_amount}= Get From Dictionary ${USERS.users['${viewer}'].tender_data.data.awards[${award_index}].value} amount | 66 | ${award_amount}= Get From Dictionary ${USERS.users['${viewer}'].tender_data.data.awards[${award_index}].value} amount |
| 65 | ${amount}= create_fake_amount ${award_amount} | 67 | ${amount}= create_fake_amount ${award_amount} |
| 66 | Set to dictionary ${USERS.users['${tender_owner}']} new_amount=${amount} | 68 | Set to dictionary ${USERS.users['${tender_owner}']} new_amount=${amount} |
| @@ -73,7 +75,7 @@ Suite Teardown Test Suite Teardown | @@ -73,7 +75,7 @@ Suite Teardown Test Suite Teardown | ||
| 73 | ... ${USERS.users['${viewer}'].broker} | 75 | ... ${USERS.users['${viewer}'].broker} |
| 74 | ... contract_view | 76 | ... contract_view |
| 75 | [Setup] Дочекатись синхронізації з майданчиком ${viewer} | 77 | [Setup] Дочекатись синхронізації з майданчиком ${viewer} |
| 76 | - ${contract_index}= Отримати останній індекс contracts ${viewer} | 78 | + ${contract_index}= Отримати останній індекс contracts ${tender_owner} ${viewer} |
| 77 | Remove From Dictionary ${USERS.users['${viewer}'].tender_data.data.contracts[${contract_index}].value} amount | 79 | Remove From Dictionary ${USERS.users['${viewer}'].tender_data.data.contracts[${contract_index}].value} amount |
| 78 | Звірити відображення поля contracts[${contract_index}].value.amount тендера із ${USERS.users['${tender_owner}'].new_amount} для користувача ${viewer} | 80 | Звірити відображення поля contracts[${contract_index}].value.amount тендера із ${USERS.users['${tender_owner}'].new_amount} для користувача ${viewer} |
| 79 | 81 | ||
| @@ -85,7 +87,7 @@ Suite Teardown Test Suite Teardown | @@ -85,7 +87,7 @@ Suite Teardown Test Suite Teardown | ||
| 85 | ... modify_contract | 87 | ... modify_contract |
| 86 | [Setup] Дочекатись синхронізації з майданчиком ${tender_owner} | 88 | [Setup] Дочекатись синхронізації з майданчиком ${tender_owner} |
| 87 | [Teardown] Оновити LAST_MODIFICATION_DATE | 89 | [Teardown] Оновити LAST_MODIFICATION_DATE |
| 88 | - ${contract_index}= Отримати останній індекс contracts ${viewer} | 90 | + ${contract_index}= Отримати останній індекс contracts ${tender_owner} ${viewer} |
| 89 | ${dateSigned}= create_fake_date | 91 | ${dateSigned}= create_fake_date |
| 90 | Set to dictionary ${USERS.users['${tender_owner}']} dateSigned=${dateSigned} | 92 | Set to dictionary ${USERS.users['${tender_owner}']} dateSigned=${dateSigned} |
| 91 | Run As ${tender_owner} Встановити дату підписання угоди ${TENDER['TENDER_UAID']} ${contract_index} ${dateSigned} | 93 | Run As ${tender_owner} Встановити дату підписання угоди ${TENDER['TENDER_UAID']} ${contract_index} ${dateSigned} |
| @@ -97,7 +99,7 @@ Suite Teardown Test Suite Teardown | @@ -97,7 +99,7 @@ Suite Teardown Test Suite Teardown | ||
| 97 | ... ${USERS.users['${viewer}'].broker} | 99 | ... ${USERS.users['${viewer}'].broker} |
| 98 | ... contract_view | 100 | ... contract_view |
| 99 | [Setup] Дочекатись синхронізації з майданчиком ${viewer} | 101 | [Setup] Дочекатись синхронізації з майданчиком ${viewer} |
| 100 | - ${contract_index}= Отримати останній індекс contracts ${viewer} | 102 | + ${contract_index}= Отримати останній індекс contracts ${tender_owner} ${viewer} |
| 101 | Звірити відображення поля contracts[${contract_index}].dateSigned тендера із ${USERS.users['${tender_owner}'].dateSigned} для користувача ${viewer} | 103 | Звірити відображення поля contracts[${contract_index}].dateSigned тендера із ${USERS.users['${tender_owner}'].dateSigned} для користувача ${viewer} |
| 102 | 104 | ||
| 103 | 105 | ||
| @@ -108,7 +110,7 @@ Suite Teardown Test Suite Teardown | @@ -108,7 +110,7 @@ Suite Teardown Test Suite Teardown | ||
| 108 | ... modify_contract | 110 | ... modify_contract |
| 109 | [Setup] Дочекатись синхронізації з майданчиком ${tender_owner} | 111 | [Setup] Дочекатись синхронізації з майданчиком ${tender_owner} |
| 110 | [Teardown] Оновити LAST_MODIFICATION_DATE | 112 | [Teardown] Оновити LAST_MODIFICATION_DATE |
| 111 | - ${contract_index}= Отримати останній індекс contracts ${viewer} | 113 | + ${contract_index}= Отримати останній індекс contracts ${tender_owner} ${viewer} |
| 112 | ${startDate}= create_fake_date | 114 | ${startDate}= create_fake_date |
| 113 | ${endDate}= add_minutes_to_date ${startDate} 10 | 115 | ${endDate}= add_minutes_to_date ${startDate} 10 |
| 114 | Set to dictionary ${USERS.users['${tender_owner}']} contract_startDate=${startDate} contract_endDate=${endDate} | 116 | Set to dictionary ${USERS.users['${tender_owner}']} contract_startDate=${startDate} contract_endDate=${endDate} |
| @@ -121,7 +123,7 @@ Suite Teardown Test Suite Teardown | @@ -121,7 +123,7 @@ Suite Teardown Test Suite Teardown | ||
| 121 | ... ${USERS.users['${viewer}'].broker} | 123 | ... ${USERS.users['${viewer}'].broker} |
| 122 | ... contract_view | 124 | ... contract_view |
| 123 | [Setup] Дочекатись синхронізації з майданчиком ${viewer} | 125 | [Setup] Дочекатись синхронізації з майданчиком ${viewer} |
| 124 | - ${contract_index}= Отримати останній індекс contracts ${viewer} | 126 | + ${contract_index}= Отримати останній індекс contracts ${tender_owner} ${viewer} |
| 125 | Звірити відображення поля contracts[${contract_index}].period.startDate тендера із ${USERS.users['${tender_owner}'].contract_startDate} для користувача ${viewer} | 127 | Звірити відображення поля contracts[${contract_index}].period.startDate тендера із ${USERS.users['${tender_owner}'].contract_startDate} для користувача ${viewer} |
| 126 | 128 | ||
| 127 | 129 | ||
| @@ -131,7 +133,7 @@ Suite Teardown Test Suite Teardown | @@ -131,7 +133,7 @@ Suite Teardown Test Suite Teardown | ||
| 131 | ... ${USERS.users['${viewer}'].broker} | 133 | ... ${USERS.users['${viewer}'].broker} |
| 132 | ... contract_view | 134 | ... contract_view |
| 133 | [Setup] Дочекатись синхронізації з майданчиком ${viewer} | 135 | [Setup] Дочекатись синхронізації з майданчиком ${viewer} |
| 134 | - ${contract_index}= Отримати останній індекс contracts ${viewer} | 136 | + ${contract_index}= Отримати останній індекс contracts ${tender_owner} ${viewer} |
| 135 | Звірити відображення поля contracts[${contract_index}].period.endDate тендера із ${USERS.users['${tender_owner}'].contract_endDate} для користувача ${viewer} | 137 | Звірити відображення поля contracts[${contract_index}].period.endDate тендера із ${USERS.users['${tender_owner}'].contract_endDate} для користувача ${viewer} |
| 136 | 138 | ||
| 137 | 139 | ||
| @@ -142,7 +144,7 @@ Suite Teardown Test Suite Teardown | @@ -142,7 +144,7 @@ Suite Teardown Test Suite Teardown | ||
| 142 | ... add_doc_to_contract | 144 | ... add_doc_to_contract |
| 143 | [Setup] Дочекатись синхронізації з майданчиком ${tender_owner} | 145 | [Setup] Дочекатись синхронізації з майданчиком ${tender_owner} |
| 144 | [Teardown] Оновити LAST_MODIFICATION_DATE | 146 | [Teardown] Оновити LAST_MODIFICATION_DATE |
| 145 | - ${contract_index}= Отримати останній індекс contracts ${viewer} | 147 | + ${contract_index}= Отримати останній індекс contracts ${tender_owner} ${viewer} |
| 146 | Можливість завантажити документ в ${contract_index} угоду користувачем ${tender_owner} | 148 | Можливість завантажити документ в ${contract_index} угоду користувачем ${tender_owner} |
| 147 | 149 | ||
| 148 | 150 | ||
| @@ -176,9 +178,10 @@ Suite Teardown Test Suite Teardown | @@ -176,9 +178,10 @@ Suite Teardown Test Suite Teardown | ||
| 176 | ... tender_owner | 178 | ... tender_owner |
| 177 | ... ${USERS.users['${tender_owner}'].broker} | 179 | ... ${USERS.users['${tender_owner}'].broker} |
| 178 | ... contract_sign level1 | 180 | ... contract_sign level1 |
| 181 | + ... critical | ||
| 179 | [Setup] Дочекатись синхронізації з майданчиком ${tender_owner} | 182 | [Setup] Дочекатись синхронізації з майданчиком ${tender_owner} |
| 180 | [Teardown] Оновити LAST_MODIFICATION_DATE | 183 | [Teardown] Оновити LAST_MODIFICATION_DATE |
| 181 | - ${contract_index}= Отримати останній індекс contracts ${viewer} | 184 | + ${contract_index}= Отримати останній індекс contracts ${tender_owner} ${viewer} |
| 182 | Run As ${tender_owner} Підтвердити підписання контракту ${TENDER['TENDER_UAID']} ${contract_index} | 185 | Run As ${tender_owner} Підтвердити підписання контракту ${TENDER['TENDER_UAID']} ${contract_index} |
| 183 | 186 | ||
| 184 | 187 | ||
| @@ -187,7 +190,8 @@ Suite Teardown Test Suite Teardown | @@ -187,7 +190,8 @@ Suite Teardown Test Suite Teardown | ||
| 187 | ... viewer | 190 | ... viewer |
| 188 | ... ${USERS.users['${viewer}'].broker} | 191 | ... ${USERS.users['${viewer}'].broker} |
| 189 | ... contract_sign | 192 | ... contract_sign |
| 193 | + ... critical | ||
| 190 | [Setup] Дочекатись синхронізації з майданчиком ${viewer} | 194 | [Setup] Дочекатись синхронізації з майданчиком ${viewer} |
| 191 | - ${contract_index}= Отримати останній індекс contracts ${viewer} | 195 | + ${contract_index}= Отримати останній індекс contracts ${tender_owner} ${viewer} |
| 192 | Run As ${viewer} Оновити сторінку з тендером ${TENDER['TENDER_UAID']} | 196 | Run As ${viewer} Оновити сторінку з тендером ${TENDER['TENDER_UAID']} |
| 193 | Звірити відображення поля contracts[${contract_index}].status тендера із active для користувача ${viewer} | 197 | Звірити відображення поля contracts[${contract_index}].status тендера із active для користувача ${viewer} |
| @@ -1019,9 +1019,13 @@ Require Failure | @@ -1019,9 +1019,13 @@ Require Failure | ||
| 1019 | 1019 | ||
| 1020 | 1020 | ||
| 1021 | Отримати останній індекс | 1021 | Отримати останній індекс |
| 1022 | - [Arguments] ${object} ${username} | ||
| 1023 | - ${status}= Run Keyword And Return Status Dictionary Should Contain Key ${USERS.users['${username}'].tender_data.data} ${object} | ||
| 1024 | - Run Keyword If '${status}' == 'False' Fail ${object} not found in \${USERS.users['${username}'].tender_data.data} | ||
| 1025 | - ${len_of_object}= Get Length ${USERS.users['${username}'].tender_data.data.${object}} | ||
| 1026 | - ${index}= subtraction ${len_of_object} 1 | ||
| 1027 | - [Return] ${index} | ||
| 1022 | + [Arguments] ${object} @{username} | ||
| 1023 | + :FOR ${role} IN @{username} | ||
| 1024 | + \ ${status} ${field_value}= Run Keyword And Ignore Error | ||
| 1025 | + ... get_from_object | ||
| 1026 | + ... ${USERS.users['${role}'].tender_data.data} | ||
| 1027 | + ... ${object} | ||
| 1028 | + \ Run Keyword If '${status}' == 'PASS' Exit For Loop | ||
| 1029 | + ${len_of_object}= Run Keyword If '${status}' == 'PASS' Get Length ${USERS.users['${role}'].tender_data.data.${object}} | ||
| 1030 | + ${index}= Run Keyword If '${status}' == 'PASS' subtraction ${len_of_object} 1 | ||
| 1031 | + [Return] ${index} |
| 1 | +*** Settings *** | ||
| 2 | +Library op_robot_tests.tests_files.service_keywords | ||
| 3 | +Library String | ||
| 4 | +Library Collections | ||
| 5 | +Library Selenium2Library | ||
| 6 | +Library OperatingSystem | ||
| 7 | +Library DateTime | ||
| 8 | +Library DebugLibrary | ||
| 9 | + | ||
| 10 | + | ||
| 11 | +Documentation | ||
| 12 | +... This resource file contains keywords that are used directly by | ||
| 13 | +... test suites or by brokers' keyword libraries (also known as drivers). | ||
| 14 | + | ||
| 15 | + | ||
| 16 | +*** Keywords *** | ||
| 17 | +Test Suite Setup | ||
| 18 | + Set Suite Variable ${WARN_RUN_AS} ${False} | ||
| 19 | + Set Selenium Implicit Wait 5 s | ||
| 20 | + Set Selenium Timeout 10 s | ||
| 21 | + Залогувати git-дані | ||
| 22 | + Порівняти системний і серверний час | ||
| 23 | + Завантажуємо дані про користувачів і майданчики | ||
| 24 | + | ||
| 25 | + | ||
| 26 | +Test Suite Teardown | ||
| 27 | + Close all browsers | ||
| 28 | + Run Keyword And Ignore Error Створити артефакт | ||
| 29 | + | ||
| 30 | + | ||
| 31 | +Set Suite Variable With Default Value | ||
| 32 | + [Arguments] ${suite_var} ${def_value} | ||
| 33 | + ${tmp}= Get Variable Value ${${suite_var}} ${def_value} | ||
| 34 | + Set Suite Variable ${${suite_var}} ${tmp} | ||
| 35 | + | ||
| 36 | + | ||
| 37 | +Порівняти системний і серверний час | ||
| 38 | + ${server_time}= request ${API_HOST_URL} HEAD | ||
| 39 | + ${local_time}= Get current TZdate | ||
| 40 | + Log ${server_time.headers['date']} | ||
| 41 | + Log ${local_time} | ||
| 42 | + ${status}= compare_date ${server_time.headers['date']} ${local_time} 5 | ||
| 43 | + Run keyword if ${status} == ${False} | ||
| 44 | + ... Log Час на сервері відрізняється від локального більше ніж на 5 секунд WARN | ||
| 45 | + | ||
| 46 | + | ||
| 47 | +Залогувати git-дані | ||
| 48 | + ${commit}= Run git log --graph --pretty --abbrev-commit --date=relative -n 30 | ||
| 49 | + ${repo}= Run git remote -v | ||
| 50 | + ${branch}= Run git branch -vva | ||
| 51 | + ${status}= Run git status | ||
| 52 | + ${diff}= Run git diff | ||
| 53 | + ${reflog}= Run git reflog | ||
| 54 | + Log ${commit} | ||
| 55 | + Log ${repo} | ||
| 56 | + Log ${branch} | ||
| 57 | + Log ${status} | ||
| 58 | + Log ${diff} | ||
| 59 | + Log ${reflog} | ||
| 60 | + | ||
| 61 | + | ||
| 62 | +Завантажуємо дані про користувачів і майданчики | ||
| 63 | + Log ${BROKER} | ||
| 64 | + Log ${ROLE} | ||
| 65 | + # Suite variable; should be present in every test suite | ||
| 66 | + # in `*** Variables ***` section | ||
| 67 | + Log Many @{USED_ROLES} | ||
| 68 | + | ||
| 69 | + # Load brokers data | ||
| 70 | + ${file_path}= Get Variable Value ${BROKERS_FILE} brokers.yaml | ||
| 71 | + ${BROKERS_PARAMS}= Get Variable Value ${BROKERS_PARAMS} | ||
| 72 | + ${BROKERS}= load_data_from ${file_path} mode=brokers external_params_name=BROKERS_PARAMS | ||
| 73 | + Log ${BROKERS} | ||
| 74 | + Set Suite Variable ${BROKERS} | ||
| 75 | + # List of currently used brokers | ||
| 76 | + ${used_brokers}= Create List | ||
| 77 | + | ||
| 78 | + # Load users data | ||
| 79 | + ${file_path}= Get Variable Value ${USERS_FILE} users.yaml | ||
| 80 | + ${USERS_PARAMS}= Get Variable Value ${USERS_PARAMS} | ||
| 81 | + ${USERS}= load_data_from ${file_path} users.yaml external_params_name=USERS_PARAMS | ||
| 82 | + Log ${USERS.users} | ||
| 83 | + Set Suite Variable ${USERS} | ||
| 84 | + # List of currently used users | ||
| 85 | + ${used_users}= Create List | ||
| 86 | + | ||
| 87 | + # Handle `-v role:something` | ||
| 88 | + Run Keyword Unless '${ROLE}' in @{USED_ROLES} | ||
| 89 | + ... Log | ||
| 90 | + ... Role ${ROLE} is not used in this test suite. | ||
| 91 | + ... WARN | ||
| 92 | + Set Suite Variable With Default Value | ||
| 93 | + ... ${ROLE} | ||
| 94 | + ... ${BROKERS['${BROKER}'].roles.${ROLE}} | ||
| 95 | + | ||
| 96 | + # Set default value for each role if it is not set yet; | ||
| 97 | + # fill `used_users`; | ||
| 98 | + # fill `used_brokers`. | ||
| 99 | + # | ||
| 100 | + # Don't even ask how this works! | ||
| 101 | + :FOR ${tmp_role} IN @{USED_ROLES} | ||
| 102 | + \ Set Suite Variable With Default Value | ||
| 103 | + \ ... ${tmp_role} | ||
| 104 | + \ ... ${BROKERS['Quinta'].roles.${tmp_role}} | ||
| 105 | + \ Append To List ${used_users} ${${tmp_role}} | ||
| 106 | + \ Append To List ${used_brokers} ${USERS.users.${${tmp_role}}.broker} | ||
| 107 | + # Since `@{USED_ROLES}` is already a suite variable, | ||
| 108 | + # let's make `@{used_brokers}` alike. | ||
| 109 | + ${used_brokers}= Remove Duplicates ${used_brokers} | ||
| 110 | + Set Suite Variable ${used_brokers} | ||
| 111 | + # We need to create two lists since Robot Framework doesn't support | ||
| 112 | + # dicts in `:FOR` loops. | ||
| 113 | + Log Many @{used_users} | ||
| 114 | + Log Many @{used_brokers} | ||
| 115 | + | ||
| 116 | + # A list of all users in users file | ||
| 117 | + ${known_users}= Get Dictionary Keys ${USERS.users} | ||
| 118 | + | ||
| 119 | + # Check whether users file contains an entry for each | ||
| 120 | + # selected user before preparing any clients | ||
| 121 | + :FOR ${username} IN @{used_users} | ||
| 122 | + \ List Should Contain Value | ||
| 123 | + \ ... ${known_users} | ||
| 124 | + \ ... ${username} | ||
| 125 | + \ ... msg=User ${username} not found in users file! | ||
| 126 | + | ||
| 127 | + # Prepare a client for each user | ||
| 128 | + :FOR ${username} IN @{used_users} | ||
| 129 | + \ ${munch_dict}= munch_dict data=${True} | ||
| 130 | + \ ${keywords_file}= Get Broker Property ${USERS.users.${username}.broker} keywords_file | ||
| 131 | + \ Завантажуємо бібліотеку з реалізацією для майданчика ${keywords_file} | ||
| 132 | + \ Run As ${username} Підготувати клієнт для користувача | ||
| 133 | + \ ${LAST_REFRESH_DATE}= Get Current TZdate | ||
| 134 | + \ Set To Dictionary ${USERS} ${username}=${USERS.users.${username}} | ||
| 135 | + \ Set To Dictionary ${USERS.${username}} tender_data=${munch_dict} | ||
| 136 | + \ Set To Dictionary ${USERS.${username}} LAST_REFRESH_DATE ${LAST_REFRESH_DATE} | ||
| 137 | + | ||
| 138 | + # Drop all unused users | ||
| 139 | + Keep In Dictionary ${USERS.users} @{used_users} | ||
| 140 | + Log Many @{USERS} | ||
| 141 | + | ||
| 142 | + | ||
| 143 | +Get Broker Property | ||
| 144 | + [Arguments] ${broker_name} ${property} | ||
| 145 | + [Documentation] | ||
| 146 | + ... This keyword returns a property of specified broker | ||
| 147 | + ... if that property exists, otherwise, it returns a | ||
| 148 | + ... default value. | ||
| 149 | + Run Keyword If '${broker_name}'=='${None}' Fail \${broker_name} is NoneType | ||
| 150 | + Should Contain ${BROKERS['${broker_name}']} ${property} | ||
| 151 | + Return From Keyword ${BROKERS['${broker_name}'].${property}} | ||
| 152 | + | ||
| 153 | + | ||
| 154 | +Get Broker Property By Username | ||
| 155 | + [Documentation] | ||
| 156 | + ... This keyword gets the corresponding broker name | ||
| 157 | + ... for a specified username and then calls | ||
| 158 | + ... "Get Broker Property" | ||
| 159 | + [Arguments] ${username} ${property} | ||
| 160 | + ${broker_name}= Get Variable Value ${USERS.users['${username}'].broker} | ||
| 161 | + Run Keyword And Return Get Broker Property ${broker_name} ${property} | ||
| 162 | + | ||
| 163 | + | ||
| 164 | +Створити артефакт | ||
| 165 | + ${artifact}= Create Dictionary | ||
| 166 | + ... api_version=${API_VERSION} | ||
| 167 | + ... tender_uaid=${TENDER['TENDER_UAID']} | ||
| 168 | + ... last_modification_date=${TENDER['LAST_MODIFICATION_DATE']} | ||
| 169 | + ... mode=${MODE} | ||
| 170 | + Run Keyword And Ignore Error Set To Dictionary ${artifact} | ||
| 171 | + ... tender_owner=${USERS.users['${tender_owner}'].broker} | ||
| 172 | + ... access_token=${USERS.users['${tender_owner}'].access_token} | ||
| 173 | + ... tender_id=${USERS.users['${tender_owner}'].tender_data.data.id} | ||
| 174 | + Run Keyword And Ignore Error Set To Dictionary ${artifact} tender_owner_access_token=${USERS.users['${tender_owner}'].access_token} | ||
| 175 | + Run Keyword And Ignore Error Set To Dictionary ${artifact} provider_access_token=${USERS.users['${provider}'].access_token} | ||
| 176 | + Run Keyword And Ignore Error Set To Dictionary ${artifact} provider1_access_token=${USERS.users['${provider1}'].access_token} | ||
| 177 | + Run Keyword And Ignore Error Set To Dictionary ${artifact} provider_bid_id=${USERS.users['${provider}'].bid_id} | ||
| 178 | + Run Keyword And Ignore Error Set To Dictionary ${artifact} provider1_bid_id=${USERS.users['${provider1}'].bid_id} | ||
| 179 | + Run Keyword And Ignore Error Set To Dictionary ${artifact} | ||
| 180 | + ... tender_file_properties=${USERS.users['${tender_owner}'].tender_document.file_properties} | ||
| 181 | + ... lot_file_properties=${USERS.users['${tender_owner}'].lots_documents[0].file_properties} | ||
| 182 | + ${status} ${lots_ids}= Run Keyword And Ignore Error Отримати ідентифікатори об’єктів ${viewer} lots | ||
| 183 | + Run Keyword If '${status}'=='PASS' | ||
| 184 | + ... Set To Dictionary ${artifact} lots=${lots_ids} | ||
| 185 | + Log ${artifact} | ||
| 186 | + log_object_data ${artifact} file_name=artifact update=${True} artifact=${True} | ||
| 187 | + | ||
| 188 | + | ||
| 189 | +Завантажити дані про тендер | ||
| 190 | + ${file_path}= Get Variable Value ${ARTIFACT_FILE} artifact.yaml | ||
| 191 | + ${ARTIFACT}= load_data_from ${file_path} | ||
| 192 | + Run Keyword And Ignore Error Set To Dictionary ${USERS.users['${tender_owner}']} access_token=${ARTIFACT.access_token} | ||
| 193 | + ${TENDER}= Create Dictionary | ||
| 194 | + ... TENDER_UAID=${ARTIFACT.tender_uaid} | ||
| 195 | + ... LAST_MODIFICATION_DATE=${ARTIFACT.last_modification_date} | ||
| 196 | + ... LOT_ID=${Empty} | ||
| 197 | + ${lot_index}= Get Variable Value ${lot_index} 0 | ||
| 198 | + Run Keyword And Ignore Error Set To Dictionary ${TENDER} LOT_ID=${ARTIFACT.lots[${lot_index}]} | ||
| 199 | + ${MODE}= Get Variable Value ${MODE} ${ARTIFACT.mode} | ||
| 200 | + Run Keyword And Ignore Error Set To Dictionary ${USERS.users['${tender_owner}']} access_token=${ARTIFACT.tender_owner_access_token} | ||
| 201 | + Run Keyword And Ignore Error Set To Dictionary ${USERS.users['${viewer}']} tender_file_properties=${ARTIFACT.tender_file_properties} | ||
| 202 | + Run Keyword And Ignore Error Set To Dictionary ${USERS.users['${viewer}']} lot_file_properties=${ARTIFACT.lot_file_properties} | ||
| 203 | + Run Keyword And Ignore Error Set To Dictionary ${USERS.users['${provider}']} access_token=${ARTIFACT.provider_access_token} | ||
| 204 | + Run Keyword And Ignore Error Set To Dictionary ${USERS.users['${provider1}']} access_token=${ARTIFACT.provider1_access_token} | ||
| 205 | + Run Keyword And Ignore Error Set To Dictionary ${USERS.users['${provider}']} bid_id=${ARTIFACT.provider_bid_id} | ||
| 206 | + Run Keyword And Ignore Error Set To Dictionary ${USERS.users['${provider1}']} bid_id=${ARTIFACT.provider1_bid_id} | ||
| 207 | + Set Suite Variable ${MODE} | ||
| 208 | + Set Suite Variable ${lot_index} | ||
| 209 | + Set Suite Variable ${TENDER} | ||
| 210 | + log_object_data ${ARTIFACT} file_name=artifact update=${True} artifact=${True} | ||
| 211 | + | ||
| 212 | + | ||
| 213 | +Підготувати дані для створення тендера | ||
| 214 | + [Arguments] ${tender_parameters} | ||
| 215 | + ${period_intervals}= compute_intrs ${BROKERS} ${used_brokers} | ||
| 216 | + ${submissionMethodDetails}= Get Variable Value ${submissionMethodDetails} | ||
| 217 | + ${accelerator}= Get Variable Value ${accelerator} | ||
| 218 | + ${funders}= Get Variable Value ${FUNDERS} | ||
| 219 | + ${tender_data}= prepare_test_tender_data ${period_intervals} ${tender_parameters} ${submissionMethodDetails} ${accelerator} ${funders} | ||
| 220 | + ${TENDER}= Create Dictionary | ||
| 221 | + Set Global Variable ${TENDER} | ||
| 222 | + Log ${tender_data} | ||
| 223 | + [return] ${tender_data} | ||
| 224 | + | ||
| 225 | + | ||
| 226 | +Підготувати дані для створення плану | ||
| 227 | + [Arguments] ${tender_parameters} | ||
| 228 | + ${data}= test_tender_data_planning ${tender_parameters} | ||
| 229 | + ${tender_data}= Create Dictionary data=${data} | ||
| 230 | + ${TENDER}= Create Dictionary | ||
| 231 | + Set Global Variable ${TENDER} | ||
| 232 | + Log ${tender_data} | ||
| 233 | + [return] ${tender_data} | ||
| 234 | + | ||
| 235 | + | ||
| 236 | +Підготувати дані для створення предмету закупівлі | ||
| 237 | + [Arguments] ${cpv} | ||
| 238 | + ${index}= Set variable if ${moz_integration} 3 4 | ||
| 239 | + ${item}= test_item_data ${cpv[:${index}]} | ||
| 240 | + [Return] ${item} | ||
| 241 | + | ||
| 242 | + | ||
| 243 | +Підготувати дані для створення предмету закупівлі плану | ||
| 244 | + [Arguments] ${cpv} | ||
| 245 | + ${item}= test_item_data ${cpv[0:4]} | ||
| 246 | + Remove From Dictionary ${item} deliveryAddress | ||
| 247 | + Remove From Dictionary ${item} deliveryLocation | ||
| 248 | + Remove From Dictionary ${item} deliveryDate.startDate | ||
| 249 | + [Return] ${item} | ||
| 250 | + | ||
| 251 | + | ||
| 252 | +Підготувати дані для створення лоту | ||
| 253 | + [Arguments] ${max_lot_value_amount} | ||
| 254 | + ${lot}= test_lot_data ${max_lot_value_amount} | ||
| 255 | + ${reply}= Create Dictionary data=${lot} | ||
| 256 | + [Return] ${reply} | ||
| 257 | + | ||
| 258 | +Підготувати дані для створення нецінового показника | ||
| 259 | + ${reply}= test_feature_data | ||
| 260 | + [Return] ${reply} | ||
| 261 | + | ||
| 262 | +Підготувати дані для подання вимоги | ||
| 263 | + ${claim}= test_claim_data | ||
| 264 | + [Return] ${claim} | ||
| 265 | + | ||
| 266 | + | ||
| 267 | +Підготувати дані для подання скарги | ||
| 268 | + [Arguments] ${lot}=${False} | ||
| 269 | + ${complaint}= test_complaint_data ${lot} | ||
| 270 | + [Return] ${complaint} | ||
| 271 | + | ||
| 272 | + | ||
| 273 | +Підготувати дані для відповіді на скаргу | ||
| 274 | + ${reply}= test_complaint_reply_data | ||
| 275 | + [Return] ${reply} | ||
| 276 | + | ||
| 277 | + | ||
| 278 | +Підготувати дані для запитання | ||
| 279 | + ${question}= test_question_data | ||
| 280 | + [Return] ${question} | ||
| 281 | + | ||
| 282 | + | ||
| 283 | +Підготувати дані для відповіді на запитання | ||
| 284 | + ${answer}= test_question_answer_data | ||
| 285 | + [Return] ${answer} | ||
| 286 | + | ||
| 287 | + | ||
| 288 | +Підготувати дані для подання пропозиції | ||
| 289 | + [Arguments] | ||
| 290 | + ${bid}= generate_test_bid_data ${USERS.users['${tender_owner}'].initial_data.data} | ||
| 291 | + [Return] ${bid} | ||
| 292 | + | ||
| 293 | + | ||
| 294 | +Підготувати дані для подання пропозиції для другого етапу | ||
| 295 | + [Arguments] ${index}=0 | ||
| 296 | + ${bid}= generate_test_bid_data_second_stage ${USERS.users['${tender_owner}'].tender_data.data} ${index} | ||
| 297 | + [Return] ${bid} | ||
| 298 | + | ||
| 299 | + | ||
| 300 | +Підготувати дані про постачальника | ||
| 301 | + [Arguments] ${username} ${lotIndex}=${-1} | ||
| 302 | + ${lotIndex}= Convert To Integer ${lotIndex} | ||
| 303 | + ${supplier_data}= test_supplier_data | ||
| 304 | + Run Keyword If ${lotIndex} > -1 Set To Dictionary ${supplier_data.data} lotID=${USERS.users['${tender_owner}'].initial_data.data['lots'][${lotIndex}]['id']} | ||
| 305 | + Set To Dictionary ${USERS.users['${tender_owner}']} supplier_data=${supplier_data} | ||
| 306 | + Log ${supplier_data} | ||
| 307 | + [Return] ${supplier_data} | ||
| 308 | + | ||
| 309 | + | ||
| 310 | +Підготувати дані про скасування | ||
| 311 | + ${cancellation_reason}= create_fake_sentence | ||
| 312 | + ${cancellation_reason}= field_with_id c ${cancellation_reason} | ||
| 313 | + ${cancellation_id}= get_id_from_string ${cancellation_reason} | ||
| 314 | + ${file_path} ${file_name} ${file_content}= create_fake_doc | ||
| 315 | + ${doc_id}= get_id_from_string ${file_name} | ||
| 316 | + ${document}= Create Dictionary | ||
| 317 | + ... doc_path=${file_path} | ||
| 318 | + ... doc_name=${file_name} | ||
| 319 | + ... doc_content=${file_content} | ||
| 320 | + ... doc_id=${doc_id} | ||
| 321 | + ${new_description}= create_fake_sentence | ||
| 322 | + ${cancellation_data}= Create Dictionary | ||
| 323 | + ... cancellation_reason=${cancellation_reason} | ||
| 324 | + ... cancellation_id=${cancellation_id} | ||
| 325 | + ... document=${document} | ||
| 326 | + ... description=${new_description} | ||
| 327 | + ${cancellation_data}= munchify ${cancellation_data} | ||
| 328 | + [Return] ${cancellation_data} | ||
| 329 | + | ||
| 330 | + | ||
| 331 | +Підготувати дані про зміну до договору | ||
| 332 | + [Arguments] ${username} | ||
| 333 | + ${change_data}= test_change_data | ||
| 334 | + Set To Dictionary ${USERS.users['${username}']} change_data=${change_data} | ||
| 335 | + Log ${change_data} | ||
| 336 | + [Return] ${change_data} | ||
| 337 | + | ||
| 338 | + | ||
| 339 | +Адаптувати дані для оголошення тендера | ||
| 340 | + [Arguments] ${tender_data} | ||
| 341 | + # munchify is used to make deep copy of ${tender_data} | ||
| 342 | + ${adapted_data}= munchify ${tender_data} | ||
| 343 | + :FOR ${username} IN @{USED_ROLES} | ||
| 344 | + # munchify is used to make deep copy of ${adapted_data} | ||
| 345 | + \ ${adapted_data_copy}= munchify ${adapted_data} | ||
| 346 | + \ ${status} ${adapted_data_from_broker}= Run keyword and ignore error Run As ${${username}} Підготувати дані для оголошення тендера ${adapted_data_copy} ${username} | ||
| 347 | + \ Log ${adapted_data_from_broker} | ||
| 348 | + # Need this in case ``${${username}}`` doesn't have `Підготувати дані для оголошення | ||
| 349 | + # тендера користувачем` keyword, so after `Run keyword and ignore error` call | ||
| 350 | + # ``${adapted_data_from_broker}`` will be ``${None}``. Else - nothing changes. | ||
| 351 | + \ ${adapted_data_from_broker}= Set variable if '${status}' == 'FAIL' ${adapted_data} ${adapted_data_from_broker} | ||
| 352 | + \ Log differences between dicts ${adapted_data.data} ${adapted_data_from_broker.data} ${username} has changed initial data! | ||
| 353 | + # Update (or not, if nothing changed) ``${adapted_data}``. | ||
| 354 | + \ ${adapted_data}= munchify ${adapted_data_from_broker} | ||
| 355 | + \ Log ${adapted_data} | ||
| 356 | + Log ${adapted_data} | ||
| 357 | + Log ${tender_data} | ||
| 358 | + [Return] ${adapted_data} | ||
| 359 | + | ||
| 360 | + | ||
| 361 | +Log differences between dicts | ||
| 362 | + [Arguments] ${left} ${right} ${begin} ${end}=${Empty} | ||
| 363 | + ${diff_status} ${diff_message}= Run Keyword And Ignore Error Dictionaries Should Be Equal ${left} ${right} | ||
| 364 | + Run keyword if '${diff_status}' == 'FAIL' Log \n${begin}\n${diff_message}\n${end} WARN | ||
| 365 | + [Return] ${diff_status} | ||
| 366 | + | ||
| 367 | + | ||
| 368 | +Завантажуємо бібліотеку з реалізацією для майданчика ${keywords_file} | ||
| 369 | + [Documentation] | ||
| 370 | + ... Load broker's driver (keyword library). | ||
| 371 | + ... | ||
| 372 | + ... `Import Resource` is called twice: | ||
| 373 | + ... | ||
| 374 | + ... 1) It tries to read from ``brokers/`` directory | ||
| 375 | + ... (located next to ``keywords.robot``). | ||
| 376 | + ... This is an old feature which will be removed in the future. | ||
| 377 | + ... | ||
| 378 | + ... 2) It looks for a given filename in ``sys.path`` | ||
| 379 | + ... (``PYTHONPATH`` environment variable). | ||
| 380 | + ... | ||
| 381 | + ... This keyword will fail if ``keywords_file`` was found | ||
| 382 | + ... in both locations. | ||
| 383 | + ${bundled_st}= Run Keyword And Return Status Import Resource ${CURDIR}${/}brokers${/}${keywords_file}.robot | ||
| 384 | + ${external_st}= Run Keyword And Return Status Import Resource ${keywords_file}.robot | ||
| 385 | + Run Keyword If ${bundled_st} == ${external_st} == ${False} Fail Resource file ${keywords_file}.robot not found | ||
| 386 | + Run Keyword If ${bundled_st} == ${external_st} == ${True} Fail Resource file ${keywords_file}.robot found in both brokers${/} and src${/} | ||
| 387 | + | ||
| 388 | + | ||
| 389 | +Дочекатись синхронізації з майданчиком | ||
| 390 | + [Arguments] ${username} | ||
| 391 | + [Documentation] | ||
| 392 | + ... Synchronise with ``username`` and update cache | ||
| 393 | + ... First section | ||
| 394 | + ... Get `timeout_on_wait` for ``username`` | ||
| 395 | + ... Add `timeout_on_wait` to `last_modification_date` in order to have | ||
| 396 | + ... correct time of data modification in CDB(every broker has different | ||
| 397 | + ... data synchronisation time with CDB). | ||
| 398 | + ... Find diff between `last_mofidication_date_corrected` | ||
| 399 | + ... and `now`. If that value is positive, sleep for `sleep` seconds, | ||
| 400 | + ... else go to next section. | ||
| 401 | + ... Thus, when this keyword is executed several times in a row, | ||
| 402 | + ... it will wait for as long as really needed. | ||
| 403 | + ... | ||
| 404 | + ... Example: | ||
| 405 | + ... | ||
| 406 | + ... The procurement is modified. | ||
| 407 | + ... In 5 seconds, this keyword is called for `viewer`. | ||
| 408 | + ... Immediately, this keyword is called for `provider`. | ||
| 409 | + ... Timeout for `viewer` is 60. | ||
| 410 | + ... Timeout for `provider` is 300. | ||
| 411 | + ... First call (for `viewer`) will trigger `Sleep 55`. | ||
| 412 | + ... Second call (for `provider`) will trigger `Sleep 235`. | ||
| 413 | + ... As a result, the delay will end in 300 seconds | ||
| 414 | + ... since last modification date. | ||
| 415 | + ... | ||
| 416 | + ... Another example (a variation of previous one): | ||
| 417 | + ... | ||
| 418 | + ... Timeout for `viewer` is 120. | ||
| 419 | + ... Timeout for `provider` is 30. | ||
| 420 | + ... First call will trigger `Sleep 115`. | ||
| 421 | + ... Second call will trigger `Sleep 0`, | ||
| 422 | + ... since we have already slept for 120 seconds | ||
| 423 | + ... and there is no need to sleep anymore. | ||
| 424 | + ... | ||
| 425 | + ... Second section | ||
| 426 | + ... Find how much time passed from ``username``'s `last_refresh_date` | ||
| 427 | + ... to `last_modification_date_corrected`. If that value is positive, then | ||
| 428 | + ... cahce for ``username`` is not up-to-date. So, it will be refreshed and | ||
| 429 | + ... `last_refresh_date` will be updated. | ||
| 430 | + ... Else do nothing. | ||
| 431 | + ${timeout_on_wait}= Get Broker Property By Username ${username} timeout_on_wait | ||
| 432 | + ${last_modification_date_corrected}= Add Time To Date | ||
| 433 | + ... ${TENDER['LAST_MODIFICATION_DATE']} | ||
| 434 | + ... ${timeout_on_wait} s | ||
| 435 | + ${now}= Get Current TZdate | ||
| 436 | + ${sleep}= Subtract Date From Date | ||
| 437 | + ... ${last_modification_date_corrected} | ||
| 438 | + ... ${now} | ||
| 439 | + Run Keyword If ${sleep} > 0 Sleep ${sleep} | ||
| 440 | + | ||
| 441 | + | ||
| 442 | + ${time_diff}= Subtract Date From Date | ||
| 443 | + ... ${last_modification_date_corrected} | ||
| 444 | + ... ${USERS.users['${username}']['LAST_REFRESH_DATE']} | ||
| 445 | + ${LAST_REFRESH_DATE}= Get Current TZdate | ||
| 446 | + Run Keyword If ${time_diff} > 0 Run Keywords | ||
| 447 | + ... Оновити сторінку ${username} | ||
| 448 | + ... AND | ||
| 449 | + ... Set To Dictionary ${USERS.users['${username}']} LAST_REFRESH_DATE=${LAST_REFRESH_DATE} | ||
| 450 | + | ||
| 451 | + | ||
| 452 | +Оновити сторінку | ||
| 453 | + [Arguments] ${username} | ||
| 454 | + Run Keyword If '${RESOURCE}' == 'plans' Run As ${username} Оновити сторінку з планом ${TENDER['TENDER_UAID']} | ||
| 455 | + ... ELSE Run As ${username} Оновити сторінку з тендером ${TENDER['TENDER_UAID']} | ||
| 456 | + | ||
| 457 | + | ||
| 458 | +Звірити поле тендера | ||
| 459 | + [Arguments] ${username} ${tender_uaid} ${tender_data} ${field} | ||
| 460 | + ${left}= get_from_object ${tender_data.data} ${field} | ||
| 461 | + Звірити поле тендера із значенням ${username} ${tender_uaid} ${left} ${field} | ||
| 462 | + | ||
| 463 | + | ||
| 464 | +Звірити поле плану | ||
| 465 | + [Arguments] ${username} ${tender_uaid} ${tender_data} ${field} | ||
| 466 | + ${left}= get_from_object ${tender_data.data} ${field} | ||
| 467 | + Звірити поле плану із значенням ${username} ${tender_uaid} ${left} ${field} | ||
| 468 | + | ||
| 469 | + | ||
| 470 | +Звірити поле плану із значенням | ||
| 471 | + [Arguments] ${username} ${tender_uaid} ${left} ${field} ${object_id}=${Empty} | ||
| 472 | + ${right}= Отримати дані із плану ${username} ${tender_uaid} ${field} ${object_id} | ||
| 473 | + Порівняти об'єкти ${left} ${right} | ||
| 474 | + | ||
| 475 | + | ||
| 476 | +Звірити поле тендера із значенням | ||
| 477 | + [Arguments] ${username} ${tender_uaid} ${left} ${field} ${object_id}=${Empty} | ||
| 478 | + ${right}= Отримати дані із тендера ${username} ${tender_uaid} ${field} ${object_id} | ||
| 479 | + Порівняти об'єкти ${left} ${right} | ||
| 480 | + | ||
| 481 | + | ||
| 482 | +Звірити поле договору | ||
| 483 | + [Arguments] ${username} ${contract_uaid} ${cotract_data} ${field} | ||
| 484 | + ${left}= get_from_object ${contract_data.data} ${field} | ||
| 485 | + Звірити поле договору із значенням ${username} ${contract_uaid} ${left} ${field} | ||
| 486 | + | ||
| 487 | + | ||
| 488 | +Звірити поле договору із значенням | ||
| 489 | + [Arguments] ${username} ${contract_uaid} ${left} ${field} | ||
| 490 | + ${right}= Отримати дані із договору ${username} ${contract_uaid} ${field} | ||
| 491 | + Порівняти об'єкти ${left} ${right} | ||
| 492 | + | ||
| 493 | + | ||
| 494 | +Звірити поле зміни до договору | ||
| 495 | + [Arguments] ${username} ${contract_uaid} ${change_data} ${field} | ||
| 496 | + ${left}= get_from_object ${change_data.data} ${field} | ||
| 497 | + Звірити поле зміни до договору із значенням ${username} ${contract_uaid} ${left} ${field} | ||
| 498 | + | ||
| 499 | + | ||
| 500 | +Звірити поле зміни до договору із значенням | ||
| 501 | + [Arguments] ${username} ${contract_uaid} ${left} ${field} | ||
| 502 | + ${field}= Evaluate "{}{}".format('changes[0].', '${field}') | ||
| 503 | + ${right}= Отримати дані із договору ${username} ${contract_uaid} ${field} | ||
| 504 | + Порівняти об'єкти ${left} ${right} | ||
| 505 | + | ||
| 506 | + | ||
| 507 | +Звірити поле донора | ||
| 508 | + [Arguments] ${username} ${tender_uaid} ${tender_data} ${field} ${funders_index} | ||
| 509 | + ${left}= get_from_object ${tender_data.data.funders[${funders_index}]} ${field} | ||
| 510 | + Log ${left} | ||
| 511 | + Звірити поле донора із значенням ${username} ${tender_uaid} ${left} ${field} ${funders_index} | ||
| 512 | + | ||
| 513 | + | ||
| 514 | +Звірити поле донора із значенням | ||
| 515 | + [Arguments] ${username} ${tender_uaid} ${left} ${field} ${funders_index} ${object_id}=${Empty} | ||
| 516 | + ${right}= Отримати дані із тендера ${username} ${tender_uaid} funders[${funders_index}].${field} ${object_id} | ||
| 517 | + Порівняти об'єкти ${left} ${right} | ||
| 518 | + | ||
| 519 | + | ||
| 520 | +Звірити відображення типу запланованого тендера для ${username} | ||
| 521 | + ${type}= Отримати дані із плану ${username} ${TENDER['TENDER_UAID']} tender.procurementMethodType | ||
| 522 | + Звірити відображення поля tender.procurementMethodType плану для користувача ${username} | ||
| 523 | + Run Keyword If '${type}' == '' Run As ${username} Перевірити наявність повідомлення "без застосування електронної системи" | ||
| 524 | + | ||
| 525 | + | ||
| 526 | +Порівняти об'єкти | ||
| 527 | + [Arguments] ${left} ${right} | ||
| 528 | + Log ${left} | ||
| 529 | + Log ${right} | ||
| 530 | + Should Not Be Equal ${left} ${None} | ||
| 531 | + Should Not Be Equal ${right} ${None} | ||
| 532 | + Should Be Equal ${left} ${right} msg=Objects are not equal | ||
| 533 | + | ||
| 534 | + | ||
| 535 | +Звірити дату тендера | ||
| 536 | + [Arguments] ${username} ${tender_uaid} ${tender_data} ${field} ${accuracy}=60 ${absolute_delta}=${False} | ||
| 537 | + ${left}= get_from_object ${tender_data.data} ${field} | ||
| 538 | + Звірити дату тендера із значенням ${username} ${tender_uaid} ${left} ${field} accuracy=${accuracy} absolute_delta=${absolute_delta} | ||
| 539 | + | ||
| 540 | + | ||
| 541 | +Звірити дату тендера із значенням | ||
| 542 | + [Arguments] ${username} ${tender_uaid} ${left} ${field} ${object_id}=${Empty} ${accuracy}=60 ${absolute_delta}=${False} | ||
| 543 | + ${right}= Отримати дані із тендера ${username} ${tender_uaid} ${field} ${object_id} | ||
| 544 | + Порівняти дати ${left} ${right} accuracy=${accuracy} absolute_delta=${absolute_delta} | ||
| 545 | + | ||
| 546 | + | ||
| 547 | +Порівняти дати | ||
| 548 | + [Documentation] | ||
| 549 | + ... Compare dates with specified ``accuracy`` (in seconds). | ||
| 550 | + ... Default is `60`. | ||
| 551 | + ... | ||
| 552 | + ... The keyword will fail if the difference between | ||
| 553 | + ... ``left`` and ``right`` dates is more than ``accuracy``, | ||
| 554 | + ... otherwise it will pass. | ||
| 555 | + [Arguments] ${left} ${right} ${accuracy}=90 ${absolute_delta}=${False} | ||
| 556 | + Log ${left} | ||
| 557 | + Log ${right} | ||
| 558 | + Should Not Be Equal ${left} ${None} | ||
| 559 | + Should Not Be Equal ${right} ${None} | ||
| 560 | + ${status}= compare_date ${left} ${right} accuracy=${accuracy} absolute_delta=${absolute_delta} | ||
| 561 | + Should Be True ${status} msg=Dates differ: ${left} != ${right} | ||
| 562 | + | ||
| 563 | + | ||
| 564 | +Звірити координати доставки тендера | ||
| 565 | + [Arguments] ${username} ${tender_uaid} ${tender_data} ${item_id} | ||
| 566 | + ${item_index}= get_object_index_by_id ${tender_data.data['items']} ${item_id} | ||
| 567 | + ${left_lat}= get_from_object ${tender_data.data} items[${item_index}].deliveryLocation.latitude | ||
| 568 | + ${left_lon}= get_from_object ${tender_data.data} items[${item_index}].deliveryLocation.longitude | ||
| 569 | + ${right_lat}= Отримати дані із тендера ${username} ${tender_uaid} deliveryLocation.latitude ${item_id} | ||
| 570 | + ${right_lat}= Convert To Number ${right_lat} | ||
| 571 | + ${right_lon}= Отримати дані із тендера ${username} ${tender_uaid} deliveryLocation.longitude ${item_id} | ||
| 572 | + ${right_lon}= Convert To Number ${right_lon} | ||
| 573 | + Порівняти координати ${left_lat} ${left_lon} ${right_lat} ${right_lon} | ||
| 574 | + | ||
| 575 | + | ||
| 576 | +Порівняти координати | ||
| 577 | + [Documentation] | ||
| 578 | + ... Compare coordinates with specified ``accuracy`` (in km). | ||
| 579 | + ... Default is `0.1`. | ||
| 580 | + ... | ||
| 581 | + ... The keyword will fail if the difference between | ||
| 582 | + ... ``left`` and ``right`` is more than ``accuracy``, | ||
| 583 | + ... otherwise it will pass. | ||
| 584 | + [Arguments] ${left_lat} ${left_lon} ${right_lat} ${right_lon} ${accuracy}=0.1 | ||
| 585 | + Should Not Be Equal ${left_lat} ${None} | ||
| 586 | + Should Not Be Equal ${left_lon} ${None} | ||
| 587 | + Should Not Be Equal ${right_lat} ${None} | ||
| 588 | + Should Not Be Equal ${right_lon} ${None} | ||
| 589 | + ${status}= compare_coordinates ${left_lat} ${left_lon} ${right_lat} ${right_lon} ${accuracy} | ||
| 590 | + Should Be True ${status} msg=Coordinates differ: (${left_lat}, ${left_lon}) != (${right_lat}, ${right_lon}) | ||
| 591 | + | ||
| 592 | + | ||
| 593 | +Звірити поля предметів закупівлі багатопредметного тендера | ||
| 594 | + [Arguments] ${username} ${tender_data} ${field} | ||
| 595 | + @{items}= get_from_object ${tender_data.data} items | ||
| 596 | + ${len_of_items}= Get Length ${items} | ||
| 597 | + :FOR ${index} IN RANGE ${len_of_items} | ||
| 598 | + \ Звірити поле тендера ${viewer} ${tender_data} items[${index}].${field} | ||
| 599 | + | ||
| 600 | + | ||
| 601 | +Звірити дату предметів закупівлі багатопредметного тендера | ||
| 602 | + [Arguments] ${username} ${tender_data} ${field} ${accuracy}=60 ${absolute_delta}=${False} | ||
| 603 | + @{items}= get_from_object ${tender_data.data} items | ||
| 604 | + :FOR ${index} ${_} IN ENUMERATE @{items} | ||
| 605 | + \ Звірити дату тендера ${viewer} ${TENDER['TENDER_UAID']} ${tender_data} items[${index}].${field} accuracy=${accuracy} absolute_delta=${absolute_delta} | ||
| 606 | + | ||
| 607 | + | ||
| 608 | +Звірити координати доставки предметів закупівлі багатопредметного тендера | ||
| 609 | + [Arguments] ${username} ${tender_data} | ||
| 610 | + @{items}= get_from_object ${tender_data.data} items | ||
| 611 | + :FOR ${index} ${_} IN ENUMERATE @{items} | ||
| 612 | + \ Звірити координати тендера ${viewer} ${tender_data} items[${index}] | ||
| 613 | + | ||
| 614 | + | ||
| 615 | +Отримати дані із тендера | ||
| 616 | + [Arguments] ${username} ${tender_uaid} ${field_name} ${object_id}=${Empty} | ||
| 617 | + ${field}= Run Keyword If '${object_id}' Отримати шлях до поля об’єкта ${username} ${field_name} ${object_id} | ||
| 618 | + ... ELSE Set Variable ${field_name} | ||
| 619 | + ${status} ${field_value}= Run keyword and ignore error | ||
| 620 | + ... get_from_object | ||
| 621 | + ... ${USERS.users['${username}'].tender_data.data} | ||
| 622 | + ... ${field} | ||
| 623 | + # If field in cache, return its value | ||
| 624 | + Run Keyword if '${status}' == 'PASS' Return from keyword ${field_value} | ||
| 625 | + # Else call broker to find field | ||
| 626 | + ${field_value}= Run Keyword IF '${object_id}' Отримати дані із об’єкта тендера ${username} ${tender_uaid} ${object_id} ${field_name} | ||
| 627 | + ... ELSE Run As ${username} Отримати інформацію із тендера ${tender_uaid} ${field} | ||
| 628 | + # And caching its value before return | ||
| 629 | + Set_To_Object ${USERS.users['${username}'].tender_data.data} ${field} ${field_value} | ||
| 630 | + ${data}= munch_dict arg=${USERS.users['${username}'].tender_data.data} | ||
| 631 | + Set To Dictionary ${USERS.users['${username}'].tender_data} data=${data} | ||
| 632 | + Log ${USERS.users['${username}'].tender_data.data} | ||
| 633 | + [return] ${field_value} | ||
| 634 | + | ||
| 635 | + | ||
| 636 | +Отримати дані із плану | ||
| 637 | + [Arguments] ${username} ${tender_uaid} ${field_name} ${object_id}=${Empty} | ||
| 638 | + ${field}= Run Keyword If '${object_id}' Отримати шлях до поля об’єкта ${username} ${field_name} ${object_id} | ||
| 639 | + ... ELSE Set Variable ${field_name} | ||
| 640 | + ${status} ${field_value}= Run keyword and ignore error | ||
| 641 | + ... get_from_object | ||
| 642 | + ... ${USERS.users['${username}'].tender_data.data} | ||
| 643 | + ... ${field} | ||
| 644 | + # If field in cache, return its value | ||
| 645 | + Run Keyword if '${status}' == 'PASS' Return from keyword ${field_value} | ||
| 646 | + # Else call broker to find field | ||
| 647 | + ${field_value}= Run As ${username} Отримати інформацію із плану ${tender_uaid} ${field} | ||
| 648 | + # And caching its value before return | ||
| 649 | + Set_To_Object ${USERS.users['${username}'].tender_data.data} ${field} ${field_value} | ||
| 650 | + ${data}= munch_dict arg=${USERS.users['${username}'].tender_data.data} | ||
| 651 | + Set To Dictionary ${USERS.users['${username}'].tender_data} data=${data} | ||
| 652 | + Log ${USERS.users['${username}'].tender_data.data} | ||
| 653 | + [return] ${field_value} | ||
| 654 | + | ||
| 655 | + | ||
| 656 | +Отримати дані із договору | ||
| 657 | + [Arguments] ${username} ${contract_uaid} ${field} | ||
| 658 | + ${status} ${field_value}= Run keyword and ignore error | ||
| 659 | + ... get_from_object | ||
| 660 | + ... ${USERS.users['${username}'].contract_data.data} | ||
| 661 | + ... ${field} | ||
| 662 | + # If field in cache, return its value | ||
| 663 | + Run Keyword if '${status}' == 'PASS' Return from keyword ${field_value} | ||
| 664 | + # Else call broker to find field | ||
| 665 | + ${field_value}= Run As ${username} Отримати інформацію із договору ${contract_uaid} ${field} | ||
| 666 | + # And caching its value before return | ||
| 667 | + Set_To_Object ${USERS.users['${username}'].contract_data.data} ${field} ${field_value} | ||
| 668 | + ${data}= munch_dict arg=${USERS.users['${username}'].contract_data.data} | ||
| 669 | + Set To Dictionary ${USERS.users['${username}'].contract_data} data=${data} | ||
| 670 | + Log ${USERS.users['${username}'].contract_data.data} | ||
| 671 | + [return] ${field_value} | ||
| 672 | + | ||
| 673 | + | ||
| 674 | +Отримати шлях до поля об’єкта | ||
| 675 | + [Arguments] ${username} ${field_name} ${object_id} | ||
| 676 | + ${object_type}= get_object_type_by_id ${object_id} | ||
| 677 | + ${objects}= Get Variable Value ${USERS.users['${username}'].tender_data.data['${object_type}']} ${None} | ||
| 678 | + ${object_index}= get_object_index_by_id ${objects} ${object_id} | ||
| 679 | + [return] ${object_type}[${object_index}].${field_name} | ||
| 680 | + | ||
| 681 | + | ||
| 682 | +Отримати дані із об’єкта тендера | ||
| 683 | + [Arguments] ${username} ${tender_uaid} ${object_id} ${field_name} | ||
| 684 | + ${object_type}= get_object_type_by_id ${object_id} | ||
| 685 | + ${status} ${value}= Run Keyword If '${object_type}'=='questions' | ||
| 686 | + ... Run Keyword And Ignore Error Run As ${username} Отримати інформацію із запитання ${tender_uaid} ${object_id} ${field_name} | ||
| 687 | + ... ELSE IF '${object_type}'=='lots' | ||
| 688 | + ... Run Keyword And Ignore Error Run As ${username} Отримати інформацію із лоту ${tender_uaid} ${object_id} ${field_name} | ||
| 689 | + ... ELSE IF '${object_type}'=='items' | ||
| 690 | + ... Run Keyword And Ignore Error Run As ${username} Отримати інформацію із предмету ${tender_uaid} ${object_id} ${field_name} | ||
| 691 | + ... ELSE IF '${object_type}'=='features' | ||
| 692 | + ... Run Keyword And Ignore Error Run As ${username} Отримати інформацію із нецінового показника ${tender_uaid} ${object_id} ${field_name} | ||
| 693 | + ${field}= Отримати шлях до поля об’єкта ${username} ${field_name} ${object_id} | ||
| 694 | + ${field_value}= Run Keyword IF '${status}'=='PASS' Set Variable ${value} | ||
| 695 | + ... ELSE Run As ${username} Отримати інформацію із тендера ${tender_uaid} ${field} | ||
| 696 | + [return] ${field_value} | ||
| 697 | + | ||
| 698 | + | ||
| 699 | +Отримати ідентифікатори об’єктів | ||
| 700 | + [Arguments] ${username} ${objects_type} | ||
| 701 | + @{objects_ids}= Create List | ||
| 702 | + @{objects}= Get from object ${USERS.users['${username}'].tender_data.data} ${objects_type} | ||
| 703 | + :FOR ${obj} IN @{objects} | ||
| 704 | + \ ${obj_id}= get_id_from_object ${obj} | ||
| 705 | + \ Append To List ${objects_ids} ${obj_id} | ||
| 706 | + [return] ${objects_ids} | ||
| 707 | + | ||
| 708 | + | ||
| 709 | +Звірити поле скарги із значенням | ||
| 710 | + [Arguments] ${username} ${tender_uaid} ${given_value} ${field_name} ${complaintID} ${award_index}=${None} | ||
| 711 | + ${received_value}= Run as ${username} Отримати інформацію із скарги ${tender_uaid} ${complaintID} ${field_name} ${award_index} | ||
| 712 | + Порівняти об'єкти ${given_value} ${received_value} | ||
| 713 | + | ||
| 714 | + | ||
| 715 | +Run As | ||
| 716 | + [Arguments] ${username} ${command} @{arguments} | ||
| 717 | + [Documentation] | ||
| 718 | + ... Run the given keyword (``command``) with given ``arguments`` | ||
| 719 | + ... using driver (keyword library) of user ``username``. | ||
| 720 | + Log ${username} | ||
| 721 | + Log ${command} | ||
| 722 | + Log Many @{arguments} | ||
| 723 | + ${keywords_file}= Get Broker Property By Username ${username} keywords_file | ||
| 724 | + Run Keyword And Return ${keywords_file}.${command} ${username} @{arguments} | ||
| 725 | + | ||
| 726 | + | ||
| 727 | +Require Failure | ||
| 728 | + [Arguments] ${username} ${command} @{arguments} | ||
| 729 | + [Documentation] | ||
| 730 | + ... Sometimes we need to make sure that the given keyword fails. | ||
| 731 | + ... | ||
| 732 | + ... This keyword works just like `Run As`, but it passes only | ||
| 733 | + ... if ``command`` with ``arguments`` fails and vice versa. | ||
| 734 | + Log ${username} | ||
| 735 | + Log ${command} | ||
| 736 | + Log Many @{arguments} | ||
| 737 | + ${keywords_file}= Get Broker Property By Username ${username} keywords_file | ||
| 738 | + ${status} ${value}= Run keyword and ignore keyword definitions ${keywords_file}.${command} ${username} @{arguments} | ||
| 739 | + Run keyword if '${status}' == 'PASS' Fail Користувач ${username} зміг виконати "${command}" | ||
| 740 | + [return] ${value} | ||
| 741 | + | ||
| 742 | + | ||
| 743 | + | ||
| 744 | +Можливість отримати посилання на аукціон для глядача | ||
| 745 | + ${timeout_on_wait}= Get Broker Property By Username ${viewer} timeout_on_wait | ||
| 746 | + ${timeout_on_wait}= Set Variable If | ||
| 747 | + ... ${timeout_on_wait} < ${120} | ||
| 748 | + ... ${120} | ||
| 749 | + ... ${timeout_on_wait} | ||
| 750 | + ${url}= Wait Until Keyword Succeeds | ||
| 751 | + ... ${timeout_on_wait} | ||
| 752 | + ... 15 s | ||
| 753 | + ... Run As ${viewer} Отримати посилання на аукціон для глядача ${TENDER['TENDER_UAID']} | ||
| 754 | + Should Be True '${url}' | ||
| 755 | + Should Match Regexp ${url} ^https?:\/\/auction(?:-sandbox)?\.openprocurement\.org\/tenders\/([0-9A-Fa-f]{32}) | ||
| 756 | + Log URL аукціону для глядача: ${url} | ||
| 757 | + | ||
| 758 | + | ||
| 759 | +Можливість отримати посилання на аукціон для учасника ${username} | ||
| 760 | + ${timeout_on_wait}= Get Broker Property By Username ${username} timeout_on_wait | ||
| 761 | + ${timeout_on_wait}= Set Variable If | ||
| 762 | + ... ${timeout_on_wait} < ${120} | ||
| 763 | + ... ${120} | ||
| 764 | + ... ${timeout_on_wait} | ||
| 765 | + ${url}= Wait Until Keyword Succeeds | ||
| 766 | + ... ${timeout_on_wait} | ||
| 767 | + ... 15 s | ||
| 768 | + ... Run As ${username} Отримати посилання на аукціон для учасника ${TENDER['TENDER_UAID']} | ||
| 769 | + Should Be True '${url}' | ||
| 770 | + Should Match Regexp ${url} ^https?:\/\/auction(?:-sandbox)?\.openprocurement\.org\/tenders\/([0-9A-Fa-f]{32}) | ||
| 771 | + Log URL аукціону для учасника: ${url} | ||
| 772 | + | ||
| 773 | + | ||
| 774 | +Дочекатись дати | ||
| 775 | + [Arguments] ${date} | ||
| 776 | + ${sleep}= wait_to_date ${date} | ||
| 777 | + Run Keyword If ${sleep} > 0 Sleep ${sleep} | ||
| 778 | + | ||
| 779 | + | ||
| 780 | +Дочекатись дати початку періоду уточнень | ||
| 781 | + [Arguments] ${username} ${tender_uaid} | ||
| 782 | + # XXX: HACK: Same as below | ||
| 783 | + ${status} ${date}= Run Keyword And Ignore Error | ||
| 784 | + ... Set Variable | ||
| 785 | + ... ${USERS.users['${username}'].tender_data.data.enquiryPeriod.startDate} | ||
| 786 | + ${date}= Set Variable If | ||
| 787 | + ... '${status}' == 'FAIL' | ||
| 788 | + ... ${USERS.users['${tender_owner}'].initial_data.data.enquiryPeriod.startDate} | ||
| 789 | + ... ${date} | ||
| 790 | + Дочекатись дати ${date} | ||
| 791 | + Оновити LAST_MODIFICATION_DATE | ||
| 792 | + Дочекатись синхронізації з майданчиком ${username} | ||
| 793 | + ${next_status}= Set variable if 'open' in '${MODE}' active.tendering active.enquiries | ||
| 794 | + Wait until keyword succeeds | ||
| 795 | + ... 5 min 15 sec | ||
| 796 | + ... 15 sec | ||
| 797 | + ... Звірити статус тендера | ||
| 798 | + ... ${username} | ||
| 799 | + ... ${tender_uaid} | ||
| 800 | + ... ${next_status} | ||
| 801 | + | ||
| 802 | + | ||
| 803 | +Дочекатись дати закінчення періоду уточнень | ||
| 804 | + [Arguments] ${username} ${tender_uaid} | ||
| 805 | + Дочекатись дати ${USERS.users['${username}'].tender_data.data.enquiryPeriod.endDate} | ||
| 806 | + Оновити LAST_MODIFICATION_DATE | ||
| 807 | + Дочекатись синхронізації з майданчиком ${username} | ||
| 808 | + Wait until keyword succeeds | ||
| 809 | + ... 10 min 15 sec | ||
| 810 | + ... 15 sec | ||
| 811 | + ... Звірити статус тендера | ||
| 812 | + ... ${username} | ||
| 813 | + ... ${tender_uaid} | ||
| 814 | + ... active.tendering | ||
| 815 | + | ||
| 816 | + | ||
| 817 | +Дочекатись дати закінчення періоду відповідей на запитання | ||
| 818 | + [Arguments] ${username} | ||
| 819 | + Дочекатись дати ${USERS.users['${username}'].tender_data.data.enquiryPeriod.clarificationsUntil} | ||
| 820 | + Оновити LAST_MODIFICATION_DATE | ||
| 821 | + Дочекатись синхронізації з майданчиком ${username} | ||
| 822 | + | ||
| 823 | + | ||
| 824 | +Звірити статус тендера | ||
| 825 | + [Arguments] ${username} ${tender_uaid} ${left} | ||
| 826 | + ${right}= Run as ${username} Отримати інформацію із тендера ${tender_uaid} status | ||
| 827 | + Порівняти об'єкти ${left} ${right} | ||
| 828 | + | ||
| 829 | + | ||
| 830 | +Звірити статус вимоги/скарги | ||
| 831 | + [Arguments] ${username} ${tender_uaid} ${complaintID} ${left} ${award_index}=${None} | ||
| 832 | + ${right}= Run as ${username} Отримати інформацію із скарги ${tender_uaid} ${complaintID} status ${award_index} | ||
| 833 | + Порівняти об'єкти ${left} ${right} | ||
| 834 | + | ||
| 835 | + | ||
| 836 | +Дочекатись дати початку прийому пропозицій | ||
| 837 | + [Arguments] ${username} ${tender_uaid} | ||
| 838 | + # This tries to get the date from current user's procurement data cache. | ||
| 839 | + # On failure, it reads from tender_owner's cached initial_data. | ||
| 840 | + # XXX: This is a dirty hack! | ||
| 841 | + # HACK: It was left here only for backward compatibiliy. | ||
| 842 | + # HACK: Before caching was implemented, this keyword used to look into | ||
| 843 | + # HACK: tender_owner's initial_data. | ||
| 844 | + # HACK: This should be cleaned up as soon as each broker implements reading | ||
| 845 | + # HACK: of the needed dates from tender's page. | ||
| 846 | + ${status} ${date}= Run Keyword And Ignore Error | ||
| 847 | + ... Set Variable | ||
| 848 | + ... ${USERS.users['${username}'].tender_data.data.tenderPeriod.startDate} | ||
| 849 | + # By default if condition is not satisfied, variable is set to None. | ||
| 850 | + # The third argument sets the variable to itself instead of None. | ||
| 851 | + ${date}= Set Variable If | ||
| 852 | + ... '${status}' == 'FAIL' | ||
| 853 | + ... ${USERS.users['${tender_owner}'].initial_data.data.tenderPeriod.startDate} | ||
| 854 | + ... ${date} | ||
| 855 | + Дочекатись дати ${date} | ||
| 856 | + Оновити LAST_MODIFICATION_DATE | ||
| 857 | + Дочекатись синхронізації з майданчиком ${username} | ||
| 858 | + Wait until keyword succeeds | ||
| 859 | + ... 30 min 15 sec | ||
| 860 | + ... 15 sec | ||
| 861 | + ... Звірити статус тендера | ||
| 862 | + ... ${username} | ||
| 863 | + ... ${tender_uaid} | ||
| 864 | + ... active.tendering | ||
| 865 | + | ||
| 866 | + | ||
| 867 | +Дочекатись дати закінчення прийому пропозицій | ||
| 868 | + [Arguments] ${username} ${tender_uaid} | ||
| 869 | + # XXX: HACK: Same as above | ||
| 870 | + ${status} ${date}= Run Keyword And Ignore Error | ||
| 871 | + ... Set Variable | ||
| 872 | + ... ${USERS.users['${username}'].tender_data.data.tenderPeriod.endDate} | ||
| 873 | + ${date}= Set Variable If | ||
| 874 | + ... '${status}' == 'FAIL' | ||
| 875 | + ... ${USERS.users['${tender_owner}'].initial_data.data.tenderPeriod.endDate} | ||
| 876 | + ... ${date} | ||
| 877 | + Дочекатись дати ${date} | ||
| 878 | + Оновити LAST_MODIFICATION_DATE | ||
| 879 | + Дочекатись синхронізації з майданчиком ${username} | ||
| 880 | + Wait until keyword succeeds | ||
| 881 | + ... 40 min 15 sec | ||
| 882 | + ... 15 sec | ||
| 883 | + ... Run Keyword And Expect Error * | ||
| 884 | + ... Звірити статус тендера | ||
| 885 | + ... ${username} | ||
| 886 | + ... ${tender_uaid} | ||
| 887 | + ... active.tendering | ||
| 888 | + | ||
| 889 | + | ||
| 890 | +Дочекатись дати початку періоду прекваліфікації | ||
| 891 | + [Arguments] ${username} ${tender_uaid} | ||
| 892 | + # XXX: HACK: Same as above | ||
| 893 | + ${status} ${date}= Run Keyword And Ignore Error | ||
| 894 | + ... Set Variable | ||
| 895 | + ... ${USERS.users['${username}'].tender_data.data.tenderPeriod.endDate} | ||
| 896 | + ${date}= Set Variable If | ||
| 897 | + ... '${status}' == 'FAIL' | ||
| 898 | + ... ${USERS.users['${tender_owner}'].initial_data.data.tenderPeriod.endDate} | ||
| 899 | + ... ${date} | ||
| 900 | + Дочекатись дати ${date} | ||
| 901 | + Оновити LAST_MODIFICATION_DATE | ||
| 902 | + Дочекатись синхронізації з майданчиком ${username} | ||
| 903 | + Wait until keyword succeeds | ||
| 904 | + ... 20 min 15 sec | ||
| 905 | + ... 15 sec | ||
| 906 | + ... Звірити статус тендера | ||
| 907 | + ... ${username} | ||
| 908 | + ... ${tender_uaid} | ||
| 909 | + ... active.pre-qualification | ||
| 910 | + | ||
| 911 | + | ||
| 912 | +Дочекатись дати початку очікування | ||
| 913 | + [Arguments] ${username} ${tender_uaid} | ||
| 914 | + # XXX: HACK: Same as above | ||
| 915 | + ${status} ${date}= Run Keyword And Ignore Error | ||
| 916 | + ... Set Variable | ||
| 917 | + ... ${USERS.users['${username}'].tender_data.data.tenderPeriod.endDate} | ||
| 918 | + ${date}= Set Variable If | ||
| 919 | + ... '${status}' == 'FAIL' | ||
| 920 | + ... ${USERS.users['${tender_owner}'].initial_data.data.tenderPeriod.endDate} | ||
| 921 | + ... ${date} | ||
| 922 | + Дочекатись дати ${date} | ||
| 923 | + Оновити LAST_MODIFICATION_DATE | ||
| 924 | + Дочекатись синхронізації з майданчиком ${username} | ||
| 925 | + Wait until keyword succeeds | ||
| 926 | + ... 5 min 15 sec | ||
| 927 | + ... 15 sec | ||
| 928 | + ... Звірити статус тендера | ||
| 929 | + ... ${username} | ||
| 930 | + ... ${tender_uaid} | ||
| 931 | + ... active.stage2.pending | ||
| 932 | + | ||
| 933 | + | ||
| 934 | +Дочекатись дати закінчення періоду прекваліфікації | ||
| 935 | + [Arguments] ${username} ${tender_uaid} | ||
| 936 | + Дочекатись дати ${USERS.users['${username}'].tender_data.data.qualificationPeriod.endDate} | ||
| 937 | + Оновити LAST_MODIFICATION_DATE | ||
| 938 | + Дочекатись синхронізації з майданчиком ${username} | ||
| 939 | + Wait until keyword succeeds | ||
| 940 | + ... 5 min 15 sec | ||
| 941 | + ... 15 sec | ||
| 942 | + ... Run Keyword And Expect Error * | ||
| 943 | + ... Звірити статус тендера | ||
| 944 | + ... ${username} | ||
| 945 | + ... ${tender_uaid} | ||
| 946 | + ... active.pre-qualification.stand-still | ||
| 947 | + | ||
| 948 | + | ||
| 949 | +Дочекатися створення нового етапу мостом | ||
| 950 | + [Arguments] ${username} ${tender_uaid} | ||
| 951 | + Оновити LAST_MODIFICATION_DATE | ||
| 952 | + Дочекатись синхронізації з майданчиком ${username} | ||
| 953 | + Wait until keyword succeeds | ||
| 954 | + ... 10 min 15 sec | ||
| 955 | + ... 15 sec | ||
| 956 | + ... Звірити статус тендера | ||
| 957 | + ... ${username} | ||
| 958 | + ... ${tender_uaid} | ||
| 959 | + ... complete | ||
| 960 | + | ||
| 961 | + | ||
| 962 | +Дочекатись дати початку періоду аукціону | ||
| 963 | + [Arguments] ${username} ${tender_uaid} | ||
| 964 | + Оновити LAST_MODIFICATION_DATE | ||
| 965 | + Дочекатись синхронізації з майданчиком ${username} | ||
| 966 | + Wait until keyword succeeds | ||
| 967 | + ... 40 min 15 sec | ||
| 968 | + ... 15 sec | ||
| 969 | + ... Звірити статус тендера | ||
| 970 | + ... ${username} | ||
| 971 | + ... ${tender_uaid} | ||
| 972 | + ... active.auction | ||
| 973 | + Sleep 120 # Auction sync | ||
| 974 | + | ||
| 975 | + | ||
| 976 | +Дочекатись дати початку періоду кваліфікації | ||
| 977 | + [Arguments] ${username} ${tender_uaid} | ||
| 978 | + Оновити LAST_MODIFICATION_DATE | ||
| 979 | + Дочекатись синхронізації з майданчиком ${username} | ||
| 980 | + Wait until keyword succeeds | ||
| 981 | + ... 40 min 15 sec | ||
| 982 | + ... 15 sec | ||
| 983 | + ... Звірити статус тендера | ||
| 984 | + ... ${username} | ||
| 985 | + ... ${tender_uaid} | ||
| 986 | + ... active.qualification | ||
| 987 | + | ||
| 988 | + | ||
| 989 | +Дочекатись дати закінчення періоду подання скарг | ||
| 990 | + [Arguments] ${username} | ||
| 991 | + Дочекатись дати ${USERS.users['${username}'].tender_data.data.complaintPeriod.endDate} | ||
| 992 | + Оновити LAST_MODIFICATION_DATE | ||
| 993 | + Дочекатись синхронізації з майданчиком ${username} | ||
| 994 | + | ||
| 995 | + | ||
| 996 | +Дочекатись зміни статусу вимоги | ||
| 997 | + [Arguments] ${username} ${status} ${complaintID} ${award_index}=${None} | ||
| 998 | + Дочекатись синхронізації з майданчиком ${username} | ||
| 999 | + Wait until keyword succeeds | ||
| 1000 | + ... 40 min 15 sec | ||
| 1001 | + ... 15 sec | ||
| 1002 | + ... Звірити статус вимоги/скарги | ||
| 1003 | + ... ${provider} | ||
| 1004 | + ... ${TENDER['TENDER_UAID']} | ||
| 1005 | + ... ${complaintID} | ||
| 1006 | + ... ${status} | ||
| 1007 | + ... ${award_index} | ||
| 1008 | + | ||
| 1009 | + | ||
| 1010 | +Оновити LAST_MODIFICATION_DATE | ||
| 1011 | + [Documentation] | ||
| 1012 | + ... Variable ``${TEST_STATUS}`` is only available in test case teardown. | ||
| 1013 | + ... When we call this keyword from elswere, we need to presume that | ||
| 1014 | + ... test status is ``PASS`` (since previous keywords passed and this | ||
| 1015 | + ... one was called). | ||
| 1016 | + ${LAST_MODIFICATION_DATE}= Get Current TZdate | ||
| 1017 | + ${status}= Get Variable Value ${TEST_STATUS} PASS | ||
| 1018 | + Run Keyword If '${status}' == 'PASS' Set To Dictionary ${TENDER} LAST_MODIFICATION_DATE=${LAST_MODIFICATION_DATE} | ||
| 1019 | + | ||
| 1020 | + | ||
| 1021 | +Отримати останній індекс | ||
| 1022 | +<<<<<<< 757d74b2c6bfa0482907833dc95b64e414708a70 | ||
| 1023 | + [Arguments] ${object} ${username} | ||
| 1024 | + ${status}= Run Keyword And Return Status Dictionary Should Contain Key ${USERS.users['${username}'].tender_data.data} ${object} | ||
| 1025 | + Run Keyword If '${status}' == 'False' Fail ${object} not found in \${USERS.users['${username}'].tender_data.data} | ||
| 1026 | + ${len_of_object}= Get Length ${USERS.users['${username}'].tender_data.data.${object}} | ||
| 1027 | + ${index}= subtraction ${len_of_object} 1 | ||
| 1028 | + [Return] ${index} | ||
| 1029 | +======= | ||
| 1030 | + [Arguments] ${object} @{username} | ||
| 1031 | + :FOR ${role} IN @{username} | ||
| 1032 | + \ ${status} ${field_value}= Run Keyword And Ignore Error | ||
| 1033 | + ... get_from_object | ||
| 1034 | + ... ${USERS.users['${role}'].tender_data.data} | ||
| 1035 | + ... ${object} | ||
| 1036 | + \ Run Keyword If '${status}' == 'PASS' Exit For Loop | ||
| 1037 | + ${len_of_object}= Run Keyword If '${status}' == 'PASS' Get Length ${USERS.users['${role}'].tender_data.data.${object}} | ||
| 1038 | + ${index}= Run Keyword If '${status}' == 'PASS' subtraction ${len_of_object} 1 | ||
| 1039 | + [Return] ${index} | ||
| 1040 | +>>>>>>> Modify Отримати останній індекс keyword |
Please
register
or
login
to post a comment