fix: improve coverage (#14117)

This commit is contained in:
Michael Kriese 2022-02-09 19:12:14 +01:00 committed by GitHub
parent 638d958cc2
commit a8ca710dd6
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
9 changed files with 98 additions and 43 deletions

View file

@ -25,7 +25,7 @@ export class CdnJsDatasource extends Datasource {
// Each library contains multiple assets, so we cache at the library level instead of per-asset // Each library contains multiple assets, so we cache at the library level instead of per-asset
const library = lookupName.split('/')[0]; const library = lookupName.split('/')[0];
const url = `${registryUrl}libraries/${library}?fields=homepage,repository,assets`; const url = `${registryUrl}libraries/${library}?fields=homepage,repository,assets`;
let result: ReleaseResult; let result: ReleaseResult | null = null;
try { try {
const { assets, homepage, repository } = ( const { assets, homepage, repository } = (
await this.http.getJson<CdnjsResponse>(url) await this.http.getJson<CdnjsResponse>(url)
@ -36,7 +36,7 @@ export class CdnJsDatasource extends Datasource {
const assetName = lookupName.replace(`${library}/`, ''); const assetName = lookupName.replace(`${library}/`, '');
const releases = assets const releases = assets
.filter(({ files }) => files.includes(assetName)) .filter(({ files }) => files.includes(assetName))
.map(({ version, sri }) => ({ version, newDigest: sri[assetName] })); .map(({ version, sri }) => ({ version, newDigest: sri?.[assetName] }));
result = { releases }; result = { releases };
@ -52,6 +52,6 @@ export class CdnJsDatasource extends Datasource {
} }
this.handleGenericErrors(err); this.handleGenericErrors(err);
} }
return result || null; return result;
} }
} }

View file

@ -77,7 +77,7 @@ export class GalaxyDatasource extends Datasource {
}; };
result.dependencyUrl = galaxyProjectUrl; result.dependencyUrl = galaxyProjectUrl;
const { github_user: user = null, github_repo: repo = null } = resultObject; const { github_user: user, github_repo: repo } = resultObject;
if (typeof user === 'string' && typeof repo === 'string') { if (typeof user === 'string' && typeof repo === 'string') {
result.sourceUrl = `https://github.com/${user}/${repo}`; result.sourceUrl = `https://github.com/${user}/${repo}`;
} }

View file

@ -0,0 +1,24 @@
import { getDepHost, getSourceUrl } from './util';
describe('datasource/gitlab-tags/util', () => {
describe('getDepHost', () => {
it('works', () => {
expect(getDepHost()).toBe('https://gitlab.com');
expect(getDepHost('https://gitlab.domain.test/api/v4')).toBe(
'https://gitlab.domain.test'
);
expect(getDepHost('https://domain.test/gitlab/api/v4')).toBe(
'https://domain.test/gitlab'
);
});
});
describe('getSourceUrl', () => {
it('works', () => {
expect(getSourceUrl('some/repo')).toBe('https://gitlab.com/some/repo');
expect(
getSourceUrl('some/repo', 'https://gitlab.domain.test/api/v4')
).toBe('https://gitlab.domain.test/some/repo');
});
});
});

View file

@ -18,7 +18,6 @@ Object {
"version": "4.1.0", "version": "4.1.0",
}, },
Object { Object {
"releaseTimestamp": "2018-12-11T18:24:13.119Z",
"version": "4.1.1", "version": "4.1.1",
}, },
Object { Object {
@ -105,7 +104,6 @@ Object {
"version": "4.1.0", "version": "4.1.0",
}, },
Object { Object {
"releaseTimestamp": "2018-12-11T18:24:13.119Z",
"version": "4.1.1", "version": "4.1.1",
}, },
Object { Object {

View file

@ -14,7 +14,7 @@ const orbData = {
{ version: '4.1.4', createdAt: '2018-12-11T22:13:29.297Z' }, { version: '4.1.4', createdAt: '2018-12-11T22:13:29.297Z' },
{ version: '4.1.3', createdAt: '2018-12-11T21:40:44.870Z' }, { version: '4.1.3', createdAt: '2018-12-11T21:40:44.870Z' },
{ version: '4.1.2', createdAt: '2018-12-11T21:28:37.846Z' }, { version: '4.1.2', createdAt: '2018-12-11T21:28:37.846Z' },
{ version: '4.1.1', createdAt: '2018-12-11T18:24:13.119Z' }, { version: '4.1.1' },
{ version: '4.1.0', createdAt: '2018-12-11T18:14:41.116Z' }, { version: '4.1.0', createdAt: '2018-12-11T18:14:41.116Z' },
{ version: '4.0.0', createdAt: '2018-12-11T17:41:26.595Z' }, { version: '4.0.0', createdAt: '2018-12-11T17:41:26.595Z' },
{ version: '3.0.0', createdAt: '2018-12-11T05:28:14.080Z' }, { version: '3.0.0', createdAt: '2018-12-11T05:28:14.080Z' },
@ -94,7 +94,7 @@ describe('datasource/orb/index', () => {
depName: 'hyper-expanse/library-release-workflows', depName: 'hyper-expanse/library-release-workflows',
}); });
expect(res).toMatchSnapshot(); expect(res).toMatchSnapshot();
expect(res.homepage).toBe('https://google.com'); expect(res?.homepage).toBe('https://google.com');
expect(httpMock.getTrace()).toMatchSnapshot(); expect(httpMock.getTrace()).toMatchSnapshot();
}); });
}); });

