Merge pull request #5591 from ianlet/master
Use https url of the repository instead of ssh given gitlab project is publicpull/5645/head
commit
3e010fc332
|
@ -148,7 +148,7 @@ class GitLabDriver extends VcsDriver
|
||||||
*/
|
*/
|
||||||
public function getRepositoryUrl()
|
public function getRepositoryUrl()
|
||||||
{
|
{
|
||||||
return $this->project['ssh_url_to_repo'];
|
return $this->project['public'] ? $this->project['http_url_to_repo'] : $this->project['ssh_url_to_repo'];
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -69,6 +69,7 @@ class GitLabDriverTest extends TestCase
|
||||||
{
|
{
|
||||||
"id": 17,
|
"id": 17,
|
||||||
"default_branch": "mymaster",
|
"default_branch": "mymaster",
|
||||||
|
"public": false,
|
||||||
"http_url_to_repo": "https://gitlab.com/mygroup/myproject.git",
|
"http_url_to_repo": "https://gitlab.com/mygroup/myproject.git",
|
||||||
"ssh_url_to_repo": "git@gitlab.com:mygroup/myproject.git",
|
"ssh_url_to_repo": "git@gitlab.com:mygroup/myproject.git",
|
||||||
"last_activity_at": "2014-12-01T09:17:51.000+01:00",
|
"last_activity_at": "2014-12-01T09:17:51.000+01:00",
|
||||||
|
@ -97,6 +98,45 @@ JSON;
|
||||||
return $driver;
|
return $driver;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @dataProvider getInitializeUrls
|
||||||
|
*/
|
||||||
|
public function testInitializePublicProject($url, $apiUrl)
|
||||||
|
{
|
||||||
|
// @link http://doc.gitlab.com/ce/api/projects.html#get-single-project
|
||||||
|
$projectData = <<<JSON
|
||||||
|
{
|
||||||
|
"id": 17,
|
||||||
|
"default_branch": "mymaster",
|
||||||
|
"public": true,
|
||||||
|
"http_url_to_repo": "https://gitlab.com/mygroup/myproject.git",
|
||||||
|
"ssh_url_to_repo": "git@gitlab.com:mygroup/myproject.git",
|
||||||
|
"last_activity_at": "2014-12-01T09:17:51.000+01:00",
|
||||||
|
"name": "My Project",
|
||||||
|
"name_with_namespace": "My Group / My Project",
|
||||||
|
"path": "myproject",
|
||||||
|
"path_with_namespace": "mygroup/myproject",
|
||||||
|
"web_url": "https://gitlab.com/mygroup/myproject"
|
||||||
|
}
|
||||||
|
JSON;
|
||||||
|
|
||||||
|
$this->remoteFilesystem
|
||||||
|
->getContents('gitlab.com', $apiUrl, false)
|
||||||
|
->willReturn($projectData)
|
||||||
|
->shouldBeCalledTimes(1)
|
||||||
|
;
|
||||||
|
|
||||||
|
$driver = new GitLabDriver(array('url' => $url), $this->io->reveal(), $this->config, $this->process->reveal(), $this->remoteFilesystem->reveal());
|
||||||
|
$driver->initialize();
|
||||||
|
|
||||||
|
$this->assertEquals($apiUrl, $driver->getApiUrl(), 'API URL is derived from the repository URL');
|
||||||
|
$this->assertEquals('mymaster', $driver->getRootIdentifier(), 'Root identifier is the default branch in GitLab');
|
||||||
|
$this->assertEquals('https://gitlab.com/mygroup/myproject.git', $driver->getRepositoryUrl(), 'The repository URL is the SSH one by default');
|
||||||
|
$this->assertEquals('https://gitlab.com/mygroup/myproject', $driver->getUrl());
|
||||||
|
|
||||||
|
return $driver;
|
||||||
|
}
|
||||||
|
|
||||||
public function testGetDist()
|
public function testGetDist()
|
||||||
{
|
{
|
||||||
$driver = $this->testInitialize('https://gitlab.com/mygroup/myproject', 'https://gitlab.com/api/v3/projects/mygroup%2Fmyproject');
|
$driver = $this->testInitialize('https://gitlab.com/mygroup/myproject', 'https://gitlab.com/api/v3/projects/mygroup%2Fmyproject');
|
||||||
|
@ -126,6 +166,20 @@ JSON;
|
||||||
$this->assertEquals($expected, $driver->getSource($reference));
|
$this->assertEquals($expected, $driver->getSource($reference));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testGetSource_GivenPublicProject()
|
||||||
|
{
|
||||||
|
$driver = $this->testInitializePublicProject('https://gitlab.com/mygroup/myproject', 'https://gitlab.com/api/v3/projects/mygroup%2Fmyproject', true);
|
||||||
|
|
||||||
|
$reference = 'c3ebdbf9cceddb82cd2089aaef8c7b992e536363';
|
||||||
|
$expected = array(
|
||||||
|
'type' => 'git',
|
||||||
|
'url' => 'https://gitlab.com/mygroup/myproject.git',
|
||||||
|
'reference' => $reference,
|
||||||
|
);
|
||||||
|
|
||||||
|
$this->assertEquals($expected, $driver->getSource($reference));
|
||||||
|
}
|
||||||
|
|
||||||
public function testGetTags()
|
public function testGetTags()
|
||||||
{
|
{
|
||||||
$driver = $this->testInitialize('https://gitlab.com/mygroup/myproject', 'https://gitlab.com/api/v3/projects/mygroup%2Fmyproject');
|
$driver = $this->testInitialize('https://gitlab.com/mygroup/myproject', 'https://gitlab.com/api/v3/projects/mygroup%2Fmyproject');
|
||||||
|
|
Loading…
Reference in New Issue