-
Notifications
You must be signed in to change notification settings - Fork 18
/
Copy pathpush.py
100 lines (93 loc) · 3.29 KB
/
push.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
import git
import time
import traceback
import subprocess
from pathlib import Path
from git import GitCommandError
from multiprocessing.pool import ThreadPool
from multiprocessing.dummy import Pool, Lock
lock = Lock()
def push(repo=None):
if not repo:
repo = git.Repo()
app_sha = None
try:
app_sha = repo.git.rev_parse('app').strip()
except GitCommandError:
pass
remote_head_list = []
remote_tag_list = []
for i in repo.git.ls_remote('origin').split('\n'):
sha, refs = i.split()
if refs.startswith('refs/heads/'):
head = refs.split('/')[2]
if head.isdecimal():
remote_head_list.append((sha, head))
elif refs.startswith('refs/tags/'):
tag = refs.split('/')[2]
remote_tag_list.append((sha, tag))
total_branch = 0
total_tag = 0
with Pool(8) as pool:
pool: ThreadPool
result_list = []
for local_head in repo.heads:
if local_head.name.isdecimal():
for remote_sha, remote_head in remote_head_list:
if local_head.name == remote_head and local_head.commit.hexsha == remote_sha:
break
else:
if local_head.commit.hexsha == app_sha:
continue
total_branch += 1
with lock:
print(local_head.name, local_head.commit.hexsha)
result_list.append(
pool.map_async(subprocess.check_call, (['git', 'push', 'origin', local_head.name],)))
for local_tag in repo.tags:
for remote_sha, remote_tag in remote_tag_list:
if remote_tag == local_tag.name:
break
else:
total_tag += 1
with lock:
print(local_tag.name, local_tag.commit.hexsha)
result_list.append(pool.map_async(subprocess.check_call, (['git', 'push', 'origin', local_tag.name],)))
try:
while pool._state == 'RUN':
if all([result.ready() for result in result_list]):
break
time.sleep(1)
except KeyboardInterrupt:
pass
finally:
with lock:
pool.terminate()
print(f'Pushed {total_branch} branch!')
print(f'Pushed {total_tag} tag!')
if not all([result.successful() for result in result_list]):
return push(repo=repo)
def push_data(repo=None):
if not repo:
repo = git.Repo('data')
print('Pushing to the data branch!')
try:
repo.git.add('client/ssfn*')
except git.exc.GitCommandError:
pass
try:
file_list = ['appinfo.json', 'userinfo.json', 'users.json', '2fa.json', 'apps.xlsx']
for i in file_list:
path = Path('data') / i
if path.is_file():
repo.git.add(path.name)
except git.exc.GitCommandError:
traceback.print_exc()
try:
repo.git.commit('-m', 'update')
repo.git.push('origin', 'data')
except git.exc.GitCommandError:
traceback.print_exc()
if __name__ == '__main__':
push()
push_data()