2022-10-13 08:53:26 +00:00
|
|
|
<?php declare(strict_types=1);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* This file is part of Composer.
|
|
|
|
*
|
|
|
|
* (c) Nils Adermann <naderman@naderman.de>
|
|
|
|
* Jordi Boggiano <j.boggiano@seld.be>
|
|
|
|
*
|
|
|
|
* For the full copyright and license information, please view the LICENSE
|
|
|
|
* file that was distributed with this source code.
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace Composer\Test\Command;
|
|
|
|
|
|
|
|
use Composer\Test\TestCase;
|
2022-10-29 07:14:48 +00:00
|
|
|
use UnexpectedValueException;
|
2022-10-13 08:53:26 +00:00
|
|
|
|
|
|
|
class AuditCommandTest extends TestCase
|
|
|
|
{
|
|
|
|
public function testSuccessfulResponseCodeWhenNoPackagesAreRequired(): void
|
|
|
|
{
|
|
|
|
$this->initTempComposer();
|
|
|
|
|
|
|
|
$appTester = $this->getApplicationTester();
|
|
|
|
$appTester->run(['command' => 'audit']);
|
|
|
|
|
|
|
|
$appTester->assertCommandIsSuccessful();
|
2022-10-29 07:14:48 +00:00
|
|
|
self::assertEquals('No packages - skipping audit.', trim($appTester->getDisplay(true)));
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testErrorAuditingLockFileWhenItIsMissing(): void
|
|
|
|
{
|
|
|
|
$this->initTempComposer();
|
|
|
|
$this->createInstalledJson([self::getPackage()]);
|
|
|
|
|
|
|
|
$this->expectException(UnexpectedValueException::class);
|
|
|
|
$this->expectExceptionMessage(
|
|
|
|
"Valid composer.json and composer.lock files are required to run this command with --locked"
|
|
|
|
);
|
|
|
|
|
|
|
|
$appTester = $this->getApplicationTester();
|
|
|
|
$appTester->run(['command' => 'audit', '--locked' => true]);
|
2022-10-13 08:53:26 +00:00
|
|
|
}
|
2024-02-07 10:40:29 +00:00
|
|
|
|
|
|
|
public function testAuditPackageWithNoSecurityVulnerabilities(): void
|
|
|
|
{
|
|
|
|
$this->initTempComposer();
|
|
|
|
$packages = [self::getPackage()];
|
|
|
|
$this->createInstalledJson($packages);
|
|
|
|
$this->createComposerLock($packages);
|
|
|
|
|
|
|
|
$appTester = $this->getApplicationTester();
|
|
|
|
$appTester->run(['command' => 'audit', '--locked' => true]);
|
|
|
|
|
|
|
|
self::assertStringContainsString(
|
|
|
|
'No security vulnerability advisories found.',
|
|
|
|
trim($appTester->getDisplay(true))
|
|
|
|
);
|
|
|
|
}
|
2024-02-08 10:06:34 +00:00
|
|
|
|
|
|
|
public function testAuditPackageWithNoDevOptionPassed(): void
|
|
|
|
{
|
|
|
|
$this->initTempComposer();
|
|
|
|
$devPackage = [self::getPackage()];
|
|
|
|
$this->createInstalledJson([], $devPackage);
|
|
|
|
$this->createComposerLock([], $devPackage);
|
|
|
|
|
|
|
|
$appTester = $this->getApplicationTester();
|
|
|
|
$appTester->run(['command' => 'audit', '--no-dev' => true]);
|
|
|
|
|
|
|
|
self::assertStringContainsString(
|
|
|
|
'No packages - skipping audit.',
|
|
|
|
trim($appTester->getDisplay(true))
|
|
|
|
);
|
|
|
|
}
|
2022-10-13 08:53:26 +00:00
|
|
|
}
|