本文整理汇总了Python中jira.JIRA.add_worklog方法的典型用法代码示例。如果您正苦于以下问题:Python JIRA.add_worklog方法的具体用法?Python JIRA.add_worklog怎么用?Python JIRA.add_worklog使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类jira.JIRA
的用法示例。
在下文中一共展示了JIRA.add_worklog方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Python代码示例。
示例1: update_jira
# 需要导入模块: from jira import JIRA [as 别名]
# 或者: from jira.JIRA import add_worklog [as 别名]
def update_jira(username, password):
"""Update time logs in Jira
Current implementation uses basic authentication,
future version will have better auth. For simplicity
the toggl log should have issue number as timelog
description.
*username* to use to connect to Jira
*password* for Jira authentication
"""
url = CONFIG.get('jira')['url']
jira = JIRA(
options={'server': url},
basic_auth=(username, password))
time_logs = toggl.Connect('jira')
get_logs = time_logs.get_time_logs()
for each_log in get_logs:
issue_id = each_log.get('description')
try:
issue = jira.issue(issue_id)
except JIRAError:
logging.warning('Failed to find issue-id {0}'.format(issue_id))
continue
# Compute time in hours and round to two decimal places
time_in_hours = round(each_log['duration']/(60*60), 2)
jira.add_worklog(issue, time_in_hours, comment='Updated using Jira API')
示例2: Jira
# 需要导入模块: from jira import JIRA [as 别名]
# 或者: from jira.JIRA import add_worklog [as 别名]
class Jira(object):
def __init__(self, url, user, password):
self.jira = JIRA(url, auth=(user, password))
def book_jira(self, bookings):
for entry in bookings:
if not ticket_pattern_jira.match(entry['issue_id']):
continue
rm_entry = entry.copy()
rm_entry['hours'] = rm_entry['time'] / 60.
del rm_entry['time']
if 'description' in rm_entry:
del rm_entry['description']
if 'activity' in rm_entry:
del rm_entry['activity']
try:
self.jira.add_worklog(
issue=entry['issue_id'],
timeSpent=entry['time'],
started=datetime.strptime(entry['spent_on'], '%Y-%m-%d'),
comment=entry['comments'],
)
except JIRAError as je:
print(u'{0}: {1} ({2})'.format(
je.status_code, je.text, rm_entry['comments']))
示例3: __init__
# 需要导入模块: from jira import JIRA [as 别名]
# 或者: from jira.JIRA import add_worklog [as 别名]
#.........这里部分代码省略.........
if sprint_dates is None:
raise RuntimeError('{} is not a proper sprint id.'.format(self.params['sprint_id']))
return sprint_dates
def __generate_date_list(self, start, end):
start = datetime.strptime(start, '%Y-%m-%d')
end = datetime.strptime(end, '%Y-%m-%d')
dates = []
for day in range(0, (end-start).days + 1):
date = start + timedelta(days=day)
if date.weekday() not in [5, 6] and date.strftime('%Y-%m-%d') not in helper.get_holidays_list().keys():
dates.append(date.strftime('%Y-%m-%d'))
return dates
def __get_params_from_config(self):
with open('sample.json') as data_file:
try:
data = json.load(data_file)
except ValueError:
raise RuntimeError("There was something wrong in you config.json. Please double check your input.")
return data
def __log_work_for_sprint(self):
sprint_dates = self.__get_start_and_end_date_for_sprint()
dates = self.__generate_date_list(sprint_dates[0], sprint_dates[1])
# TODO: check if already logged. Maybe change logging per day instead.
# TODO: check if exceeds time. Print warning before actually logging.
print 'Logging work.'
# self.__log_holidays(sprint_dates)
# self.__log_leaves()
self.__log_daily_work(dates)
# self.__log_meetings()
# self.__log_sprint_meetings(sprint_dates)
# self.__log_trainings()
# self.__log_reviews()
# self.__log_other_tasks()
def __log_holidays(self, sprint_dates):
holidays = helper.get_holidays_list()
print 'Logging holidays...'
for holiday in holidays:
if sprint_dates[0] <= holiday <= sprint_dates[1]:
worklog = self.jira.add_worklog(self.params['holidays_id'], '8h', started=parser.parse(holiday + 'T08:00:00-00:00'), comment=holidays[holiday])
if not isinstance(worklog, int):
raise RuntimeError('There was a problem logging your holidays.')
def __log_leaves(self):
# TODO: Support for not whole day leaves
print 'Logging your leaves...'
for leave in self.params['leaves']:
worklog = self.jira.add_worklog(leave['id'], leave['timeSpent'], started=parser.parse(leave['started'] + 'T08:00:00-00:00'), comment=leave['comment'])
print worklog
if not isinstance(worklog, int):
raise RuntimeError('There was a problem logging your leaves.')
def __log_daily_work(self, dates):
print 'Logging your daily tasks...'
for task in self.params['daily_tasks']:
for date in dates:
worklog = self.jira.add_worklog(task['id'], task['timeSpent'], started=parser.parse(date + 'T08:00:00-00:00'), comment=task['comment'])
if not isinstance(worklog, int):
raise RuntimeError('There was a problem logging your daily work.')
def __log_meetings(self):
print 'Logging your meetings...'
for meeting in self.params['meetings']:
worklog = self.jira.add_worklog(meeting['id'], meeting['timeSpent'], started=parser.parse(meeting['started'] + 'T08:00:00-00:00'), comment=meeting['comment'])
if not isinstance(worklog, int):
raise RuntimeError('There was a problem logging your meetings.')
def __log_sprint_meetings(self, sprint_dates):
print 'Logging your sprint meetings...'
for sprint_meeting in self.params['sprint_meetings']:
worklog = worklog = self.jira.add_worklog(sprint_meeting['id'], sprint_meeting['timeSpent'], started=parser.parse(sprint_meeting['started'] + 'T08:00:00-00:00'), comment=sprint_meeting['comment'])
if not isinstance(worklog, int):
raise RuntimeError('There was a problem logging your sprint meetings.')
def __log_trainings(self):
print 'Logging your trainings...'
for training in self.params['trainings']:
worklog = self.jira.add_worklog(training['id'], training['timeSpent'], started=parser.parse(training['started'] + 'T08:00:00-00:00'), comment=training['comment'])
if not isinstance(worklog, int):
raise RuntimeError('There was a problem logging your trainings.')
def __log_reviews(self):
# TODO: Find a way to automate this
print 'Logging your reviews...'
for review in self.params['reviews']:
worklog = self.jira.add_worklog(self.params('reviews_id'), '{}h'.format(.5 * len(reviews[review])), started=parser.parse(review + 'T08:00:00-00:00'), comment='\n'.join(reviews[review]))
if not isinstance(worklog, int):
raise RuntimeError('There was a problem logging your reviews.')
def __log_other_tasks(self):
# TODO: Make this a filler task function.
print "Not yet supported"