Skip to content
Snippets Groups Projects
Select Git revision
  • aa0536b569822bc6fcd78ef7f663a3747b972aba
  • master default
  • feat/info-xml-backends
  • fix/shareapi-l10n
  • fix/missing-RemoteException-class
  • backport/46504/stable28
  • backport/46504/stable29
  • automated/noid/stable29-update-psalm-baseline
  • automated/noid/stable28-update-psalm-baseline
  • feat/46438/provide-feedback-edit-locally
  • fix-getimagesize
  • stable27
  • stable28
  • stable29
  • query-builder-connection
  • feature/request-803
  • autosharding
  • fix/noid/test-samba-with-self-hosted
  • fix/bring-back-forbidden-names
  • fix/htaccess
  • fix/use-filename-validator
  • v28.0.8rc1
  • v29.0.4rc1
  • v27.1.11
  • v28.0.7
  • v29.0.3
  • v28.0.7rc4
  • v29.0.3rc4
  • v29.0.3rc3
  • v28.0.7rc3
  • v27.1.11rc3
  • v27.1.11rc2
  • v28.0.7rc2
  • v29.0.3rc2
  • v27.1.11rc1
  • v28.0.7rc1
  • v29.0.3rc1
  • v29.0.2
  • v27.1.10
  • v29.0.2rc2
  • v29.0.2rc1
41 results

autotest-external.sh

Blame
  • automerge.spec.ts 2.79 KiB
    import { defaultConfig, git, platform } from '../../../test/util';
    import { RenovateConfig } from '../../config';
    import { setAdminConfig } from '../../config/admin';
    import { BranchStatus } from '../../types';
    import { tryBranchAutomerge } from './automerge';
    
    jest.mock('../../util/git');
    
    describe('workers/branch/automerge', () => {
      describe('tryBranchAutomerge', () => {
        let config: RenovateConfig;
        beforeEach(() => {
          config = {
            ...defaultConfig,
          };
          setAdminConfig();
        });
        it('returns false if not configured for automerge', async () => {
          config.automerge = false;
          expect(await tryBranchAutomerge(config)).toBe('no automerge');
        });
        it('returns false if automergeType is pr', async () => {
          config.automerge = true;
          config.automergeType = 'pr';
          expect(await tryBranchAutomerge(config)).toBe('no automerge');
        });
        it('returns false if branch status is not success', async () => {
          config.automerge = true;
          config.automergeType = 'branch';
          platform.getBranchStatus.mockResolvedValueOnce(BranchStatus.yellow);
          expect(await tryBranchAutomerge(config)).toBe('no automerge');
        });
        it('returns branch status error if branch status is failure', async () => {
          config.automerge = true;
          config.automergeType = 'branch';
          platform.getBranchStatus.mockResolvedValueOnce(BranchStatus.red);
          expect(await tryBranchAutomerge(config)).toBe('branch status error');
        });
        it('returns false if PR exists', async () => {
          platform.getBranchPr.mockResolvedValueOnce({} as never);
          config.automerge = true;
          config.automergeType = 'branch';
          platform.getBranchStatus.mockResolvedValueOnce(BranchStatus.green);
          expect(await tryBranchAutomerge(config)).toBe(
            'automerge aborted - PR exists'
          );
        });
        it('returns false if automerge fails', async () => {
          config.automerge = true;
          config.automergeType = 'branch';
          platform.getBranchStatus.mockResolvedValueOnce(BranchStatus.green);
          git.mergeBranch.mockImplementationOnce(() => {
            throw new Error('merge error');
          });
          expect(await tryBranchAutomerge(config)).toBe('failed');
        });
        it('returns true if automerge succeeds', async () => {
          config.automerge = true;
          config.automergeType = 'branch';
          platform.getBranchStatus.mockResolvedValueOnce(BranchStatus.green);
          expect(await tryBranchAutomerge(config)).toBe('automerged');
        });
        it('returns true if automerge succeeds (dry-run)', async () => {
          config.automerge = true;
          config.automergeType = 'branch';
          setAdminConfig({ dryRun: true });
          platform.getBranchStatus.mockResolvedValueOnce(BranchStatus.green);
          expect(await tryBranchAutomerge(config)).toBe('automerged');
        });
      });