initial commit

This commit is contained in:
Nathaniel Landau
2021-07-26 09:34:39 -04:00
parent f3eab826ca
commit 3685880727
3 changed files with 339 additions and 1 deletions

100
test/numbers.bats Executable file
View File

@@ -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='<temp>'
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"
}

238
test/textProcessing.bats Executable file
View File

@@ -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='<temp>'
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&amp; to &gt; be h?t/M(l&bull; en&trade;code&ccedil;&pound;&sect;&para;d"
}
@test "_htmlDecode_" {
run _htmlDecode_ "&clubs;Here's some text &amp; to &gt; be h?t/M(l&bull; en&trade;code&ccedil;&pound;&sect;&para;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
}

View File

@@ -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