forked from Honey723/ManifestAutoUpdate-Cache
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpush.py
107 lines (99 loc) · 3.56 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
101
102
103
104
105
106
107
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,delete_tag=set()):
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 tag in delete_tag:
with lock:
print('delete_tag => ', tag)
result_list.append(pool.map_async(subprocess.check_call, (['git', 'push', 'origin', f':refs/tags/{tag}'],)))
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:
#添加push appuserlist.json文件到仓库
file_list = ['appinfo.json', 'userinfo.json', 'users.json', '2fa.json', 'apps.xlsx', 'appuserlist.json','Avalidaccount.json']
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()