refactor(core): general refactor for subtasks and their nested mapping

This commit is contained in:
cyrill 2023-12-08 17:55:38 +05:00
parent fe39119518
commit 0b668f85c5

View File

@ -22,6 +22,14 @@ sys.stdout.reconfigure(encoding='utf-8')
QUEUE_NAME = 'TESTIMPORT' QUEUE_NAME = 'TESTIMPORT'
headers = {
'Host': 'api.tracker.yandex.net',
'Authorization': 'OAuth y0_AgAEA7qkB3KjAArkXwAAAADzMlP9oR1lwMzBS2e94jHzdnII8Laxi7k',
'X-Org-ID': '7095769',
'Content-Type': 'appication/json',
}
def get_assignee_data(): def get_assignee_data():
""" Получение данных для поля assignee """ """ Получение данных для поля assignee """
@ -71,7 +79,7 @@ def transform_data(data):
""" Преобразование данных из Asana в ЯндексТрекер в совместимом формате """ """ Преобразование данных из Asana в ЯндексТрекер в совместимом формате """
transformed_data = [] transformed_data = []
for task in data["data"]: for task in data:
status, completed_at = get_task_status(task) status, completed_at = get_task_status(task)
transformed_task = { transformed_task = {
'gid':task['gid'], 'gid':task['gid'],
@ -82,32 +90,16 @@ def transform_data(data):
'assignee': task['assignee'], 'assignee': task['assignee'],
'status': status, 'status': status,
'completedAt': completed_at, 'completedAt': completed_at,
'parent': task['parent'] 'parent': task['parent'],
'subtasks' : transform_data(task['subtasks'])
# 'parent': task['parent'] # это я добавила, чтоб parent добавить # 'parent': task['parent'] # это я добавила, чтоб parent добавить
} }
transformed_data.append(transformed_task) transformed_data.append(transformed_task)
return transformed_data return transformed_data
def create_task(task):
def create_tasks_in_tracker(data, limit=10):
""" Создание задач в ЯндексТрекер """
base_url = 'https://api.tracker.yandex.net/v2/issues/_import' base_url = 'https://api.tracker.yandex.net/v2/issues/_import'
headers = { print(task)
'Host': 'api.tracker.yandex.net',
'Authorization': 'OAuth y0_AgAEA7qkB3KjAArkXwAAAADzMlP9oR1lwMzBS2e94jHzdnII8Laxi7k',
'X-Org-ID': '7095769',
'Content-Type': 'appication/json',
}
datalen = (len(data) if limit==-1 else min(limit, len(data)))
logger.info('Import started. Task count: %d', datalen)
# этот датасет тоже для parent добавлен
ya_imported_task_response = {}
for i in range(datalen):
task = data[i]
if task.get('assignee') and 'gid' in task['assignee']: if task.get('assignee') and 'gid' in task['assignee']:
ya_assignee = assignee.get(task['assignee']['gid'], 'dr.cyrill') ya_assignee = assignee.get(task['assignee']['gid'], 'dr.cyrill')
else: else:
@ -137,13 +129,7 @@ def create_tasks_in_tracker(data, limit=10):
print('Задача успешно создана в ЯндексТрекер') print('Задача успешно создана в ЯндексТрекер')
# здесь добавлено про родительскую задачу # здесь добавлено про родительскую задачу
return response.json()['id']
if 'gid' in task:
ya_imported_task_response[task['gid']] = response.json()['id']
logger.info('Got respnse for asana task gid = %s: ya.task.id = %s',task['gid'],ya_imported_task_response[task['gid']])
if task['parent'] is not None:
assign_parent_task(ya_imported_task_response[task['gid']], task['parent']['gid'])
else: else:
print( print(
@ -153,11 +139,32 @@ def create_tasks_in_tracker(data, limit=10):
logger.debug('Response: %s', response.content) logger.debug('Response: %s', response.content)
# вот здесь тоже про родительскую задачу добавлено
parent_task_ids = get_parent_task_ids(task, ya_imported_task_response)
for gid, parent_id in parent_task_ids.items(): def create_tasks_in_tracker(data, limit=10):
assign_parent_task(ya_imported_task_response[gid], parent_id) """ Создание задач в ЯндексТрекер """
datalen = (len(data) if limit==-1 else min(limit, len(data)))
logger.info('Import started. Task count: %d', datalen)
# этот датасет тоже для parent добавлен
ya_imported_task_response = {}
for i in range(datalen):
task = data[i]
task_id = create_task(task)
logger.info('Created task id = %s',task_id)
for subtask in task['subtasks']:
logger.info('Found subtask gid = %s for id = %s',subtask['gid'], task_id)
subtask_id = create_task(subtask)
assign_parent_task(subtask_id, task_id)
# вот здесь тоже про родительскую задачу добавлено
#parent_task_ids = get_parent_task_ids(task, ya_imported_task_response)
#for gid, parent_id in parent_task_ids.items():
# assign_parent_task(ya_imported_task_response[gid], parent_id)
#и эта функция для родительской задачи написана #и эта функция для родительской задачи написана
@ -186,6 +193,7 @@ def assign_parent_task(task_id, parent_id):
if response.status_code == 200: if response.status_code == 200:
print('Родительская задача успешно назначена') print('Родительская задача успешно назначена')
logger.info('Task %s successfully assigned a parent',task_id)
else: else:
print('Ошибка при назначении родительской задачи:', response.content) print('Ошибка при назначении родительской задачи:', response.content)
@ -198,5 +206,5 @@ def assign_parent_task(task_id, parent_id):
file = open(asana_data_json, "r", encoding="utf8") file = open(asana_data_json, "r", encoding="utf8")
json_data = json.loads(file.read()) json_data = json.loads(file.read())
yandex_tracker_data = transform_data(json_data) yandex_tracker_data = transform_data(json_data['data'])
create_tasks_in_tracker(yandex_tracker_data, limit=3) create_tasks_in_tracker(yandex_tracker_data, limit=3)