mirror of
https://github.com/nvbn/thefuck.git
synced 2025-01-18 03:56:01 +00:00
Added a rule to match az binary sub-command misses (#834)
This commit is contained in:
parent
9d46291944
commit
926e9ef963
@ -175,6 +175,7 @@ following rules are enabled by default:
|
||||
* `adb_unknown_command` – fixes misspelled commands like `adb logcta`;
|
||||
* `ag_literal` – adds `-Q` to `ag` when suggested;
|
||||
* `aws_cli` – fixes misspelled commands like `aws dynamdb scan`;
|
||||
* `az_cli` – fixes misspelled commands like `az providers`;
|
||||
* `cargo` – runs `cargo build` instead of `cargo`;
|
||||
* `cargo_no_command` – fixes wrongs commands like `cargo buid`;
|
||||
* `cat_dir` – replaces `cat` with `ls` when you try to `cat` a directory;
|
||||
|
44
tests/rules/test_az_cli.py
Normal file
44
tests/rules/test_az_cli.py
Normal file
@ -0,0 +1,44 @@
|
||||
import pytest
|
||||
|
||||
from thefuck.rules.az_cli import match, get_new_command
|
||||
from thefuck.types import Command
|
||||
|
||||
|
||||
no_suggestions = '''\
|
||||
az provider: error: the following arguments are required: _subcommand
|
||||
usage: az provider [-h] {list,show,register,unregister,operation} ...
|
||||
'''
|
||||
|
||||
|
||||
misspelled_command = '''\
|
||||
az: 'providers' is not in the 'az' command group. See 'az --help'.
|
||||
|
||||
The most similar choice to 'providers' is:
|
||||
provider
|
||||
'''
|
||||
|
||||
misspelled_subcommand = '''\
|
||||
az provider: 'lis' is not in the 'az provider' command group. See 'az provider --help'.
|
||||
|
||||
The most similar choice to 'lis' is:
|
||||
list
|
||||
'''
|
||||
|
||||
|
||||
@pytest.mark.parametrize('command', [
|
||||
Command('az providers', misspelled_command),
|
||||
Command('az provider lis', misspelled_subcommand)])
|
||||
def test_match(command):
|
||||
assert match(command)
|
||||
|
||||
|
||||
def test_not_match():
|
||||
assert not match(Command('az provider', no_suggestions))
|
||||
|
||||
|
||||
@pytest.mark.parametrize('command, result', [
|
||||
(Command('az providers list', misspelled_command), ['az provider list']),
|
||||
(Command('az provider lis', misspelled_subcommand), ['az provider list'])
|
||||
])
|
||||
def test_get_new_command(command, result):
|
||||
assert get_new_command(command) == result
|
17
thefuck/rules/az_cli.py
Normal file
17
thefuck/rules/az_cli.py
Normal file
@ -0,0 +1,17 @@
|
||||
import re
|
||||
|
||||
from thefuck.utils import for_app, replace_argument
|
||||
|
||||
INVALID_CHOICE = "(?=az)(?:.*): '(.*)' is not in the '.*' command group."
|
||||
OPTIONS = "^The most similar choice to '.*' is:\n\s*(.*)$"
|
||||
|
||||
|
||||
@for_app('az')
|
||||
def match(command):
|
||||
return "is not in the" in command.output and "command group" in command.output
|
||||
|
||||
|
||||
def get_new_command(command):
|
||||
mistake = re.search(INVALID_CHOICE, command.output).group(1)
|
||||
options = re.findall(OPTIONS, command.output, flags=re.MULTILINE)
|
||||
return [replace_argument(command.script, mistake, o) for o in options]
|
Loading…
Reference in New Issue
Block a user