Skip to content
Snippets Groups Projects
Select Git revision
  • 4bc7414df2fa67ad51e1512d3ef1ea5ddbb99c1b
  • main default protected
  • renovate/main-renovatebot-github-action-43.x
  • next
  • feat/gnupg
  • fix/36615b-branch-reuse-no-cache
  • renovate/main-redis-5.x
  • chore/punycode
  • refactor/pin-new-value
  • feat/36219--git-x509-signing
  • feat/structured-logger
  • hotfix/39.264.1
  • feat/skip-dangling
  • gh-readonly-queue/next/pr-36034-7a061c4ca1024a19e2c295d773d9642625d1c2be
  • hotfix/39.238.3
  • refactor/gitlab-auto-approve
  • feat/template-strings
  • gh-readonly-queue/next/pr-35654-137d934242c784e0c45d4b957362214f0eade1d7
  • fix/32307-global-extends-merging
  • fix/32307-global-extends-repositories
  • gh-readonly-queue/next/pr-35009-046ebf7cb84ab859f7fefceb5fa53a54ce9736f8
  • 41.45.0
  • 41.44.0
  • 41.43.7
  • 41.43.6
  • 41.43.5
  • 41.43.4
  • 41.43.3
  • 41.43.2
  • 41.43.1
  • 41.43.0
  • 41.42.12
  • 41.42.11
  • 41.42.10
  • 41.42.9
  • 41.42.8
  • 41.42.7
  • 41.42.6
  • 41.42.5
  • 41.42.4
  • 41.42.3
41 results

modified-cache.spec.ts

Blame
  • modified-cache.spec.ts 3.61 KiB
    import { logger, mocked, partial } from '../../../test/util';
    import * as _repositoryCache from '../cache/repository';
    import type { BranchCache, RepoCacheData } from '../cache/repository/types';
    import {
      getCachedModifiedResult,
      setCachedModifiedResult,
    } from './modified-cache';
    
    jest.mock('../cache/repository');
    const repositoryCache = mocked(_repositoryCache);
    
    describe('util/git/modified-cache', () => {
      let repoCache: RepoCacheData = {};
    
      beforeEach(() => {
        repoCache = {};
        repositoryCache.getCache.mockReturnValue(repoCache);
      });
    
      describe('getCachedModifiedResult', () => {
        it('returns null if cache is not populated', () => {
          expect(getCachedModifiedResult('foo', 'aaa')).toBeNull();
        });
    
        it('returns null if branch not found', () => {
          repoCache.branches = [
            partial<BranchCache>({ branchName: 'not_foo', sha: 'aaa' }),
          ];
          expect(getCachedModifiedResult('foo', 'aaa')).toBeNull();
        });
    
        it('returns null if branch SHA has changed', () => {
          repoCache.branches = [
            partial<BranchCache>({ branchName: 'foo', sha: 'aaa' }),
          ];
          expect(getCachedModifiedResult('foo', 'not_aaa')).toBeNull();
        });
    
        it('returns null if cached value is undefined', () => {
          repoCache.branches = [
            partial<BranchCache>({ branchName: 'foo', sha: 'aaa' }),
          ];
          expect(getCachedModifiedResult('foo', 'aaa')).toBeNull();
        });
    
        it('returns null if branch sha is null', () => {
          repoCache.branches = [
            partial<BranchCache>({ branchName: 'foo', sha: 'aaa' }),
          ];
          expect(getCachedModifiedResult('foo', null)).toBeNull();
        });
    
        it('returns cached value', () => {
          repoCache.branches = [
            partial<BranchCache>({
              branchName: 'foo',
              sha: '111',
              isModified: true,
            }),
          ];
          expect(getCachedModifiedResult('foo', '111')).toBeTrue();
        });
      });
    
      describe('setCachedModifiedResult', () => {
        it('returns without updating when cache not populated', () => {
          setCachedModifiedResult('foo', false);
          expect(repoCache).toEqual({});
          expect(logger.logger.debug).toHaveBeenCalledWith(
            'setCachedModifiedResult(): Branch cache not present',
          );
        });
    
        it('returns without updating when branch not found', () => {
          setCachedModifiedResult('foo', false);
          expect(repoCache).toEqual({});
          expect(logger.logger.debug).toHaveBeenCalledWith(
            'setCachedModifiedResult(): Branch cache not present',
          );
        });
    
        it('handles multiple branches', () => {
          repoCache = {
            branches: [
              partial<BranchCache>({
                branchName: 'foo-1',
                sha: '111',
                isModified: true,
              }),
              partial<BranchCache>({
                branchName: 'foo-2',
                sha: 'aaa',
                isModified: false,
              }),
              partial<BranchCache>({
                branchName: 'foo-3',
                sha: '222',
                isModified: true,
              }),
            ],
          };
          repositoryCache.getCache.mockReturnValue(repoCache);
          setCachedModifiedResult('foo-1', false);
          setCachedModifiedResult('foo-2', true);
          setCachedModifiedResult('foo-3', false);
          expect(repoCache).toEqual({
            branches: [
              {
                branchName: 'foo-1',
                sha: '111',
                isModified: false,
              },
              {
                branchName: 'foo-2',
                sha: 'aaa',
                isModified: true,
              },
              {
                branchName: 'foo-3',
                sha: '222',
                isModified: false,
              },
            ],
          });
        });
      });
    });