From 8ba83f0720d50f33ab1dcd278f98216d0b4db4f0 Mon Sep 17 00:00:00 2001 From: gazorby Date: Thu, 19 Jan 2023 15:48:51 +0100 Subject: [PATCH 01/10] =?UTF-8?q?=E2=99=BB=EF=B8=8F=20refactor:=20reinstal?= =?UTF-8?q?l=20tips=20on=20update=20&=20fix=20init?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- conf.d/abbr_tips.fish | 32 ++++++++++++++++---------------- functions/__abbr_tips_reset.fish | 19 +++++++++++++++++++ 2 files changed, 35 insertions(+), 16 deletions(-) create mode 100644 functions/__abbr_tips_reset.fish diff --git a/conf.d/abbr_tips.fish b/conf.d/abbr_tips.fish index 848ee6d..bb10271 100644 --- a/conf.d/abbr_tips.fish +++ b/conf.d/abbr_tips.fish @@ -1,7 +1,7 @@ for mode in default insert - bind --mode $mode " " '__abbr_tips_bind_space' - bind --mode $mode \n '__abbr_tips_bind_newline' - bind --mode $mode \r '__abbr_tips_bind_newline' + bind --mode $mode " " __abbr_tips_bind_space + bind --mode $mode \n __abbr_tips_bind_newline + bind --mode $mode \r __abbr_tips_bind_newline end set -g __abbr_tips_used 0 @@ -21,13 +21,9 @@ function __abbr_tips_install --on-event abbr_tips_install set -a ABBR_TIPS_REGEXES '(^(\s?(\w-?)+){1}).*' set -Ux ABBR_TIPS_PROMPT "\nšŸ’” \e[1m{{ .abbr }}\e[0m => {{ .cmd }}" - set -gx ABBR_TIPS_AUTO_UPDATE 'background' + set -gx ABBR_TIPS_AUTO_UPDATE background - # Locking mechanism - # Prevent this file to spawn more than one subshell - if test "$USER" != 'root' - fish -c '__abbr_tips_init' & - end + __abbr_tips_init end function __abbr_tips --on-event fish_postexec -d "Abbreviation reminder for the current command" @@ -35,9 +31,9 @@ function __abbr_tips --on-event fish_postexec -d "Abbreviation reminder for the set -l cmd (string replace -r -a '\\s+' ' ' -- "$argv" ) # Update abbreviations lists when adding/removing abbreviations - if test "$command[1]" = "abbr" + if test "$command[1]" = abbr # Parse args as abbr options - argparse --name 'abbr' --ignore-unknown 'a/add' 'e/erase' 'g/global' 'U/universal' -- $command + argparse --name abbr --ignore-unknown a/add e/erase g/global U/universal -- $command if set -q _flag_a and not contains -- "$argv[2]" $__ABBR_TIPS_KEYS @@ -48,13 +44,13 @@ function __abbr_tips --on-event fish_postexec -d "Abbreviation reminder for the set -e __ABBR_TIPS_KEYS[$abb] set -e __ABBR_TIPS_VALUES[$abb] end - else if test "$command[1]" = "alias" + else if test "$command[1]" = alias # Update abbreviations list when adding aliases set -l alias_key set -l alias_value # Parse args as `alias` options - argparse --name 'alias' --ignore-unknown 's/save' -- $command + argparse --name alias --ignore-unknown s/save -- $command if string match -q '*=*' -- "$argv[2]" if test (count $argv) = 2 @@ -77,9 +73,9 @@ function __abbr_tips --on-event fish_postexec -d "Abbreviation reminder for the set -a __ABBR_TIPS_KEYS $alias_key set -a __ABBR_TIPS_VALUES $alias_value end - else if test "$command[1]" = "functions" + else if test "$command[1]" = functions # Parse args as `functions` options - argparse --name 'functions' 'e/erase' -- $command + argparse --name functions e/erase -- $command # Update abbreviations list when removing aliases if set -q _flag_e @@ -102,7 +98,7 @@ function __abbr_tips --on-event fish_postexec -d "Abbreviation reminder for the return else if string match -q -- "alias $cmd *" (alias) return - else if test (type -t "$command[1]") = 'function' + else if test (type -t "$command[1]") = function and count $ABBR_TIPS_ALIAS_WHITELIST >/dev/null and not contains "$command[1]" $ABBR_TIPS_ALIAS_WHITELIST return @@ -136,6 +132,10 @@ function __abbr_tips --on-event fish_postexec -d "Abbreviation reminder for the return end +function __abbr_tips_update --on-event abbr_tips_update + __abbr_tips_reset +end + function __abbr_tips_uninstall --on-event abbr_tips_uninstall bind --erase \n bind --erase \r diff --git a/functions/__abbr_tips_reset.fish b/functions/__abbr_tips_reset.fish new file mode 100644 index 0000000..3e07a4a --- /dev/null +++ b/functions/__abbr_tips_reset.fish @@ -0,0 +1,19 @@ +function __abbr_tips_reset + # Same as __abbr_tips_uninstall, but keep __abbr_tips_init + bind --erase \n + bind --erase \r + bind --erase " " + set --erase __abbr_tips_used + set --erase __abbr_tips_run_once + set --erase __ABBR_TIPS_VALUES + set --erase __ABBR_TIPS_KEYS + set --erase ABBR_TIPS_PROMPT + set --erase ABBR_TIPS_AUTO_UPDATE + set --erase ABBR_TIPS_ALIAS_WHITELIST + set --erase ABBR_TIPS_REGEXES + functions --erase __abbr_tips_bind_newline + functions --erase __abbr_tips_bind_space + functions --erase __abbr_tips + + __abbr_tips_install +end From 6e129b0c63fd9e3aa973c9607f527815b8e0ba5f Mon Sep 17 00:00:00 2001 From: gazorby Date: Thu, 19 Jan 2023 16:19:00 +0100 Subject: [PATCH 02/10] =?UTF-8?q?=E2=99=BB=EF=B8=8F=20refactor:=20plugin?= =?UTF-8?q?=20update/init?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- conf.d/abbr_tips.fish | 18 +++--------------- ..._tips_reset.fish => __abbr_tips_clean.fish} | 5 +---- 2 files changed, 4 insertions(+), 19 deletions(-) rename functions/{__abbr_tips_reset.fish => __abbr_tips_clean.fish} (80%) diff --git a/conf.d/abbr_tips.fish b/conf.d/abbr_tips.fish index bb10271..bf4cdc1 100644 --- a/conf.d/abbr_tips.fish +++ b/conf.d/abbr_tips.fish @@ -133,23 +133,11 @@ function __abbr_tips --on-event fish_postexec -d "Abbreviation reminder for the end function __abbr_tips_update --on-event abbr_tips_update - __abbr_tips_reset + __abbr_tips_clean + __abbr_tips_init end function __abbr_tips_uninstall --on-event abbr_tips_uninstall - bind --erase \n - bind --erase \r - bind --erase " " - set --erase __abbr_tips_used - set --erase __abbr_tips_run_once - set --erase __ABBR_TIPS_VALUES - set --erase __ABBR_TIPS_KEYS - set --erase ABBR_TIPS_PROMPT - set --erase ABBR_TIPS_AUTO_UPDATE - set --erase ABBR_TIPS_ALIAS_WHITELIST - set --erase ABBR_TIPS_REGEXES + __abbr_tips_clean functions --erase __abbr_tips_init - functions --erase __abbr_tips_bind_newline - functions --erase __abbr_tips_bind_space - functions --erase __abbr_tips end diff --git a/functions/__abbr_tips_reset.fish b/functions/__abbr_tips_clean.fish similarity index 80% rename from functions/__abbr_tips_reset.fish rename to functions/__abbr_tips_clean.fish index 3e07a4a..772bcc6 100644 --- a/functions/__abbr_tips_reset.fish +++ b/functions/__abbr_tips_clean.fish @@ -1,5 +1,4 @@ -function __abbr_tips_reset - # Same as __abbr_tips_uninstall, but keep __abbr_tips_init +function __abbr_tips_clean -d "Clean plugin variables and functions" bind --erase \n bind --erase \r bind --erase " " @@ -14,6 +13,4 @@ function __abbr_tips_reset functions --erase __abbr_tips_bind_newline functions --erase __abbr_tips_bind_space functions --erase __abbr_tips - - __abbr_tips_install end From ee4d1383e2b2aab887b815e4f2d26b31adfda836 Mon Sep 17 00:00:00 2001 From: gazorby Date: Sat, 21 Jan 2023 12:50:42 +0100 Subject: [PATCH 03/10] =?UTF-8?q?=F0=9F=90=9B=20fix:=20update=20event?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- conf.d/abbr_tips.fish | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/conf.d/abbr_tips.fish b/conf.d/abbr_tips.fish index bf4cdc1..8931bf9 100644 --- a/conf.d/abbr_tips.fish +++ b/conf.d/abbr_tips.fish @@ -134,7 +134,7 @@ end function __abbr_tips_update --on-event abbr_tips_update __abbr_tips_clean - __abbr_tips_init + __abbr_tips_install end function __abbr_tips_uninstall --on-event abbr_tips_uninstall From c0ac7111b46dacc4670537feb9d89a69340052d5 Mon Sep 17 00:00:00 2001 From: gazorby Date: Mon, 23 Jan 2023 08:42:57 +0100 Subject: [PATCH 04/10] =?UTF-8?q?=F0=9F=90=9B=20fix:=20set=20alias=20with?= =?UTF-8?q?=20=3D=20and=20quotes?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- conf.d/abbr_tips.fish | 9 +++------ test/fish-abbreviation-tips.fish | 15 +++++++++++++-- 2 files changed, 16 insertions(+), 8 deletions(-) diff --git a/conf.d/abbr_tips.fish b/conf.d/abbr_tips.fish index 8931bf9..1c6f180 100644 --- a/conf.d/abbr_tips.fish +++ b/conf.d/abbr_tips.fish @@ -53,12 +53,9 @@ function __abbr_tips --on-event fish_postexec -d "Abbreviation reminder for the argparse --name alias --ignore-unknown s/save -- $command if string match -q '*=*' -- "$argv[2]" - if test (count $argv) = 2 - set command_split (string split '=' -- $argv[2]) - set alias_key "a__$command_split[1]" - set alias_value $command_split[2] - set -a alias_value $command[3..-1] - end + set command_split (string split '=' -- $argv[2]) + set alias_key "a__$command_split[1]" + set alias_value $command_split[2..-1] else set alias_key "a__$argv[2]" set alias_value $argv[3..-1] diff --git a/test/fish-abbreviation-tips.fish b/test/fish-abbreviation-tips.fish index 4df19f8..ae3da63 100644 --- a/test/fish-abbreviation-tips.fish +++ b/test/fish-abbreviation-tips.fish @@ -134,16 +134,27 @@ setup @test "add alias tip value with =" ( clear_test_var - __abbr_tips 'alias __abbr_test_alias=grep"' + __abbr_tips 'alias __abbr_test_alias=grep' contains "grep" $__ABBR_TIPS_VALUES ) "$status" = 0 @test "add alias tip key with =" ( clear_test_var - __abbr_tips 'alias __abbr_test_alias=grep"' + __abbr_tips 'alias __abbr_test_alias=grep' contains "a____abbr_test_alias" $__ABBR_TIPS_KEYS ) "$status" = 0 +@test "add alias tip value with = and quotes" ( + clear_test_var + __abbr_tips 'alias __abbr_test_alias="grep "' + contains "grep" $__ABBR_TIPS_VALUES +) "$status" = 0 + +@test "add alias tip key with = and quotes" ( + clear_test_var + __abbr_tips 'alias __abbr_test_alias="grep "' + contains "a____abbr_test_alias" $__ABBR_TIPS_KEYS +) "$status" = 0 # Remove alias @test "remove alias tip key" ( From 39caf113ab17221af9a77dc26abcc61e449fd215 Mon Sep 17 00:00:00 2001 From: gazorby Date: Mon, 23 Jan 2023 08:55:52 +0100 Subject: [PATCH 05/10] =?UTF-8?q?=E2=9C=85=20test:=20reorganize=20unit=20t?= =?UTF-8?q?ests?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .github/workflows/tests.yml | 2 +- test/fish-abbreviation-tips.fish | 205 ------------------------------- tests/common.fish | 32 +++++ tests/test_abbr.fish | 59 +++++++++ tests/test_alias.fish | 70 +++++++++++ tests/test_init.fish | 22 ++++ tests/test_tips.fish | 35 ++++++ 7 files changed, 219 insertions(+), 206 deletions(-) delete mode 100644 test/fish-abbreviation-tips.fish create mode 100644 tests/common.fish create mode 100644 tests/test_abbr.fish create mode 100644 tests/test_alias.fish create mode 100644 tests/test_init.fish create mode 100644 tests/test_tips.fish diff --git a/.github/workflows/tests.yml b/.github/workflows/tests.yml index ca16781..5d98b36 100644 --- a/.github/workflows/tests.yml +++ b/.github/workflows/tests.yml @@ -39,4 +39,4 @@ jobs: - name: Run tests run: | fish -c "fisher install jorgebucaran/fishtape; and fisher install ." - fish -c "fishtape test/*.fish" + fish -c "fishtape tests/*.fish" diff --git a/test/fish-abbreviation-tips.fish b/test/fish-abbreviation-tips.fish deleted file mode 100644 index ae3da63..0000000 --- a/test/fish-abbreviation-tips.fish +++ /dev/null @@ -1,205 +0,0 @@ -# Use with jorgebucaran/fishtape to run tests -# i.e. fishtape test/fish-abbreviation-tips.fish - -function setup - # Source plugin - source functions/__abbr_tips_init.fish - source conf.d/abbr_tips.fish - source functions/__abbr_tips_bind_newline.fish - source functions/__abbr_tips_bind_space.fish - # Backup settings variables - set -g tmp_keys $__ABBR_TIPS_KEYS - set -g tmp_values $__ABBR_TIPS_VALUES - set -g tmp_tips_prompt $ABBR_TIPS_PROMPT - set -g ABBR_TIPS_PROMPT "{{ .abbr }} => {{ .cmd }}" -end - -function teardown - # Restore variables - set __ABBR_TIPS_KEYS $tmp_keys - set __ABBR_TIPS_VALUES $tmp_values - set ABBR_TIPS_PROMPT "$tmp_tips_prompt" -end - -function clear_test_var - # Clear variables to prevent the results - # of each unit test from affecting each other - set -g __ABBR_TIPS_KEYS - set -g __ABBR_TIPS_VALUES - abbr -e __abbr_test - abbr -e __abbr_test_one - abbr -e __abbr_test_two -end - -setup - -# Tests - -# Initialization -@test "initial tip key" ( - clear_test_var - abbr -a __abbr_test ps - set -e __ABBR_TIPS_KEYS - __abbr_tips_init - contains "__abbr_test" $__ABBR_TIPS_KEYS -) "$status" = 0 - -@test "initial tip value" ( - clear_test_var - abbr -a __abbr_test ps - set -e __ABBR_TIPS_VALUES - __abbr_tips_init - contains "ps" $__ABBR_TIPS_VALUES -) "$status" = 0 - - -# Add abbreviation -@test "add abbreviation tip key" ( - clear_test_var - __abbr_tips 'abbr -a __abbr_test grep -q' - contains "__abbr_test" $__ABBR_TIPS_KEYS -) "$status" = 0 - -@test "add abbreviation tip value" ( - clear_test_var - __abbr_tips 'abbr -a __abbr_test grep -q' - contains "grep -q" $__ABBR_TIPS_VALUES -) "$status" = 0 - -@test "add abbreviation tip key with simple quotes" ( - clear_test_var - __abbr_tips 'abbr -a __abbr_test \'grep -q\'' - contains "__abbr_test" $__ABBR_TIPS_KEYS -) "$status" = 0 - -@test "add abbreviation tip value with simple quotes" ( - clear_test_var - __abbr_tips 'abbr -a __abbr_test \'grep -q\'' - contains "grep -q" $__ABBR_TIPS_VALUES -) "$status" = 0 - -@test "add abbreviation tip key with double quotes" ( - clear_test_var - __abbr_tips 'abbr -a __abbr_test "grep -q"' - contains "__abbr_test" $__ABBR_TIPS_KEYS -) "$status" = 0 - -@test "add abbreviation tip value with double quotes" ( - clear_test_var - __abbr_tips 'abbr -a __abbr_test "grep -q"' - contains "grep -q" $__ABBR_TIPS_VALUES -) "$status" = 0 - - -# Remove abbreviation -@test "remove abbreviation tip key" ( - clear_test_var - __abbr_tips 'abbr -a __abbr_test ps' - __abbr_tips 'abbr -e __abbr_test' - not contains "__abbr_test" $__ABBR_TIPS_KEYS -) "$status" = 0 - -@test "remove abbreviation tip value" ( - clear_test_var - __abbr_tips 'abbr -a __abbr_test ps' - __abbr_tips 'abbr -e __abbr_test' - not contains "ps" $__ABBR_TIPS_VALUES -) "$status" = 0 - - -# Add alias -@test "add alias tip key simple quotes" ( - clear_test_var - __abbr_tips 'alias __abbr_test_alias \'grep -q\'' - contains "a____abbr_test_alias" $__ABBR_TIPS_KEYS -) "$status" = 0 - -@test "add alias tip value simple quotes" ( - clear_test_var - __abbr_tips 'alias __abbr_test_alias \'grep -q\'' - contains "grep -q" $__ABBR_TIPS_VALUES -) "$status" = 0 - -@test "add alias tip key double quotes" ( - clear_test_var - __abbr_tips 'alias __abbr_test_alias "grep -q"' - contains "a____abbr_test_alias" $__ABBR_TIPS_KEYS -) "$status" = 0 - -@test "add alias tip value double quotes" ( - clear_test_var - __abbr_tips 'alias __abbr_test_alias "grep -q"' - contains "grep -q" $__ABBR_TIPS_VALUES -) "$status" = 0 - -@test "add alias tip value with =" ( - clear_test_var - __abbr_tips 'alias __abbr_test_alias=grep' - contains "grep" $__ABBR_TIPS_VALUES -) "$status" = 0 - -@test "add alias tip key with =" ( - clear_test_var - __abbr_tips 'alias __abbr_test_alias=grep' - contains "a____abbr_test_alias" $__ABBR_TIPS_KEYS -) "$status" = 0 - -@test "add alias tip value with = and quotes" ( - clear_test_var - __abbr_tips 'alias __abbr_test_alias="grep "' - contains "grep" $__ABBR_TIPS_VALUES -) "$status" = 0 - -@test "add alias tip key with = and quotes" ( - clear_test_var - __abbr_tips 'alias __abbr_test_alias="grep "' - contains "a____abbr_test_alias" $__ABBR_TIPS_KEYS -) "$status" = 0 - -# Remove alias -@test "remove alias tip key" ( - clear_test_var - __abbr_tips 'alias __abbr_test_alias "grep -q"' - __abbr_tips 'functions --erase __abbr_test_alias' - not contains "a____abbr_test_alias" $__ABBR_TIPS_KEYS -) "$status" = 0 - -@test "remove alias tip value" ( - clear_test_var - __abbr_tips 'alias __abbr_test_alias "grep -q"' - __abbr_tips 'functions --erase __abbr_test_alias' - not contains "grep -q" $__ABBR_TIPS_VALUES -) "$status" = 0 - - -# Test tip -@test "abbreviation tip match" ( - clear_test_var - __abbr_tips 'abbr -a __abbr_test ps' - echo (__abbr_tips 'ps') -) = "__abbr_test => ps" - -@test "alias tip match" ( - clear_test_var - alias __abbr_test_alias "grep -q" - __abbr_tips 'alias __abbr_test_alias "grep -q"' - echo (__abbr_tips 'grep -q') -) = "__abbr_test_alias => grep -q" - -@test "multiple abbreviation tip match" ( - clear_test_var - abbr -a __abbr_test_one ps - abbr -a __abbr_test_two "grep -q" - __abbr_tips_init - echo (__abbr_tips 'grep -q') -) = "__abbr_test_two => grep -q" - -@test "multiple alias tip match" ( - clear_test_var - alias abbr_test_alias_one ps - alias abbr_test_alias_two "grep -q" - __abbr_tips_init - echo (__abbr_tips 'grep -q') -) = "abbr_test_alias_two => grep -q" - -teardown diff --git a/tests/common.fish b/tests/common.fish new file mode 100644 index 0000000..9bc7161 --- /dev/null +++ b/tests/common.fish @@ -0,0 +1,32 @@ +# Use with jorgebucaran/fishtape to run tests +# i.e. fishtape test/fish-abbreviation-tips.fish + +function setup + # Source plugin + source functions/__abbr_tips_init.fish + source conf.d/abbr_tips.fish + source functions/__abbr_tips_bind_newline.fish + source functions/__abbr_tips_bind_space.fish + # Backup settings variables + set -g tmp_keys $__ABBR_TIPS_KEYS + set -g tmp_values $__ABBR_TIPS_VALUES + set -g tmp_tips_prompt $ABBR_TIPS_PROMPT + set -g ABBR_TIPS_PROMPT "{{ .abbr }} => {{ .cmd }}" +end + +function teardown + # Restore variables + set __ABBR_TIPS_KEYS $tmp_keys + set __ABBR_TIPS_VALUES $tmp_values + set ABBR_TIPS_PROMPT "$tmp_tips_prompt" +end + +function clear_test_var + # Clear variables to prevent the results + # of each unit test from affecting each other + set -g __ABBR_TIPS_KEYS + set -g __ABBR_TIPS_VALUES + abbr -e __abbr_test + abbr -e __abbr_test_one + abbr -e __abbr_test_two +end \ No newline at end of file diff --git a/tests/test_abbr.fish b/tests/test_abbr.fish new file mode 100644 index 0000000..8d38228 --- /dev/null +++ b/tests/test_abbr.fish @@ -0,0 +1,59 @@ +source (string join "/" (dirname (status --current-filename)) "common.fish") + +setup + +# Add abbreviation +@test "add abbreviation tip key" ( + clear_test_var + __abbr_tips 'abbr -a __abbr_test grep -q' + contains "__abbr_test" $__ABBR_TIPS_KEYS +) "$status" = 0 + +@test "add abbreviation tip value" ( + clear_test_var + __abbr_tips 'abbr -a __abbr_test grep -q' + contains "grep -q" $__ABBR_TIPS_VALUES +) "$status" = 0 + +@test "add abbreviation tip key with simple quotes" ( + clear_test_var + __abbr_tips 'abbr -a __abbr_test \'grep -q\'' + contains "__abbr_test" $__ABBR_TIPS_KEYS +) "$status" = 0 + +@test "add abbreviation tip value with simple quotes" ( + clear_test_var + __abbr_tips 'abbr -a __abbr_test \'grep -q\'' + contains "grep -q" $__ABBR_TIPS_VALUES +) "$status" = 0 + +@test "add abbreviation tip key with double quotes" ( + clear_test_var + __abbr_tips 'abbr -a __abbr_test "grep -q"' + contains "__abbr_test" $__ABBR_TIPS_KEYS +) "$status" = 0 + +@test "add abbreviation tip value with double quotes" ( + clear_test_var + __abbr_tips 'abbr -a __abbr_test "grep -q"' + contains "grep -q" $__ABBR_TIPS_VALUES +) "$status" = 0 + + +# Remove abbreviation +@test "remove abbreviation tip key" ( + clear_test_var + __abbr_tips 'abbr -a __abbr_test ps' + __abbr_tips 'abbr -e __abbr_test' + not contains "__abbr_test" $__ABBR_TIPS_KEYS +) "$status" = 0 + +@test "remove abbreviation tip value" ( + clear_test_var + __abbr_tips 'abbr -a __abbr_test ps' + __abbr_tips 'abbr -e __abbr_test' + not contains "ps" $__ABBR_TIPS_VALUES +) "$status" = 0 + + +teardown diff --git a/tests/test_alias.fish b/tests/test_alias.fish new file mode 100644 index 0000000..bd5a9be --- /dev/null +++ b/tests/test_alias.fish @@ -0,0 +1,70 @@ +source (string join "/" (dirname (status --current-filename)) "common.fish") + +setup + +# Add alias +@test "add alias tip key simple quotes" ( + clear_test_var + __abbr_tips 'alias __abbr_test_alias \'grep -q\'' + contains "a____abbr_test_alias" $__ABBR_TIPS_KEYS +) "$status" = 0 + +@test "add alias tip value simple quotes" ( + clear_test_var + __abbr_tips 'alias __abbr_test_alias \'grep -q\'' + contains "grep -q" $__ABBR_TIPS_VALUES +) "$status" = 0 + +@test "add alias tip key double quotes" ( + clear_test_var + __abbr_tips 'alias __abbr_test_alias "grep -q"' + contains "a____abbr_test_alias" $__ABBR_TIPS_KEYS +) "$status" = 0 + +@test "add alias tip value double quotes" ( + clear_test_var + __abbr_tips 'alias __abbr_test_alias "grep -q"' + contains "grep -q" $__ABBR_TIPS_VALUES +) "$status" = 0 + +@test "add alias tip value with =" ( + clear_test_var + __abbr_tips 'alias __abbr_test_alias=grep' + contains "grep" $__ABBR_TIPS_VALUES +) "$status" = 0 + +@test "add alias tip key with =" ( + clear_test_var + __abbr_tips 'alias __abbr_test_alias=grep' + contains "a____abbr_test_alias" $__ABBR_TIPS_KEYS +) "$status" = 0 + +@test "add alias tip value with = and quotes" ( + clear_test_var + __abbr_tips 'alias __abbr_test_alias="grep "' + contains "grep" $__ABBR_TIPS_VALUES +) "$status" = 0 + +@test "add alias tip key with = and quotes" ( + clear_test_var + __abbr_tips 'alias __abbr_test_alias="grep "' + contains "a____abbr_test_alias" $__ABBR_TIPS_KEYS +) "$status" = 0 + +# Remove alias +@test "remove alias tip key" ( + clear_test_var + __abbr_tips 'alias __abbr_test_alias "grep -q"' + __abbr_tips 'functions --erase __abbr_test_alias' + not contains "a____abbr_test_alias" $__ABBR_TIPS_KEYS +) "$status" = 0 + +@test "remove alias tip value" ( + clear_test_var + __abbr_tips 'alias __abbr_test_alias "grep -q"' + __abbr_tips 'functions --erase __abbr_test_alias' + not contains "grep -q" $__ABBR_TIPS_VALUES +) "$status" = 0 + + +teardown diff --git a/tests/test_init.fish b/tests/test_init.fish new file mode 100644 index 0000000..3b52b92 --- /dev/null +++ b/tests/test_init.fish @@ -0,0 +1,22 @@ +source (string join "/" (dirname (status --current-filename)) "common.fish") + +setup + +# Initialization +@test "initial tip key" ( + clear_test_var + abbr -a __abbr_test ps + set -e __ABBR_TIPS_KEYS + __abbr_tips_init + contains "__abbr_test" $__ABBR_TIPS_KEYS +) "$status" = 0 + +@test "initial tip value" ( + clear_test_var + abbr -a __abbr_test ps + set -e __ABBR_TIPS_VALUES + __abbr_tips_init + contains "ps" $__ABBR_TIPS_VALUES +) "$status" = 0 + +teardown diff --git a/tests/test_tips.fish b/tests/test_tips.fish new file mode 100644 index 0000000..11f6e7f --- /dev/null +++ b/tests/test_tips.fish @@ -0,0 +1,35 @@ +source (string join "/" (dirname (status --current-filename)) "common.fish") + +setup + +# Test tip +@test "abbreviation tip match" ( + clear_test_var + __abbr_tips 'abbr -a __abbr_test ps' + echo (__abbr_tips 'ps') +) = "__abbr_test => ps" + +@test "alias tip match" ( + clear_test_var + alias __abbr_test_alias "grep -q" + __abbr_tips 'alias __abbr_test_alias "grep -q"' + echo (__abbr_tips 'grep -q') +) = "__abbr_test_alias => grep -q" + +@test "multiple abbreviation tip match" ( + clear_test_var + abbr -a __abbr_test_one ps + abbr -a __abbr_test_two "grep -q" + __abbr_tips_init + echo (__abbr_tips 'grep -q') +) = "__abbr_test_two => grep -q" + +@test "multiple alias tip match" ( + clear_test_var + alias abbr_test_alias_one ps + alias abbr_test_alias_two "grep -q" + __abbr_tips_init + echo (__abbr_tips 'grep -q') +) = "abbr_test_alias_two => grep -q" + +teardown From b7a7c8f58853ab31df537ca7787b69e6ff4e45ff Mon Sep 17 00:00:00 2001 From: gazorby Date: Mon, 23 Jan 2023 15:07:05 +0100 Subject: [PATCH 06/10] =?UTF-8?q?=F0=9F=91=B7=20build:=20add=20pre-commit?= =?UTF-8?q?=20configuration?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .github/ISSUE_TEMPLATE/ask_question.md | 5 ++- .github/ISSUE_TEMPLATE/bug_report.md | 8 ++--- .github/ISSUE_TEMPLATE/feature_request.md | 5 ++- .pre-commit-config.yaml | 27 ++++++++++++++++ CHANGELOG.md | 39 ++++++++++++----------- CONTRIBUTING.md | 1 + README.md | 3 +- tests/common.fish | 2 +- 8 files changed, 60 insertions(+), 30 deletions(-) create mode 100644 .pre-commit-config.yaml diff --git a/.github/ISSUE_TEMPLATE/ask_question.md b/.github/ISSUE_TEMPLATE/ask_question.md index bf31a5e..5385b4f 100644 --- a/.github/ISSUE_TEMPLATE/ask_question.md +++ b/.github/ISSUE_TEMPLATE/ask_question.md @@ -1,10 +1,9 @@ --- name: Question about: Ask a question. -title: '' +title: "" labels: question -assignees: '' - +assignees: "" --- **Question** diff --git a/.github/ISSUE_TEMPLATE/bug_report.md b/.github/ISSUE_TEMPLATE/bug_report.md index 0b9badc..d23c653 100644 --- a/.github/ISSUE_TEMPLATE/bug_report.md +++ b/.github/ISSUE_TEMPLATE/bug_report.md @@ -1,10 +1,9 @@ --- name: Bug report about: Create a report to help us improve -title: '' +title: "" labels: bug assignees: Gazorby - --- **Describe the bug** @@ -20,8 +19,9 @@ A clear and concise description of what you expected to happen. If applicable, add screenshots to help explain your problem. **System (please complete the following information):** - - fish version - - Distribution `cat /etc/os-release` + +- fish version +- Distribution `cat /etc/os-release` **Additional context** Add any other context about the problem here. diff --git a/.github/ISSUE_TEMPLATE/feature_request.md b/.github/ISSUE_TEMPLATE/feature_request.md index 11fc491..d883b8f 100644 --- a/.github/ISSUE_TEMPLATE/feature_request.md +++ b/.github/ISSUE_TEMPLATE/feature_request.md @@ -1,10 +1,9 @@ --- name: Feature request about: Suggest an idea for this project -title: '' +title: "" labels: enhancement -assignees: '' - +assignees: "" --- **Is your feature request related to a problem? Please describe.** diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml new file mode 100644 index 0000000..bc046c0 --- /dev/null +++ b/.pre-commit-config.yaml @@ -0,0 +1,27 @@ +repos: + - repo: https://github.com/pre-commit/pre-commit-hooks + rev: v4.3.0 + hooks: + - id: check-toml + - id: mixed-line-ending + - id: check-case-conflict + - id: check-merge-conflict + - id: check-docstring-first + - id: check-added-large-files + - id: check-executables-have-shebangs + - id: debug-statements + - id: end-of-file-fixer + - id: fix-byte-order-marker + - id: trailing-whitespace + + - repo: https://github.com/hugoh/pre-commit-fish.git + rev: v1.2 + hooks: + - id: fish_syntax + - id: fish_indent + + - repo: https://github.com/pre-commit/mirrors-prettier + rev: "v2.7.1" + hooks: + - id: prettier + types: [markdown] diff --git a/CHANGELOG.md b/CHANGELOG.md index db86096..b2a32e8 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,50 +1,53 @@ ## 0.5.1 (2020-05-12) -- ā™»ļø ref: prefix with '__' for private scope + +- ā™»ļø ref: prefix with '\_\_' for private scope - šŸ› fix(regex): don't treat '-' as a word separator ## 0.5.0 (2020-05-12) + - āœØ feat: customize regexes - ā™»ļø ref: use verbose conditional operators ## 0.4.0 (2020-04-20) + - āš” perf: update abbreviations list incrementally # [0.3.1](https://github.com/Gazorby/abbr-tips/compare/v0.3.0...v0.3.1) (2020-04-17) ### šŸ› Bug Fixes -* fix: test variable existence instead of value ([f33cf23](https://github.com/Gazorby/abbr-tips/commit/f33cf23)) -* fix: update function to erase on uninstall ([ba239d1](https://github.com/Gazorby/abbr-tips/commit/ba239d1)) +- fix: test variable existence instead of value ([f33cf23](https://github.com/Gazorby/abbr-tips/commit/f33cf23)) +- fix: update function to erase on uninstall ([ba239d1](https://github.com/Gazorby/abbr-tips/commit/ba239d1)) # [0.3.0](https://github.com/Gazorby/abbr-tips/compare/v0.2.0...v0.3.0) (2020-04-16) ### ā™»ļø Refactor -* refactor: remove flock dependency ([376072d](https://github.com/Gazorby/abbr-tips/commit/376072d)) +- refactor: remove flock dependency ([376072d](https://github.com/Gazorby/abbr-tips/commit/376072d)) # [0.2.0](https://github.com/Gazorby/abbr-tips/compare/v0.1.0...v0.2.0) (2020-04-13) ### šŸ› Bug Fixes -* fix: don't use universal scope by default ([832691a](https://github.com/Gazorby/abbr-tips/commit/832691a)) -* fix: erase functions on uninstall ([cd1a75a](https://github.com/Gazorby/abbr-tips/commit/cd1a75a)) -* fix: fix uninstall function ([b58971f](https://github.com/Gazorby/abbr-tips/commit/b58971f)) -* fix: still need univresal scope for abbr lists ([6a700a0](https://github.com/Gazorby/abbr-tips/commit/6a700a0)) +- fix: don't use universal scope by default ([832691a](https://github.com/Gazorby/abbr-tips/commit/832691a)) +- fix: erase functions on uninstall ([cd1a75a](https://github.com/Gazorby/abbr-tips/commit/cd1a75a)) +- fix: fix uninstall function ([b58971f](https://github.com/Gazorby/abbr-tips/commit/b58971f)) +- fix: still need univresal scope for abbr lists ([6a700a0](https://github.com/Gazorby/abbr-tips/commit/6a700a0)) # [0.1.0](https://github.com/Gazorby/abbr-tips/compare/f5ab8ed...v0.1.0) (2020-04-13) ### āœØ Features -* feat: customize tips prompt ([ae29fca](https://github.com/Gazorby/abbr-tips/commit/ae29fca)) -* feat: customize tips update mode ([4681009](https://github.com/Gazorby/abbr-tips/commit/4681009)) -* feat: don't show tips if an abbr was used ([5f2e6ac](https://github.com/Gazorby/abbr-tips/commit/5f2e6ac)) -* feat: prettier tips ([f5ab8ed](https://github.com/Gazorby/abbr-tips/commit/f5ab8ed)) +- feat: customize tips prompt ([ae29fca](https://github.com/Gazorby/abbr-tips/commit/ae29fca)) +- feat: customize tips update mode ([4681009](https://github.com/Gazorby/abbr-tips/commit/4681009)) +- feat: don't show tips if an abbr was used ([5f2e6ac](https://github.com/Gazorby/abbr-tips/commit/5f2e6ac)) +- feat: prettier tips ([f5ab8ed](https://github.com/Gazorby/abbr-tips/commit/f5ab8ed)) ### šŸ› Bug Fixes -* fix: check for abbr status in on whitespace input ([421ede5](https://github.com/Gazorby/abbr-tips/commit/421ede5)) -* fix: delete keybindings when uninstalling ([11ce0ae](https://github.com/Gazorby/abbr-tips/commit/11ce0ae)) -* fix: don't show tips if abbr was used and options added ([a2b5214](https://github.com/Gazorby/abbr-tips/commit/a2b5214)) -* fix: prompt variable not properly set ([1cc43e0](https://github.com/Gazorby/abbr-tips/commit/1cc43e0)) -* fix: properly resetting abbr status ([59e90e2](https://github.com/Gazorby/abbr-tips/commit/59e90e2)) -* fix: reset abbr status after displaying tip ([46c70c1](https://github.com/Gazorby/abbr-tips/commit/46c70c1)) +- fix: check for abbr status in on whitespace input ([421ede5](https://github.com/Gazorby/abbr-tips/commit/421ede5)) +- fix: delete keybindings when uninstalling ([11ce0ae](https://github.com/Gazorby/abbr-tips/commit/11ce0ae)) +- fix: don't show tips if abbr was used and options added ([a2b5214](https://github.com/Gazorby/abbr-tips/commit/a2b5214)) +- fix: prompt variable not properly set ([1cc43e0](https://github.com/Gazorby/abbr-tips/commit/1cc43e0)) +- fix: properly resetting abbr status ([59e90e2](https://github.com/Gazorby/abbr-tips/commit/59e90e2)) +- fix: reset abbr status after displaying tip ([46c70c1](https://github.com/Gazorby/abbr-tips/commit/46c70c1)) diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index ed591bb..c4ed673 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -22,5 +22,6 @@ You can use (and enhance!) scripts in `test` folder to test your code. You need ## IDE If you are using Visual Studio Code, i recommend these extensions : + - [fish-vscode](https://marketplace.visualstudio.com/items?itemName=skyapps.fish-vscode) for syntax highlighting - [fish-ide](https://marketplace.visualstudio.com/items?itemName=lunaryorn.fish-ide) for syntax errors checking diff --git a/README.md b/README.md index db86613..baf973b 100644 --- a/README.md +++ b/README.md @@ -82,7 +82,7 @@ gcm => git commit -m So you want a tip when typing `git commit -m "my commit"`, but the command doesn't match exactly `git commit -m`. To tackle this, we have a default regex that will match commands with arguments removed, so your `git commit -m "my commit"` will be tested as `git commit -m`. -You can add such regexes to the `ABBR_TIPS_REGEXES` list, and they will be tested in the order in which they have been added (see [default configuration](#default-configuration)). Matching is lazy, so if the string extracted with the first regex matches an abbreviation/alias, it won't go further. Remember that only the *first matching group* will be tested. (so you must have at least one per regex) +You can add such regexes to the `ABBR_TIPS_REGEXES` list, and they will be tested in the order in which they have been added (see [default configuration](#default-configuration)). Matching is lazy, so if the string extracted with the first regex matches an abbreviation/alias, it won't go further. Remember that only the _first matching group_ will be tested. (so you must have at least one per regex) ## šŸŽ„ Behind the scenes @@ -95,4 +95,5 @@ The plugin will create lists once during installation by calling `__abbr_tips_in Inspired by [zsh-fast-alias-tips](https://github.com/sei40kr/zsh-fast-alias-tips) and [alias-tips](https://github.com/djui/alias-tips) zsh plugins ## šŸ“ License + [MIT](https://github.com/Gazorby/fish-abbreviation-tips/blob/master/LICENSE) diff --git a/tests/common.fish b/tests/common.fish index 9bc7161..020782d 100644 --- a/tests/common.fish +++ b/tests/common.fish @@ -29,4 +29,4 @@ function clear_test_var abbr -e __abbr_test abbr -e __abbr_test_one abbr -e __abbr_test_two -end \ No newline at end of file +end From 2fd45a716464de687c0c2efb5daebf381b05858e Mon Sep 17 00:00:00 2001 From: gazorby Date: Mon, 23 Jan 2023 15:08:34 +0100 Subject: [PATCH 07/10] =?UTF-8?q?=F0=9F=91=B7=20build:=20update=20ci=20wor?= =?UTF-8?q?kflow?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .github/workflows/ci.yml | 70 +++++++++++++++++++++++++++++++++++++ .github/workflows/tests.yml | 42 ---------------------- 2 files changed, 70 insertions(+), 42 deletions(-) create mode 100644 .github/workflows/ci.yml delete mode 100644 .github/workflows/tests.yml diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml new file mode 100644 index 0000000..120ea43 --- /dev/null +++ b/.github/workflows/ci.yml @@ -0,0 +1,70 @@ +# From https://github.com/PatrickF1/fzf.fish/blob/a79dc7510d02f25360c2f30e50287abd0766a588/.github/workflows/continuous_integration.yml + +name: CI + +on: + push: + branches: [main] + pull_request: + + # Allows you to run this workflow manually from the Actions tab + workflow_dispatch: + +jobs: + tests: + runs-on: ${{ matrix.os }} + strategy: + matrix: + os: [macos-latest, ubuntu-latest] + + steps: + - uses: actions/checkout@v3 + - uses: fish-actions/install-fish@v1.1.0 + + - uses: fish-actions/fisher@v1 + with: + plugins: jorgebucaran/fishtape ilancosman/clownfish $GITHUB_WORKSPACE + + - name: Set up Homebrew + uses: Homebrew/actions/setup-homebrew@master + # Homebrew is only missing from ubuntu images per https://github.com/actions/runner-images/issues/6283 + if: matrix.os == 'ubuntu-latest' + + - name: Install fzf and fd + run: brew install fzf fd + + - name: Run full test suite + run: fishtape tests/*.fish + shell: fish {0} + # timeout in case tests get stuck on fzf + timeout-minutes: 3 + + syntax-check: + runs-on: ubuntu-latest + + steps: + - uses: actions/checkout@v3 + + - uses: fish-actions/install-fish@v1 + + - uses: fish-actions/syntax-check@v1 + + # check Fish format + format-check: + runs-on: ubuntu-latest + + steps: + - uses: actions/checkout@v3 + + - uses: fish-actions/install-fish@v1 + + - uses: fish-actions/format-check@v1 + + # check Markdown and Yaml format + prettier: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v3 + - uses: actionsx/prettier@v2 + with: + args: --check . diff --git a/.github/workflows/tests.yml b/.github/workflows/tests.yml deleted file mode 100644 index 5d98b36..0000000 --- a/.github/workflows/tests.yml +++ /dev/null @@ -1,42 +0,0 @@ -# This is a basic workflow to help you get started with Actions - -name: CI - -# Controls when the action will run. Triggers the workflow on push or pull request -# events but only for the master branch -on: - push: - branches: [ master ] - pull_request: - branches: [ master ] - -# A workflow run is made up of one or more jobs that can run sequentially or in parallel -jobs: - # This workflow contains a single job called "build" - build: - # The type of runner that the job will run on - runs-on: ubuntu-latest - - # Steps represent a sequence of tasks that will be executed as part of the job - steps: - # Checks-out your repository under $GITHUB_WORKSPACE, so your job can access it - - name: Checkout - uses: actions/checkout@v2 - - # Runs a set of commands using the runners shell - - name: Install fish - run: | - sudo add-apt-repository ppa:fish-shell/release-3 - sudo apt-get update - sudo apt-get -y install fish - - - name: Install fisher - run: | - fish --version - fish -c "curl -sL git.io/fisher | source && fisher install jorgebucaran/fisher" - - # Runs a single command using the runners shell - - name: Run tests - run: | - fish -c "fisher install jorgebucaran/fishtape; and fisher install ." - fish -c "fishtape tests/*.fish" From d51ad2ad7192305a1c7f602a9ed75842c70c9e7e Mon Sep 17 00:00:00 2001 From: gazorby Date: Mon, 23 Jan 2023 15:17:31 +0100 Subject: [PATCH 08/10] =?UTF-8?q?=F0=9F=91=B7=20build:=20update=20ci=20wor?= =?UTF-8?q?kflow?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .github/workflows/ci.yml | 29 +++++++++---------------- functions/__abbr_tips_bind_newline.fish | 2 +- functions/__abbr_tips_bind_space.fish | 2 +- 3 files changed, 12 insertions(+), 21 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 120ea43..7e92954 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -1,5 +1,3 @@ -# From https://github.com/PatrickF1/fzf.fish/blob/a79dc7510d02f25360c2f30e50287abd0766a588/.github/workflows/continuous_integration.yml - name: CI on: @@ -21,23 +19,16 @@ jobs: - uses: actions/checkout@v3 - uses: fish-actions/install-fish@v1.1.0 - - uses: fish-actions/fisher@v1 + - name: Install abbreviation-tips with Fisher + uses: fish-shop/install-plugin@v1 with: - plugins: jorgebucaran/fishtape ilancosman/clownfish $GITHUB_WORKSPACE - - - name: Set up Homebrew - uses: Homebrew/actions/setup-homebrew@master - # Homebrew is only missing from ubuntu images per https://github.com/actions/runner-images/issues/6283 - if: matrix.os == 'ubuntu-latest' + plugin-manager: fisher + plugins: gazorby/fish-abbrevation-tips - - name: Install fzf and fd - run: brew install fzf fd - - - name: Run full test suite - run: fishtape tests/*.fish - shell: fish {0} - # timeout in case tests get stuck on fzf - timeout-minutes: 3 + - name: Run Fishtape tests + uses: fish-shop/run-fishtape-tests@v1 + with: + pattern: tests/**.fish syntax-check: runs-on: ubuntu-latest @@ -49,7 +40,7 @@ jobs: - uses: fish-actions/syntax-check@v1 - # check Fish format + # Check Fish format format-check: runs-on: ubuntu-latest @@ -60,7 +51,7 @@ jobs: - uses: fish-actions/format-check@v1 - # check Markdown and Yaml format + # Check Markdown and Yaml format prettier: runs-on: ubuntu-latest steps: diff --git a/functions/__abbr_tips_bind_newline.fish b/functions/__abbr_tips_bind_newline.fish index 8cc8992..6d91aeb 100644 --- a/functions/__abbr_tips_bind_newline.fish +++ b/functions/__abbr_tips_bind_newline.fish @@ -6,5 +6,5 @@ function __abbr_tips_bind_newline set -g __abbr_tips_used 0 end end - commandline -f 'execute' + commandline -f execute end diff --git a/functions/__abbr_tips_bind_space.fish b/functions/__abbr_tips_bind_space.fish index 0f37103..e83caf6 100644 --- a/functions/__abbr_tips_bind_space.fish +++ b/functions/__abbr_tips_bind_space.fish @@ -7,5 +7,5 @@ function __abbr_tips_bind_space set -g __abbr_tips_used 0 end end - commandline -f 'expand-abbr' + commandline -f expand-abbr end From 2fd7e50daeabc6fc92268234ec22b5dba943069e Mon Sep 17 00:00:00 2001 From: gazorby Date: Mon, 23 Jan 2023 15:19:20 +0100 Subject: [PATCH 09/10] =?UTF-8?q?=F0=9F=91=B7=20build(ci):=20fix=20typo?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .github/workflows/ci.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 7e92954..ed857fd 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -23,7 +23,7 @@ jobs: uses: fish-shop/install-plugin@v1 with: plugin-manager: fisher - plugins: gazorby/fish-abbrevation-tips + plugins: gazorby/fish-abbreviation-tips - name: Run Fishtape tests uses: fish-shop/run-fishtape-tests@v1 From aadfd86c771bd8b02d419c2830e045f2a3d32c5b Mon Sep 17 00:00:00 2001 From: gazorby Date: Mon, 23 Jan 2023 16:25:00 +0100 Subject: [PATCH 10/10] =?UTF-8?q?=E2=9C=85=20test:=20add=20tests=20for=20p?= =?UTF-8?q?lugin=20update?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- tests/common.fish | 1 + .../{test_init.fish => test_plugin_init.fish} | 0 tests/test_plugin_update.fish | 44 +++++++++++++++++++ 3 files changed, 45 insertions(+) rename tests/{test_init.fish => test_plugin_init.fish} (100%) create mode 100644 tests/test_plugin_update.fish diff --git a/tests/common.fish b/tests/common.fish index 020782d..f182a71 100644 --- a/tests/common.fish +++ b/tests/common.fish @@ -4,6 +4,7 @@ function setup # Source plugin source functions/__abbr_tips_init.fish + source functions/__abbr_tips_clean.fish source conf.d/abbr_tips.fish source functions/__abbr_tips_bind_newline.fish source functions/__abbr_tips_bind_space.fish diff --git a/tests/test_init.fish b/tests/test_plugin_init.fish similarity index 100% rename from tests/test_init.fish rename to tests/test_plugin_init.fish diff --git a/tests/test_plugin_update.fish b/tests/test_plugin_update.fish new file mode 100644 index 0000000..b0dec2f --- /dev/null +++ b/tests/test_plugin_update.fish @@ -0,0 +1,44 @@ +source (string join "/" (dirname (status --current-filename)) "common.fish") + +# Test that plugin update reset tip keys + +setup + +@test "plugin update __ABBR_TIPS_KEYS length" ( + set len_keys (count $__ABBR_TIPS_KEYS) + set -a __ABBR_TIPS_KEYS __wrong_key + __abbr_tips_update + test (count $__ABBR_TIPS_KEYS) -eq $len_keys +) "$status" = 0 + +setup + +@test "plugin update __ABBR_TIPS_KEYS value" ( + set last_key "$__ABBR_TIPS_KEYS[-1]" + set -a __ABBR_TIPS_KEYS __wrong_key + __abbr_tips_update + test "$__ABBR_TIPS_KEYS[-1]" = "$last_key" +) "$status" = 0 + +setup + +# Test that plugin update reset tip values + +@test "plugin update __ABBR_TIPS_VALUES length" ( + set len_keys (count $__ABBR_TIPS_VALUES) + set -a __ABBR_TIPS_VALUES __wrong_key + __abbr_tips_update + test (count $__ABBR_TIPS_VALUES) -eq $len_keys +) "$status" = 0 + +setup + +@test "plugin update __ABBR_TIPS_VALUES value" ( + set last_key "$__ABBR_TIPS_VALUES[-1]" + set -a __ABBR_TIPS_VALUES __wrong_key + __abbr_tips_update + test "$__ABBR_TIPS_VALUES[-1]" = "$last_key" +) "$status" = 0 + + +teardown