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