diff --git a/test/numbers.bats b/test/numbers.bats new file mode 100755 index 0000000..d9653cf --- /dev/null +++ b/test/numbers.bats @@ -0,0 +1,100 @@ +#!/usr/bin/env bats +#shellcheck disable + +load 'test_helper/bats-support/load' +load 'test_helper/bats-file/load' +load 'test_helper/bats-assert/load' + +######## SETUP TESTS ######## +ROOTDIR="$(git rev-parse --show-toplevel)" +SOURCEFILE="${ROOTDIR}/utilities/numbers.bash" +BASEHELPERS="${ROOTDIR}/utilities/baseHelpers.bash" +ALERTS="${ROOTDIR}/utilities/alerts.bash" + +if test -f "${SOURCEFILE}" >&2; then + source "${SOURCEFILE}" +else + echo "Sourcefile not found: ${SOURCEFILE}" >&2 + printf "Can not run tests.\n" >&2 + exit 1 +fi + +if test -f "${BASEHELPERS}" >&2; then + source "${BASEHELPERS}" +else + echo "Sourcefile not found: ${BASEHELPERS}" >&2 + printf "Can not run tests.\n" >&2 + exit 1 +fi + +if test -f "${ALERTS}" >&2; then + source "${ALERTS}" +else + echo "Sourcefile not found: ${ALERTS}" >&2 + printf "Can not run tests.\n" >&2 + exit 1 +fi + +setup() { + + TESTDIR="$(temp_make)" + curPath="${PWD}" + + BATSLIB_FILE_PATH_REM="#${TEST_TEMP_DIR}" + BATSLIB_FILE_PATH_ADD='' + + pushd "${TESTDIR}" &>/dev/null + + ######## DEFAUL FLAGS ######## + LOGFILE="${TESTDIR}/logs/log.txt" + QUIET=false + LOGLEVEL=OFF + VERBOSE=false + FORCE=false + DRYRUN=false + +} + +teardown() { + popd &>/dev/null + temp_del "${TESTDIR}" +} + +######## RUN TESTS ######## +@test "Sanity..." { + run true + + assert_success + assert_output "" +} + +@test "_convertSecs_: Seconds to human readable" { + + run _fromSeconds_ "9255" + assert_success + assert_output "02:34:15" +} + +@test "_toSeconds_: HH MM SS to Seconds" { + run _toSeconds_ 12 3 33 + assert_success + assert_output "43413" +} + +@test "_countdown_: custom message, default wait" { + run _countdown_ 10 0 "something" + assert_line --index 0 --partial "something 10" + assert_line --index 9 --partial "something 1" +} + +@test "_countdown_: default message, custom wait" { + run _countdown_ 5 0 + assert_line --index 0 --partial "... 5" + assert_line --index 4 --partial "... 1" +} + +@test "_countdown_: all defaults" { + run _countdown_ + assert_line --index 0 --partial "... 10" + assert_line --index 9 --partial "... 1" +} diff --git a/test/textProcessing.bats b/test/textProcessing.bats new file mode 100755 index 0000000..201fb98 --- /dev/null +++ b/test/textProcessing.bats @@ -0,0 +1,238 @@ +#!/usr/bin/env bats +#shellcheck disable + +load 'test_helper/bats-support/load' +load 'test_helper/bats-file/load' +load 'test_helper/bats-assert/load' + +######## SETUP TESTS ######## +ROOTDIR="$(git rev-parse --show-toplevel)" +SOURCEFILE="${ROOTDIR}/utilities/textProcessing.bash" +BASEHELPERS="${ROOTDIR}/utilities/baseHelpers.bash" +ALERTS="${ROOTDIR}/utilities/alerts.bash" + +if test -f "${SOURCEFILE}" >&2; then + source "${SOURCEFILE}" +else + echo "Sourcefile not found: ${SOURCEFILE}" >&2 + printf "Can not run tests.\n" >&2 + exit 1 +fi + +if test -f "${BASEHELPERS}" >&2; then + source "${BASEHELPERS}" +else + echo "Sourcefile not found: ${BASEHELPERS}" >&2 + printf "Can not run tests.\n" >&2 + exit 1 +fi + +if test -f "${ALERTS}" >&2; then + source "${ALERTS}" +else + echo "Sourcefile not found: ${ALERTS}" >&2 + printf "Can not run tests.\n" >&2 + exit 1 +fi + +setup() { + + TESTDIR="$(temp_make)" + curPath="${PWD}" + + BATSLIB_FILE_PATH_REM="#${TEST_TEMP_DIR}" + BATSLIB_FILE_PATH_ADD='' + + pushd "${TESTDIR}" &>/dev/null + + ######## DEFAUL FLAGS ######## + LOGFILE="${TESTDIR}/logs/log.txt" + QUIET=false + LOGLEVEL=OFF + VERBOSE=false + FORCE=false + DRYRUN=false + +} + +teardown() { + popd &>/dev/null + temp_del "${TESTDIR}" +} + +######## RUN TESTS ######## +@test "Sanity..." { + run true + + assert_success + assert_output "" +} + +_testCleanString_() { + + @test "_cleanString_: fail" { + run _cleanString_ + assert_failure + } + + @test "_cleanString_: lowercase" { + run _cleanString_ -l "I AM IN CAPS" + assert_success + assert_output "i am in caps" + } + + @test "_cleanString_: uppercase" { + run _cleanString_ -u "i am in caps" + assert_success + assert_output "I AM IN CAPS" + } + + @test "_cleanString_: remove white space" { + run _cleanString_ -u " i am in caps " + assert_success + assert_output "I AM IN CAPS" + } + + @test "_cleanString_: remove spaces before/aftrer -_" { + run _cleanString_ "word - another- word- another-word" + assert_success + assert_output "word-another-word-another-word" + } + + @test "_cleanString_: alnum" { + run _cleanString_ -a " !@#$%^%& i am in caps 12345 == " + assert_success + assert_output "i am in caps 12345" + } + + @test "_cleanString_: alnum w/ spaces" { + run _cleanString_ -as "this(is)a[string]" + assert_success + assert_output "this is a string" + } + + @test "_cleanString_: alnum w/ spaces and dashes" { + run _cleanString_ -as "this(is)a-string" + assert_success + assert_output "this is a-string" + } + + @test "_cleanString_: user replacement" { + run _cleanString_ -p "e,g" "there should be a lot of e's in this sentence" + assert_success + assert_output "thgrg should bg a lot of g's in this sgntgncg" + } + + @test "_cleanString_: remove specified characters" { + run _cleanString_ "there should be a lot of e's in this sentence" "e" + assert_success + assert_output "thr should b a lot of 's in this sntnc" + } + + @test "_cleanString_: compound test 1" { + run _cleanString_ -p "2,4" -au " @#$%[]{} clean a compound command ==23---- " "e" + assert_success + assert_output "CLAN A COMPOUND COMMAND 43-" + } + +} +_testCleanString_ + +_testStopWords_() { + + @test "_stopWords_: success" { + run _stopWords_ "A string to be parsed" + assert_success + assert_output "string parsed" + } + + @test "_stopWords_: success w/ user terms" { + run _stopWords_ "A string to be parsed to help pass this test being performed by bats" "bats,string" + assert_success + assert_output "parsed pass performed" + } + + @test "_stopWords_: No changes" { + run _stopWords_ "string parsed pass performed" + assert_success + assert_output "string parsed pass performed" + } + + @test "_stopWords_: fail" { + run _stopWords_ + assert_failure + } + +} +_testStopWords_ + +@test "_escape_" { + run _escape_ "Here is some / text to & be - escape'd" + assert_success + assert_output "Here\ is\ some\ /\ text\ to\ &\ be\ -\ escape'd" +} + +@test "_htmlEncode_" { + run _htmlEncode_ "Here's some text& to > be h?t/M(l• en™code磧¶d" + assert_success + assert_output "Here's some text& to > be h?t/M(l• en™code磧¶d" +} + +@test "_htmlDecode_" { + run _htmlDecode_ "♣Here's some text & to > be h?t/M(l• en™code磧¶d" + assert_success + assert_output "♣Here's some text & to > be h?t/M(l• en™code磧¶d" +} + +@test "_lower" { + local text="$(echo "MAKE THIS LOWERCASE" | _lower_)" + + run echo "$text" + assert_output "make this lowercase" +} + +@test "_ltrim_" { + local text=$(_ltrim_ <<<" some text") + + run echo "$text" + assert_output "some text" +} + +@test "_rtrim_" { + local text=$(_rtrim_ <<<"some text ") + + run echo "$text" + assert_output "some text" +} + +@test "_upper_" { + local text="$(echo "make this uppercase" | _upper_)" + + run echo "$text" + assert_output "MAKE THIS UPPERCASE" +} + +@test "_urlEncode_" { + run _urlEncode_ "Here's some.text%that&needs_to-be~encoded+a*few@more(characters)" + assert_success + assert_output "Here%27s%20some.text%25that%26needs_to-be~encoded%2Ba%2Afew%40more%28characters%29" +} + +@test "_urlDecode_" { + run _urlDecode_ "Here%27s%20some.text%25that%26needs_to-be~encoded%2Ba%2Afew%40more%28characters%29" + assert_success + assert_output "Here's some.text%that&needs_to-be~encoded+a*few@more(characters)" +} + +@test "_regex_: success" { + run _regex_ "#FFFFFF" '^(#?([a-fA-F0-9]{6}|[a-fA-F0-9]{3}))$' || echo "no match found" + + assert_success + assert_output "#FFFFFF" +} + +@test "_regex_: failure" { + run _regex_ "gggggg" '^(#?([a-fA-F0-9]{6}|[a-fA-F0-9]{3}))$' + + assert_failure +} diff --git a/utilities/textProcessing.bash b/utilities/textProcessing.bash index aad6bec..f9cc1a3 100644 --- a/utilities/textProcessing.bash +++ b/utilities/textProcessing.bash @@ -218,7 +218,7 @@ _regex_() { # $2 (Required) - Regex pattern # OUTS: Prints string matching regex # Returns error if no part of string did not match regex - # USAGE: regex "#FFFFFF" '^(#?([a-fA-F0-9]{6}|[a-fA-F0-9]{3}))$' || echo "no match found" + # USAGE: _regex_ "#FFFFFF" '^(#?([a-fA-F0-9]{6}|[a-fA-F0-9]{3}))$' # NOTE: This example only prints the first matching group. When using multiple capture # groups some modification is needed. # https://github.com/dylanaraps/pure-bash-bible