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