-
Notifications
You must be signed in to change notification settings - Fork 18
/
Copy pathmove_closed_issues.py
executable file
·113 lines (92 loc) · 2.92 KB
/
move_closed_issues.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
#!/usr/bin/env python3
"""
Move closed Issues out of Backlog and into Active Sprint: Done.
"""
# Standard library
import argparse
import sys
import traceback
# Third-party
from github import GithubException
# First-party/Local
import ccos.log
from ccos import gh_utils
LOG = ccos.log.setup_logger()
class ScriptError(Exception):
def __init__(self, message, code=None):
self.code = code if code else 1
message = "({}) {}".format(self.code, message)
super(ScriptError, self).__init__(message)
def setup():
"""Instantiate and configure argparse and logging.
Return argsparse namespace.
"""
ap = argparse.ArgumentParser(description=__doc__)
ap.add_argument(
"-n",
"--dryrun",
action="store_true",
help="dry run: do not make any changes",
)
args = ap.parse_args()
return args
def get_cards(cc):
active = None
backlog = None
done = None
for project in cc.get_projects():
if project.name == "Active Sprint":
active = project
elif project.name == "Backlog":
backlog = project
for column in active.get_columns():
if column.name == "Done":
done = column
break
return backlog, done
def move_cards(args, github, backlog, done):
for column in backlog.get_columns():
LOG.info(f"{backlog.name}: {column.name}")
for card in column.get_cards():
if not card.content_url or "/issues/" not in card.content_url:
continue
content = card.get_content(content_type="Issue")
if content.state != "closed":
continue
LOG.info(f" {content.title}")
try:
if not args.dryrun:
done.create_card(
content_id=content.id, content_type="Issue"
)
LOG.info(f" -> added to Active Sprint: {done.name}")
except GithubException as e:
if e.data["errors"][0]["message"] != (
"Project already has the associated issue"
):
raise
if not args.dryrun:
card.delete()
LOG.info(" -> removed.")
LOG.success("done.")
def main():
args = setup()
github = gh_utils.set_up_github_client()
cc = gh_utils.get_cc_organization(github)
backlog, done = get_cards(cc)
move_cards(args, github, backlog, done)
if __name__ == "__main__":
try:
main()
except SystemExit as e:
sys.exit(e.code)
except KeyboardInterrupt:
LOG.info("Halted via KeyboardInterrupt.")
sys.exit(130)
except ScriptError:
error_type, error_value, error_traceback = sys.exc_info()
LOG.critical(f"{error_value}")
sys.exit(error_value.code)
except Exception:
LOG.error(f"Unhandled exception: {traceback.format_exc()}")
sys.exit(1)