Splitting classes into multiple files

This commit is contained in:
VakarisZ 2020-04-20 18:23:25 +03:00
parent 636c8f6d3f
commit b6e0e30d58
3 changed files with 42 additions and 39 deletions

View File

@ -0,0 +1,11 @@
class FakeIpGenerator:
def __init__(self):
self.fake_ip_parts = [1, 1, 1, 1]
def generate_fake_ips_for_real_ips(self, real_ips):
self.fake_ip_parts[2] += 1
fake_ips = []
for i in range(len(real_ips)):
fake_ips.append('.'.join(str(part) for part in self.fake_ip_parts))
self.fake_ip_parts[3] += 1
return fake_ips

View File

@ -0,0 +1,17 @@
import random
from envs.monkey_zoo.blackbox.tests.performance.utils.fake_ip_generator import FakeIpGenerator
class FakeMonkey:
def __init__(self, ips, guid, fake_ip_generator: FakeIpGenerator, on_island=False):
self.original_ips = ips
self.original_guid = guid
self.fake_ip_generator = fake_ip_generator
self.on_island = on_island
self.fake_guid = str(random.randint(1000000000000, 9999999999999))
self.fake_ips = fake_ip_generator.generate_fake_ips_for_real_ips(ips)
def change_fake_data(self):
self.fake_ips = self.fake_ip_generator.generate_fake_ips_for_real_ips(self.original_ips)
self.fake_guid = str(random.randint(1000000000000, 9999999999999))

View File

@ -1,40 +1,15 @@
from typing import List, Dict from typing import List, Dict
from os import listdir, path from os import listdir, path
import copy import copy
import random
import json import json
from envs.monkey_zoo.blackbox.tests.performance.utils.fake_ip_generator import FakeIpGenerator
from envs.monkey_zoo.blackbox.tests.performance.utils.fake_monkey import FakeMonkey
TELEM_DIR_PATH = './tests/performance/test_telems' TELEM_DIR_PATH = './tests/performance/test_telems'
class FakeIpGenerator:
def __init__(self):
self.fake_ip_parts = [1, 1, 1, 1]
def generate_fake_ips_for_real_ips(self, real_ips):
self.fake_ip_parts[2] += 1
fake_ips = []
for i in range(len(real_ips)):
fake_ips.append('.'.join(str(part) for part in self.fake_ip_parts))
self.fake_ip_parts[3] += 1
return fake_ips
class Monkey:
def __init__(self, ips, guid, fake_ip_generator: FakeIpGenerator, on_island=False):
self.ips = ips
self.guid = guid
self.fake_ip_generator = fake_ip_generator
self.on_island = on_island
self.fake_guid = str(random.randint(1000000000000, 9999999999999))
self.fake_ips = fake_ip_generator.generate_fake_ips_for_real_ips(ips)
def change_fake_data(self):
self.fake_ips = self.fake_ip_generator.generate_fake_ips_for_real_ips(self.ips)
self.fake_guid = str(random.randint(1000000000000, 9999999999999))
class TelemParser: class TelemParser:
def __init__(self, island_ip: str, multiplier: int): def __init__(self, island_ip: str, multiplier: int):
self.multiplier = multiplier self.multiplier = multiplier
@ -54,16 +29,16 @@ class TelemParser:
TelemParser.save_teletries_to_files(fake_telem_batch) TelemParser.save_teletries_to_files(fake_telem_batch)
@staticmethod @staticmethod
def fabricate_monkeys_in_telems(telems: List[Dict], monkeys: List[Monkey]): def fabricate_monkeys_in_telems(telems: List[Dict], monkeys: List[FakeMonkey]):
for telem in telems: for telem in telems:
for monkey in monkeys: for monkey in monkeys:
if monkey.on_island: if monkey.on_island:
continue continue
if (monkey.guid in telem['content'] or monkey.guid in telem['endpoint']) and not monkey.on_island: if (monkey.original_guid in telem['content'] or monkey.original_guid in telem['endpoint']) and not monkey.on_island:
telem['content'] = telem['content'].replace(monkey.guid, monkey.fake_guid) telem['content'] = telem['content'].replace(monkey.original_guid, monkey.fake_guid)
telem['endpoint'] = telem['endpoint'].replace(monkey.guid, monkey.fake_guid) telem['endpoint'] = telem['endpoint'].replace(monkey.original_guid, monkey.fake_guid)
for i in range(len(monkey.ips)): for i in range(len(monkey.original_ips)):
telem['content'] = telem['content'].replace(monkey.ips[i], monkey.fake_ips[i]) telem['content'] = telem['content'].replace(monkey.original_ips[i], monkey.fake_ips[i])
@staticmethod @staticmethod
def offset_telem_times(iteration: int, telems: List[Dict]): def offset_telem_times(iteration: int, telems: List[Dict]):
@ -105,7 +80,7 @@ class TelemParser:
if 'network_info' not in telem['data']: if 'network_info' not in telem['data']:
continue continue
guid = telem['monkey_guid'] guid = telem['monkey_guid']
monkey_present = [monkey for monkey in monkeys if monkey.guid == guid] monkey_present = [monkey for monkey in monkeys if monkey.original_guid == guid]
if not monkey_present: if not monkey_present:
ips = [net_info['addr'] for net_info in telem['data']['network_info']['networks']] ips = [net_info['addr'] for net_info in telem['data']['network_info']['networks']]
if self.island_ip in ips: if self.island_ip in ips:
@ -113,10 +88,10 @@ class TelemParser:
else: else:
on_island = False on_island = False
monkeys.append(Monkey(ips=ips, monkeys.append(FakeMonkey(ips=ips,
guid=guid, guid=guid,
fake_ip_generator=self.fake_ip_generator, fake_ip_generator=self.fake_ip_generator,
on_island=on_island)) on_island=on_island))
return monkeys return monkeys