mirror of
https://github.com/nvbn/thefuck.git
synced 2025-01-19 12:24:29 +00:00
54 lines
1.9 KiB
Python
54 lines
1.9 KiB
Python
import pytest
|
|
from thefuck.rules.git_checkout import match, get_new_command
|
|
from tests.utils import Command
|
|
|
|
|
|
@pytest.fixture
|
|
def did_not_match(target, did_you_forget=False):
|
|
error = ("error: pathspec '{}' did not match any "
|
|
"file(s) known to git.".format(target))
|
|
if did_you_forget:
|
|
error = ("{}\nDid you forget to 'git add'?'".format(error))
|
|
return error
|
|
|
|
|
|
@pytest.fixture
|
|
def get_branches(mocker):
|
|
return mocker.patch('thefuck.rules.git_checkout.get_branches')
|
|
|
|
|
|
@pytest.mark.parametrize('command', [
|
|
Command(script='git checkout unknown', stderr=did_not_match('unknown')),
|
|
Command(script='git commit unknown', stderr=did_not_match('unknown'))])
|
|
def test_match(command):
|
|
assert match(command)
|
|
|
|
|
|
@pytest.mark.parametrize('command', [
|
|
Command(script='git submodule update unknown',
|
|
stderr=did_not_match('unknown', True)),
|
|
Command(script='git checkout known', stderr=('')),
|
|
Command(script='git commit known', stderr=(''))])
|
|
def test_not_match(command):
|
|
assert not match(command)
|
|
|
|
|
|
@pytest.mark.parametrize('branches, command, new_command', [
|
|
([],
|
|
Command(script='git checkout unknown', stderr=did_not_match('unknown')),
|
|
'git branch unknown && git checkout unknown'),
|
|
([],
|
|
Command('git commit unknown', stderr=did_not_match('unknown')),
|
|
'git branch unknown && git commit unknown'),
|
|
(['test-random-branch-123'],
|
|
Command(script='git checkout tst-rdm-brnch-123',
|
|
stderr=did_not_match('tst-rdm-brnch-123')),
|
|
'git checkout test-random-branch-123'),
|
|
(['test-random-branch-123'],
|
|
Command(script='git commit tst-rdm-brnch-123',
|
|
stderr=did_not_match('tst-rdm-brnch-123')),
|
|
'git commit test-random-branch-123')])
|
|
def test_get_new_command(branches, command, new_command, get_branches):
|
|
get_branches.return_value = branches
|
|
assert get_new_command(command) == new_command
|