mirror of
				https://github.com/nvbn/thefuck.git
				synced 2025-10-31 07:04:12 +00:00 
			
		
		
		
	Merge pull request #596 from josephfrazier/git-tag-force
Add git_tag_force rule
This commit is contained in:
		| @@ -189,6 +189,7 @@ using the matched rule and runs it. Rules enabled by default are as follows: | |||||||
| * `git_remote_seturl_add` – runs `git remote add` when `git remote set_url` on nonexistant remote; | * `git_remote_seturl_add` – runs `git remote add` when `git remote set_url` on nonexistant remote; | ||||||
| * `git_stash` – stashes you local modifications before rebasing or switching branch; | * `git_stash` – stashes you local modifications before rebasing or switching branch; | ||||||
| * `git_stash_pop` – adds your local modifications before popping stash, then resets; | * `git_stash_pop` – adds your local modifications before popping stash, then resets; | ||||||
|  | * `git_tag_force` – adds `--force` to `git tag <tagname>` when the tag already exists; | ||||||
| * `git_two_dashes` – adds a missing dash to commands like `git commit -amend` or `git rebase -continue`; | * `git_two_dashes` – adds a missing dash to commands like `git commit -amend` or `git rebase -continue`; | ||||||
| * `go_run` – appends `.go` extension when compiling/running Go programs; | * `go_run` – appends `.go` extension when compiling/running Go programs; | ||||||
| * `gradle_no_task` – fixes not found or ambiguous `gradle` task; | * `gradle_no_task` – fixes not found or ambiguous `gradle` task; | ||||||
|   | |||||||
							
								
								
									
										18
									
								
								tests/rules/test_git_tag_force.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								tests/rules/test_git_tag_force.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,18 @@ | |||||||
|  | import pytest | ||||||
|  | from thefuck.rules.git_tag_force import match, get_new_command | ||||||
|  | from tests.utils import Command | ||||||
|  |  | ||||||
|  |  | ||||||
|  | @pytest.fixture | ||||||
|  | def stderr(): | ||||||
|  |     return '''fatal: tag 'alert' already exists''' | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def test_match(stderr): | ||||||
|  |     assert match(Command('git tag alert', stderr=stderr)) | ||||||
|  |     assert not match(Command('git tag alert')) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def test_get_new_command(stderr): | ||||||
|  |     assert get_new_command(Command('git tag alert', stderr=stderr)) \ | ||||||
|  |            == "git tag --force alert" | ||||||
							
								
								
									
										13
									
								
								thefuck/rules/git_tag_force.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								thefuck/rules/git_tag_force.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,13 @@ | |||||||
|  | from thefuck.utils import replace_argument | ||||||
|  | from thefuck.specific.git import git_support | ||||||
|  |  | ||||||
|  |  | ||||||
|  | @git_support | ||||||
|  | def match(command): | ||||||
|  |     return ('tag' in command.script_parts | ||||||
|  |             and 'already exists' in command.stderr) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | @git_support | ||||||
|  | def get_new_command(command): | ||||||
|  |     return replace_argument(command.script, 'tag', 'tag --force') | ||||||
		Reference in New Issue
	
	Block a user