-
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathChangelogCheckCommand.php
More file actions
115 lines (103 loc) · 3.7 KB
/
ChangelogCheckCommand.php
File metadata and controls
115 lines (103 loc) · 3.7 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
<?php
declare(strict_types=1);
/**
* Fast Forward Development Tools for PHP projects.
*
* This file is part of fast-forward/dev-tools project.
*
* @author Felipe Sayão Lobato Abreu <github@mentordosnerds.com>
* @license https://opensource.org/licenses/MIT MIT License
*
* @see https://github.com/php-fast-forward/
* @see https://github.com/php-fast-forward/dev-tools
* @see https://github.com/php-fast-forward/dev-tools/issues
* @see https://php-fast-forward.github.io/dev-tools/
* @see https://datatracker.ietf.org/doc/html/rfc2119
*/
namespace FastForward\DevTools\Console\Command;
use FastForward\DevTools\Console\Command\Traits\LogsCommandResults;
use Composer\Command\BaseCommand;
use FastForward\DevTools\Changelog\Checker\UnreleasedEntryCheckerInterface;
use FastForward\DevTools\Console\Input\HasJsonOption;
use FastForward\DevTools\Filesystem\FilesystemInterface;
use Psr\Log\LoggerInterface;
use Symfony\Component\Console\Attribute\AsCommand;
use Symfony\Component\Console\Input\InputInterface;
use Symfony\Component\Console\Input\InputOption;
use Symfony\Component\Console\Output\OutputInterface;
/**
* Verifies that the changelog contains pending unreleased notes.
*/
#[AsCommand(
name: 'changelog:check',
description: 'Checks whether a changelog file contains meaningful unreleased entries.'
)]
final class ChangelogCheckCommand extends BaseCommand implements LoggerAwareCommandInterface
{
use HasJsonOption;
use LogsCommandResults;
/**
* @param FilesystemInterface $filesystem
* @param UnreleasedEntryCheckerInterface $unreleasedEntryChecker
* @param LoggerInterface $logger
*/
public function __construct(
private readonly FilesystemInterface $filesystem,
private readonly UnreleasedEntryCheckerInterface $unreleasedEntryChecker,
private readonly LoggerInterface $logger,
) {
parent::__construct();
}
/**
* Configures changelog verification options.
*/
protected function configure(): void
{
$this->setHelp(
'This command validates the current Unreleased section and may compare it against a base git'
. ' reference to enforce pull request changelog updates.'
);
$this->addJsonOption()
->addOption(
name: 'against',
mode: InputOption::VALUE_REQUIRED,
description: 'Optional git reference used as the baseline changelog file.',
)
->addOption(
name: 'file',
mode: InputOption::VALUE_REQUIRED,
description: 'Path to the changelog file.',
default: 'CHANGELOG.md',
);
}
/**
* Executes the changelog verification.
*
* @param InputInterface $input
* @param OutputInterface $output
*/
protected function execute(InputInterface $input, OutputInterface $output): int
{
$path = $this->filesystem->getAbsolutePath($input->getOption('file'));
$against = $input->getOption('against');
$hasPendingChanges = $this->unreleasedEntryChecker
->hasPendingChanges($path, $against);
if ($hasPendingChanges) {
return $this->success(
'The changelog contains unreleased changes ready for review.',
$input,
[
'has_pending_changes' => true,
],
);
}
return $this->failure(
'The changelog must add a meaningful entry to the Unreleased section.',
$input,
[
'has_pending_changes' => false,
],
(string) $input->getOption('file'),
);
}
}