Showing
2 changed files
with
145 additions
and
0 deletions
This diff could not be displayed because it is too large.
op_robot_tests/tests_files/op_faker.py
0 → 100644
1 | +# -*- coding: utf-8 -*- | |
2 | +from faker import Faker | |
3 | +from faker.providers import BaseProvider | |
4 | +from munch import Munch | |
5 | +from json import load | |
6 | +import os | |
7 | + | |
8 | + | |
9 | +def load_data_from_file(file_name): | |
10 | + if not os.path.exists(file_name): | |
11 | + file_name = os.path.join(os.path.dirname(__file__), 'data', file_name) | |
12 | + with open(file_name) as file_obj: | |
13 | + if file_name.endswith(".json"): | |
14 | + return Munch.fromDict(load(file_obj)) | |
15 | + elif file_name.endswith(".yaml"): | |
16 | + return fromYAML(file_obj) | |
17 | + | |
18 | + | |
19 | +class OP_Provider(BaseProvider): | |
20 | + __fake_data = load_data_from_file("faker_data.json") | |
21 | + word_list = __fake_data.words | |
22 | + procuringEntities = __fake_data.procuringEntities | |
23 | + addresses = __fake_data.addresses | |
24 | + classifications = __fake_data.classifications | |
25 | + units = __fake_data.units | |
26 | + cpvs = __fake_data.cpvs | |
27 | + items_base_data = __fake_data.items_base_data | |
28 | + | |
29 | + | |
30 | + @classmethod | |
31 | + def randomize_nb_elements(self, number=10, le=60, ge=140): | |
32 | + """ | |
33 | + Returns a random value near number. | |
34 | + | |
35 | + :param number: value to which the result must be near | |
36 | + :param le: lower limit of randomizing (percents). Default - 60 | |
37 | + :param ge: upper limit of randomizing (percents). Default - 140 | |
38 | + :returns: a random int in range [le * number / 100, ge * number / 100] | |
39 | + with minimum of 1 | |
40 | + """ | |
41 | + if le > ge: | |
42 | + raise Exception("Lower bound: {} is greater then upper: {}.".format(le, ge)) | |
43 | + return int(number * self.random_int(min=le, max=ge) / 100) + 1 | |
44 | + | |
45 | + | |
46 | + @classmethod | |
47 | + def word(self): | |
48 | + """ | |
49 | + :example 'Курка' | |
50 | + """ | |
51 | + return self.random_element(self.word_list) | |
52 | + | |
53 | + | |
54 | + @classmethod | |
55 | + def words(self, nb=3): | |
56 | + """ | |
57 | + Generate an array of random words | |
58 | + :example: array('Надіньте', 'фуражка', 'зелено') | |
59 | + :param nb: how many words to return | |
60 | + """ | |
61 | + return [self.word() for _ in range(0, nb)] | |
62 | + | |
63 | + | |
64 | + @classmethod | |
65 | + def sentence(self, nb_words=5, variable_nb_words=True): | |
66 | + """ | |
67 | + Generate a random sentence | |
68 | + :example: 'Курка надіньте пречудовий зелено на.' | |
69 | + :param nb_words: how many words the sentence should contain | |
70 | + :param variable_nb_words: set to false if you want exactly $nbWords returned, | |
71 | + otherwise $nbWords may vary by +/-40% with a minimum of 1 | |
72 | + """ | |
73 | + if nb_words <= 0: | |
74 | + return '' | |
75 | + | |
76 | + if variable_nb_words: | |
77 | + nb_words = self.randomize_nb_elements(number=nb_words) | |
78 | + | |
79 | + words = self.words(nb_words) | |
80 | + words[0] = words[0].title() | |
81 | + | |
82 | + return " ".join(words) + '.' | |
83 | + | |
84 | + | |
85 | + @classmethod | |
86 | + def title(self): | |
87 | + return self.sentence(nb_words = 3) | |
88 | + | |
89 | + | |
90 | + @classmethod | |
91 | + def description(self): | |
92 | + return self.sentence(nb_words = 10) | |
93 | + | |
94 | + | |
95 | + @classmethod | |
96 | + def procuringEntity(self): | |
97 | + return self.random_element(self.procuringEntities) | |
98 | + | |
99 | + | |
100 | + @classmethod | |
101 | + def cpv(self): | |
102 | + return self.random_element(self.cpvs) | |
103 | + | |
104 | + | |
105 | + @classmethod | |
106 | + def fake_item(self, cpv_group=None): | |
107 | + """ | |
108 | + Generate a random item for openprocurement tenders | |
109 | + | |
110 | + :param cpv_group: gives possibility to generate items | |
111 | + from one cpv group. Cpv group is three digits in the beginning | |
112 | + of each cpv id. | |
113 | + """ | |
114 | + if cpv_group is None: | |
115 | + item_base_data = self.random_element(self.items_base_data) | |
116 | + else: | |
117 | + cpv_group = str(cpv_group) | |
118 | + similar_cpvs = [] | |
119 | + for cpv_element in self.cpvs: | |
120 | + if cpv_element.startswith(cpv_group): | |
121 | + similar_cpvs.append(cpv_element) | |
122 | + cpv = self.random_element(similar_cpvs) | |
123 | + for entity in self.items_base_data: | |
124 | + if entity["cpv_id"] == cpv: | |
125 | + item_base_data = entity | |
126 | + break | |
127 | + | |
128 | + # choose appropriate dkpp classification for item_base_data's cpv | |
129 | + for entity in self.classifications: | |
130 | + if entity["classification"]["id"] == item_base_data["cpv_id"]: | |
131 | + classification = entity | |
132 | + break | |
133 | + | |
134 | + address = self.random_element(self.addresses) | |
135 | + unit = self.random_element(self.units) | |
136 | + item = { | |
137 | + "description": item_base_data["description"], | |
138 | + "classification": classification["classification"], | |
139 | + "additionalClassifications": classification["additionalClassifications"], | |
140 | + "deliveryAddress": address["deliveryAddress"], | |
141 | + "deliveryLocation": address["deliveryLocation"], | |
142 | + "unit": item_base_data["unit"], | |
143 | + "quantity": self.randomize_nb_elements(number=item_base_data["quantity"], le=80, ge=120) | |
144 | + } | |
145 | + return item | ... | ... |
Please
register
or
login
to post a comment