View file

@ -35,5 +35,9 @@ describe('manager/pip_setup/extract', () => {
], ],
}); });
}); });
it('returns nothing', () => {
expect(extractPackageFile('', packageFile, config)).toBeNull();
});
}); });
}); });

View file

@ -14,6 +14,10 @@ describe('versioning/semver-coerced/index', () => {
it('should return false for non-equal versions', () => { it('should return false for non-equal versions', () => {
expect(semverCoerced.equals('2.0.1', '2.3.0')).toBeFalse(); expect(semverCoerced.equals('2.0.1', '2.3.0')).toBeFalse();
}); });
it('invalid version', () => {
expect(semverCoerced.equals('xxx', '1.2.3')).toBeFalse();
});
}); });
describe('.getMajor(input)', () => { describe('.getMajor(input)', () => {
@ -24,6 +28,10 @@ describe('versioning/semver-coerced/index', () => {
it('should return major version number for non-strict semver', () => { it('should return major version number for non-strict semver', () => {
expect(semverCoerced.getMajor('v3.1')).toBe(3); expect(semverCoerced.getMajor('v3.1')).toBe(3);
}); });
it('invalid version', () => {
expect(semverCoerced.getMajor('xxx')).toBeNull();
});
}); });
describe('.getMinor(input)', () => { describe('.getMinor(input)', () => {
@ -34,6 +42,10 @@ describe('versioning/semver-coerced/index', () => {
it('should return minor version number for non-strict semver', () => { it('should return minor version number for non-strict semver', () => {
expect(semverCoerced.getMinor('v3.1')).toBe(1); expect(semverCoerced.getMinor('v3.1')).toBe(1);
}); });
it('invalid version', () => {
expect(semverCoerced.getMajor('xxx')).toBeNull();
});
}); });
describe('.getPatch(input)', () => { describe('.getPatch(input)', () => {
@ -44,133 +56,145 @@ describe('versioning/semver-coerced/index', () => {
it('should return patch version number for non-strict semver', () => { it('should return patch version number for non-strict semver', () => {
expect(semverCoerced.getPatch('v3.1.2-foo')).toBe(2); expect(semverCoerced.getPatch('v3.1.2-foo')).toBe(2);
}); });
it('invalid version', () => {
expect(semverCoerced.getMajor('xxx')).toBeNull();
});
}); });
describe('.isCompatible(input)', () => { describe('.isCompatible(input)', () => {
it('should return true for strict semver', () => { it('should return true for strict semver', () => {
expect(semverCoerced.isCompatible('1.0.2')).toBeTruthy(); expect(semverCoerced.isCompatible('1.0.2')).toBeTrue();
}); });
it('should return true for non-strict semver', () => { it('should return true for non-strict semver', () => {
expect(semverCoerced.isCompatible('v3.1.2-foo')).toBeTruthy(); expect(semverCoerced.isCompatible('v3.1.2-foo')).toBeTrue();
}); });
it('should return false for non-semver', () => { it('should return false for non-semver', () => {
expect(semverCoerced.isCompatible('foo')).toBeFalsy(); expect(semverCoerced.isCompatible('foo')).toBeFalse();
}); });
}); });
describe('.isGreaterThan(a, b)', () => { describe('.isGreaterThan(a, b)', () => {
it('should return true for a greater version in strict semver', () => { it('should return true for a greater version in strict semver', () => {
expect(semverCoerced.isGreaterThan('1.0.2', '1.0.0')).toBeTruthy(); expect(semverCoerced.isGreaterThan('1.0.2', '1.0.0')).toBeTrue();
}); });
it('should return false for lower version in strict semver', () => { it('should return false for lower version in strict semver', () => {
expect(semverCoerced.isGreaterThan('3.1.2', '4.1.0')).toBeFalsy(); expect(semverCoerced.isGreaterThan('3.1.2', '4.1.0')).toBeFalse();
}); });
it('should return false if version cannot be coerced', () => { it('should return false if version cannot be coerced', () => {
expect(semverCoerced.isGreaterThan('e.e.e', '4.1.0')).toBeFalsy(); expect(semverCoerced.isGreaterThan('e.e.e', '4.1.0')).toBeFalse();
}); });
}); });
describe('.isLessThanRange(version, range)', () => { describe('.isLessThanRange(version, range)', () => {
it('should return true for a lower version in strict semver', () => { it('should return true for a lower version in strict semver', () => {
expect(semverCoerced.isLessThanRange?.('1.0.2', '~2.0')).toBeTruthy(); expect(semverCoerced.isLessThanRange?.('1.0.2', '~2.0')).toBeTrue();
}); });
it('should return false for in-range version in strict semver', () => { it('should return false for in-range version in strict semver', () => {
expect(semverCoerced.isLessThanRange?.('3.0.2', '~3.0')).toBeFalsy(); expect(semverCoerced.isLessThanRange?.('3.0.2', '~3.0')).toBeFalse();
});
it('invalid version', () => {
expect(semverCoerced.isLessThanRange?.('xxx', '1.2.3')).toBeFalse();
}); });
}); });
describe('.isSingleVersion()', () => { describe('.isSingleVersion()', () => {
it('returns true if naked version', () => { it('returns true if naked version', () => {
expect(semverCoerced.isSingleVersion('1.2.3')).toBeTruthy(); expect(semverCoerced.isSingleVersion('1.2.3')).toBeTrue();
expect(semverCoerced.isSingleVersion('1.2.3-alpha.1')).toBeTruthy(); expect(semverCoerced.isSingleVersion('1.2.3-alpha.1')).toBeTrue();
}); });
it('returns false if equals', () => { it('returns false if equals', () => {
expect(semverCoerced.isSingleVersion('=1.2.3')).toBeFalsy(); expect(semverCoerced.isSingleVersion('=1.2.3')).toBeFalse();
expect(semverCoerced.isSingleVersion('= 1.2.3')).toBeFalsy(); expect(semverCoerced.isSingleVersion('= 1.2.3')).toBeFalse();
}); });
it('returns false when not version', () => { it('returns false when not version', () => {
expect(semverCoerced.isSingleVersion('~1.0')).toBeFalsy(); expect(semverCoerced.isSingleVersion('~1.0')).toBeFalse();
}); });
}); });
describe('.isStable(input)', () => { describe('.isStable(input)', () => {
it('should return true for a stable version', () => { it('should return true for a stable version', () => {
expect(semverCoerced.isStable('1.0.0')).toBeTruthy(); expect(semverCoerced.isStable('1.0.0')).toBeTrue();
}); });
it('should return false for an prerelease version', () => { it('should return false for an prerelease version', () => {
expect(semverCoerced.isStable('v1.0-alpha')).toBeFalsy(); expect(semverCoerced.isStable('v1.0-alpha')).toBeFalse();
}); });
}); });
describe('.isValid(input)', () => { describe('.isValid(input)', () => {
it('should return null for non-digit version strings', () => { it('should return null for non-digit version strings', () => {
expect(semverCoerced.isValid('version two')).toBeFalsy(); expect(semverCoerced.isValid('version two')).toBeFalse();
}); });
it('should return null for irregular version strings', () => { it('should return null for irregular version strings', () => {
expect(semverCoerced.isValid('17.04.0')).toBeFalsy(); expect(semverCoerced.isValid('17.04.0')).toBeFalse();
}); });
it('should support strict semver', () => { it('should support strict semver', () => {
expect(semverCoerced.isValid('1.2.3')).toBeTruthy(); expect(semverCoerced.isValid('1.2.3')).toBeTrue();
}); });
it('should treat semver with dash as a valid version', () => { it('should treat semver with dash as a valid version', () => {
expect(semverCoerced.isValid('1.2.3-foo')).toBeTruthy(); expect(semverCoerced.isValid('1.2.3-foo')).toBeTrue();
}); });
it('should treat semver without dash as a valid version', () => { it('should treat semver without dash as a valid version', () => {
expect(semverCoerced.isValid('1.2.3foo')).toBeTruthy(); expect(semverCoerced.isValid('1.2.3foo')).toBeTrue();
}); });
it('should treat ranges as valid versions', () => { it('should treat ranges as valid versions', () => {
expect(semverCoerced.isValid('~1.2.3')).toBeTruthy(); expect(semverCoerced.isValid('~1.2.3')).toBeTrue();
expect(semverCoerced.isValid('^1.2.3')).toBeTruthy(); expect(semverCoerced.isValid('^1.2.3')).toBeTrue();
expect(semverCoerced.isValid('>1.2.3')).toBeTruthy(); expect(semverCoerced.isValid('>1.2.3')).toBeTrue();
}); });
it('should reject github repositories', () => { it('should reject github repositories', () => {
expect(semverCoerced.isValid('renovatebot/renovate')).toBeFalsy(); expect(semverCoerced.isValid('renovatebot/renovate')).toBeFalse();
expect(semverCoerced.isValid('renovatebot/renovate#master')).toBeFalsy(); expect(semverCoerced.isValid('renovatebot/renovate#master')).toBeFalse();
expect( expect(
semverCoerced.isValid('https://github.com/renovatebot/renovate.git') semverCoerced.isValid('https://github.com/renovatebot/renovate.git')
).toBeFalsy(); ).toBeFalse();
}); });
}); });
describe('.isVersion(input)', () => { describe('.isVersion(input)', () => {
it('should return null for non-digit versions', () => { it('should return null for non-digit versions', () => {
expect(semverCoerced.isValid('version one')).toBeFalsy(); expect(semverCoerced.isValid('version one')).toBeFalse();
}); });
it('should support strict semver versions', () => { it('should support strict semver versions', () => {
expect(semverCoerced.isValid('1.2.3')).toBeTruthy(); expect(semverCoerced.isValid('1.2.3')).toBeTrue();
}); });
it('should support non-strict versions', () => { it('should support non-strict versions', () => {
expect(semverCoerced.isValid('v1.2')).toBeTruthy(); expect(semverCoerced.isValid('v1.2')).toBeTrue();
}); });
}); });
describe('.matches(version, range)', () => { describe('.matches(version, range)', () => {
it('should return true when version is in range', () => { it('should return true when version is in range', () => {
expect(semverCoerced.matches('1.0.0', '1.0.0 || 1.0.1')).toBeTruthy(); expect(semverCoerced.matches('1.0.0', '1.0.0 || 1.0.1')).toBeTrue();
}); });
it('should return true with non-strict version in range', () => { it('should return true with non-strict version in range', () => {
expect(semverCoerced.matches('v1.0', '1.0.0 || 1.0.1')).toBeTruthy(); expect(semverCoerced.matches('v1.0', '1.0.0 || 1.0.1')).toBeTrue();
}); });
it('should return false when version is not in range', () => { it('should return false when version is not in range', () => {
expect(semverCoerced.matches('1.2.3', '1.4.1 || 1.4.2')).toBeFalsy(); expect(semverCoerced.matches('1.2.3', '1.4.1 || 1.4.2')).toBeFalse();
});
it('invalid version', () => {
expect(semverCoerced.matches('xxx', '1.2.3')).toBe(false);
}); });
}); });
@ -231,5 +255,9 @@ describe('versioning/semver-coerced/index', () => {
it('should return zero for equal non-strict versions', () => { it('should return zero for equal non-strict versions', () => {
expect(semverCoerced.sortVersions('v1.0', '1.x')).toBe(0); expect(semverCoerced.sortVersions('v1.0', '1.x')).toBe(0);
}); });
it('works with invalid version', () => {
expect(semverCoerced.sortVersions('v1.0', 'xx')).toBe(0);
});
}); });
}); });

