2015-05-14 17:34:40 -03:00
|
|
|
import pytest
|
|
|
|
from thefuck.rules.git_stash import match, get_new_command
|
2017-08-31 17:58:56 +02:00
|
|
|
from thefuck.types import Command
|
2015-05-14 17:34:40 -03:00
|
|
|
|
|
|
|
|
2015-07-17 11:55:44 +02:00
|
|
|
cherry_pick_error = (
|
2016-10-06 14:51:22 -04:00
|
|
|
'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')
|
2015-05-14 17:34:40 -03:00
|
|
|
|
|
|
|
|
2015-07-17 11:55:44 +02:00
|
|
|
rebase_error = (
|
2016-10-06 14:51:22 -04:00
|
|
|
'Cannot rebase: Your index contains uncommitted changes.\n'
|
|
|
|
'Please commit or stash them.')
|
2015-05-14 17:34:40 -03:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize('command', [
|
2017-08-31 17:58:56 +02:00
|
|
|
Command('git cherry-pick a1b2c3d', cherry_pick_error),
|
|
|
|
Command('git rebase -i HEAD~7', rebase_error)])
|
2015-05-14 17:34:40 -03:00
|
|
|
def test_match(command):
|
2015-09-07 13:00:29 +03:00
|
|
|
assert match(command)
|
2015-05-14 17:34:40 -03:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize('command', [
|
2017-08-31 17:58:56 +02:00
|
|
|
Command('git cherry-pick a1b2c3d', ''),
|
|
|
|
Command('git rebase -i HEAD~7', '')])
|
2015-05-14 17:34:40 -03:00
|
|
|
def test_not_match(command):
|
2015-09-07 13:00:29 +03:00
|
|
|
assert not match(command)
|
2015-05-14 17:34:40 -03:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize('command, new_command', [
|
2017-08-31 17:58:56 +02:00
|
|
|
(Command('git cherry-pick a1b2c3d', cherry_pick_error),
|
2015-05-14 17:34:40 -03:00
|
|
|
'git stash && git cherry-pick a1b2c3d'),
|
2017-08-31 17:58:56 +02:00
|
|
|
(Command('git rebase -i HEAD~7', rebase_error),
|
2015-05-14 17:34:40 -03:00
|
|
|
'git stash && git rebase -i HEAD~7')])
|
|
|
|
def test_get_new_command(command, new_command):
|
2015-09-07 13:00:29 +03:00
|
|
|
assert get_new_command(command) == new_command
|