Commit 869316bde4772cd09631b8ca89086eb85736dab5
Merge remote-tracking branch 'yboi/E-Tender' into candy
Conflicts: op_robot_tests/tests_files/brokers/etender.robot op_robot_tests/tests_files/service_keywords.py
Showing
2 changed files
with
258 additions
and
115 deletions
| ... | ... | @@ -4,15 +4,44 @@ Library String |
| 4 | 4 | Library DateTime |
| 5 | 5 | |
| 6 | 6 | *** Variables *** |
| 7 | -${locator.tenderId} jquery=h3 | |
| 8 | -##Використовую такий шлях у кожного буде мінятись /yboi/. Міняйте на сві шлях до файлу | |
| 9 | -${file_add} /home/yboi/openprocurement.robottests.buildout/Document.docx | |
| 10 | -${locator.title} xpath=(//div[@class = 'col-sm-8']/p[@class='ng-binding'])[6] | |
| 11 | -${locator.description} xpath=(//div[@class = 'col-sm-8']/p[@class='ng-binding'])[7] | |
| 12 | -${locator.minimalStep.amount} xpath=(//div[@class = 'col-sm-8']/p[@class='ng-binding'])[9] | |
| 13 | -${locator.value.amount} xpath=(//div[@class = 'col-sm-8']/p[@class='ng-binding'])[8] | |
| 7 | +${locator.tenderId} jquery=h3 | |
| 8 | +${locator.title} jquery=tender-subject-info>div.row:contains("Назва закупівлі:")>:eq(1)> | |
| 9 | +${locator.description} jquery=tender-subject-info>div.row:contains("Детальний опис закупівлі:")>:eq(1)> | |
| 10 | +${locator.minimalStep.amount} xpath=(//div[@class = 'col-sm-8']/p[@class='ng-binding'])[9] | |
| 11 | +${locator.procuringEntity.name} jquery=customer-info>div.row:contains("Найменування:")>:eq(1)> | |
| 12 | +${locator.value.amount} xpath=(//div[@class = 'col-sm-8']/p[@class='ng-binding'])[8] | |
| 13 | +${locator.tenderPeriod.startDate} xpath=(//div[@class = 'col-sm-8']/p[@class='ng-binding'])[3] | |
| 14 | +${locator.tenderPeriod.endDate} xpath=(//div[@class = 'col-sm-8']/p[@class='ng-binding'])[4] | |
| 15 | +${locator.enquiryPeriod.startDate} xpath=(//div[@class = 'col-sm-8']/p[@class='ng-binding'])[1] | |
| 16 | +${locator.enquiryPeriod.endDate} xpath=(//div[@class = 'col-sm-8']/p[@class='ng-binding'])[2] | |
| 17 | +${locator.items[0].description} xpath=(//div[@class = 'col-sm-8']/p[@class='ng-binding'])[12] | |
| 18 | +${locator.items[0].deliveryDate.endDate} xpath=(//div[@class = 'col-sm-8']/p[@class='ng-binding'])[14] | |
| 19 | +${locator.items[0].deliveryLocation.latitude} xpath=(//div[@class = 'col-sm-8']/p[@class='ng-binding'])[15] | |
| 20 | +${locator.items[0].deliveryLocation.longitude} xpath=(//div[@class = 'col-sm-8']/p[@class='ng-binding'])[15] | |
| 21 | +${locator.items[0].deliveryAddress.postalCode} xpath=//div[@class='col-sm-8']//span[@ng-if='item.deliveryAddress.postIndex'] | |
| 22 | +${locator.items[0].deliveryAddress.countryName} xpath=//div[@class='col-sm-8']//span[@ng-if='item.deliveryAddress.country.title'] | |
| 23 | +${locator.items[0].deliveryAddress.region} xpath=//div[@class='col-sm-8']//span[@ng-if='item.deliveryAddress.region.title'] | |
| 24 | +${locator.items[0].deliveryAddress.locality} xpath=//div[@class='col-sm-8']//span[@ng-if='item.deliveryAddress.city.title'] | |
| 25 | +${locator.items[0].deliveryAddress.streetAddress} xpath=//div[@class='col-sm-8']//span[@ng-if='item.deliveryAddress.addressStr'] | |
| 26 | +${locator.items[0].classification.scheme} xpath=(//div[@class = 'col-sm-4']/p)[11] | |
| 27 | +${locator.items[0].classification.id} xpath=(//div[@class = 'col-sm-8']/p[@class='ng-binding'])[10] | |
| 28 | +${locator.items[0].classification.description} xpath=(//div[@class = 'col-sm-8']/p[@class='ng-binding'])[10] | |
| 29 | +${locator.items[0].additionalClassifications[0].scheme} xpath=(//div[@class = 'col-sm-4']/p)[12] | |
| 30 | +${locator.items[0].additionalClassifications[0].id} xpath=(//div[@class = 'col-sm-8']/p[@class='ng-binding'])[11] | |
| 31 | +${locator.items[0].additionalClassifications[0].description} xpath=(//div[@class = 'col-sm-8']/p[@class='ng-binding'])[11] | |
| 32 | +${locator.items[0].unit.code} xpath=(//div[@class = 'col-sm-8']/p[@class='ng-binding'])[13] | |
| 33 | +${locator.items[0].quantity} xpath=(//div[@class = 'col-sm-8']/p[@class='ng-binding'])[13] | |
| 34 | +${locator.questions[0].title} xpath=(//div[@class='col-sm-10']/span[@class='ng-binding'])[2] | |
| 35 | +${locator.questions[0].description} xpath=(//div[@class='col-sm-10']/span[@class='ng-binding'])[3] | |
| 36 | +${locator.questions[0].date} xpath=(//div[@class='col-sm-10']/span[@class='ng-binding'])[1] | |
| 37 | +${locator.questions[0].answer} xpath=(//div[@textarea='question.answer']/pre[@class='ng-binding'])[1] | |
| 14 | 38 | |
| 15 | 39 | *** Keywords *** |
| 40 | +Підготувати дані для оголошення тендера | |
| 41 | + ${INITIAL_TENDER_DATA}= prepare_test_tender_data | |
| 42 | + ${INITIAL_TENDER_DATA}= Add_data_for_GUI_FrontEnds ${INITIAL_TENDER_DATA} | |
| 43 | + [return] ${INITIAL_TENDER_DATA} | |
| 44 | + | |
| 16 | 45 | Підготувати клієнт для користувача |
| 17 | 46 | [Arguments] @{ARGUMENTS} |
| 18 | 47 | [Documentation] Відкрити брaвзер, створити обєкт api wrapper, тощо |
| ... | ... | @@ -23,9 +52,9 @@ ${locator.value.amount} xpath=(//div[@class = 'col-sm-8']/p[@class= |
| 23 | 52 | Run Keyword If '${username}' != 'E-tender_Viewer' Login |
| 24 | 53 | |
| 25 | 54 | Login |
| 26 | - Wait Until Page Contains Element id=inputUsername 100 | |
| 55 | + Wait Until Page Contains Element id=inputUsername 10 | |
| 27 | 56 | Input text id=inputUsername ${USERS.users['${username}'].login} |
| 28 | - Wait Until Page Contains Element id=inputPassword 100 | |
| 57 | + Wait Until Page Contains Element id=inputPassword 10 | |
| 29 | 58 | Input text id=inputPassword ${USERS.users['${username}'].password} |
| 30 | 59 | Click Button id=btn_submit |
| 31 | 60 | |
| ... | ... | @@ -33,31 +62,39 @@ Login |
| 33 | 62 | [Arguments] @{ARGUMENTS} |
| 34 | 63 | [Documentation] |
| 35 | 64 | ... ${ARGUMENTS[0]} == username |
| 36 | - ... ${ARGUMENTS[1]} == initial_tender_data | |
| 37 | - ${prepared_tender_data}= Add_data_for_GUI_FrontEnds ${ARGUMENTS[1]} | |
| 38 | - ${items}= Get From Dictionary ${prepared_tender_data.data} items | |
| 39 | - ${title}= Get From Dictionary ${prepared_tender_data.data} title | |
| 40 | - ${description}= Get From Dictionary ${prepared_tender_data.data} description | |
| 41 | - ${budget}= Get From Dictionary ${prepared_tender_data.data.value} amount | |
| 42 | - ${step_rate}= Get From Dictionary ${prepared_tender_data.data.minimalStep} amount | |
| 43 | - ${items_description}= Get From Dictionary ${prepared_tender_data.data} description | |
| 65 | + ... ${ARGUMENTS[1]} == tender_data | |
| 66 | + ${INITIAL_TENDER_DATA}= procuringEntity_name ${INITIAL_TENDER_DATA} | |
| 67 | + ${tender_data}= Add_data_for_GUI_FrontEnds ${ARGUMENTS[1]} | |
| 68 | + ${items}= Get From Dictionary ${tender_data.data} items | |
| 69 | + ${title}= Get From Dictionary ${tender_data.data} title | |
| 70 | + ${description}= Get From Dictionary ${tender_data.data} description | |
| 71 | + ${budget}= Get From Dictionary ${tender_data.data.value} amount | |
| 72 | + ${step_rate}= Get From Dictionary ${tender_data.data.minimalStep} amount | |
| 73 | + ${items_description}= Get From Dictionary ${items[0]} description | |
| 44 | 74 | ${quantity}= Get From Dictionary ${items[0]} quantity |
| 45 | 75 | ${cpv}= Get From Dictionary ${items[0].classification} id |
| 46 | 76 | ${unit}= Get From Dictionary ${items[0].unit} name |
| 47 | - ${start_date}= Get From Dictionary ${prepared_tender_data.data.tenderPeriod} startDate | |
| 77 | + ${latitude} Get From Dictionary ${items[0].deliveryLocation} latitude | |
| 78 | + ${longitude} Get From Dictionary ${items[0].deliveryLocation} longitude | |
| 79 | + ${postalCode} Get From Dictionary ${items[0].deliveryAddress} postalCode | |
| 80 | + ${streetAddress} Get From Dictionary ${items[0].deliveryAddress} streetAddress | |
| 81 | + ${deliveryDate} Get From Dictionary ${items[0].deliveryDate} endDate | |
| 82 | + ${deliveryDate} convert_date_to_etender_format ${deliveryDate} | |
| 83 | + ${start_date}= Get From Dictionary ${tender_data.data.tenderPeriod} startDate | |
| 48 | 84 | ${start_date}= convert_date_to_etender_format ${start_date} |
| 49 | - ${start_time}= Get From Dictionary ${prepared_tender_data.data.tenderPeriod} startDate | |
| 85 | + ${start_time}= Get From Dictionary ${tender_data.data.tenderPeriod} startDate | |
| 50 | 86 | ${start_time}= convert_time_to_etender_format ${start_time} |
| 51 | - ${end_date}= Get From Dictionary ${prepared_tender_data.data.tenderPeriod} endDate | |
| 87 | + ${end_date}= Get From Dictionary ${tender_data.data.tenderPeriod} endDate | |
| 52 | 88 | ${end_date}= convert_date_to_etender_format ${end_date} |
| 53 | - ${end_time}= Get From Dictionary ${prepared_tender_data.data.tenderPeriod} endDate | |
| 89 | + ${end_time}= Get From Dictionary ${tender_data.data.tenderPeriod} endDate | |
| 54 | 90 | ${end_time}= convert_time_to_etender_format ${end_time} |
| 55 | - ${enquiry_end_date}= Get From Dictionary ${prepared_tender_data.data.enquiryPeriod} endDate | |
| 91 | + ${enquiry_end_date}= Get From Dictionary ${tender_data.data.enquiryPeriod} endDate | |
| 56 | 92 | ${enquiry_end_date}= convert_date_to_etender_format ${enquiry_end_date} |
| 57 | - ${enquiry_end_time}= Get From Dictionary ${prepared_tender_data.data.enquiryPeriod} endDate | |
| 93 | + ${enquiry_end_time}= Get From Dictionary ${tender_data.data.enquiryPeriod} endDate | |
| 58 | 94 | ${enquiry_end_time}= convert_time_to_etender_format ${enquiry_end_time} |
| 95 | + | |
| 59 | 96 | Selenium2Library.Switch Browser ${ARGUMENTS[0]} |
| 60 | - Wait Until Page Contains Мої закупівлі 100 | |
| 97 | + Wait Until Page Contains Мої закупівлі 10 | |
| 61 | 98 | Sleep 1 |
| 62 | 99 | Click Element xpath=//a[contains(@class, 'ng-binding')][./text()='Мої закупівлі'] |
| 63 | 100 | Wait Until Page Contains Element xpath=//a[contains(@class, 'btn btn-info')] |
| ... | ... | @@ -71,6 +108,16 @@ Login |
| 71 | 108 | Input text id=minimalStep ${step_rate} |
| 72 | 109 | Input text id=itemsDescription ${items_description} |
| 73 | 110 | Input text id=itemsQuantity ${quantity} |
| 111 | + Input text name=delStartDate ${deliveryDate} | |
| 112 | + Sleep 2 | |
| 113 | + Input text xpath=//input[@ng-model='data.items[0].deliveryDate.endDate'] ${deliveryDate} | |
| 114 | + Input text name=latitude ${latitude} | |
| 115 | + Input text name=longitude ${longitude} | |
| 116 | + Click Element xpath=//select[@name='region']//option[@label='Київська'] | |
| 117 | + Sleep 2 | |
| 118 | + Click Element xpath=//select[@name='city']//option[@label='Київ'] | |
| 119 | + Input text name=addressStr ${streetAddress} | |
| 120 | + Input text name=postIndex ${postalCode} | |
| 74 | 121 | Wait Until Page Contains Element xpath=//select[@name="itemsUnit"]/option[@value='kilogram'] |
| 75 | 122 | Click Element xpath=//select[@name="itemsUnit"]/option[@value='kilogram'] |
| 76 | 123 | Input text xpath=//div[contains(@class, 'form-group col-sm-8')]//input[@name='enqPEndDate'] ${enquiry_end_date} |
| ... | ... | @@ -95,7 +142,7 @@ Login |
| 95 | 142 | Wait Until Page Contains Element xpath=//div[contains(@class, 'form-actions')]//button[@type='submit'] |
| 96 | 143 | Click Element xpath=//div[contains(@class, 'form-actions')]//button[@type='submit'] |
| 97 | 144 | Sleep 1 |
| 98 | - Wait Until Page Contains [ТЕСТУВАННЯ] 100 | |
| 145 | + Wait Until Page Contains [ТЕСТУВАННЯ] 10 | |
| 99 | 146 | Sleep 20 |
| 100 | 147 | Click Element xpath=//*[text()='${title}'] |
| 101 | 148 | Sleep 5 |
| ... | ... | @@ -113,16 +160,6 @@ Set Multi Ids |
| 113 | 160 | ${id}= Get Substring ${current_location} 10 |
| 114 | 161 | ${Ids}= Create List ${tender_UAid} ${id} |
| 115 | 162 | |
| 116 | -Oтримати internal id по UAid | |
| 117 | - [Arguments] @{ARGUMENTS} | |
| 118 | - [Documentation] | |
| 119 | - ... ${ARGUMENTS[0]} == username | |
| 120 | - ... ${ARGUMENTS[1]} == ${tender_UAid} | |
| 121 | - etender.Пошук тендера по ідентифікатору ${ARGUMENTS[0]} ${ARGUMENTS[1]} | |
| 122 | - ${current_location}= Get Location | |
| 123 | - ${tender_id}= Fetch From Right ${current_location} / | |
| 124 | - [return] ${tender_id} | |
| 125 | - | |
| 126 | 163 | Додати предмет |
| 127 | 164 | [Arguments] @{ARGUMENTS} |
| 128 | 165 | [Documentation] |
| ... | ... | @@ -167,19 +204,61 @@ Oтримати internal id по UAid |
| 167 | 204 | sleep 1 |
| 168 | 205 | Capture Page Screenshot |
| 169 | 206 | |
| 170 | -Подати цінову пропозицію | |
| 207 | +Завантажити документ | |
| 171 | 208 | [Arguments] @{ARGUMENTS} |
| 172 | 209 | [Documentation] |
| 173 | 210 | ... ${ARGUMENTS[0]} == username |
| 174 | 211 | ... ${ARGUMENTS[1]} == ${TENDER_UAID} |
| 175 | - ... ${ARGUMENTS[2]} == test_bid_data | |
| 212 | + ... ${ARGUMENTS[2]} == ${Complain} | |
| 213 | + Fail Тест не написаний | |
| 176 | 214 | |
| 215 | +Подати скаргу | |
| 216 | + [Arguments] @{ARGUMENTS} | |
| 217 | + [Documentation] | |
| 218 | + ... ${ARGUMENTS[0]} == username | |
| 219 | + ... ${ARGUMENTS[1]} == ${TENDER_UAID} | |
| 220 | + ... ${ARGUMENTS[2]} == ${Complain} | |
| 221 | + Fail Не реалізований функціонал | |
| 222 | + | |
| 223 | +порівняти скаргу | |
| 224 | + [Arguments] @{ARGUMENTS} | |
| 225 | + [Documentation] | |
| 226 | + ... ${ARGUMENTS[0]} == username | |
| 227 | + ... ${ARGUMENTS[1]} == ${file_path} | |
| 228 | + ... ${ARGUMENTS[2]} == ${TENDER_UAID} | |
| 229 | + Fail Не реалізований функціонал | |
| 230 | + | |
| 231 | +Подати цінову пропозицію | |
| 232 | + [Arguments] @{ARGUMENTS} | |
| 233 | + [Documentation] | |
| 234 | + ... ${ARGUMENTS[0]} == username | |
| 235 | + ... ${ARGUMENTS[1]} == ${TENDER_UAID} | |
| 236 | + ... ${ARGUMENTS[2]} == ${test_bid_data} | |
| 177 | 237 | ${bid}= Get From Dictionary ${ARGUMENTS[2].data.value} amount |
| 178 | 238 | etender.Пошук тендера по ідентифікатору ${ARGUMENTS[0]} ${ARGUMENTS[1]} |
| 179 | - Wait Until Page Contains Інформація про процедуру закупівлі 100 | |
| 239 | + Wait Until Page Contains Інформація про процедуру закупівлі 10 | |
| 180 | 240 | Wait Until Page Contains Element id=amount 10 |
| 181 | 241 | Input text id=amount ${bid} |
| 182 | 242 | Click Element xpath=//button[contains(@class, 'btn btn-success')][./text()='Реєстрація пропозиції'] |
| 243 | + DEBUG | |
| 244 | + Click Element xpath=//div[@class='row']/button[@class='btn btn-success'] | |
| 245 | + | |
| 246 | +скасувати цінову пропозицію | |
| 247 | + [Arguments] @{ARGUMENTS} | |
| 248 | + [Documentation] | |
| 249 | + ... ${ARGUMENTS[0]} == username | |
| 250 | + ... ${ARGUMENTS[1]} == ${TENDER_UAID} | |
| 251 | + etender.Пошук тендера по ідентифікатору ${ARGUMENTS[0]} ${ARGUMENTS[1]} | |
| 252 | + Click Element xpath=//button[@class='btn-sm btn-danger ng-isolate-scope'] | |
| 253 | + | |
| 254 | +обновити сторінку з тендером | |
| 255 | + [Arguments] @{ARGUMENTS} | |
| 256 | + [Documentation] | |
| 257 | + ... ${ARGUMENTS[0]} = username | |
| 258 | + ... ${ARGUMENTS[1]} = ${TENDER_UAID} | |
| 259 | + Selenium2Library.Switch Browser ${ARGUMENTS[0]} | |
| 260 | + etender.Пошук тендера по ідентифікатору ${ARGUMENTS[0]} ${ARGUMENTS[1]} | |
| 261 | + Reload Page | |
| 183 | 262 | |
| 184 | 263 | Задати питання |
| 185 | 264 | [Arguments] @{ARGUMENTS} |
| ... | ... | @@ -193,8 +272,7 @@ Oтримати internal id по UAid |
| 193 | 272 | |
| 194 | 273 | Selenium2Library.Switch Browser ${ARGUMENTS[0]} |
| 195 | 274 | etender.Пошук тендера по ідентифікатору ${ARGUMENTS[0]} ${ARGUMENTS[1]} |
| 196 | - | |
| 197 | - Wait Until Page Contains Element jquery=a[href^="#/addQuestion/"] 100 | |
| 275 | + Wait Until Page Contains Element jquery=a[href^="#/addQuestion/"] 10 | |
| 198 | 276 | Click Element jquery=a[href^="#/addQuestion/"] |
| 199 | 277 | Wait Until Page Contains Element id=title |
| 200 | 278 | Input text id=title ${title} |
| ... | ... | @@ -213,22 +291,10 @@ Oтримати internal id по UAid |
| 213 | 291 | |
| 214 | 292 | Selenium2Library.Switch Browser ${ARGUMENTS[0]} |
| 215 | 293 | etender.Пошук тендера по ідентифікатору ${ARGUMENTS[0]} ${ARGUMENTS[1]} |
| 216 | - | |
| 217 | - Click Element xpath=//div[div/pre[1]]/div[1] | |
| 218 | - Input text xpath=//div[textarea]/textarea ${answer} | |
| 219 | - Click Element xpath=//div[textarea]/span/button[1] | |
| 220 | - | |
| 221 | -обновити сторінку з тендером | |
| 222 | - [Arguments] @{ARGUMENTS} | |
| 223 | - [Documentation] | |
| 224 | - ... ${ARGUMENTS[0]} == username | |
| 225 | - ... ${ARGUMENTS[1]} == tenderId | |
| 226 | - ... ${ARGUMENTS[2]} == id | |
| 227 | - ${current_location}= Get Location | |
| 228 | - Run keyword if '${BROKERS['${USERS.users['${username}'].broker}'].url}/#/tenderDetailes/${ARGUMENTS[2]}'=='${current_location}' Reload Page | |
| 229 | - Run keyword unless '${BROKERS['${USERS.users['${username}'].broker}'].url}/#/tenderDetailes/${ARGUMENTS[2]}'=='${current_location}' Пошук тендера по ідентифікатору @{ARGUMENTS} | |
| 230 | - Wait Until Page Contains ${ARGUMENTS[1]} 10 | |
| 231 | - sleep 1 | |
| 294 | + Wait Until Page Contains Element xpath=//pre[@class='ng-binding'][text()='Додати відповідь'] 10 | |
| 295 | + Click Element xpath=//pre[@class='ng-binding'][text()='Додати відповідь'] | |
| 296 | + Input text xpath=//div[@class='editable-controls form-group']//textarea ${answer} | |
| 297 | + Click Element xpath=//span[@class='editable-buttons']/button[@type='submit'] | |
| 232 | 298 | |
| 233 | 299 | Внести зміни в тендер |
| 234 | 300 | [Arguments] @{ARGUMENTS} |
| ... | ... | @@ -271,7 +337,7 @@ Oтримати internal id по UAid |
| 271 | 337 | \ Додати предмет ${items[${INDEX}]} ${INDEX} |
| 272 | 338 | Sleep 2 |
| 273 | 339 | Click Element xpath=//div[@class='form-actions']/button[./text()='Зберегти зміни'] |
| 274 | - Wait Until Page Contains [ТЕСТУВАННЯ] 100 | |
| 340 | + Wait Until Page Contains [ТЕСТУВАННЯ] 10 | |
| 275 | 341 | |
| 276 | 342 | видалити позиції |
| 277 | 343 | etender.Пошук тендера по ідентифікатору ${ARGUMENTS[0]} ${ARGUMENTS[1]} |
| ... | ... | @@ -283,7 +349,7 @@ Oтримати internal id по UAid |
| 283 | 349 | Sleep 2 |
| 284 | 350 | Wait Until Page Contains Element xpath=//div[@class='form-actions']/button[./text()='Зберегти зміни'] 10 |
| 285 | 351 | Click Element xpath=//div[@class='form-actions']/button[./text()='Зберегти зміни'] |
| 286 | - Wait Until Page Contains [ТЕСТУВАННЯ] 100 | |
| 352 | + Wait Until Page Contains [ТЕСТУВАННЯ] 10 | |
| 287 | 353 | |
| 288 | 354 | отримати інформацію із тендера |
| 289 | 355 | [Arguments] @{ARGUMENTS} |
| ... | ... | @@ -329,8 +395,8 @@ Oтримати internal id по UAid |
| 329 | 395 | Remove element ${last_note_id} |
| 330 | 396 | |
| 331 | 397 | отримати інформацію про tenderId |
| 332 | - ${return_value}= отримати тест із поля і показати на сторінці tenderId | |
| 333 | - ${return_value}= Get Substring ${return_value} 10 | |
| 398 | + ${return_value}= Отримати тест із поля і показати на сторінці tenderId | |
| 399 | + ${return_value}= Get Substring ${return_value} 10 | |
| 334 | 400 | [return] ${return_value} |
| 335 | 401 | |
| 336 | 402 | отримати інформацію про procuringEntity.name |
| ... | ... | @@ -338,72 +404,139 @@ Oтримати internal id по UAid |
| 338 | 404 | [return] ${return_value} |
| 339 | 405 | |
| 340 | 406 | отримати інформацію про tenderPeriod.startDate |
| 341 | - ${return_value}= Отримати тест із поля і показати на сторінці tenderPeriod.startDate | |
| 407 | + ${return_value}= Отримати тест із поля і показати на сторінці tenderPeriod.startDate | |
| 408 | + ${return_value}= Change_date_to_month ${return_value} | |
| 342 | 409 | [return] ${return_value} |
| 343 | 410 | |
| 344 | 411 | отримати інформацію про tenderPeriod.endDate |
| 345 | - ${return_value}= Отримати тест із поля і показати на сторінці tenderPeriod.endDate | |
| 412 | + ${return_value}= Отримати тест із поля і показати на сторінці tenderPeriod.endDate | |
| 413 | + ${return_value}= Change_date_to_month ${return_value} | |
| 346 | 414 | [return] ${return_value} |
| 347 | 415 | |
| 348 | 416 | отримати інформацію про enquiryPeriod.startDate |
| 349 | - ${return_value}= Отримати тест із поля і показати на сторінці enquiryPeriod.startDate | |
| 417 | + ${return_value}= Отримати тест із поля і показати на сторінці enquiryPeriod.startDate | |
| 418 | + ${return_value}= Change_date_to_month ${return_value} | |
| 350 | 419 | [return] ${return_value} |
| 351 | 420 | |
| 352 | 421 | отримати інформацію про enquiryPeriod.endDate |
| 353 | - ${return_value}= Отримати тест із поля і показати на сторінці enquiryPeriod.endDate | |
| 422 | + ${return_value}= Отримати тест із поля і показати на сторінці enquiryPeriod.endDate | |
| 423 | + ${return_value}= Change_date_to_month ${return_value} | |
| 354 | 424 | [return] ${return_value} |
| 355 | 425 | |
| 356 | -отримати інформацію про items[${item_id}].description | |
| 357 | - відмітити на сторінці поле з тендера items[${item_id}].description jquery=tender-subject-info.ng-isolate-scope>div.row:contains("Детальний опис предмету закупівлі:")>:eq(1)> | |
| 358 | - ${return_value}= Get Text jquery=tender-subject-info.ng-isolate-scope>div.row:contains("Детальний опис предмету закупівлі:")>:eq(1)> | |
| 426 | +Change_date_to_month | |
| 427 | + [Arguments] @{ARGUMENTS} | |
| 428 | + [Documentation] | |
| 429 | + ... ${ARGUMENTS[0]} == date | |
| 430 | + ${day}= Get Substring ${ARGUMENTS[0]} 0 2 | |
| 431 | + ${month}= Get Substring ${ARGUMENTS[0]} 3 6 | |
| 432 | + ${year}= Get Substring ${ARGUMENTS[0]} 5 | |
| 433 | + ${return_value}= Convert To String ${month}${day}${year} | |
| 434 | + [return] ${return_value} | |
| 435 | + | |
| 436 | +отримати інформацію про items[0].description | |
| 437 | + ${return_value}= Отримати тест із поля і показати на сторінці items[0].description | |
| 359 | 438 | [return] ${return_value} |
| 360 | 439 | |
| 361 | -отримати інформацію про items[${item_id}].quantity | |
| 362 | - відмітити на сторінці поле з тендера items[${item_id}].quantity jquery=tender-subject-info.ng-isolate-scope>div.row:contains("Кількість:")>:eq(1)> | |
| 363 | - ${return_value}= Get Text jquery=tender-subject-info.ng-isolate-scope>div.row:contains("Кількість:")>:eq(1)> | |
| 364 | - ${return_value}= Convert To Number ${return_value} | |
| 440 | +отримати інформацію про items[0].deliveryLocation.latitude | |
| 441 | + ${return_value}= Отримати тест із поля і показати на сторінці items[0].deliveryLocation.latitude | |
| 442 | + ${return_value}= Get Substring ${return_value} 0 10 | |
| 365 | 443 | [return] ${return_value} |
| 366 | 444 | |
| 367 | -отримати інформацію про items[${item_id}].classification.id | |
| 368 | - відмітити на сторінці поле з тендера items[0].classification.id jquery=tender-subject-info>div.row:contains("Класифікатор CPV:")>:eq(1)> | |
| 369 | - ${return_value}= Get Text jquery=tender-subject-info>div.row:contains("Класифікатор CPV:")>:eq(1)> | |
| 445 | +отримати інформацію про items[0].deliveryLocation.longitude | |
| 446 | + ${return_value}= Отримати тест із поля і показати на сторінці items[0].deliveryLocation.longitude | |
| 447 | + ${return_value}= Get Substring ${return_value} 12 22 | |
| 448 | + [return] ${return_value} | |
| 449 | + | |
| 450 | +отримати інформацію про items[0].unit.code | |
| 451 | + ${return_value}= Отримати тест із поля і показати на сторінці items[0].unit.code | |
| 452 | + ${return_value}= Get Substring ${return_value} 5 | |
| 453 | + ${return_value}= Run keyword if '${return_value}' == 'кг.' Convert To String KGM | |
| 454 | + [return] ${return_value} | |
| 455 | + | |
| 456 | +отримати інформацію про items[0].quantity | |
| 457 | + ${return_value}= Отримати тест із поля і показати на сторінці items[0].quantity | |
| 458 | + ${return_value}= Get Substring ${return_value} 0 4 | |
| 459 | + ${return_value}= Convert To Number ${return_value} | |
| 460 | + [return] ${return_value} | |
| 461 | + | |
| 462 | +отримати інформацію про items[0].classification.id | |
| 463 | + ${return_value}= Отримати тест із поля і показати на сторінці items[0].classification.id | |
| 370 | 464 | [return] ${return_value.split(' ')[0]} |
| 371 | 465 | |
| 372 | -отримати інформацію про items[${item_id}].classification.scheme | |
| 373 | - відмітити на сторінці поле з тендера items[0].classification.id jquery=tender-subject-info>div.row:contains("CPV")>:eq(1)> | |
| 374 | - ${return_value}= Get Text jquery=tender-subject-info>div.row:contains("CPV")>:eq(1)> | |
| 466 | +отримати інформацію про items[0].classification.scheme | |
| 467 | + ${return_value}= Отримати тест із поля і показати на сторінці items[0].classification.scheme | |
| 468 | + ${return_value}= Get Substring ${return_value} 0 -1 | |
| 469 | + [return] ${return_value.split(' ')[1]} | |
| 470 | + | |
| 471 | +отримати інформацію про items[0].classification.description | |
| 472 | + ${return_value}= Отримати тест із поля і показати на сторінці items[0].classification.description | |
| 473 | + ${return_value}= Get Substring ${return_value} 11 | |
| 474 | + ${return_value}= Run keyword if '${return_value}' == 'Картонки' Convert To String Cartons | |
| 475 | + [return] ${return_value} | |
| 476 | + | |
| 477 | +отримати інформацію про items[0].additionalClassifications[0].id | |
| 478 | + ${return_value}= Отримати тест із поля і показати на сторінці items[0].additionalClassifications[0].id | |
| 375 | 479 | [return] ${return_value.split(' ')[0]} |
| 376 | 480 | |
| 377 | -отримати інформацію про items[${item_id}].classification.description | |
| 378 | - відмітити на сторінці поле з тендера classification.description jquery=tender-subject-info>div.row:contains("Класифікатор CPV:")>:eq(1)> | |
| 379 | - ${return_value}= Get Text jquery=tender-subject-info>div.row:contains("Класифікатор CPV:")>:eq(1)> | |
| 380 | - ${return_value}= catenate @{return_value.split(' ')[1:]} | |
| 481 | +отримати інформацію про items[0].additionalClassifications[0].scheme | |
| 482 | + ${return_value}= Отримати тест із поля і показати на сторінці items[0].additionalClassifications[0].scheme | |
| 483 | + ${return_value}= Get Substring ${return_value} 0 -1 | |
| 484 | + [return] ${return_value.split(' ')[1]} | |
| 485 | + | |
| 486 | +отримати інформацію про items[0].additionalClassifications[0].description | |
| 487 | + ${return_value}= Отримати тест із поля і показати на сторінці items[0].additionalClassifications[0].description | |
| 488 | + ${return_value}= Get Substring ${return_value} 8 60 | |
| 489 | + ${return_value}= Remove String ${return_value} " | |
| 490 | + ${return_value}= Convert To Lowercase ${return_value} | |
| 491 | + [return] ${return_value} | |
| 492 | + | |
| 493 | +отримати інформацію про items[0].deliveryAddress.postalCode | |
| 494 | + ${return_value}= Отримати тест із поля і показати на сторінці items[0].deliveryAddress.postalCode | |
| 495 | + ${return_value}= Get Substring ${return_value} 0 5 | |
| 496 | + [return] ${return_value} | |
| 497 | + | |
| 498 | +отримати інформацію про items[0].deliveryAddress.countryName | |
| 499 | + ${return_value}= Отримати тест із поля і показати на сторінці items[0].deliveryAddress.countryName | |
| 500 | + ${return_value}= Get Substring ${return_value} 0 7 | |
| 501 | + [return] ${return_value} | |
| 502 | + | |
| 503 | +отримати інформацію про items[0].deliveryAddress.region | |
| 504 | + ${return_value}= Отримати тест із поля і показати на сторінці items[0].deliveryAddress.region | |
| 505 | + ${return_value}= Run keyword if '${return_value}' == 'Київська,' Convert To String м. Київ | |
| 381 | 506 | [return] ${return_value} |
| 382 | 507 | |
| 383 | -отримати інформацію про items[${item_id}].deliveryAddress | |
| 384 | - ${return_value}= Отримати тест із поля і показати на сторінці items[${item_id}].deliveryAddress | |
| 508 | +отримати інформацію про items[0].deliveryAddress.locality | |
| 509 | + ${return_value}= Отримати тест із поля і показати на сторінці items[0].deliveryAddress.locality | |
| 510 | + ${return_value}= Run keyword if '${return_value}' == 'Київ,' Convert To String м. Київ | |
| 385 | 511 | [return] ${return_value} |
| 386 | 512 | |
| 387 | -отримати інформацію про items[${item_id}].deliveryDate | |
| 388 | - ${return_value}= Отримати тест із поля і показати на сторінці items[${item_id}].deliveryDate | |
| 513 | +отримати інформацію про items[0].deliveryAddress.streetAddress | |
| 514 | + ${return_value}= Отримати тест із поля і показати на сторінці items[0].deliveryAddress.streetAddress | |
| 389 | 515 | [return] ${return_value} |
| 390 | 516 | |
| 391 | -отримати інформацію про questions[${question_id}].title | |
| 392 | - відмітити на сторінці поле з тендера questions title jquery=tender-questions>div:eq(1)>div.row:contains("Тема:")>:eq(1)> | |
| 393 | - ${return_value}= Get Text jquery=tender-questions>div:eq(1)>div.row:contains("Тема:")>:eq(1)> | |
| 517 | +отримати інформацію про items[0].deliveryDate.endDate | |
| 518 | + ${return_value}= Отримати тест із поля і показати на сторінці items[0].deliveryDate.endDate | |
| 519 | + ${time}= Отримати тест із поля і показати на сторінці enquiryPeriod.startDate | |
| 520 | + ${time}= Get Substring ${time} 11 | |
| 521 | + ${day}= Get Substring ${return_value} 16 18 | |
| 522 | + ${month}= Get Substring ${return_value} 18 22 | |
| 523 | + ${year}= Get Substring ${return_value} 22 | |
| 524 | + ${return_value}= Convert To String ${year}${month}${day}${time} | |
| 394 | 525 | [return] ${return_value} |
| 395 | 526 | |
| 396 | -отримати інформацію про questions[${question_id}].description | |
| 397 | - відмітити на сторінці поле з тендера questions description jquery=tender-questions>div:eq(1)>div.row:contains("Питання:")>:eq(1)> | |
| 398 | - ${return_value}= Get Text jquery=tender-questions>div:eq(1)>div.row:contains("Питання:")>:eq(1)> | |
| 527 | +отримати інформацію про questions[0].title | |
| 528 | + ${return_value}= отримати тест із поля і показати на сторінці questions[0].title | |
| 399 | 529 | [return] ${return_value} |
| 400 | 530 | |
| 401 | -отримати інформацію про questions[${question_id}].date | |
| 402 | - відмітити на сторінці поле з тендера question date jquery=tender-questions>div:eq(1)>div.row:contains("Дата:")>:eq(1)> | |
| 403 | - ${return_value}= Get Text jquery=tender-questions>div:eq(1)>div.row:contains("Дата:")>:eq(1)> | |
| 531 | +отримати інформацію про questions[0].description | |
| 532 | + ${return_value}= отримати тест із поля і показати на сторінці questions[0].description | |
| 404 | 533 | [return] ${return_value} |
| 405 | 534 | |
| 406 | -отримати інформацію про questions[${question_id}].answer | |
| 407 | - відмітити на сторінці поле з тендера question answer jquery=tender-questions>div:eq(1)>div:last> | |
| 408 | - ${return_value}= Get Text jquery=tender-questions>div:eq(1)>div:last> | |
| 535 | +отримати інформацію про questions[0].date | |
| 536 | + ${return_value}= отримати тест із поля і показати на сторінці questions[0].date | |
| 537 | + ${return_value}= Change_date_to_month ${return_value} | |
| 409 | 538 | [return] ${return_value} |
| 539 | + | |
| 540 | +отримати інформацію про questions[0].answer | |
| 541 | + ${return_value}= отримати тест із поля і показати на сторінці questions[0].answer | |
| 542 | + [return] ${return_value} | |
| \ No newline at end of file | ... | ... |
| ... | ... | @@ -39,12 +39,10 @@ def prepare_prom_test_tender_data(): |
| 39 | 39 | return munchify({'data': prom_test_tender_data()}) |
| 40 | 40 | |
| 41 | 41 | def compare_date(data1, data2): |
| 42 | - LOGGER.log_message(Message("data1: {}".format(data1), "INFO")) | |
| 43 | - LOGGER.log_message(Message("data2: {}".format(data2), "INFO")) | |
| 44 | 42 | data1=parse(data1) |
| 45 | 43 | data2=parse(data2) |
| 46 | - LOGGER.log_message(Message("data1: {}".format(data1), "INFO")) | |
| 47 | - LOGGER.log_message(Message("data2: {}".format(data2), "INFO")) | |
| 44 | + #LOGGER.log_message(Message("data1: {}".format(data1), "INFO")) | |
| 45 | + #LOGGER.log_message(Message("data2: {}".format(data2), "INFO")) | |
| 48 | 46 | if data1.tzinfo is None: |
| 49 | 47 | data1 = TIMEZONE.localize(data1) |
| 50 | 48 | if data2.tzinfo is None: |
| ... | ... | @@ -142,21 +140,46 @@ def wait_to_date(date_stamp): |
| 142 | 140 | return 0 |
| 143 | 141 | return wait_seconds |
| 144 | 142 | |
| 143 | +##GUI Frontends common | |
| 145 | 144 | def convert_date_to_slash_format(isodate): |
| 146 | 145 | iso_dt=parse_date(isodate) |
| 147 | 146 | date_string = iso_dt.strftime("%d/%m/%Y") |
| 148 | 147 | return date_string |
| 149 | 148 | |
| 149 | +def Add_data_for_GUI_FrontEnds(INITIAL_TENDER_DATA): | |
| 150 | + now = datetime.now() | |
| 151 | + #INITIAL_TENDER_DATA.data.enquiryPeriod['startDate'] = (now + timedelta(minutes=2)).isoformat() | |
| 152 | + INITIAL_TENDER_DATA.data.enquiryPeriod['endDate'] = (now + timedelta(minutes=6)).isoformat() | |
| 153 | + INITIAL_TENDER_DATA.data.tenderPeriod['startDate'] = (now + timedelta(minutes=7)).isoformat() | |
| 154 | + INITIAL_TENDER_DATA.data.tenderPeriod['endDate'] = (now + timedelta(minutes=11)).isoformat() | |
| 155 | + return INITIAL_TENDER_DATA | |
| 156 | + | |
| 157 | +def local_path_to_file(file_name): | |
| 158 | + path = os.getcwd() | |
| 159 | + path = path.split("brokers", 1)[0] + "/src/op_robot_tests/op_robot_tests/tests_files/documents/" + file_name | |
| 160 | + return path | |
| 161 | + | |
| 162 | +## E-Tender | |
| 150 | 163 | def convert_date_to_etender_format(isodate): |
| 151 | 164 | iso_dt=parse_date(isodate) |
| 152 | 165 | date_string = iso_dt.strftime("%d-%m-%Y") |
| 153 | 166 | return date_string |
| 154 | 167 | |
| 168 | +def convert_date_for_delivery(isodate): | |
| 169 | + iso_dt=parse_date(isodate) | |
| 170 | + date_string = iso_dt.strftime("%Y-%m-%d %H:%M") | |
| 171 | + return date_string | |
| 172 | + | |
| 155 | 173 | def convert_time_to_etender_format(isodate): |
| 156 | 174 | iso_dt=parse_date(isodate) |
| 157 | 175 | time_string = iso_dt.strftime("%H:%M") |
| 158 | 176 | return time_string |
| 159 | 177 | |
| 178 | +def procuringEntity_name(INITIAL_TENDER_DATA): | |
| 179 | + INITIAL_TENDER_DATA.data.procuringEntity['name'] = u"Повна назва невідомо чого" | |
| 180 | + return INITIAL_TENDER_DATA | |
| 181 | + | |
| 182 | +##Newtend | |
| 160 | 183 | def newtend_date_picker_index(isodate): |
| 161 | 184 | now = datetime.today() |
| 162 | 185 | date_str = '01' + str(now.month) + str(now.year) |
| ... | ... | @@ -169,20 +192,7 @@ def newtend_date_picker_index(isodate): |
| 169 | 192 | mod = calendar.monthrange(now.year, now.month)[1] + mod |
| 170 | 193 | return mod + iso_dt.day |
| 171 | 194 | |
| 172 | -def Add_data_for_GUI_FrontEnds(INITIAL_TENDER_DATA): | |
| 173 | - now = datetime.now() | |
| 174 | - #INITIAL_TENDER_DATA.data.enquiryPeriod['startDate'] = (now + timedelta(minutes=2)).isoformat() | |
| 175 | - INITIAL_TENDER_DATA.data.enquiryPeriod['endDate'] = (now + timedelta(minutes=5)).isoformat() | |
| 176 | - INITIAL_TENDER_DATA.data.tenderPeriod['startDate'] = (now + timedelta(minutes=6)).isoformat() | |
| 177 | - INITIAL_TENDER_DATA.data.tenderPeriod['endDate'] = (now + timedelta(minutes=7)).isoformat() | |
| 178 | - return INITIAL_TENDER_DATA | |
| 179 | - | |
| 180 | -def local_path_to_file(file_name): | |
| 181 | - path = os.getcwd() | |
| 182 | - path = path.split("brokers", 1)[0] + "/src/op_robot_tests/op_robot_tests/tests_files/documents/" + file_name | |
| 183 | - return path | |
| 184 | - | |
| 185 | 195 | def Update_data_for_Newtend(INITIAL_TENDER_DATA): |
| 186 | - #INITIAL_TENDER_DATA.data.items.classification['description'] = u"Картонки" | |
| 196 | + #INITIAL_TENDER_DATA.data.items[0].classification['description'] = u"Картонки" | |
| 187 | 197 | INITIAL_TENDER_DATA.data.procuringEntity['name'] = u"openprocurement" |
| 188 | 198 | return INITIAL_TENDER_DATA |
| \ No newline at end of file | ... | ... |
Please
register
or
login
to post a comment