home = self::getUniqueTmpDirectory(); $this->config = new Config(); $this->config->merge(array( 'config' => array( 'home' => $this->home, ), )); } public function testGetBranchesFilterInvalidBranchNames() { $process = new ProcessExecutorMock; $io = $this->getMockBuilder('Composer\IO\IOInterface')->getMock(); $driver = new GitDriver(array('url' => 'https://example.org/acme.git'), $io, $this->config, $this->getMockBuilder('Composer\Util\HttpDownloader')->disableOriginalConstructor()->getMock(), $process); $this->setRepoDir($driver, $this->home); // Branches starting with a - character are not valid git branches names // Still assert that they get filtered to prevent issues later on $stdout = <<expects(array(array( 'cmd' => 'git branch --no-color --no-abbrev -v', 'stdout' => $stdout, ))); $branches = $driver->getBranches(); $this->assertSame(array( 'main' => '089681446ba44d6d9004350192486f2ceb4eaa06', '2.2' => '12681446ba44d6d9004350192486f2ceb4eaa06', ), $branches); } public function testFileGetContentInvalidIdentifier() { $this->setExpectedException('\RuntimeException'); $process = new ProcessExecutorMock; $io = $this->getMockBuilder('Composer\IO\IOInterface')->getMock(); $driver = new GitDriver(array('url' => 'https://example.org/acme.git'), $io, $this->config, $this->getMockBuilder('Composer\Util\HttpDownloader')->disableOriginalConstructor()->getMock(), $process); $this->assertNull($driver->getFileContent('file.txt', 'h')); $driver->getFileContent('file.txt', '-h'); } /** * @param GitDriver $driver * @param string $path */ private function setRepoDir($driver, $path): void { $reflectionClass = new \ReflectionClass($driver); $reflectionProperty = $reflectionClass->getProperty('repoDir'); $reflectionProperty->setAccessible(true); $reflectionProperty->setValue($driver, $path); } }