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

status-checks.spec.ts

Blame
  • user avatar
    Rhys Arkins authored and GitHub committed
    588616f6
    History
    status-checks.spec.ts 2.60 KiB
    import {
      setStability,
      setUnpublishable,
      StabilityConfig,
      UnpublishableConfig,
    } from './status-checks';
    import { defaultConfig, platform } from '../../../test/util';
    import { BranchStatus } from '../../types';
    
    describe('workers/branch/status-checks', () => {
      describe('setStability', () => {
        let config: StabilityConfig;
        beforeEach(() => {
          config = {
            ...defaultConfig,
            branchName: 'renovate/some-branch',
          };
        });
        afterEach(() => {
          jest.resetAllMocks();
        });
        it('returns if not configured', async () => {
          await setStability(config);
          expect(platform.getBranchStatusCheck).toHaveBeenCalledTimes(0);
        });
        it('sets status yellow', async () => {
          config.stabilityStatus = BranchStatus.yellow;
          await setStability(config);
          expect(platform.getBranchStatusCheck).toHaveBeenCalledTimes(1);
          expect(platform.setBranchStatus).toHaveBeenCalledTimes(1);
        });
        it('sets status green', async () => {
          config.stabilityStatus = BranchStatus.green;
          await setStability(config);
          expect(platform.getBranchStatusCheck).toHaveBeenCalledTimes(1);
          expect(platform.setBranchStatus).toHaveBeenCalledTimes(1);
        });
      });
      describe('setUnpublishable', () => {
        let config: UnpublishableConfig;
        beforeEach(() => {
          config = {
            ...defaultConfig,
            branchName: 'renovate/some-branch',
          };
        });
        afterEach(() => {
          jest.resetAllMocks();
        });
        it('returns if not configured', async () => {
          await setUnpublishable(config);
          expect(platform.getBranchStatusCheck).toHaveBeenCalledTimes(0);
        });
        it('defaults to canBeUnpublished', async () => {
          config.unpublishSafe = true;
          await setUnpublishable(config);
          expect(platform.getBranchStatusCheck).toHaveBeenCalledTimes(1);
          expect(platform.setBranchStatus).toHaveBeenCalledTimes(1);
        });
        it('finds canBeUnpublished false and sets status', async () => {
          config.canBeUnpublished = true;
          config.unpublishSafe = true;
          await setUnpublishable(config);
          expect(platform.getBranchStatusCheck).toHaveBeenCalledTimes(1);
          expect(platform.setBranchStatus).toHaveBeenCalledTimes(1);
        });
        it('finds canBeUnpublished false and skips status', async () => {
          config.unpublishSafe = true;
          config.canBeUnpublished = false;
          platform.getBranchStatusCheck.mockResolvedValueOnce(BranchStatus.green);
          await setUnpublishable(config);
          expect(platform.getBranchStatusCheck).toHaveBeenCalledTimes(1);
          expect(platform.setBranchStatus).toHaveBeenCalledTimes(0);
        });
      });
    });