Fixing bug not cleaning up workspaces.

main
Clark Stuth 10 years ago
parent 492539101c
commit c11105dd60

@ -193,4 +193,10 @@ class PerforceDriver extends VcsDriver
{ {
$this->perforce = $perforce; $this->perforce = $perforce;
} }
public function getPerforce()
{
return $this->perforce;
}
} }

@ -37,6 +37,8 @@ class Perforce
protected $io; protected $io;
protected $filesystem;
public function __construct($repoConfig, $port, $path, ProcessExecutor $process, $isWindows, IOInterface $io) public function __construct($repoConfig, $port, $path, ProcessExecutor $process, $isWindows, IOInterface $io)
{ {
$this->windowsFlag = $isWindows; $this->windowsFlag = $isWindows;
@ -109,10 +111,10 @@ class Perforce
public function cleanupClientSpec() public function cleanupClientSpec()
{ {
$client = $this->getClient(); $client = $this->getClient();
$command = 'p4 client -d $client'; $command = 'p4 client -d ' . $client;
$this->executeCommand($command); $this->executeCommand($command);
$clientSpec = $this->getP4ClientSpec(); $clientSpec = $this->getP4ClientSpec();
$fileSystem = new FileSystem($this->process); $fileSystem = $this->getFilesystem();
$fileSystem->remove($clientSpec); $fileSystem->remove($clientSpec);
} }
@ -141,7 +143,7 @@ class Perforce
public function initializePath($path) public function initializePath($path)
{ {
$this->path = $path; $this->path = $path;
$fs = new Filesystem(); $fs = $this->getFilesystem();
$fs->ensureDirectoryExists($path); $fs->ensureDirectoryExists($path);
} }
@ -559,4 +561,20 @@ class Perforce
return $result; return $result;
} }
public function getFilesystem()
{
if (empty($this->filesystem))
{
$this->filesystem = new Filesystem($this->process);
}
return $this->filesystem;
}
public function setFilesystem(Filesystem $fs)
{
$this->filesystem = $fs;
}
} }

@ -93,7 +93,7 @@ class PerforceDriverTest extends \PHPUnit_Framework_TestCase
protected function getMockPerforce() protected function getMockPerforce()
{ {
$methods = array('p4login', 'checkStream', 'writeP4ClientSpec', 'connectClient', 'getComposerInformation'); $methods = array('p4login', 'checkStream', 'writeP4ClientSpec', 'connectClient', 'getComposerInformation', 'cleanupClientSpec');
return $this->getMockBuilder('Composer\Util\Perforce', $methods)->disableOriginalConstructor()->getMock(); return $this->getMockBuilder('Composer\Util\Perforce', $methods)->disableOriginalConstructor()->getMock();
} }
@ -159,4 +159,13 @@ class PerforceDriverTest extends \PHPUnit_Framework_TestCase
$this->expectOutputString(''); $this->expectOutputString('');
$this->assertFalse(PerforceDriver::supports($this->io, $this->config, 'existing.url')); $this->assertFalse(PerforceDriver::supports($this->io, $this->config, 'existing.url'));
} }
public function testCleanup()
{
$this->perforce->expects($this->once())->method('cleanupClientSpec');
$this->driver->setPerforce($this->perforce);
$this->driver->cleanup();
$this->assertNull($this->driver->getPerforce());
}
} }

@ -679,4 +679,19 @@ class PerforceTest extends \PHPUnit_Framework_TestCase
{ {
$this->perforce->setStream('//depot/branch'); $this->perforce->setStream('//depot/branch');
} }
public function testCleanupClientSpecShouldDeleteClient()
{
$fs = $this->getMock('Composer\Util\Filesystem');
$this->perforce->setFilesystem($fs);
$testClient = $this->perforce->getClient();
$expectedCommand = 'p4 client -d ' . $testClient;
$this->processExecutor->expects($this->once())->method('execute')->with($this->equalTo($expectedCommand));
$fs->expects($this->once())->method('remove')->with($this->perforce->getP4ClientSpec());
$this->perforce->cleanupClientSpec();
}
} }

Loading…
Cancel
Save