Python Gitlab Api 使用方法
阿新 • • 發佈:2020-01-08
簡述
公司使用gitlab 來託管程式碼,日常程式碼merge request 以及其他管理是交給測試,鑑於操作需經常開啟網頁,重複且繁瑣,所以交給Python 管理。
官方文件
安裝
pip install python-gitlab
環境: py3
DEMO
# -*- coding: utf-8 -*- __Author__ = "xiewm" __Date__ = '2017/12/26 13:46' """ gitlab 經常使用到的api DOC_URL: http://python-gitlab.readthedocs.io/en/stable/ LOCAL_PATH: C:\Python36\Lib\site-packages\gitlab """ import gitlab url = 'http://xxxxxxx' token = 'xxxxxxxxxxxxxx' # 登入 gl = gitlab.Gitlab(url,token) # ---------------------------------------------------------------- # # 獲取第一頁project projects = gl.projects.list() # 獲取所有的project projects = gl.projects.list(all=True) # ---------------------------------------------------------------- # # ---------------------------------------------------------------- # # 獲取所有project的name,id for p in gl.projects.list(all=True,as_list=False): print(p.name,p.id) # ---------------------------------------------------------------- # # ---------------------------------------------------------------- # # 獲取第一頁project的name,id for p in gl.projects.list(page=1): print(p.name,p.id) # ---------------------------------------------------------------- # # ---------------------------------------------------------------- # # 通過指定id 獲取 project 物件 project = gl.projects.get(501) # ---------------------------------------------------------------- # # ---------------------------------------------------------------- # # 查詢專案 projects = gl.projects.list(search='keyword') # ---------------------------------------------------------------- # # ---------------------------------------------------------------- # # 建立一個專案 project = gl.projects.create({'name':'project1'}) # ---------------------------------------------------------------- # # ---------------------------------------------------------------- # # 獲取公開的專案 projects = gl.projects.list(visibility='public') # public,internal or private # ---------------------------------------------------------------- # # 獲取 project 物件是以下操作的基礎 # ---------------------------------------------------------------- # # 通過指定project物件獲取該專案的所有分支 branches = project.branches.list() print(branches) # ---------------------------------------------------------------- # # ---------------------------------------------------------------- # # 獲取指定分支的屬性 branch = project.branches.get('master') print(branch) # ---------------------------------------------------------------- # # ---------------------------------------------------------------- # # 建立分支 branch = project.branches.create({'branch_name': 'feature1','ref': 'master'}) # ---------------------------------------------------------------- # # ---------------------------------------------------------------- # # 刪除分支 project.branches.delete('feature1') # ---------------------------------------------------------------- # # ---------------------------------------------------------------- # # 分支保護/取消保護 branch.protect() branch.unprotect() # ---------------------------------------------------------------- # # ---------------------------------------------------------------- # # 獲取指定專案的所有tags tags = project.tags.list() # 獲取某個指定tag 的資訊 tags = project.tags.list('1.0') # 建立一個tag tag = project.tags.create({'tag_name':'1.0','ref':'master'}) # 設定tags 說明: tag.set_release_description('awesome v1.0 release') # 刪除tags project.tags.delete('1.0') # or tag.delete() # ---------------------------------------------------------------- # # 獲取所有commit info commits = project.commits.list() for c in commits: print(c.author_name,c.message,c.title) # ---------------------------------------------------------------- # # ---------------------------------------------------------------- # # 獲取指定commit的info commit = project.commits.get('e3d5a71b') # ---------------------------------------------------------------- # # ---------------------------------------------------------------- # # 獲取指定專案的所有merge request mrs = project.mergerequests.list() print(mrs) # ---------------------------------------------------------------- # # ---------------------------------------------------------------- # # 獲取 指定mr info mr = project.mergerequests.get(mr_id) # ---------------------------------------------------------------- # # ---------------------------------------------------------------- # # 建立一個merge request mr = project.mergerequests.create({'source_branch':'cool_feature','target_branch':'master','title':'merge cool feature',}) # ---------------------------------------------------------------- # # ---------------------------------------------------------------- # # 更新一個merge request 的描述 mr.description = 'New description' mr.save() # ---------------------------------------------------------------- # # ---------------------------------------------------------------- # # 開關一個merge request (close or reopen): mr.state_event = 'close' # or 'reopen' mr.save() # ---------------------------------------------------------------- # # ---------------------------------------------------------------- # # Delete a MR: project.mergerequests.delete(mr_id) # or mr.delete() # ---------------------------------------------------------------- # # ---------------------------------------------------------------- # # Accept a MR: mr.merge() # ---------------------------------------------------------------- # # ---------------------------------------------------------------- # # 指定條件過濾 所有的merge request # state: state of the MR. It can be one of all,merged,opened or closed # order_by: sort by created_at or updated_at # sort: sort order (asc or desc) mrs = project.mergerequests.list(state='merged',sort='asc') # all,opened or closed # ---------------------------------------------------------------- # # ---------------------------------------------------------------- # # 建立一個commit data = { 'branch_name': 'master',# v3 'commit_message': 'blah blah blah','actions': [ { 'action': 'create','file_path': 'blah','content': 'blah' } ] } commit = project.commits.create(data) # ---------------------------------------------------------------- # # ---------------------------------------------------------------- # # Compare two branches,tags or commits: result = project.repository_compare('develop','feature-20180104') print(result) # get the commits for commit in result['commits']: print(commit) # # get the diffs for file_diff in result['diffs']: print(file_diff) # ---------------------------------------------------------------- # # ---------------------------------------------------------------- # # get the commits for commit in result['commits']: print(commit) # # get the diffs for file_diff in result['diffs']: print(file_diff) # ---------------------------------------------------------------- #
總結
通過以上的api 可以封裝一整套gitlab 的指令碼操作或者是命令列操作。
以上這篇Python Gitlab Api 使用方法就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支援我們。