Merge pull request #131 from adam111316/feature/AddPullRequestCheckout

Add pull request checkout option to General Config/Advanced Settings
This commit is contained in:
adam111316 2015-01-02 07:47:37 +08:00
commit 4930a69798
6 changed files with 80 additions and 2 deletions

View file

@ -15,6 +15,7 @@
* Add anime unit test cases (port from lad1337/sickbeard) * Add anime unit test cases (port from lad1337/sickbeard)
* Fix normal tv show regex (port from midgetspy/sickbeard) * Fix normal tv show regex (port from midgetspy/sickbeard)
* Fix anime regex (port from lad1337/sickbeard) * Fix anime regex (port from lad1337/sickbeard)
* Add pull request checkout option to General Config/Advanced Settings
[develop changelog] [develop changelog]

View file

@ -461,6 +461,24 @@
</label> </label>
</div> </div>
#set pulls = sickbeard.versionCheckScheduler.action.list_remote_pulls()
#if len(pulls) > 0 and $sickbeard.BRANCH != 'master':
<div class="field-pair">
<label>
<span class="component-title">Pull request:</span>
<span class="component-desc">
<select id="pullRequestVersion" class="form-control form-control-inline input-sm pull-left">
#for $cur_branch in $pulls:
<option value="$cur_branch.fetch_name()" #if $cur_branch == $sickbeard.BRANCH then 'selected="selected"' else ''#>$cur_branch</option>
#end for
</select>
<input class="btn btn-inline" style="margin-left: 6px;" type="button" id="pullRequestCheckout" value="Checkout Pull Request">
<div class="clear-left"><p>select pull request to test (restart required)</p></div>
</span>
</label>
</div>
#end if
<div class="field-pair"> <div class="field-pair">
<label for="git_remote"> <label for="git_remote">
<span class="component-title">Git remote for branch</span> <span class="component-title">Git remote for branch</span>

View file

@ -114,6 +114,10 @@ $(document).ready(function(){
window.location.href = sbRoot + '/home/branchCheckout?branch=' + $('#branchVersion').val(); window.location.href = sbRoot + '/home/branchCheckout?branch=' + $('#branchVersion').val();
}); });
$('#pullRequestCheckout').click(function(){
window.location.href = sbRoot + '/home/pullRequestCheckout?branch=' + $('#pullRequestVersion').val();
});
}); });
function config_success(){ function config_success(){

View file

@ -93,3 +93,26 @@ class GitHub(object):
['repos', self.github_repo_user, self.github_repo, 'branches'], ['repos', self.github_repo_user, self.github_repo, 'branches'],
params={'per_page': 100}) params={'per_page': 100})
return access_API return access_API
def pull_requests(self):
access_API = self._access_API(
['repos', self.github_repo_user, self.github_repo, 'pulls'],
params={'per_page': 100})
pull = []
for x in access_API:
try:
pull.append(PullRequest(x['head']['ref'], x['number']))
except:
continue
return pull
class PullRequest(object):
def __init__(self, ref, number):
self.ref = ref
self.number = number
def __repr__(self):
return '%s: %s' % (self.number, self.ref)
def fetch_name(self):
return 'pull/%s/head:pull/%s/%s' % (self.number, self.number, self.ref)

View file

@ -115,9 +115,15 @@ class CheckVersion():
if self.updater.need_update(): if self.updater.need_update():
return self.updater.update() return self.updater.update()
def fetch(self, pull_request):
return self.updater.fetch(pull_request)
def list_remote_branches(self): def list_remote_branches(self):
return self.updater.list_remote_branches() return self.updater.list_remote_branches()
def list_remote_pulls(self):
return self.updater.list_remote_pulls()
def get_branch(self): def get_branch(self):
return self.updater.branch return self.updater.branch
@ -400,6 +406,17 @@ class GitUpdateManager(UpdateManager):
return re.findall('\S+\Wrefs/heads/(.*)', branches) return re.findall('\S+\Wrefs/heads/(.*)', branches)
return [] return []
def list_remote_pulls(self):
gh = github.GitHub(self.github_repo_user, self.github_repo, self.branch)
return gh.pull_requests()
def fetch(self, pull_request):
output, err, exit_status = self._run_git(self._git_path, 'fetch -f %s %s' % (sickbeard.GIT_REMOTE, pull_request)) # @UnusedVariable
if exit_status == 0:
return True
return False
class SourceUpdateManager(UpdateManager): class SourceUpdateManager(UpdateManager):
def __init__(self): def __init__(self):
@ -597,3 +614,7 @@ class SourceUpdateManager(UpdateManager):
def list_remote_branches(self): def list_remote_branches(self):
gh = github.GitHub(self.github_repo_user, self.github_repo, self.branch) gh = github.GitHub(self.github_repo_user, self.github_repo, self.branch)
return [x['name'] for x in gh.branches() if x and 'name' in x] return [x['name'] for x in gh.branches() if x and 'name' in x]
def list_remote_pulls(self):
# we don't care about testers that don't use git
return []

View file

@ -3628,6 +3628,17 @@ class Home(MainHandler):
ui.notifications.message('Checking out branch: ', branch) ui.notifications.message('Checking out branch: ', branch)
return self.update(sickbeard.PID) return self.update(sickbeard.PID)
def pullRequestCheckout(self, branch):
pull_request = branch
branch = branch.split(':')[1]
fetched = sickbeard.versionCheckScheduler.action.fetch(pull_request)
if fetched:
sickbeard.BRANCH = branch
ui.notifications.message('Checking out branch: ', branch)
return self.update(sickbeard.PID)
else:
return redirect('/home/')
def displayShow(self, show=None): def displayShow(self, show=None):
if show is None: if show is None: