diff --git a/examples/tests/test.sh b/examples/tests/test.sh index 815d938d..e9f95f7c 100755 --- a/examples/tests/test.sh +++ b/examples/tests/test.sh @@ -8,27 +8,30 @@ readonly d=$(cd "$(dirname "${BASH_SOURCE[0]:-$PWD}")" 2>/dev/null 1>&2 && pwd) # Point this to your dagger binary readonly DAGGER_BINARY="${DAGGER_BINARY:-$d/../../cmd/dagger/dagger}" - +# The default arguments are a no-op, but having "anything" is a little cheat necessary for "${DAGGER_BINARY_ARGS[@]}" to not be empty down there +DAGGER_BINARY_ARGS="${DAGGER_BINARY_ARGS:---log-format json}" +read -ra DAGGER_BINARY_ARGS <<< "${DAGGER_BINARY_ARGS:-}" +readonly DAGGER_BINARY_ARGS test::compute(){ local dagger="$1" # Compute test::one "Compute: invalid string should fail" --exit=1 --stdout= \ - "$dagger" compute "$d"/compute/invalid/string + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/compute/invalid/string test::one "Compute: invalid bool should fail" --exit=1 --stdout= \ - "$dagger" compute "$d"/compute/invalid/bool + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/compute/invalid/bool test::one "Compute: invalid int should fail" --exit=1 --stdout= \ - "$dagger" compute "$d"/compute/invalid/int + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/compute/invalid/int test::one "Compute: invalid struct should fail" --exit=1 --stdout= \ - "$dagger" compute "$d"/compute/invalid/struct + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/compute/invalid/struct test::one "Compute: noop should succeed" --exit=0 --stdout='{"empty":{},"realempty":{},"withprops":{}}' \ - "$dagger" compute "$d"/compute/noop + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/compute/noop test::one "Compute: simple should succeed" --exit=0 --stdout="{}" \ - "$dagger" compute "$d"/compute/simple + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/compute/simple disable test::one "Compute: unresolved should fail (FIXME https://github.com/blocklayerhq/dagger/issues/28)" --exit=1 --stdout= \ - "$dagger" compute "$d"/compute/invalid/undefined_prop + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/compute/invalid/undefined_prop } test::fetchcontainer(){ @@ -36,19 +39,19 @@ test::fetchcontainer(){ # Fetch container test::one "FetchContainer: missing ref" --exit=1 --stdout= \ - "$dagger" compute "$d"/fetch-container/invalid + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/fetch-container/invalid test::one "FetchContainer: non existent container image" --exit=1 --stdout= \ - "$dagger" compute "$d"/fetch-container/nonexistent/image + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/fetch-container/nonexistent/image test::one "FetchContainer: non existent container tag" --exit=1 --stdout= \ - "$dagger" compute "$d"/fetch-container/nonexistent/tag + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/fetch-container/nonexistent/tag test::one "FetchContainer: non existent container digest" --exit=1 --stdout= \ - "$dagger" compute "$d"/fetch-container/nonexistent/digest + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/fetch-container/nonexistent/digest test::one "FetchContainer: valid containers" --exit=0 \ - "$dagger" compute "$d"/fetch-container/exist + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/fetch-container/exist disable test::one "FetchContainer: non existent container image with valid digest (FIXME https://github.com/blocklayerhq/dagger/issues/32)" --exit=1 --stdout= \ - "$dagger" compute "$d"/fetch-container/nonexistent/image-with-valid-digest + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/fetch-container/nonexistent/image-with-valid-digest } test::fetchgit(){ @@ -56,90 +59,90 @@ test::fetchgit(){ # Fetch git test::one "FetchGit: valid" --exit=0 --stdout="{}" \ - "$dagger" compute "$d"/fetch-git/exist + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/fetch-git/exist test::one "FetchGit: invalid" --exit=1 --stdout= \ - "$dagger" compute "$d"/fetch-git/invalid + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/fetch-git/invalid test::one "FetchGit: non existent remote" --exit=1 --stdout= \ - "$dagger" compute "$d"/fetch-git/nonexistent/remote + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/fetch-git/nonexistent/remote test::one "FetchGit: non existent ref" --exit=1 --stdout= \ - "$dagger" compute "$d"/fetch-git/nonexistent/ref + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/fetch-git/nonexistent/ref test::one "FetchGit: non existent bork" --exit=1 --stdout= \ - "$dagger" compute "$d"/fetch-git/nonexistent/bork + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/fetch-git/nonexistent/bork } test::exec(){ # Exec test::one "Exec: invalid" --exit=1 --stdout= \ - "$dagger" compute "$d"/exec/invalid + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/exec/invalid test::one "Exec: error" --exit=1 --stdout= \ - "$dagger" compute "$d"/exec/error + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/exec/error test::one "Exec: simple" --exit=0 --stdout={} \ - "$dagger" compute "$d"/exec/simple + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/exec/simple # XXX should run twice and test that the string "always output" is visible with DOCKER_OUTPUT=1 # Alternatively, use export, but this would test multiple things then... test::one "Exec: always" --exit=0 --stdout={} \ - "$dagger" compute "$d"/exec/always + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/exec/always test::one "Exec: env invalid" --exit=1 --stdout= \ - "$dagger" compute "$d"/exec/env/invalid + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/exec/env/invalid test::one "Exec: env valid" --exit=0 --stdout={} \ - "$dagger" compute "$d"/exec/env/valid + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/exec/env/valid test::one "Exec: env with overlay" --exit=0 \ - "$dagger" compute --input 'bar: "overlay environment"' "$d"/exec/env/overlay + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute --input 'bar: "overlay environment"' "$d"/exec/env/overlay disable test::one "Exec: non existent dir (FIXME https://github.com/blocklayerhq/dagger/issues/30)" --exit=0 --stdout={} \ - "$dagger" compute "$d"/exec/dir/doesnotexist + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/exec/dir/doesnotexist disable test::one "Exec: valid dir (FIXME https://github.com/blocklayerhq/dagger/issues/30)" --exit=0 --stdout={} \ - "$dagger" compute "$d"/exec/dir/exist + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/exec/dir/exist } test::export(){ test::one "Export: json" --exit=0 --stdout='{"test":{"something":"something"}}' \ - "$dagger" compute "$d"/export/json + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/export/json test::one "Export: string" --exit=0 --stdout='{"test":"something"}' \ - "$dagger" compute "$d"/export/string + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/export/string test::one "Export: string with additional constraint success" --exit=0 --stdout='{"test":"something"}' \ - "$dagger" compute "$d"/export/withvalidation + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/export/withvalidation test::one "Export: many concurrent" --exit=0 \ - "$dagger" compute "$d"/export/concurrency + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/export/concurrency test::one "Export: does not pass additional validation" --exit=1 --stdout= \ - "$dagger" compute "$d"/export/invalid/validation + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/export/invalid/validation test::one "Export: invalid format" --exit=1 --stdout= \ - "$dagger" compute "$d"/export/invalid/format + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/export/invalid/format test::one "Export: invalid path" --exit=1 --stdout= \ - "$dagger" compute "$d"/export/invalid/path + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/export/invalid/path disable test::one "Export: number (FIXME https://github.com/blocklayerhq/dagger/issues/36)" --exit=0 --stdout='{"test": -123.5}' \ - "$dagger" compute "$d"/export/number + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/export/number disable test::one "Export: yaml (FIXME https://github.com/blocklayerhq/dagger/issues/36)" --exit=0 --stdout='XXXXXX' \ - "$dagger" compute "$d"/export/yaml + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/export/yaml disable test::one "Export: bool (FIXME https://github.com/blocklayerhq/dagger/issues/35)" --exit=0 --stdout='{"test": false}' \ - "$dagger" compute "$d"/export/bool + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/export/bool } test::copy(){ test::one "Copy: valid components" --exit=0 --stdout='{"component":{},"test1":"lol","test2":"lol"}' \ - "$dagger" compute "$d"/copy/valid/component + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/copy/valid/component test::one "Copy: valid script" --exit=0 \ - "$dagger" compute "$d"/copy/valid/script + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/copy/valid/script disable test::one "Copy: invalid caching (FIXME https://github.com/blocklayerhq/dagger/issues/44)" --exit=1 --stdout= \ - "$dagger" compute "$d"/copy/invalid/cache + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/copy/invalid/cache } test::load(){ test::one "Load: valid components" --exit=0 --stdout='{"component":{},"test1":"lol","test2":"lol"}' \ - "$dagger" compute "$d"/load/valid/component + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/load/valid/component test::one "Load: valid script" --exit=0 \ - "$dagger" compute "$d"/load/valid/script + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/load/valid/script test::one "Load: invalid caching (FIXME https://github.com/blocklayerhq/dagger/issues/44)" --exit=1 --stdout= \ - "$dagger" compute "$d"/load/invalid/cache + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/load/invalid/cache } test::local(){ @@ -149,16 +152,16 @@ test::local(){ test::mount(){ disable test::one "Mount: tmpfs (FIXME https://github.com/blocklayerhq/dagger/issues/46)" --exit=0 \ - "$dagger" compute "$d"/mount/valid/tmpfs + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/mount/valid/tmpfs disable test::one "Mount: cache (FIXME https://github.com/blocklayerhq/dagger/issues/46)" --exit=0 \ - "$dagger" compute "$d"/mount/valid/cache + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/mount/valid/cache disable test::one "Mount: component (FIXME https://github.com/blocklayerhq/dagger/issues/46)" --exit=0 \ - "$dagger" compute "$d"/mount/valid/component + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/mount/valid/component disable test::one "Mount: script (FIXME https://github.com/blocklayerhq/dagger/issues/46)" --exit=0 \ - "$dagger" compute "$d"/mount/valid/script + "$dagger" "${DAGGER_BINARY_ARGS[@]}" compute "$d"/mount/valid/script } test::all(){