mirror of
https://github.com/nvbn/thefuck.git
synced 2025-01-31 10:11:14 +00:00
#N/A: Refactor for better readability (#1094)
* #N/A: Refactor for better readability * Change typename for test tuple * Rename variable
This commit is contained in:
parent
81b39defe4
commit
365db1ee41
@ -2,98 +2,54 @@
|
|||||||
|
|
||||||
import pytest
|
import pytest
|
||||||
import os
|
import os
|
||||||
|
from collections import namedtuple
|
||||||
from thefuck.rules.fix_file import match, get_new_command
|
from thefuck.rules.fix_file import match, get_new_command
|
||||||
from thefuck.types import Command
|
from thefuck.types import Command
|
||||||
|
|
||||||
|
FixFileTest = namedtuple('FixFileTest', ['script', 'file', 'line', 'col', 'output'])
|
||||||
|
|
||||||
# (script, file, line, col (or None), output)
|
|
||||||
tests = (
|
tests = (
|
||||||
(
|
FixFileTest('gcc a.c', 'a.c', 3, 1, """
|
||||||
"gcc a.c",
|
|
||||||
"a.c",
|
|
||||||
3,
|
|
||||||
1,
|
|
||||||
"""
|
|
||||||
a.c: In function 'main':
|
a.c: In function 'main':
|
||||||
a.c:3:1: error: expected expression before '}' token
|
a.c:3:1: error: expected expression before '}' token
|
||||||
}
|
}
|
||||||
^
|
^
|
||||||
""",
|
"""),
|
||||||
),
|
|
||||||
(
|
FixFileTest('clang a.c', 'a.c', 3, 1, """
|
||||||
"clang a.c",
|
|
||||||
"a.c",
|
|
||||||
3,
|
|
||||||
1,
|
|
||||||
"""
|
|
||||||
a.c:3:1: error: expected expression
|
a.c:3:1: error: expected expression
|
||||||
}
|
}
|
||||||
^
|
^
|
||||||
""",
|
"""),
|
||||||
),
|
|
||||||
(
|
FixFileTest('perl a.pl', 'a.pl', 3, None, """
|
||||||
"perl a.pl",
|
|
||||||
"a.pl",
|
|
||||||
3,
|
|
||||||
None,
|
|
||||||
"""
|
|
||||||
syntax error at a.pl line 3, at EOF
|
syntax error at a.pl line 3, at EOF
|
||||||
Execution of a.pl aborted due to compilation errors.
|
Execution of a.pl aborted due to compilation errors.
|
||||||
""",
|
"""),
|
||||||
),
|
|
||||||
(
|
FixFileTest('perl a.pl', 'a.pl', 2, None, """
|
||||||
"perl a.pl",
|
|
||||||
"a.pl",
|
|
||||||
2,
|
|
||||||
None,
|
|
||||||
"""
|
|
||||||
Search pattern not terminated at a.pl line 2.
|
Search pattern not terminated at a.pl line 2.
|
||||||
""",
|
"""),
|
||||||
),
|
|
||||||
(
|
FixFileTest('sh a.sh', 'a.sh', 2, None, """
|
||||||
"sh a.sh",
|
|
||||||
"a.sh",
|
|
||||||
2,
|
|
||||||
None,
|
|
||||||
"""
|
|
||||||
a.sh: line 2: foo: command not found
|
a.sh: line 2: foo: command not found
|
||||||
""",
|
"""),
|
||||||
),
|
|
||||||
(
|
FixFileTest('zsh a.sh', 'a.sh', 2, None, """
|
||||||
"zsh a.sh",
|
|
||||||
"a.sh",
|
|
||||||
2,
|
|
||||||
None,
|
|
||||||
"""
|
|
||||||
a.sh:2: command not found: foo
|
a.sh:2: command not found: foo
|
||||||
""",
|
"""),
|
||||||
),
|
|
||||||
(
|
FixFileTest('bash a.sh', 'a.sh', 2, None, """
|
||||||
"bash a.sh",
|
|
||||||
"a.sh",
|
|
||||||
2,
|
|
||||||
None,
|
|
||||||
"""
|
|
||||||
a.sh: line 2: foo: command not found
|
a.sh: line 2: foo: command not found
|
||||||
""",
|
"""),
|
||||||
),
|
|
||||||
(
|
FixFileTest('rustc a.rs', 'a.rs', 2, 5, """
|
||||||
"rustc a.rs",
|
|
||||||
"a.rs",
|
|
||||||
2,
|
|
||||||
5,
|
|
||||||
"""
|
|
||||||
a.rs:2:5: 2:6 error: unexpected token: `+`
|
a.rs:2:5: 2:6 error: unexpected token: `+`
|
||||||
a.rs:2 +
|
a.rs:2 +
|
||||||
^
|
^
|
||||||
""",
|
"""),
|
||||||
),
|
|
||||||
(
|
FixFileTest('cargo build', 'src/lib.rs', 3, 5, """
|
||||||
"cargo build",
|
|
||||||
"src/lib.rs",
|
|
||||||
3,
|
|
||||||
5,
|
|
||||||
"""
|
|
||||||
Compiling test v0.1.0 (file:///tmp/fix-error/test)
|
Compiling test v0.1.0 (file:///tmp/fix-error/test)
|
||||||
src/lib.rs:3:5: 3:6 error: unexpected token: `+`
|
src/lib.rs:3:5: 3:6 error: unexpected token: `+`
|
||||||
src/lib.rs:3 +
|
src/lib.rs:3 +
|
||||||
@ -101,26 +57,16 @@ a.rs:2 +
|
|||||||
Could not compile `test`.
|
Could not compile `test`.
|
||||||
|
|
||||||
To learn more, run the command again with --verbose.
|
To learn more, run the command again with --verbose.
|
||||||
""",
|
"""),
|
||||||
),
|
|
||||||
(
|
FixFileTest('python a.py', 'a.py', 2, None, """
|
||||||
"python a.py",
|
|
||||||
"a.py",
|
|
||||||
2,
|
|
||||||
None,
|
|
||||||
"""
|
|
||||||
File "a.py", line 2
|
File "a.py", line 2
|
||||||
+
|
+
|
||||||
^
|
^
|
||||||
SyntaxError: invalid syntax
|
SyntaxError: invalid syntax
|
||||||
""",
|
"""),
|
||||||
),
|
|
||||||
(
|
FixFileTest('python a.py', 'a.py', 8, None, """
|
||||||
"python a.py",
|
|
||||||
"a.py",
|
|
||||||
8,
|
|
||||||
None,
|
|
||||||
"""
|
|
||||||
Traceback (most recent call last):
|
Traceback (most recent call last):
|
||||||
File "a.py", line 8, in <module>
|
File "a.py", line 8, in <module>
|
||||||
match("foo")
|
match("foo")
|
||||||
@ -131,14 +77,9 @@ Traceback (most recent call last):
|
|||||||
File "/usr/lib/python3.4/re.py", line 293, in _compile
|
File "/usr/lib/python3.4/re.py", line 293, in _compile
|
||||||
raise TypeError("first argument must be string or compiled pattern")
|
raise TypeError("first argument must be string or compiled pattern")
|
||||||
TypeError: first argument must be string or compiled pattern
|
TypeError: first argument must be string or compiled pattern
|
||||||
""",
|
"""),
|
||||||
),
|
|
||||||
(
|
FixFileTest(u'python café.py', u'café.py', 8, None, u"""
|
||||||
u"python café.py",
|
|
||||||
u"café.py",
|
|
||||||
8,
|
|
||||||
None,
|
|
||||||
u"""
|
|
||||||
Traceback (most recent call last):
|
Traceback (most recent call last):
|
||||||
File "café.py", line 8, in <module>
|
File "café.py", line 8, in <module>
|
||||||
match("foo")
|
match("foo")
|
||||||
@ -149,95 +90,50 @@ Traceback (most recent call last):
|
|||||||
File "/usr/lib/python3.4/re.py", line 293, in _compile
|
File "/usr/lib/python3.4/re.py", line 293, in _compile
|
||||||
raise TypeError("first argument must be string or compiled pattern")
|
raise TypeError("first argument must be string or compiled pattern")
|
||||||
TypeError: first argument must be string or compiled pattern
|
TypeError: first argument must be string or compiled pattern
|
||||||
""",
|
"""),
|
||||||
),
|
|
||||||
(
|
FixFileTest('ruby a.rb', 'a.rb', 3, None, """
|
||||||
"ruby a.rb",
|
|
||||||
"a.rb",
|
|
||||||
3,
|
|
||||||
None,
|
|
||||||
"""
|
|
||||||
a.rb:3: syntax error, unexpected keyword_end
|
a.rb:3: syntax error, unexpected keyword_end
|
||||||
""",
|
"""),
|
||||||
),
|
|
||||||
(
|
FixFileTest('lua a.lua', 'a.lua', 2, None, """
|
||||||
"lua a.lua",
|
|
||||||
"a.lua",
|
|
||||||
2,
|
|
||||||
None,
|
|
||||||
"""
|
|
||||||
lua: a.lua:2: unexpected symbol near '+'
|
lua: a.lua:2: unexpected symbol near '+'
|
||||||
""",
|
"""),
|
||||||
),
|
|
||||||
(
|
FixFileTest('fish a.sh', '/tmp/fix-error/a.sh', 2, None, """
|
||||||
"fish a.sh",
|
|
||||||
"/tmp/fix-error/a.sh",
|
|
||||||
2,
|
|
||||||
None,
|
|
||||||
"""
|
|
||||||
fish: Unknown command 'foo'
|
fish: Unknown command 'foo'
|
||||||
/tmp/fix-error/a.sh (line 2): foo
|
/tmp/fix-error/a.sh (line 2): foo
|
||||||
^
|
^
|
||||||
""",
|
"""),
|
||||||
),
|
|
||||||
(
|
FixFileTest('./a', './a', 2, None, """
|
||||||
"./a",
|
|
||||||
"./a",
|
|
||||||
2,
|
|
||||||
None,
|
|
||||||
"""
|
|
||||||
awk: ./a:2: BEGIN { print "Hello, world!" + }
|
awk: ./a:2: BEGIN { print "Hello, world!" + }
|
||||||
awk: ./a:2: ^ syntax error
|
awk: ./a:2: ^ syntax error
|
||||||
""",
|
"""),
|
||||||
),
|
|
||||||
(
|
FixFileTest('llc a.ll', 'a.ll', 1, 2, """
|
||||||
"llc a.ll",
|
|
||||||
"a.ll",
|
|
||||||
1,
|
|
||||||
2,
|
|
||||||
"""
|
|
||||||
llc: a.ll:1:2: error: expected top-level entity
|
llc: a.ll:1:2: error: expected top-level entity
|
||||||
+
|
+
|
||||||
^
|
^
|
||||||
""",
|
"""),
|
||||||
),
|
|
||||||
(
|
FixFileTest('go build a.go', 'a.go', 1, 2, """
|
||||||
"go build a.go",
|
|
||||||
"a.go",
|
|
||||||
1,
|
|
||||||
2,
|
|
||||||
"""
|
|
||||||
can't load package:
|
can't load package:
|
||||||
a.go:1:2: expected 'package', found '+'
|
a.go:1:2: expected 'package', found '+'
|
||||||
""",
|
"""),
|
||||||
),
|
|
||||||
(
|
FixFileTest('make', 'Makefile', 2, None, """
|
||||||
"make",
|
|
||||||
"Makefile",
|
|
||||||
2,
|
|
||||||
None,
|
|
||||||
"""
|
|
||||||
bidule
|
bidule
|
||||||
make: bidule: Command not found
|
make: bidule: Command not found
|
||||||
Makefile:2: recipe for target 'target' failed
|
Makefile:2: recipe for target 'target' failed
|
||||||
make: *** [target] Error 127
|
make: *** [target] Error 127
|
||||||
""",
|
"""),
|
||||||
),
|
|
||||||
(
|
FixFileTest('git st', '/home/martin/.config/git/config', 1, None, """
|
||||||
"git st",
|
|
||||||
"/home/martin/.config/git/config",
|
|
||||||
1,
|
|
||||||
None,
|
|
||||||
"""
|
|
||||||
fatal: bad config file line 1 in /home/martin/.config/git/config
|
fatal: bad config file line 1 in /home/martin/.config/git/config
|
||||||
""",
|
"""),
|
||||||
),
|
|
||||||
(
|
FixFileTest('node fuck.js asdf qwer', '/Users/pablo/Workspace/barebones/fuck.js', '2', 5, """
|
||||||
"node fuck.js asdf qwer",
|
|
||||||
"/Users/pablo/Workspace/barebones/fuck.js",
|
|
||||||
"2",
|
|
||||||
5,
|
|
||||||
"""
|
|
||||||
/Users/pablo/Workspace/barebones/fuck.js:2
|
/Users/pablo/Workspace/barebones/fuck.js:2
|
||||||
conole.log(arg); // this should read console.log(arg);
|
conole.log(arg); // this should read console.log(arg);
|
||||||
^
|
^
|
||||||
@ -252,26 +148,16 @@ ReferenceError: conole is not defined
|
|||||||
at Function.Module.runMain (module.js:501:10)
|
at Function.Module.runMain (module.js:501:10)
|
||||||
at startup (node.js:129:16)
|
at startup (node.js:129:16)
|
||||||
at node.js:814:3
|
at node.js:814:3
|
||||||
""",
|
"""),
|
||||||
),
|
|
||||||
(
|
FixFileTest('pep8', './tests/rules/test_systemctl.py', 17, 80, """
|
||||||
"pep8",
|
|
||||||
"./tests/rules/test_systemctl.py",
|
|
||||||
17,
|
|
||||||
80,
|
|
||||||
"""
|
|
||||||
./tests/rules/test_systemctl.py:17:80: E501 line too long (93 > 79 characters)
|
./tests/rules/test_systemctl.py:17:80: E501 line too long (93 > 79 characters)
|
||||||
./tests/rules/test_systemctl.py:18:80: E501 line too long (103 > 79 characters)
|
./tests/rules/test_systemctl.py:18:80: E501 line too long (103 > 79 characters)
|
||||||
./tests/rules/test_whois.py:20:80: E501 line too long (89 > 79 characters)
|
./tests/rules/test_whois.py:20:80: E501 line too long (89 > 79 characters)
|
||||||
./tests/rules/test_whois.py:22:80: E501 line too long (83 > 79 characters)
|
./tests/rules/test_whois.py:22:80: E501 line too long (83 > 79 characters)
|
||||||
""",
|
"""),
|
||||||
),
|
|
||||||
(
|
FixFileTest('py.test', '/home/thefuck/tests/rules/test_fix_file.py', 218, None, """
|
||||||
"py.test",
|
|
||||||
"/home/thefuck/tests/rules/test_fix_file.py",
|
|
||||||
218,
|
|
||||||
None,
|
|
||||||
"""
|
|
||||||
monkeypatch = <_pytest.monkeypatch.monkeypatch object at 0x7fdb76a25b38>
|
monkeypatch = <_pytest.monkeypatch.monkeypatch object at 0x7fdb76a25b38>
|
||||||
test = ('fish a.sh', '/tmp/fix-error/a.sh', 2, None, '', "\\nfish: Unknown command 'foo'\\n/tmp/fix-error/a.sh (line 2): foo\\n ^\\n")
|
test = ('fish a.sh', '/tmp/fix-error/a.sh', 2, None, '', "\\nfish: Unknown command 'foo'\\n/tmp/fix-error/a.sh (line 2): foo\\n ^\\n")
|
||||||
|
|
||||||
@ -282,8 +168,7 @@ test = ('fish a.sh', '/tmp/fix-error/a.sh', 2, None, '', "\\nfish: Unknown comma
|
|||||||
E NameError: name 'mocker' is not defined
|
E NameError: name 'mocker' is not defined
|
||||||
|
|
||||||
/home/thefuck/tests/rules/test_fix_file.py:218: NameError
|
/home/thefuck/tests/rules/test_fix_file.py:218: NameError
|
||||||
""",
|
"""),
|
||||||
),
|
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
@ -292,7 +177,7 @@ E NameError: name 'mocker' is not defined
|
|||||||
def test_match(mocker, monkeypatch, test):
|
def test_match(mocker, monkeypatch, test):
|
||||||
mocker.patch('os.path.isfile', return_value=True)
|
mocker.patch('os.path.isfile', return_value=True)
|
||||||
monkeypatch.setenv('EDITOR', 'dummy_editor')
|
monkeypatch.setenv('EDITOR', 'dummy_editor')
|
||||||
assert match(Command('', test[4]))
|
assert match(Command('', test.output))
|
||||||
|
|
||||||
|
|
||||||
@pytest.mark.parametrize('test', tests)
|
@pytest.mark.parametrize('test', tests)
|
||||||
@ -302,7 +187,7 @@ def test_no_editor(mocker, monkeypatch, test):
|
|||||||
if 'EDITOR' in os.environ:
|
if 'EDITOR' in os.environ:
|
||||||
monkeypatch.delenv('EDITOR')
|
monkeypatch.delenv('EDITOR')
|
||||||
|
|
||||||
assert not match(Command('', test[4]))
|
assert not match(Command('', test.output))
|
||||||
|
|
||||||
|
|
||||||
@pytest.mark.parametrize('test', tests)
|
@pytest.mark.parametrize('test', tests)
|
||||||
@ -311,7 +196,7 @@ def test_not_file(mocker, monkeypatch, test):
|
|||||||
mocker.patch('os.path.isfile', return_value=False)
|
mocker.patch('os.path.isfile', return_value=False)
|
||||||
monkeypatch.setenv('EDITOR', 'dummy_editor')
|
monkeypatch.setenv('EDITOR', 'dummy_editor')
|
||||||
|
|
||||||
assert not match(Command('', test[4]))
|
assert not match(Command('', test.output))
|
||||||
|
|
||||||
|
|
||||||
@pytest.mark.parametrize('test', tests)
|
@pytest.mark.parametrize('test', tests)
|
||||||
@ -327,12 +212,12 @@ def test_get_new_command_with_settings(mocker, monkeypatch, test, settings):
|
|||||||
mocker.patch('os.path.isfile', return_value=True)
|
mocker.patch('os.path.isfile', return_value=True)
|
||||||
monkeypatch.setenv('EDITOR', 'dummy_editor')
|
monkeypatch.setenv('EDITOR', 'dummy_editor')
|
||||||
|
|
||||||
cmd = Command(test[0], test[4])
|
cmd = Command(test.script, test.output)
|
||||||
settings.fixcolcmd = '{editor} {file} +{line}:{col}'
|
settings.fixcolcmd = '{editor} {file} +{line}:{col}'
|
||||||
|
|
||||||
if test[3]:
|
if test.col:
|
||||||
assert (get_new_command(cmd) ==
|
assert (get_new_command(cmd) ==
|
||||||
u'dummy_editor {} +{}:{} && {}'.format(test[1], test[2], test[3], test[0]))
|
u'dummy_editor {} +{}:{} && {}'.format(test.file, test.line, test.col, test.script))
|
||||||
else:
|
else:
|
||||||
assert (get_new_command(cmd) ==
|
assert (get_new_command(cmd) ==
|
||||||
u'dummy_editor {} +{} && {}'.format(test[1], test[2], test[0]))
|
u'dummy_editor {} +{} && {}'.format(test.file, test.line, test.script))
|
||||||
|
Loading…
x
Reference in New Issue
Block a user