File: test_git_stash.py

package info (click to toggle)
thefuck 3.32-0.4
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 3,132 kB
  • sloc: python: 12,011; makefile: 5; sh: 2
file content (37 lines) | stat: -rw-r--r-- 1,155 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
import pytest
from thefuck.rules.git_stash import match, get_new_command
from thefuck.types import Command


cherry_pick_error = (
    'error: Your local changes would be overwritten by cherry-pick.\n'
    'hint: Commit your changes or stash them to proceed.\n'
    'fatal: cherry-pick failed')


rebase_error = (
    'Cannot rebase: Your index contains uncommitted changes.\n'
    'Please commit or stash them.')


@pytest.mark.parametrize('command', [
    Command('git cherry-pick a1b2c3d', cherry_pick_error),
    Command('git rebase -i HEAD~7', rebase_error)])
def test_match(command):
    assert match(command)


@pytest.mark.parametrize('command', [
    Command('git cherry-pick a1b2c3d', ''),
    Command('git rebase -i HEAD~7', '')])
def test_not_match(command):
    assert not match(command)


@pytest.mark.parametrize('command, new_command', [
    (Command('git cherry-pick a1b2c3d', cherry_pick_error),
     'git stash && git cherry-pick a1b2c3d'),
    (Command('git rebase -i HEAD~7', rebase_error),
     'git stash && git rebase -i HEAD~7')])
def test_get_new_command(command, new_command):
    assert get_new_command(command) == new_command