summaryrefslogtreecommitdiff
path: root/test/end-to-end/actions/error-reporting.sh
blob: 8705e6ec226969b7296b0be59e20c1e98006355b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
#!/bin/sh
# Copyright 2024 Huawei Cloud Computing Technology Co., Ltd.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#     http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

set -e

readonly ROOT="$(pwd)"
readonly LBR="${TMPDIR}/local-build-root"
readonly OUT="${TMPDIR}/out"
readonly JUST="${ROOT}/bin/tool-under-test"
readonly LOCAL_TOOLS="${TMPDIR}/tools"

touch ROOT
cat > TARGETS <<'EOF'
{ "theTargetCausingTheFailure":
  { "type": "generic"
  , "arguments_config": ["foo", "bar"]
  , "outs": ["a.txt"]
  , "cmds":
    [ { "type": "join"
      , "$1":
        [ "echo -n stdout-of-; echo failing-target-"
        , {"type": "var", "name": "foo", "default": ""}
        , {"type": "var", "name": "bar", "default": ""}
        ]
      }
    , "touch a.txt"
    , "exit 42"
    ]
  }
}
EOF
cat TARGETS
echo

# Verify tat a failing build provides enough meaningful
# information at log-level ERROR.
mkdir -p "${OUT}"
"${JUST}" build --local-build-root "${LBR}" \
          -f "${OUT}/log" --log-limit 0 \
          -D '{"foo": "FOO", "irrelevant": "abc"}' \
          2>&1 && exit 1 || :

# The exit code should be reported
grep 42 "${OUT}/log"

# The target name should be reported
grep theTargetCausingTheFailure "${OUT}/log"

# The pruned effective configuration should be reported in canonical
# compact form.
grep '{"foo":"FOO"}' "${OUT}/log"

# At default level we should also find stdout of the target
echo
"${JUST}" build --local-build-root "${LBR}" \
          -f "${OUT}/log.default" \
          -D '{"foo": "FOO", "irrelevant": "abc"}' \
          2>&1 && exit 1 || :

grep stdout-of-failing-target-FOO "${OUT}/log.default"

echo OK