165 lines
3.7 KiB
Bash
Executable File
165 lines
3.7 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
set -euo pipefail
|
|
|
|
working_dir="$(cd "$(dirname "$BASH_SOURCE")"; pwd -P)"
|
|
source "$working_dir"/bach/bach.sh
|
|
|
|
@setup {
|
|
set -euo pipefail
|
|
}
|
|
|
|
@setup-test {
|
|
@mocktrue ufw status
|
|
@mocktrue grep -Fq "Status: active"
|
|
|
|
@ignore remove_blank_lines
|
|
@ignore echo
|
|
@ignore err
|
|
|
|
DEFAULT_PROTO=tcp
|
|
GREP_REGEXP_INSTANCE_NAME="[-_.[:alnum:]]\\+"
|
|
}
|
|
|
|
function die() {
|
|
return 1
|
|
}
|
|
|
|
function load-ufw-docker-function() {
|
|
set -euo pipefail
|
|
|
|
@load_function "$working_dir/../ufw-docker" "$1"
|
|
}
|
|
|
|
|
|
test-ufw-docker--service-not-parameters() {
|
|
load-ufw-docker-function ufw-docker--service
|
|
|
|
ufw-docker--service
|
|
}
|
|
test-ufw-docker--service-not-parameters-assert() {
|
|
ufw-docker--help
|
|
}
|
|
|
|
|
|
test-ufw-docker--service-allow() {
|
|
load-ufw-docker-function ufw-docker--service
|
|
|
|
ufw-docker--service allow
|
|
}
|
|
test-ufw-docker--service-allow-assert() {
|
|
@do-nothing
|
|
@fail
|
|
}
|
|
|
|
|
|
test-ufw-docker--service-allow-webapp() {
|
|
load-ufw-docker-function ufw-docker--service
|
|
|
|
ufw-docker--service allow webapp
|
|
}
|
|
test-ufw-docker--service-allow-webapp-assert() {
|
|
#ufw-docker--service-allow webapp "" ""
|
|
@do-nothing
|
|
@fail
|
|
}
|
|
|
|
|
|
test-ufw-docker--service-allow-webapp-80tcp() {
|
|
load-ufw-docker-function ufw-docker--service
|
|
|
|
ufw-docker--service allow webapp 80/tcp
|
|
}
|
|
test-ufw-docker--service-allow-webapp-80tcp-assert() {
|
|
ufw-docker--service-allow webapp 80/tcp
|
|
}
|
|
|
|
|
|
test-ufw-docker--service-delete-deny() {
|
|
load-ufw-docker-function ufw-docker--service
|
|
|
|
ufw-docker--service delete deny
|
|
}
|
|
test-ufw-docker--service-delete-deny-assert() {
|
|
@do-nothing
|
|
@fail
|
|
}
|
|
|
|
|
|
test-ufw-docker--service-delete-allow-no-service() {
|
|
load-ufw-docker-function ufw-docker--service
|
|
|
|
ufw-docker--service delete allow
|
|
}
|
|
test-ufw-docker--service-delete-allow-no-service-assert() {
|
|
@do-nothing
|
|
@fail
|
|
}
|
|
|
|
|
|
test-ufw-docker--service-delete-allow-webapp() {
|
|
load-ufw-docker-function ufw-docker--service
|
|
|
|
ufw-docker--service delete allow webapp
|
|
}
|
|
test-ufw-docker--service-delete-allow-webapp-assert() {
|
|
ufw-docker--service-delete webapp
|
|
}
|
|
|
|
|
|
test-ufw-docker--get-service-id() {
|
|
load-ufw-docker-function ufw-docker--get-service-id
|
|
ufw-docker--get-service-id database
|
|
}
|
|
test-ufw-docker--get-service-id-assert() {
|
|
docker service inspect database --format "{{.ID}}"
|
|
}
|
|
|
|
|
|
test-ufw-docker--get-service-name() {
|
|
load-ufw-docker-function ufw-docker--get-service-name
|
|
ufw-docker--get-service-name database
|
|
}
|
|
test-ufw-docker--get-service-name-assert() {
|
|
docker service inspect database --format "{{.Spec.Name}}"
|
|
}
|
|
|
|
|
|
test-ufw-docker--service-allow-invalid-port-syntax() {
|
|
@mockfalse grep -E '^[0-9]+(/(tcp|udp))?$'
|
|
|
|
load-ufw-docker-function ufw-docker--service-allow
|
|
ufw-docker--service-allow webapp invalid-port
|
|
}
|
|
test-ufw-docker--service-allow-invalid-port-syntax-assert() {
|
|
@do-nothing
|
|
@fail
|
|
}
|
|
|
|
|
|
test-ufw-docker--service-allow-an-non-existed-service() {
|
|
@mocktrue grep -E '^[0-9]+(/(tcp|udp))?$'
|
|
@mock ufw-docker--get-service-id web404 === @stdout ""
|
|
|
|
load-ufw-docker-function ufw-docker--service-allow
|
|
ufw-docker--service-allow web404 80/tcp
|
|
}
|
|
test-ufw-docker--service-allow-an-non-existed-service-assert() {
|
|
@do-nothing
|
|
@fail
|
|
}
|
|
|
|
|
|
test-ufw-docker--service-allow-a-service-without-ports-published() {
|
|
@mocktrue grep -E '^[0-9]+(/(tcp|udp))?$'
|
|
@mock ufw-docker--get-service-id private-web === @stdout ""
|
|
@mock docker service inspect private-web \
|
|
--format '{{range .Endpoint.Spec.Ports}}{{.PublishedPort}} {{.TargetPort}}/{{.Protocol}}{{"\n"}}{{end}}' === @stdout ""
|
|
|
|
load-ufw-docker-function ufw-docker--service-allow
|
|
ufw-docker--service-allow private-web 80/tcp
|
|
}
|
|
test-ufw-docker--service-allow-a-service-without-ports-published-assert() {
|
|
@do-nothing
|
|
@fail
|
|
}
|