fix: Update repology multi package project filtering (#13368)

Co-authored-by: Michael Kriese <michael.kriese@visualon.de>
This commit is contained in:
Richard Versteeg 2022-01-05 08:49:11 +01:00 committed by GitHub
parent 9e7c3ae074
commit a3d38b1e0d
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 125 additions and 8 deletions

File diff suppressed because one or more lines are too long

View file

@ -51,6 +51,7 @@ const fixtureGccDefaults = loadFixture(`gcc-defaults.json`);
const fixtureGcc = loadFixture(`gcc.json`);
const fixturePulseaudio = loadFixture(`pulseaudio.json`);
const fixtureJdk = loadFixture(`openjdk.json`);
const fixturePython = loadFixture(`python.json`);
describe('datasource/repology/index', () => {
describe('getReleases', () => {
@ -343,5 +344,121 @@ describe('datasource/repology/index', () => {
expect(release).toBeNull();
expect(httpMock.getTrace()).toMatchSnapshot();
});
it('returns correct package types for api_call', async () => {
const pkgs: RepologyPackage[] = [
{
repo: 'some_repo',
version: '1.0.0',
visiblename: 'some-package',
srcname: 'some-package',
},
{
repo: 'some_repo',
version: '2.0.0',
visiblename: 'not-some-package',
srcname: 'not-some-package',
},
{
repo: 'some_repo',
version: '3.0.0',
visiblename: 'some-package',
srcname: 'not-some-package',
},
{
repo: 'some_repo',
version: '4.0.0',
visiblename: 'some-package',
binname: 'some-package',
},
{
repo: 'some_repo',
version: '5.0.0',
visiblename: 'not-some-package',
binname: 'not-some-package',
},
{
repo: 'some_repo',
version: '6.0.0',
visiblename: 'some-package',
binname: 'not-some-package',
},
{ repo: 'some_repo', version: '7.0.0', visiblename: 'some-package' },
{
repo: 'some_repo',
version: '8.0.0',
visiblename: 'not-some-package',
},
{
repo: 'not_some_repo',
version: '9.0.0',
visiblename: 'some-package',
},
{
repo: 'not_some_repo',
version: '10.0.0',
visiblename: 'some-package',
srcname: 'some-package',
},
{
repo: 'not_some_repo',
version: '11.0.0',
visiblename: 'some-package',
binname: 'some-package',
},
];
const pkgsJSON = JSON.stringify(pkgs);
mockResolverCall('some_repo', 'some-package', 'binname', {
status: 403,
});
mockApiCall('some-package', {
status: 200,
body: pkgsJSON,
});
const res = await getPkgReleases({
datasource,
versioning,
depName: 'some_repo/some-package',
});
expect(res).toEqual({
registryUrl: 'https://repology.org',
releases: [
{ version: '1.0.0' },
{
version: '4.0.0',
},
],
});
});
it('returns correct package versions for multi-package project', async () => {
mockResolverCall('ubuntu_20_04', 'python3.8', 'binname', {
status: 200,
body: fixturePython,
});
mockResolverCall('ubuntu_20_04', 'python3.8', 'srcname', {
status: 200,
body: fixturePython,
});
const res = await getPkgReleases({
datasource,
versioning,
depName: 'ubuntu_20_04/python3.8',
});
expect(res).toEqual({
registryUrl: 'https://repology.org',
releases: [
{ version: '3.8.2-1ubuntu1' },
{
version: '3.8.10-0ubuntu1~20.04.2',
},
],
});
});
});
});

View file

@ -92,15 +92,14 @@ function findPackageInResponse(
// In some cases Repology bundles multiple packages into a single project, which might result in ambiguous results.
// We need to do additional filtering by matching allowed package types passed as params with package description.
// Remaining packages are the one we are looking for
let packagesWithType: RepologyPackage[];
const packagesWithType = repoPackages.filter((pkg) => {
for (const pkgType of types) {
packagesWithType = repoPackages.filter(
(pkg) => !pkg[pkgType] || pkg[pkgType] === pkgName
);
if (packagesWithType.length === 1) {
break;
if (pkg[pkgType] && pkg[pkgType] === pkgName) {
return true;
}
}
return false;
});
return packagesWithType.length > 0 ? packagesWithType : null;
}