View file

@ -197,6 +197,7 @@ describe('versioning/ubuntu/index', () => {
${'16.04.7'} | ${'16.04.1'} | ${true} ${'16.04.7'} | ${'16.04.1'} | ${true}
${'19.10.1'} | ${'20.04.1'} | ${false} ${'19.10.1'} | ${'20.04.1'} | ${false}
${'20.04.1'} | ${'19.10.1'} | ${true} ${'20.04.1'} | ${'19.10.1'} | ${true}
${'xxx'} | ${'yyy'} | ${false}
`('isGreaterThan("$a", "$b") === $expected', ({ a, b, expected }) => { `('isGreaterThan("$a", "$b") === $expected', ({ a, b, expected }) => {
expect(ubuntu.isGreaterThan(a, b)).toBe(expected); expect(ubuntu.isGreaterThan(a, b)).toBe(expected);
}); });

View file

@ -44,7 +44,7 @@ function isStable(version: string): boolean {
function getMajor(version: string): null | number { function getMajor(version: string): null | number {
if (isValid(version)) { if (isValid(version)) {
const [major] = version.split('.') || []; const [major] = version.split('.');
return parseInt(major, 10); return parseInt(major, 10);
} }
return null; return null;
@ -52,7 +52,7 @@ function getMajor(version: string): null | number {
function getMinor(version: string): null | number { function getMinor(version: string): null | number {
if (isValid(version)) { if (isValid(version)) {
const [, minor] = version.split('.') || []; const [, minor] = version.split('.');
return parseInt(minor, 10); return parseInt(minor, 10);
} }
return null; return null;
@ -60,7 +60,7 @@ function getMinor(version: string): null | number {
function getPatch(version: string): null | number { function getPatch(version: string): null | number {
if (isValid(version)) { if (isValid(version)) {
const [, , patch] = version.split('.') || []; const [, , patch] = version.split('.');
return patch ? parseInt(patch, 10) : null; return patch ? parseInt(patch, 10) : null;
} }
return null; return null;