aboutsummaryrefslogtreecommitdiffstats
path: root/resources/libraries/bash/entry/tox/doc_verify.sh
blob: 7eec4b69e4cb981ad7bb5e5a3704fee069b4dc9d (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
# Copyright (c) 2022 Cisco and/or its affiliates.
# 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 -xeuo pipefail

# This file should be executed from tox, as the assumend working directory
# is different from where this file is located.
# This file does not have executable flag nor shebang,
# to dissuade non-tox callers.

# "set -eu" handles failures from the following two lines.
BASH_CHECKS_DIR="$(dirname $(readlink -e "${BASH_SOURCE[0]}"))"
BASH_FUNCTION_DIR="$(readlink -e "${BASH_CHECKS_DIR}/../../function")"
source "${BASH_FUNCTION_DIR}/common.sh" || {
    echo "Source failed." >&2
    exit 1
}
source "${BASH_FUNCTION_DIR}/docs.sh" || die "Source failed."
common_dirs || die
activate_virtualenv || die

# Documentation generation.
# Here we do store only stderr to file while stdout (inlcuding Xtrace) is
# printed to console. This way we can track increased errors in future.
# We do not need to do trap as the env will be closed after tox finished the
# task.
exec 3>&1 || die
export BASH_XTRACEFD="3" || die
log_file="$(pwd)/doc_verify.log" || die

generate_docs 2> ${log_file} || die

if [[ "${DOCS_EXIT_STATUS}" != 0 ]]; then
    # Failed to generate report.
    warn
    warn "Doc verify checker: FAIL"
    exit 1
fi

warn
warn "Doc verify checker: PASS"