Showing
1 changed file
with
411 additions
and
0 deletions
publicbid_service.py
0 → 100644
| 1 | +# -*- coding: utf-8 - | ||
| 2 | +import re | ||
| 3 | +import copy | ||
| 4 | +import urllib | ||
| 5 | +import urllib3 | ||
| 6 | +import string | ||
| 7 | + | ||
| 8 | +import dateutil.parser | ||
| 9 | +from iso8601 import parse_date | ||
| 10 | +from robot.libraries.BuiltIn import BuiltIn | ||
| 11 | +from datetime import datetime, timedelta | ||
| 12 | +import pytz | ||
| 13 | + | ||
| 14 | +TZ = pytz.timezone('Europe/Kiev') | ||
| 15 | + | ||
| 16 | +def get_library(): | ||
| 17 | + return BuiltIn().get_library_instance('Selenium2Library') | ||
| 18 | + | ||
| 19 | + | ||
| 20 | +def get_webdriver_instance(): | ||
| 21 | + return get_library()._current_browser() | ||
| 22 | + | ||
| 23 | + | ||
| 24 | +# return of variable is None | ||
| 25 | +def get_variable_is_none(variable): | ||
| 26 | + if variable is None: | ||
| 27 | + return True | ||
| 28 | + return False | ||
| 29 | + | ||
| 30 | + | ||
| 31 | +# run specified keyword if condition is not none type | ||
| 32 | +def run_keyword_if_condition_is_not_none(condition, name, *args): | ||
| 33 | + if get_variable_is_none(condition) == False: | ||
| 34 | + BuiltIn().run_keyword(name, *args) | ||
| 35 | + | ||
| 36 | + | ||
| 37 | +# run specified keyword if condition is none type | ||
| 38 | +def run_keyword_if_condition_is_none(condition, name, *args): | ||
| 39 | + if get_variable_is_none(condition) == True: | ||
| 40 | + BuiltIn().run_keyword(name, *args) | ||
| 41 | + | ||
| 42 | + | ||
| 43 | +# return value for *keys (nested) in `element` (dict). | ||
| 44 | +def get_from_dictionary_by_keys(element, *keys): | ||
| 45 | + if not isinstance(element, dict): | ||
| 46 | + raise AttributeError('keys_exists() expects dict as first argument.') | ||
| 47 | + if len(keys) == 0: | ||
| 48 | + raise AttributeError('keys_exists() expects at least two arguments, one given.') | ||
| 49 | + | ||
| 50 | + _element = element | ||
| 51 | + for key in keys: | ||
| 52 | + try: | ||
| 53 | + _element = _element[key] | ||
| 54 | + except KeyError: | ||
| 55 | + return None | ||
| 56 | + return _element | ||
| 57 | + | ||
| 58 | + | ||
| 59 | +# returns if element exists on page. optimization | ||
| 60 | +def get_is_element_exist(locator): | ||
| 61 | + jquery_locator = convert_locator_to_jquery(locator) | ||
| 62 | + if get_variable_is_none(jquery_locator) == False: | ||
| 63 | + jquery_locator = jquery_locator.replace('"', '\\"') | ||
| 64 | + length = get_webdriver_instance().execute_script('return $("' + jquery_locator + '").length;') | ||
| 65 | + return length > 0 | ||
| 66 | + | ||
| 67 | + try: | ||
| 68 | + get_library()._element_find(locator, None, True) | ||
| 69 | + except Exception: | ||
| 70 | + return False | ||
| 71 | + return True | ||
| 72 | + | ||
| 73 | + | ||
| 74 | +# click | ||
| 75 | +def js_click_element(locator): | ||
| 76 | + element = get_library()._element_find(locator, None, True) | ||
| 77 | + get_webdriver_instance().execute_script( | ||
| 78 | + 'var $el = jQuery(arguments[0]); if($el.length) $el.click();', | ||
| 79 | + element | ||
| 80 | + ) | ||
| 81 | + | ||
| 82 | + | ||
| 83 | +# convert locator to jquery locator | ||
| 84 | +def convert_locator_to_jquery(locator): | ||
| 85 | + locator_params = locator.split('=', 1) | ||
| 86 | + if locator_params[0] == 'id': | ||
| 87 | + return '#' + locator_params[1] | ||
| 88 | + if locator_params[0] == 'jquery': | ||
| 89 | + return locator_params[1] | ||
| 90 | + if locator_params[0] == 'css': | ||
| 91 | + return locator_params[1] | ||
| 92 | + return None | ||
| 93 | + | ||
| 94 | + | ||
| 95 | +# set scroll to element in view | ||
| 96 | +def set_element_scroll_into_view(locator): | ||
| 97 | + element = get_library()._element_find(locator, None, True) | ||
| 98 | + get_webdriver_instance().execute_script( | ||
| 99 | + 'var $el = jQuery(arguments[0]); if($el.length) $el.get(0).scrollIntoView();', | ||
| 100 | + element | ||
| 101 | + ) | ||
| 102 | + | ||
| 103 | + | ||
| 104 | +# return text/value by specified locator | ||
| 105 | +def get_value_by_locator(locator): | ||
| 106 | + element = get_library()._element_find(locator, None, True) | ||
| 107 | + text = get_webdriver_instance().execute_script( | ||
| 108 | + 'var $element = jQuery(arguments[0]);' | ||
| 109 | + 'if($element.is("input[type=checkbox]")) return $element.is(":checked") ? "1":"0";' | ||
| 110 | + 'if($element.is("input,textarea,select")) return $element.val();' | ||
| 111 | + 'return $element.text();', | ||
| 112 | + element | ||
| 113 | + ) | ||
| 114 | + return text | ||
| 115 | + | ||
| 116 | + | ||
| 117 | +# input text to hidden input | ||
| 118 | +def input_text_to_hidden_input(locator, text): | ||
| 119 | + element = get_library()._element_find(locator, None, True) | ||
| 120 | + get_webdriver_instance().execute_script( | ||
| 121 | + 'jQuery(arguments[0]).val("' + text.replace('"', '\\"') + '");', | ||
| 122 | + element | ||
| 123 | + ) | ||
| 124 | + | ||
| 125 | + | ||
| 126 | +# select option by label for hidden select | ||
| 127 | +def select_from_hidden_list_by_label(locator, label): | ||
| 128 | + element = get_library()._element_find(locator, None, True) | ||
| 129 | + get_webdriver_instance().execute_script( | ||
| 130 | + 'var $option = jQuery("option:contains(' + label.replace('"', '\\"') + ')", arguments[0]);' + | ||
| 131 | + 'if($option.length) jQuery(arguments[0]).val($option.attr("value"));', | ||
| 132 | + element | ||
| 133 | + ) | ||
| 134 | + | ||
| 135 | + | ||
| 136 | +# trigger change event for input by locator | ||
| 137 | +def trigger_input_change_event(locator): | ||
| 138 | + element = get_library()._element_find(locator, None, True) | ||
| 139 | + get_webdriver_instance().execute_script( | ||
| 140 | + 'var $el = jQuery(arguments[0]); if($el.length) $el.trigger("change");', | ||
| 141 | + element | ||
| 142 | + ) | ||
| 143 | + | ||
| 144 | + | ||
| 145 | +# convert all numners to string | ||
| 146 | +def convert_float_to_string(number): | ||
| 147 | + return repr(float(number)) | ||
| 148 | + | ||
| 149 | + | ||
| 150 | +def convert_esco__float_to_string(number): | ||
| 151 | + return '{0:.5f}'.format(float(number)) | ||
| 152 | + | ||
| 153 | + | ||
| 154 | +def convert_float_to_string_3f(number): | ||
| 155 | + return '{0:.3f}'.format(float(number)) | ||
| 156 | + | ||
| 157 | + | ||
| 158 | +# convert any variable to specified type | ||
| 159 | +def convert_to_specified_type(value, type): | ||
| 160 | + value = "%s" % (value) | ||
| 161 | + if type == 'integer': | ||
| 162 | + value = value.split() | ||
| 163 | + value = ''.join(value) | ||
| 164 | + print(value) | ||
| 165 | + value = int(value) | ||
| 166 | + if type == 'float': | ||
| 167 | + value = value.split() | ||
| 168 | + value = ''.join(value) | ||
| 169 | + print(value) | ||
| 170 | + value = float(value) | ||
| 171 | + return value | ||
| 172 | + | ||
| 173 | + | ||
| 174 | +# prepare isodate in needed format | ||
| 175 | +def isodate_format(isodate, format): | ||
| 176 | + iso_dt = parse_date(isodate) | ||
| 177 | + return iso_dt.strftime(format) | ||
| 178 | + | ||
| 179 | + | ||
| 180 | +def procuring_entity_name(tender_data): | ||
| 181 | + tender_data.data.procuringEntity['name'] = u"ТОВ \"ПлейТендер\"" | ||
| 182 | + tender_data.data.procuringEntity['name_en'] = u"TOV \"playtender\"" | ||
| 183 | + tender_data.data.procuringEntity.identifier['id'] = u"1234567890-playtender" | ||
| 184 | + tender_data.data.procuringEntity.identifier['legalName'] = u"ТОВ \"ПлейТендер\"" | ||
| 185 | + tender_data.data.procuringEntity.identifier['legalName_en'] = u"TOV \"playtender\"" | ||
| 186 | + if 'address' in tender_data.data.procuringEntity: | ||
| 187 | + tender_data.data.procuringEntity.address['region'] = u"м. Київ" | ||
| 188 | + tender_data.data.procuringEntity.address['postalCode'] = u"123123" | ||
| 189 | + tender_data.data.procuringEntity.address['locality'] = u"Київ" | ||
| 190 | + tender_data.data.procuringEntity.address['streetAddress'] = u"address" | ||
| 191 | + if 'contactPoint' in tender_data.data.procuringEntity: | ||
| 192 | + tender_data.data.procuringEntity.contactPoint['name'] = u"Test ЗамовникОборони" | ||
| 193 | + tender_data.data.procuringEntity.contactPoint['name_en'] = u"Test" | ||
| 194 | + tender_data.data.procuringEntity.contactPoint['email'] = u"chuzhin@mail.ua" | ||
| 195 | + tender_data.data.procuringEntity.contactPoint['telephone'] = u"+3801111111111" | ||
| 196 | + tender_data.data.procuringEntity.contactPoint['url'] = u"http://playtender.com.ua" | ||
| 197 | + if 'buyers' in tender_data.data: | ||
| 198 | + tender_data.data.buyers[0]['name'] = u"ТОВ \"ПлейТендер\"" | ||
| 199 | + tender_data.data.buyers[0].identifier['id'] = u"1234567890-playtender" | ||
| 200 | + tender_data.data.buyers[0].identifier['legalName'] = u"ТОВ \"ПлейТендер\"" | ||
| 201 | + return tender_data | ||
| 202 | + | ||
| 203 | +# prepare data | ||
| 204 | +def prepare_procuring_entity_data(data): | ||
| 205 | + try: | ||
| 206 | + data['name'] = u"Playtender" | ||
| 207 | + data.identifier['id'] = u"playtender" | ||
| 208 | + data.identifier['legalName'] = u"Playtender" | ||
| 209 | + data.identifier['scheme'] = u"UA-EDR" | ||
| 210 | + if 'name_en' in data: | ||
| 211 | + data['name_en'] = u"Playtender" | ||
| 212 | + if 'legalName_en' in data.identifier: | ||
| 213 | + data.identifier['legalName_en'] = u"Playtender" | ||
| 214 | + if 'address' in data: | ||
| 215 | + data.address['countryName'] = u"Україна" | ||
| 216 | + data.address['locality'] = u"Київ" | ||
| 217 | + data.address['postalCode'] = u"01111" | ||
| 218 | + data.address['region'] = u"місто Київ" | ||
| 219 | + data.address['streetAddress'] = u"вулиця Тестова, 220, 8" | ||
| 220 | + if 'contactPoint' in data: | ||
| 221 | + data.contactPoint['email'] = u"chuzhin@mail.ua" | ||
| 222 | + data.contactPoint['faxNumber'] = u"+3801111111111" | ||
| 223 | + data.contactPoint['telephone'] = u"+3801111111111" | ||
| 224 | + data.contactPoint['name'] = u"Test" | ||
| 225 | + if 'name_en' in data.contactPoint: | ||
| 226 | + data.contactPoint['name_en'] = u"Test" | ||
| 227 | + data.contactPoint['url'] = u"https://playtender.com.ua" | ||
| 228 | + except Exception: | ||
| 229 | + raise Exception('data is not a dictionary') | ||
| 230 | + | ||
| 231 | + | ||
| 232 | +# prepare data | ||
| 233 | +def prepare_buyers_data(data): | ||
| 234 | + if type(data) is not list: | ||
| 235 | + raise Exception('data is not a list') | ||
| 236 | + | ||
| 237 | + # preventing console errors about changing buyer data in cases | ||
| 238 | + if len(data) != 1: | ||
| 239 | + return | ||
| 240 | + | ||
| 241 | + item = next(iter(data), None) | ||
| 242 | + item['name'] = u"Playtender" | ||
| 243 | + item.identifier['id'] = u"playtender" | ||
| 244 | + item.identifier['legalName'] = u"Playtender" | ||
| 245 | + item.identifier['scheme'] = u"UA-EDR" | ||
| 246 | + | ||
| 247 | + | ||
| 248 | +# prepare dictionary from field path + value | ||
| 249 | +def generate_dictionary_from_field_path_and_value(path, value): | ||
| 250 | + data = dict() | ||
| 251 | + path_keys_list = path.split('.') | ||
| 252 | + if len(path_keys_list) > 1: | ||
| 253 | + key = path_keys_list.pop(0) | ||
| 254 | + value = generate_dictionary_from_field_path_and_value('.'.join(path_keys_list), value) | ||
| 255 | + indexRegex = re.compile(r'(\[(\d+)\]$)') | ||
| 256 | + matchObj = indexRegex.search(key) | ||
| 257 | + print matchObj | ||
| 258 | + if matchObj: | ||
| 259 | + key = indexRegex.sub('', key) | ||
| 260 | + value['list_index'] = matchObj.group(2) | ||
| 261 | + value = [value] | ||
| 262 | + data[key] = value | ||
| 263 | + else: | ||
| 264 | + data = dict() | ||
| 265 | + data[path] = value | ||
| 266 | + return data | ||
| 267 | + | ||
| 268 | + | ||
| 269 | +# Percentage conversion | ||
| 270 | +def multiply_hundred(number): | ||
| 271 | + return number * 100 | ||
| 272 | + | ||
| 273 | + | ||
| 274 | +# prepares data for filling form in easiest way | ||
| 275 | +def prepare_tender_data(data_original): | ||
| 276 | + # preventing change data in global view | ||
| 277 | + data = copy.deepcopy(data_original) | ||
| 278 | + | ||
| 279 | + # check if data is for multilot | ||
| 280 | + if 'lots' not in data: | ||
| 281 | + return data | ||
| 282 | + | ||
| 283 | + # moves features to its related items | ||
| 284 | + if 'features' in data: | ||
| 285 | + i = 0 | ||
| 286 | + l = len(data['features']) | ||
| 287 | + while i < l: | ||
| 288 | + if data['features'][i]['featureOf'] == 'lot': | ||
| 289 | + for lot in data['lots']: | ||
| 290 | + if lot['id'] == data['features'][i]['relatedItem']: | ||
| 291 | + if 'features' not in lot: | ||
| 292 | + lot['features'] = [] | ||
| 293 | + lot['features'].append(data['features'].pop(i)) | ||
| 294 | + l = l - 1 | ||
| 295 | + i = i - 1 | ||
| 296 | + break | ||
| 297 | + if data['features'][i]['featureOf'] == 'item': | ||
| 298 | + for item in data['items']: | ||
| 299 | + if item['id'] == data['features'][i]['relatedItem']: | ||
| 300 | + if 'features' not in item: | ||
| 301 | + item['features'] = [] | ||
| 302 | + item['features'].append(data['features'].pop(i)) | ||
| 303 | + l = l - 1 | ||
| 304 | + i = i - 1 | ||
| 305 | + break | ||
| 306 | + i = i + 1 | ||
| 307 | + | ||
| 308 | + if 'features' in data: | ||
| 309 | + if len(data['features']) == 0: | ||
| 310 | + del data['features'] | ||
| 311 | + | ||
| 312 | + # moves items to its related lots | ||
| 313 | + i = 0 | ||
| 314 | + l = len(data['items']) | ||
| 315 | + while i < l: | ||
| 316 | + for lot in data['lots']: | ||
| 317 | + if lot['id'] == data['items'][i]['relatedLot']: | ||
| 318 | + if 'items' not in lot: | ||
| 319 | + lot['items'] = [] | ||
| 320 | + lot['items'].append(data['items'].pop(i)) | ||
| 321 | + l = l - 1 | ||
| 322 | + i = i - 1 | ||
| 323 | + break | ||
| 324 | + i = i + 1 | ||
| 325 | + | ||
| 326 | + del data['items'] | ||
| 327 | + | ||
| 328 | + if 'milestones' not in data: | ||
| 329 | + return data | ||
| 330 | + # moves milestones to its related lots | ||
| 331 | + i = 0 | ||
| 332 | + l = len(data['milestones']) | ||
| 333 | + while i < l: | ||
| 334 | + for lot in data['lots']: | ||
| 335 | + if lot['id'] == data['milestones'][i]['relatedLot']: | ||
| 336 | + if 'milestones' not in lot: | ||
| 337 | + lot['milestones'] = [] | ||
| 338 | + lot['milestones'].append(data['milestones'].pop(i)) | ||
| 339 | + l = l - 1 | ||
| 340 | + i = i - 1 | ||
| 341 | + break | ||
| 342 | + i = i + 1 | ||
| 343 | + | ||
| 344 | + del data['milestones'] | ||
| 345 | + | ||
| 346 | + return data | ||
| 347 | + | ||
| 348 | + | ||
| 349 | +def split_agreementDuration(str, type): | ||
| 350 | + if type in 'year': | ||
| 351 | + year_temp = str.split('Y', 1) | ||
| 352 | + value = year_temp[0].split('P', 1) | ||
| 353 | + elif type in 'month': | ||
| 354 | + month_temp = str.split('M', 1) | ||
| 355 | + value = month_temp[0].split('Y', 1) | ||
| 356 | + else: | ||
| 357 | + day_temp = str.split('D', 1) | ||
| 358 | + value = day_temp[0].split('M', 1) | ||
| 359 | + return value[1] | ||
| 360 | + | ||
| 361 | + | ||
| 362 | +def convert_date_to_string_contr(date): | ||
| 363 | + date = dateutil.parser.parse(date) | ||
| 364 | + date = date.strftime("%d.%m.%Y %H:%M:%S") | ||
| 365 | + return date | ||
| 366 | + | ||
| 367 | +def get_value_minimalStepPercentage(value): | ||
| 368 | + value = value / 100 | ||
| 369 | + return value | ||
| 370 | + | ||
| 371 | +def set_value_minimalStepPercentage(value): | ||
| 372 | + value = value * 100 | ||
| 373 | + return value | ||
| 374 | + | ||
| 375 | +def convert_esco__float_to_string(number): | ||
| 376 | + return '{0:.5f}'.format(float(number)) | ||
| 377 | + | ||
| 378 | +def convert_string_to_float(number): | ||
| 379 | + return float(number) | ||
| 380 | + | ||
| 381 | +def download_file(url, file_name, output_dir): | ||
| 382 | + urllib.urlretrieve(url, ('{}/{}'.format(output_dir, file_name))) | ||
| 383 | + | ||
| 384 | +def parse_complaintPeriod_date(date_string): | ||
| 385 | + date_str = datetime.strptime(date_string, "%d.%m.%Y %H:%M") | ||
| 386 | + date = datetime(date_str.year, date_str.month, date_str.day, date_str.hour, date_str.minute, date_str.second, | ||
| 387 | + date_str.microsecond) | ||
| 388 | + date = TZ.localize(date).isoformat() | ||
| 389 | + return date | ||
| 390 | + | ||
| 391 | +def parse_deliveryPeriod_date1(date): | ||
| 392 | + date = dateutil.parser.parse(date) | ||
| 393 | + date = date.strftime("%d.%m.%Y") | ||
| 394 | + return date | ||
| 395 | + | ||
| 396 | +def parse_deliveryPeriod_date(date_string): | ||
| 397 | +# date_str = datetime.strptime(date_string, "%Y-%m-%dT%H:%M:%S+03:00") | ||
| 398 | + if '+03' in date_string: | ||
| 399 | + date_str = datetime.strptime(date_string, "%Y-%m-%dT%H:%M:%S+03:00") | ||
| 400 | + else: | ||
| 401 | + date_str = datetime.strptime(date_string, "%Y-%m-%dT%H:%M:%S+02:00") | ||
| 402 | + date = datetime(date_str.year, date_str.month, date_str.day) | ||
| 403 | + date = date.strftime("%d.%m.%Y") | ||
| 404 | + return date | ||
| 405 | + | ||
| 406 | +def split_joinvalue(str_value): | ||
| 407 | + str_value = str_value.split() | ||
| 408 | + str_value = ''.join(str_value) | ||
| 409 | + print(str_value) | ||
| 410 | + str_value.replace(" ", "") | ||
| 411 | + return str_value |
Please
register
or
login
to post a comment