Skip to content
This repository has been archived by the owner on Apr 29, 2021. It is now read-only.

Commit

Permalink
Add standard library
Browse files Browse the repository at this point in the history
  • Loading branch information
ztombol committed Aug 5, 2015
1 parent 291d9c0 commit 61c7689
Show file tree
Hide file tree
Showing 34 changed files with 2,515 additions and 7 deletions.
417 changes: 417 additions & 0 deletions README.md

Large diffs are not rendered by default.

2 changes: 2 additions & 0 deletions install.sh
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,9 @@ BATS_ROOT="$(abs_dirname "$0")"
mkdir -p "$PREFIX"/{bin,libexec,share/man/man{1,7}}
cp -R "$BATS_ROOT"/bin/* "$PREFIX"/bin
cp -R "$BATS_ROOT"/libexec/* "$PREFIX"/libexec
cp -R "$BATS_ROOT"/lib/* "$PREFIX"/lib
cp "$BATS_ROOT"/man/bats.1 "$PREFIX"/share/man/man1
cp "$BATS_ROOT"/man/bats.7 "$PREFIX"/share/man/man7
cp "$BATS_ROOT"/man/batslib.7 "$PREFIX"/share/man/man7

echo "Installed Bats to $PREFIX/bin/bats"
300 changes: 300 additions & 0 deletions lib/bats/batslib.bash
Original file line number Diff line number Diff line change
@@ -0,0 +1,300 @@
#
# batslib.bash
# ------------
#
# The Standard Library is a collection of test helpers intended to
# simplify testing. It contains the following types of test helpers.
#
# - Assertions are functions that perform a test and output relevant
# information on failure to help debugging. They return 1 on failure
# and 0 otherwise.
#
# All output is formatted for readability using the functions of
# `output.bash' and sent to the standard error.
#

source "${BATS_LIB}/batslib/output.bash"


########################################################################
# ASSERTIONS
########################################################################

# Fail and display an error message. The message is specified either by
# positional parameters or on the standard input (by piping or
# redirection).
#
# Globals:
# none
# Arguments:
# $@ - [opt = STDIN] message to display
# Returns:
# 1 - always
# Inputs:
# STDIN - [opt = $@] message to display
# Outputs:
# STDERR - error message
flunk() {
(( $# == 0 )) && batslib_err || batslib_err "$@"
return 1
}

# Fail and display the given condition if it evaluates to false. Only
# simple commands can be used in the expression given to `assert'.
# Compound commands, such as `[[', are not supported.
#
# Globals:
# none
# Arguments:
# $@ - condition to evaluate
# Returns:
# 0 - condition evaluated to TRUE
# 1 - condition evaluated to FALSE
# Outputs:
# STDERR - failed condition, on failure
assert() {
if ! "$@"; then
echo "condition : $@" | batslib_decorate 'assertion failed' | flunk
fi
}

# Fail and display an error message if the two parameters, expected and
# actual value respectively, do not equal. The error message contains
# both parameters.
#
# Globals:
# none
# Arguments:
# $1 - expected value
# $2 - actual value
# Returns:
# 0 - expected equals actual value
# 1 - otherwise
# Outputs:
# STDERR - expected and actual value, on failure
assert_equal() {
if [[ $1 != "$2" ]]; then
batslib_print_kv_single_or_multi 8 \
'expected' "$1" \
'actual' "$2" \
| batslib_decorate 'values do not equal' \
| flunk
fi
}

# Fail and display an error message if `$output' does not equal the
# expected output as specified either by the first positional parameter
# or on the standard input (by piping or redirection). The error message
# contains the expected and the actual output.
#
# Globals:
# output
# Arguments:
# $1 - [opt = STDIN] expected output
# Returns:
# 0 - expected equals actual output
# 1 - otherwise
# Inputs:
# STDIN - [opt = $1] expected output
# Outputs:
# STDERR - expected and actual output, on failure
assert_output() {
local expected
(( $# == 0 )) && expected="$(cat -)" || expected="$1"
if [[ $expected != "$output" ]]; then
batslib_print_kv_single_or_multi 8 \
'expected' "$expected" \
'actual' "$output" \
| batslib_decorate 'output differs' \
| flunk
fi
}

# Fail and display an error message if `$status' is not zero. The error
# message contains `$status' and `$output'.
#
# Optionally, if the status check passed, `$output' can be tested
# against the first positional parameter as expected output. If the
# output check fails the error message contains the expected and the
# actual output.
#
# Globals:
# status
# output
# Arguments:
# $1 - [opt] expected output
# Returns:
# 0 - status and, optionally, output check passed
# 1 - otherwise
# Outputs:
# STDERR - `$status' and `$output', if status check fails
# expected and actual output, if output check fails
assert_success() {
(( $# > 0 )) && local -r expected="$1"
if (( status != 0 )); then
{ local -ir width=6
batslib_print_kv_single "$width" 'status' "$status"
batslib_print_kv_single_or_multi "$width" 'output' "$output"
} | batslib_decorate 'command failed' \
| flunk
elif (( $# > 0 )) && [[ $output != "$1" ]]; then
batslib_print_kv_single_or_multi 8 \
'expected' "$expected" \
'actual' "$output" \
| batslib_decorate 'command succeeded, but output differs' \
| flunk
fi
}

# Fail and display `$output' if `$status' is zero.
#
# Optionally, if the status check passed, `$output' can be tested
# against the first positional parameter as expected output. If the
# output check fails the error message contains the expected and the
# actual output.
#
# Globals:
# status
# output
# Arguments:
# $1 - [opt] expected output
# Returns:
# 0 - status and, optionally, output check passed
# 1 - otherwise
# Outputs:
# STDERR - `$output', if status check fails
# expected and actual output, if output check fails
assert_failure() {
if (( status == 0 )); then
batslib_print_kv_single_or_multi 6 'output' "$output" \
| batslib_decorate 'command succeeded, but it was expected to fail' \
| flunk
elif (( $# > 0 )) && [[ $output != "$1" ]]; then
batslib_print_kv_single_or_multi 8 \
'expected' "$1" \
'actual' "$output" \
| batslib_decorate 'command failed as expected, but output differs' \
| flunk
fi
}

# Fail and display an error message if `${lines[@]}' does not contain
# the expected line. The error message contains the expected line and
# `$output'.
#
# Optionally, if two positional parameters are specified, the expected
# line is only sought in the line whose index is given in the first
# parameter. In this case, the error message contains the line index,
# and the expected and actual line at the given index.
#
# Globals:
# lines
# output
# Arguments:
# $1 - [opt] zero-based index of line to match against
# $2 - line to look for
# Returns:
# 0 - line found
# 1 - otherwise
# Outputs:
# STDERR - expected line and `$output', on failure
# index, expected and actual line at index, on failure
assert_line() {
if (( $# > 1 )); then
local -ir idx="$1"
local -r line="$2"

if [[ ${lines[$idx]} != "$line" ]]; then
batslib_print_kv_single 8 \
'index' "$idx" \
'expected' "$line" \
'actual' "${lines[$idx]}" \
| batslib_decorate 'line differs' \
| flunk
fi
else
local -r line="$1"
local temp_line

for temp_line in "${lines[@]}"; do
[[ $temp_line == "$line" ]] && return 0
done
{ local -ar single=(
'line' "$line"
)
local -ar may_be_multi=(
'output' "$output"
)
local -ir width="$( batslib_get_max_single_line_key_width \
"${single[@]}" "${may_be_multi[@]}" )"
batslib_print_kv_single "$width" "${single[@]}"
batslib_print_kv_single_or_multi "$width" "${may_be_multi[@]}"
} | batslib_decorate 'line is not in output' \
| flunk
fi
}

# Fail and display an error message if `${lines[@]}' contains the given
# line. The error message contains the unexpected line, its index in
# `$output', and `$output'.
#
# Optionally, if two positional parameters are specified, the unexpected
# line is only sought in the line whose index is given in the first
# parameter. In this case, the error message contains the line index,
# and the unexpected line.
#
# Globals:
# lines
# output
# Arguments:
# $1 - [opt] zero-based index of line to match against
# $2 - line to look for
# Returns:
# 0 - line not found
# 1 - otherwise
# Outputs:
# STDERR - unexpected line, its index and `$output', on failure
# index and unexpected line, on failure
refute_line() {
if (( $# > 1 )); then
local -ir idx="$1"
local -r line="$2"

if [[ ${lines[$idx]} == "$line" ]]; then
batslib_print_kv_single 5 \
'index' "$idx" \
'line' "$line" \
| batslib_decorate 'line should differ from expected' \
| flunk
fi
else
local -r line="$1"

local idx
for (( idx = 0; idx < ${#lines[@]}; ++idx )); do
if [[ ${lines[$idx]} == "$line" ]]; then
{ local -ar single=(
'line' "$line"
'index' "$idx"
)
local -a may_be_multi=(
'output' "$output"
)
local -ir width="$( batslib_get_max_single_line_key_width \
"${single[@]}" "${may_be_multi[@]}" )"
batslib_print_kv_single "$width" "${single[@]}"
if batslib_is_single_line "${may_be_multi[1]}"; then
batslib_print_kv_single "$width" "${may_be_multi[@]}"
else
may_be_multi[1]="$( printf '%s' "${may_be_multi[1]}" \
| batslib_prefix \
| batslib_mark '>' "$idx" )"
batslib_print_kv_multi "${may_be_multi[@]}"
fi
} | batslib_decorate 'line should not be in output' \
| flunk
return 1
fi
done
fi
}
Loading

0 comments on commit 61c7689

Please sign in to comment.