1
0
Fork 0

Merge pull request #12247 from andrewnicols/skipInvalidFormatFundingOnImport

Discard unsupported FUNDING.yml URL values
pull/12271/head
Jordi Boggiano 2025-01-10 16:46:38 +01:00 committed by GitHub
commit f5e7a8390d
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 132 additions and 0 deletions

View File

@ -293,6 +293,24 @@ class GitHubDriver extends VcsDriver
case 'otechie':
$result[$key]['url'] = 'https://otechie.com/' . basename($item['url']);
break;
case 'custom':
$bits = parse_url($item['url']);
if ($bits === false) {
unset($result[$key]);
break;
}
if (!array_key_exists('scheme', $bits) && !array_key_exists('host', $bits)) {
if (Preg::isMatch('{^[a-z0-9-]++\.[a-z]{2,3}$}', $item['url'])) {
$result[$key]['url'] = 'https://'.$item['url'];
break;
}
$this->io->writeError('<warning>Funding URL '.$item['url'].' not in a supported format.</warning>');
unset($result[$key]);
break;
}
break;
}
}

View File

@ -237,6 +237,120 @@ class GitHubDriverTest extends TestCase
self::assertSame('https://github.com/composer/packagist/tree/feature/3.2-foo', $data['support']['source']);
}
/**
* @dataProvider fundingUrlProvider
* @param array<array{type: string, url: string}>|null $expected
*/
public function testFundingFormat(string $funding, ?array $expected): void
{
$repoUrl = 'http://github.com/composer/packagist';
$repoApiUrl = 'https://api.github.com/repos/composer/packagist';
$identifier = 'feature/3.2-foo';
$sha = 'SOMESHA';
$io = $this->getMockBuilder('Composer\IO\IOInterface')->getMock();
$io->expects($this->any())
->method('isInteractive')
->will($this->returnValue(true));
$httpDownloader = $this->getHttpDownloaderMock($io, $this->config);
$httpDownloader->expects(
[
['url' => $repoApiUrl, 'body' => '{"master_branch": "test_master", "owner": {"login": "composer"}, "name": "packagist"}'],
['url' => 'https://api.github.com/repos/composer/packagist/contents/composer.json?ref=feature%2F3.2-foo', 'body' => '{"encoding":"base64","content":"'.base64_encode('{"support": {"source": "'.$repoUrl.'" }}').'"}'],
['url' => 'https://api.github.com/repos/composer/packagist/commits/feature%2F3.2-foo', 'body' => '{"commit": {"committer":{ "date": "2012-09-10"}}}'],
['url' => 'https://api.github.com/repos/composer/packagist/contents/.github/FUNDING.yml', 'body' => '{"encoding": "base64", "content": "'.base64_encode($funding).'"}'],
],
true
);
$repoConfig = [
'url' => $repoUrl,
];
$gitHubDriver = new GitHubDriver($repoConfig, $io, $this->config, $httpDownloader, $this->getProcessExecutorMock());
$gitHubDriver->initialize();
$this->setAttribute($gitHubDriver, 'tags', [$identifier => $sha]);
$this->setAttribute($gitHubDriver, 'branches', ['test_master' => $sha]);
$data = $gitHubDriver->getComposerInformation($identifier);
self::assertIsArray($data);
if ($expected === null) {
self::assertArrayNotHasKey('funding', $data);
} else {
self::assertSame(array_values($expected), array_values($data['funding']));
}
}
public static function fundingUrlProvider(): array
{
return [
[
'custom: example.com',
[
[
'type' => 'custom',
'url' => 'https://example.com',
],
],
],
[
'custom: [example.com]',
[
[
'type' => 'custom',
'url' => 'https://example.com',
],
],
],
[
'custom: "https://example.com"',
[
[
'type' => 'custom',
'url' => 'https://example.com',
],
],
],
[
'custom: ["https://example.com"]',
[
[
'type' => 'custom',
'url' => 'https://example.com',
],
],
],
[
'custom: ["https://example.com", example.org]',
[
[
'type' => 'custom',
'url' => 'https://example.com',
],
[
'type' => 'custom',
'url' => 'https://example.org',
],
],
],
[
'custom: [example.net/funding, "https://example.com", example.org]',
[
[
'type' => 'custom',
'url' => 'https://example.com',
],
[
'type' => 'custom',
'url' => 'https://example.org',
],
],
],
];
}
public function testPublicRepositoryArchived(): void
{
$repoUrl = 'http://github.com/composer/packagist';