0
0
Fork 0
mirror of https://github.com/renovatebot/renovate.git synced 2025-03-13 07:43:27 +00:00
renovatebot_renovate/lib/modules/datasource/github-releases/index.spec.ts
2022-06-03 11:27:26 +02:00

124 lines
3.7 KiB
TypeScript

import { getDigest, getPkgReleases } from '..';
import * as _hostRules from '../../../util/host-rules';
import { CacheableGithubReleases } from './cache';
import { GitHubReleaseMocker } from './test';
import { GithubReleasesDatasource } from '.';
jest.mock('../../../util/host-rules');
const hostRules: any = _hostRules;
const githubApiHost = 'https://api.github.com';
describe('modules/datasource/github-releases/index', () => {
const cacheGetItems = jest.spyOn(
CacheableGithubReleases.prototype,
'getItems'
);
beforeEach(() => {
jest.resetAllMocks();
hostRules.hosts.mockReturnValue([]);
hostRules.find.mockReturnValue({
token: 'some-token',
});
});
describe('getReleases', () => {
it('returns releases', async () => {
cacheGetItems.mockResolvedValueOnce([
{ version: 'a', releaseTimestamp: '2020-03-09T13:00:00Z' },
{ version: 'v', releaseTimestamp: '2020-03-09T12:00:00Z' },
{ version: '1.0.0', releaseTimestamp: '2020-03-09T11:00:00Z' },
{ version: 'v1.1.0', releaseTimestamp: '2020-03-09T10:00:00Z' },
{
version: '2.0.0',
releaseTimestamp: '2020-04-09T10:00:00Z',
isStable: false,
},
] as never);
const res = await getPkgReleases({
datasource: GithubReleasesDatasource.id,
depName: 'some/dep',
});
expect(res).toMatchObject({
registryUrl: 'https://github.com',
releases: [
{ releaseTimestamp: '2020-03-09T11:00:00.000Z', version: '1.0.0' },
{ version: 'v1.1.0', releaseTimestamp: '2020-03-09T10:00:00.000Z' },
{
version: '2.0.0',
releaseTimestamp: '2020-04-09T10:00:00.000Z',
isStable: false,
},
],
sourceUrl: 'https://github.com/some/dep',
});
});
});
describe('getDigest', () => {
const depName = 'some/dep';
const currentValue = 'v1.0.0';
const currentDigest = 'v1.0.0-digest';
const releaseMock = new GitHubReleaseMocker(githubApiHost, depName);
it('requires currentDigest', async () => {
const digest = await getDigest(
{ datasource: GithubReleasesDatasource.id, depName },
currentValue
);
expect(digest).toBeNull();
});
it('defaults to currentDigest when currentVersion is missing', async () => {
const digest = await getDigest(
{
datasource: GithubReleasesDatasource.id,
depName,
currentDigest,
},
currentValue
);
expect(digest).toEqual(currentDigest);
});
it('returns updated digest in new release', async () => {
releaseMock.withDigestFileAsset(
currentValue,
`${currentDigest} asset.zip`
);
const nextValue = 'v1.0.1';
const nextDigest = 'updated-digest';
releaseMock.withDigestFileAsset(nextValue, `${nextDigest} asset.zip`);
const digest = await getDigest(
{
datasource: GithubReleasesDatasource.id,
depName,
currentValue,
currentDigest,
},
nextValue
);
expect(digest).toEqual(nextDigest);
});
// This is awkward, but I found returning `null` in this case to not produce an update
// I'd prefer a PR with the old digest (that I can manually patch) to no PR, so I made this decision.
it('ignores failures verifying currentDigest', async () => {
releaseMock.release(currentValue);
const digest = await getDigest(
{
datasource: GithubReleasesDatasource.id,
depName,
currentValue,
currentDigest,
},
currentValue
);
expect(digest).toEqual(currentDigest);
});
});
});