1 | #!/bin/bash |
---|
2 | #------------------------------------------------------------------------------- |
---|
3 | # Copyright (C) 2006-2021 British Crown (Met Office) & Contributors. |
---|
4 | # |
---|
5 | # This file is part of FCM, tools for managing and building source code. |
---|
6 | # |
---|
7 | # FCM is free software: you can redistribute it and/or modify |
---|
8 | # it under the terms of the GNU General Public License as published by |
---|
9 | # the Free Software Foundation, either version 3 of the License, or |
---|
10 | # (at your option) any later version. |
---|
11 | # |
---|
12 | # FCM is distributed in the hope that it will be useful, |
---|
13 | # but WITHOUT ANY WARRANTY; without even the implied warranty of |
---|
14 | # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
---|
15 | # GNU General Public License for more details. |
---|
16 | # |
---|
17 | # You should have received a copy of the GNU General Public License |
---|
18 | # along with FCM. If not, see <http://www.gnu.org/licenses/>. |
---|
19 | #------------------------------------------------------------------------------- |
---|
20 | # Tests "fcm make", generation of log files. |
---|
21 | #------------------------------------------------------------------------------- |
---|
22 | . $(dirname $0)/test_header |
---|
23 | #------------------------------------------------------------------------------- |
---|
24 | tests 12 |
---|
25 | cp -r $TEST_SOURCE_DIR/$TEST_KEY_BASE/* . |
---|
26 | #------------------------------------------------------------------------------- |
---|
27 | TEST_KEY="$TEST_KEY_BASE" |
---|
28 | run_pass "$TEST_KEY" fcm make |
---|
29 | if [[ -d $FCM_HOME/.git ]]; then |
---|
30 | VERSION="FCM $(git --git-dir=$FCM_HOME/.git describe)" |
---|
31 | else |
---|
32 | VERSION=$(sed '/FCM\.VERSION/!d; s/^.*="\(.*\)";$/\1/' \ |
---|
33 | $FCM_HOME/doc/etc/fcm-version.js) |
---|
34 | VERSION="FCM $VERSION" |
---|
35 | fi |
---|
36 | file_grep "${TEST_KEY}.log.version" "\\[info\\] ${VERSION}" '.fcm-make/log' |
---|
37 | file_grep "${TEST_KEY}.log.mode" '\[info\] mode=new' '.fcm-make/log' |
---|
38 | file_grep "${TEST_KEY}.log.description" \ |
---|
39 | '\[info\] description=There is nothing like a good test' '.fcm-make/log' |
---|
40 | if [[ $(ls .fcm-make/log-* | wc -l) == 1 ]]; then |
---|
41 | pass "$TEST_KEY-n-logs" |
---|
42 | else |
---|
43 | fail "$TEST_KEY-n-logs" |
---|
44 | fi |
---|
45 | run_pass "$TEST_KEY-symlink-1" \ |
---|
46 | test "$(readlink 'fcm-make.log')" '=' '.fcm-make/log' |
---|
47 | run_pass "$TEST_KEY-symlink-2" \ |
---|
48 | test "$(readlink '.fcm-make/log')" \ |
---|
49 | '=' "$(cd '.fcm-make'; ls 'log-'* | sort | tail -1)" |
---|
50 | #------------------------------------------------------------------------------- |
---|
51 | TEST_KEY="$TEST_KEY_BASE-incr" |
---|
52 | sleep 1 |
---|
53 | run_pass "$TEST_KEY" fcm make |
---|
54 | file_grep "$TEST_KEY.log.mode" '\[info\] mode=incremental' .fcm-make/log |
---|
55 | if [[ $(ls .fcm-make/log-* | wc -l) == 2 ]]; then |
---|
56 | pass "$TEST_KEY-n-logs" |
---|
57 | else |
---|
58 | fail "$TEST_KEY-n-logs" |
---|
59 | fi |
---|
60 | run_pass "$TEST_KEY-symlink-1" \ |
---|
61 | test "$(readlink 'fcm-make.log')" '=' '.fcm-make/log' |
---|
62 | run_pass "$TEST_KEY-symlink-2" \ |
---|
63 | test "$(readlink '.fcm-make/log')" \ |
---|
64 | '=' "$(cd '.fcm-make'; ls 'log-'* | sort | tail -1)" |
---|
65 | #------------------------------------------------------------------------------- |
---|
66 | exit 0 |
---|