2013-05-11 16:39:06 +04:00
|
|
|
Feature: hub checkout <PULLREQ-URL>
|
|
|
|
Background:
|
|
|
|
Given I am in "git://github.com/mojombo/jekyll.git" git repo
|
|
|
|
And I am "mislav" on github.com with OAuth token "OTOKEN"
|
|
|
|
|
|
|
|
Scenario: Unchanged command
|
|
|
|
When I run `hub checkout master`
|
|
|
|
Then "git checkout master" should be run
|
|
|
|
|
|
|
|
Scenario: Checkout a pull request
|
|
|
|
Given the GitHub API server:
|
|
|
|
"""
|
|
|
|
get('/repos/mojombo/jekyll/pulls/77') {
|
2014-04-01 04:00:12 +04:00
|
|
|
halt 406 unless request.env['HTTP_ACCEPT'] == 'application/vnd.github.v3+json;charset=utf-8'
|
2013-05-11 16:39:06 +04:00
|
|
|
json :head => {
|
2015-02-23 08:44:36 +03:00
|
|
|
:ref => "fixes",
|
2015-01-21 09:53:01 +03:00
|
|
|
:repo => {
|
2015-02-26 09:43:23 +03:00
|
|
|
:owner => { :login => "mislav" },
|
2015-02-23 08:44:36 +03:00
|
|
|
:name => "jekyll",
|
2015-01-21 09:53:01 +03:00
|
|
|
:private => false
|
|
|
|
}
|
2016-08-20 23:49:56 +03:00
|
|
|
}, :base => {
|
|
|
|
:repo => {
|
|
|
|
:name => 'jekyll',
|
|
|
|
:html_url => 'https://github.com/mojombo/jekyll',
|
|
|
|
:owner => { :login => "mojombo" },
|
|
|
|
}
|
2013-05-11 16:39:06 +04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
"""
|
|
|
|
When I run `hub checkout -f https://github.com/mojombo/jekyll/pull/77 -q`
|
2016-08-20 23:49:56 +03:00
|
|
|
Then "git fetch origin pull/77/head:mislav-fixes" should be run
|
2016-08-18 22:12:34 +03:00
|
|
|
And "git checkout -f mislav-fixes -q" should be run
|
2013-05-11 16:39:06 +04:00
|
|
|
|
2016-08-20 23:49:56 +03:00
|
|
|
Scenario: No matching remotes for pull request base
|
2015-01-21 09:53:01 +03:00
|
|
|
Given the GitHub API server:
|
|
|
|
"""
|
2016-08-20 23:49:56 +03:00
|
|
|
get('/repos/mislav/jekyll/pulls/77') {
|
|
|
|
json :base => {
|
2015-01-21 09:53:01 +03:00
|
|
|
:repo => {
|
2016-08-20 23:49:56 +03:00
|
|
|
:name => 'jekyll',
|
|
|
|
:html_url => 'https://github.com/mislav/jekyll',
|
2015-02-26 09:43:23 +03:00
|
|
|
:owner => { :login => "mislav" },
|
2015-01-21 09:53:01 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
"""
|
2016-08-20 23:49:56 +03:00
|
|
|
When I run `hub checkout -f https://github.com/mislav/jekyll/pull/77 -q`
|
|
|
|
Then the exit status should be 1
|
|
|
|
And the stderr should contain exactly:
|
2013-05-11 16:39:06 +04:00
|
|
|
"""
|
2016-08-20 23:49:56 +03:00
|
|
|
could not find git remote for mislav/jekyll\n
|
2013-05-11 16:39:06 +04:00
|
|
|
"""
|
|
|
|
|
2016-08-20 23:49:56 +03:00
|
|
|
Scenario: Custom name for new branch
|
2013-05-11 16:39:06 +04:00
|
|
|
Given the GitHub API server:
|
|
|
|
"""
|
|
|
|
get('/repos/mojombo/jekyll/pulls/77') {
|
|
|
|
json :head => {
|
2015-02-23 08:44:36 +03:00
|
|
|
:ref => "fixes",
|
2015-01-21 09:53:01 +03:00
|
|
|
:repo => {
|
2015-02-23 08:44:36 +03:00
|
|
|
:name => "jekyll",
|
2016-08-20 23:49:56 +03:00
|
|
|
:owner => { :login => "mislav" },
|
2015-01-21 09:53:01 +03:00
|
|
|
}
|
2016-08-20 23:49:56 +03:00
|
|
|
}, :base => {
|
2015-01-21 09:53:01 +03:00
|
|
|
:repo => {
|
2016-08-20 23:49:56 +03:00
|
|
|
:name => 'jekyll',
|
|
|
|
:html_url => 'https://github.com/mojombo/jekyll',
|
|
|
|
:owner => { :login => "mojombo" },
|
2015-01-21 09:53:01 +03:00
|
|
|
}
|
2013-05-11 16:39:06 +04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
"""
|
2016-08-20 23:49:56 +03:00
|
|
|
When I run `hub checkout https://github.com/mojombo/jekyll/pull/77 fixes-from-mislav`
|
|
|
|
Then "git fetch origin pull/77/head:fixes-from-mislav" should be run
|
|
|
|
And "git checkout fixes-from-mislav" should be run
|
2016-08-21 01:00:13 +03:00
|
|
|
|
|
|
|
Scenario: Same-repo
|
|
|
|
Given the GitHub API server:
|
|
|
|
"""
|
|
|
|
get('/repos/mojombo/jekyll/pulls/77') {
|
|
|
|
json :head => {
|
|
|
|
:ref => "fixes",
|
|
|
|
:repo => {
|
|
|
|
:name => "jekyll",
|
|
|
|
:owner => { :login => "mojombo" },
|
|
|
|
}
|
|
|
|
}, :base => {
|
|
|
|
:repo => {
|
|
|
|
:name => "jekyll",
|
|
|
|
:html_url => "https://github.com/mojombo/jekyll",
|
|
|
|
:owner => { :login => "mojombo" },
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
"""
|
|
|
|
When I run `hub checkout -f https://github.com/mojombo/jekyll/pull/77 -q`
|
|
|
|
Then "git fetch origin +refs/heads/fixes:refs/remotes/origin/fixes" should be run
|
|
|
|
And "git checkout -f -b fixes --track origin/fixes -q" should be run
|
|
|
|
|
|
|
|
Scenario: Same-repo with custom branch name
|
|
|
|
Given the GitHub API server:
|
|
|
|
"""
|
|
|
|
get('/repos/mojombo/jekyll/pulls/77') {
|
|
|
|
json :head => {
|
|
|
|
:ref => "fixes",
|
|
|
|
:repo => {
|
|
|
|
:name => "jekyll",
|
|
|
|
:owner => { :login => "mojombo" },
|
|
|
|
}
|
|
|
|
}, :base => {
|
|
|
|
:repo => {
|
|
|
|
:name => "jekyll",
|
|
|
|
:html_url => "https://github.com/mojombo/jekyll",
|
|
|
|
:owner => { :login => "mojombo" },
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
"""
|
|
|
|
When I run `hub checkout https://github.com/mojombo/jekyll/pull/77 mycustombranch`
|
|
|
|
Then "git fetch origin +refs/heads/fixes:refs/remotes/origin/fixes" should be run
|
|
|
|
And "git checkout -b mycustombranch --track origin/fixes" should be run
|
2016-10-03 19:39:46 +03:00
|
|
|
|
|
|
|
Scenario: Unavailable fork
|
|
|
|
Given the GitHub API server:
|
|
|
|
"""
|
|
|
|
get('/repos/mojombo/jekyll/pulls/77') {
|
|
|
|
json :head => {
|
|
|
|
:ref => "fixes",
|
|
|
|
:repo => nil
|
|
|
|
}, :base => {
|
|
|
|
:repo => {
|
|
|
|
:name => "jekyll",
|
|
|
|
:html_url => "https://github.com/mojombo/jekyll",
|
|
|
|
:owner => { :login => "mojombo" },
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
"""
|
|
|
|
When I run `hub checkout https://github.com/mojombo/jekyll/pull/77`
|
|
|
|
Then "git fetch origin pull/77/head:pr-77" should be run
|
|
|
|
And "git checkout pr-77" should be run
|