Skip to content
Snippets Groups Projects
Select Git revision
  • f8be45055a3e93bced050d143529304fba761be8
  • main default protected
  • renovate/main-ghcr.io-renovatebot-base-image-10.x
  • renovate/main-ghcr.io-containerbase-devcontainer-13.x
  • next
  • revert-31645-feat/rename-gradle-wrapper-validation-action
  • renovate/main-redis-5.x
  • fix/36615b-branch-reuse-no-cache
  • chore/punycode
  • fix/36615-branch-reuse-bug
  • 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
  • 41.30.4
  • 41.30.3
  • 41.30.2
  • 41.30.1
  • 41.30.0
  • 41.29.1
  • 41.29.0
  • 41.28.2
  • 41.28.1
  • 41.28.0
  • 41.27.1
  • 41.27.0
  • 41.26.2
  • 41.26.1
  • 41.26.0
  • 41.25.1
  • 41.25.0
  • 41.24.0
  • 41.23.5
  • 41.23.4
41 results

status-checks.spec.js

Blame
  • user avatar
    Rhys Arkins authored and GitHub committed
    f8be4505
    History
    status-checks.spec.js 2.11 KiB
    const {
      setUnpublishable,
    } = require('../../../lib/workers/branch/status-checks');
    const defaultConfig = require('../../../lib/config/defaults').getConfig();
    const logger = require('../../_fixtures/logger');
    
    describe('workers/branch/status-checks', () => {
      describe('setUnpublishable', () => {
        let config;
        beforeEach(() => {
          config = {
            ...defaultConfig,
            logger,
            upgrades: [],
          };
        });
        afterEach(() => {
          jest.resetAllMocks();
        });
        it('defaults to unpublishable', async () => {
          await setUnpublishable(config);
          expect(platform.getBranchStatusCheck.mock.calls.length).toBe(1);
          expect(platform.setBranchStatus.mock.calls.length).toBe(0);
        });
        it('finds unpublishable true', async () => {
          config.upgrades = [{ unpublishable: true }];
          await setUnpublishable(config);
          expect(platform.getBranchStatusCheck.mock.calls.length).toBe(1);
          expect(platform.setBranchStatus.mock.calls.length).toBe(0);
        });
        it('removes status check', async () => {
          config.upgrades = [{ unpublishable: true }];
          platform.getBranchStatusCheck.mockReturnValueOnce('pending');
          await setUnpublishable(config);
          expect(platform.getBranchStatusCheck.mock.calls.length).toBe(1);
          expect(platform.setBranchStatus.mock.calls.length).toBe(1);
        });
        it('finds unpublishable false and sets status', async () => {
          config.unpublishSafe = true;
          config.upgrades = [{ unpublishable: true }, { unpublishable: false }];
          await setUnpublishable(config);
          expect(platform.getBranchStatusCheck.mock.calls.length).toBe(1);
          expect(platform.setBranchStatus.mock.calls.length).toBe(1);
        });
        it('finds unpublishable false and skips status', async () => {
          config.unpublishSafe = true;
          config.upgrades = [{ unpublishable: true }, { unpublishable: false }];
          platform.getBranchStatusCheck.mockReturnValueOnce('pending');
          await setUnpublishable(config);
          expect(platform.getBranchStatusCheck.mock.calls.length).toBe(1);
          expect(platform.setBranchStatus.mock.calls.length).toBe(0);
        });
      });
    });