2016-10-30 20:07:14 -02:00
|
|
|
import pytest
|
|
|
|
from thefuck.rules.git_rebase_merge_dir import match, get_new_command
|
2017-08-31 17:58:56 +02:00
|
|
|
from thefuck.types import Command
|
2016-10-30 20:07:14 -02:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture
|
2017-08-31 17:58:56 +02:00
|
|
|
def output():
|
2016-10-30 20:07:14 -02:00
|
|
|
return ('\n\nIt seems that there is already a rebase-merge directory, and\n'
|
|
|
|
'I wonder if you are in the middle of another rebase. If that is the\n'
|
|
|
|
'case, please try\n'
|
|
|
|
'\tgit rebase (--continue | --abort | --skip)\n'
|
|
|
|
'If that is not the case, please\n'
|
|
|
|
'\trm -fr "/foo/bar/baz/egg/.git/rebase-merge"\n'
|
|
|
|
'and run me again. I am stopping in case you still have something\n'
|
|
|
|
'valuable there.\n')
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize('script', [
|
2017-08-31 17:58:56 +02:00
|
|
|
'git rebase master',
|
|
|
|
'git rebase -skip',
|
|
|
|
'git rebase'])
|
|
|
|
def test_match(output, script):
|
|
|
|
assert match(Command(script, output))
|
2016-10-30 20:07:14 -02:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize('script', ['git rebase master', 'git rebase -abort'])
|
|
|
|
def test_not_match(script):
|
2017-08-31 17:58:56 +02:00
|
|
|
assert not match(Command(script, ''))
|
2016-10-30 20:07:14 -02:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize('script, result', [
|
|
|
|
('git rebase master', [
|
|
|
|
'git rebase --abort', 'git rebase --skip', 'git rebase --continue',
|
|
|
|
'rm -fr "/foo/bar/baz/egg/.git/rebase-merge"']),
|
|
|
|
('git rebase -skip', [
|
|
|
|
'git rebase --skip', 'git rebase --abort', 'git rebase --continue',
|
|
|
|
'rm -fr "/foo/bar/baz/egg/.git/rebase-merge"']),
|
|
|
|
('git rebase', [
|
|
|
|
'git rebase --skip', 'git rebase --abort', 'git rebase --continue',
|
|
|
|
'rm -fr "/foo/bar/baz/egg/.git/rebase-merge"'])])
|
2017-08-31 17:58:56 +02:00
|
|
|
def test_get_new_command(output, script, result):
|
|
|
|
assert get_new_command(Command(script, output)) == result
|