Skip to content
Snippets Groups Projects
Select Git revision
  • 181c52f1d7ce6d73ac4094579d3d3361d390cb7d
  • 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

conflicts-cache.spec.ts

Blame
  • user avatar
    Sergei Zharinov authored and GitHub committed
    b69416ce
    History
    conflicts-cache.spec.ts 4.40 KiB
    import { mocked, partial } from '../../../test/util';
    import * as _repositoryCache from '../cache/repository';
    import type { BranchCache, RepoCacheData } from '../cache/repository/types';
    import {
      getCachedConflictResult,
      setCachedConflictResult,
    } from './conflicts-cache';
    
    jest.mock('../cache/repository');
    const repositoryCache = mocked(_repositoryCache);
    
    describe('util/git/conflicts-cache', () => {
      let repoCache: RepoCacheData = {};
    
      beforeEach(() => {
        repoCache = {};
        repositoryCache.getCache.mockReturnValue(repoCache);
      });
    
      describe('getCachedConflictResult', () => {
        it('returns null if cache is not populated', () => {
          expect(
            getCachedConflictResult('foo', 'sha', 'bar', 'base_sha'),
          ).toBeNull();
        });
    
        it('returns null if branch cache not found', () => {
          repoCache.branches = [
            partial<BranchCache>({
              branchName: 'foo',
              sha: 'sha',
              baseBranch: 'bar',
              baseBranchSha: 'base_sha',
              isConflicted: true,
            }),
          ];
          expect(
            getCachedConflictResult('not_foo', 'sha', 'bar', 'base_sha'),
          ).toBeNull();
        });
    
        it('returns null if base branch SHA has changed', () => {
          repoCache.branches = [
            partial<BranchCache>({
              branchName: 'foo',
              sha: 'sha',
              baseBranch: 'bar',
              baseBranchSha: 'base_sha',
              isConflicted: true,
            }),
          ];
          expect(
            getCachedConflictResult('foo', 'sha', 'bar', 'not_base_sha'),
          ).toBeNull();
        });
    
        it('returns null if branch SHA has changed', () => {
          repoCache.branches = [
            partial<BranchCache>({
              branchName: 'foo',
              sha: 'sha',
              baseBranch: 'bar',
              baseBranchSha: 'base_sha',
              isConflicted: true,
            }),
          ];
          expect(
            getCachedConflictResult('foo', 'not_sha', 'bar', 'base_sha'),
          ).toBeNull();
        });
    
        it('returns null if isConfliced is undefined', () => {
          repoCache.branches = [
            partial<BranchCache>({
              branchName: 'foo',
              sha: 'sha',
              baseBranch: 'bar',
              baseBranchSha: 'base_sha',
            }),
          ];
          expect(
            getCachedConflictResult('foo', 'sha', 'bar', 'base_sha'),
          ).toBeNull();
        });
    
        it('returns true', () => {
          repoCache.branches = [
            partial<BranchCache>({
              branchName: 'foo',
              sha: 'sha',
              baseBranch: 'bar',
              baseBranchSha: 'base_sha',
              isConflicted: true,
            }),
          ];
          expect(
            getCachedConflictResult('foo', 'sha', 'bar', 'base_sha'),
          ).toBeTrue();
        });
      });
    
      describe('setCachedConflictResult', () => {
        it('return without updating value for unpopulated cache', () => {
          setCachedConflictResult('foo', false);
          expect(repoCache).toEqual({});
        });
    
        it('updates value', () => {
          repoCache.branches = [
            partial<BranchCache>({
              branchName: 'foo',
              sha: 'sha',
              baseBranch: 'bar',
              baseBranchSha: 'base_sha',
              isConflicted: true,
            }),
          ];
          setCachedConflictResult('foo', false);
          expect(repoCache).toEqual({
            branches: [
              {
                branchName: 'foo',
                sha: 'sha',
                baseBranch: 'bar',
                baseBranchSha: 'base_sha',
                isConflicted: false,
              },
            ],
          });
        });
    
        it('handles multiple branches', () => {
          repoCache.branches = [
            partial<BranchCache>({
              branchName: 'foo-1',
              sha: 'sha',
              baseBranch: 'bar',
              baseBranchSha: 'base_sha',
              isConflicted: true,
            }),
            partial<BranchCache>({
              branchName: 'foo-2',
              sha: 'sha',
              baseBranch: 'bar',
              baseBranchSha: 'base_sha',
              isConflicted: false,
            }),
          ];
          setCachedConflictResult('foo-1', false);
          setCachedConflictResult('foo-2', true);
          expect(repoCache).toEqual({
            branches: [
              {
                branchName: 'foo-1',
                sha: 'sha',
                baseBranch: 'bar',
                baseBranchSha: 'base_sha',
                isConflicted: false,
              },
              {
                branchName: 'foo-2',
                sha: 'sha',
                baseBranch: 'bar',
                baseBranchSha: 'base_sha',
                isConflicted: true,
              },
            ],
          });
        });
      });
    });