source: LMDZ6/branches/Amaury_dev/tools/fcm/t/fcm-make/10-log.t @ 5095

Last change on this file since 5095 was 5095, checked in by abarral, 4 months ago

Revert cosp*/ from the trunk, as it's external code
Add missing bits from FCM2 source

  • Property svn:executable set to *
File size: 2.8 KB
Line 
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#-------------------------------------------------------------------------------
24tests 12
25cp -r $TEST_SOURCE_DIR/$TEST_KEY_BASE/* .
26#-------------------------------------------------------------------------------
27TEST_KEY="$TEST_KEY_BASE"
28run_pass "$TEST_KEY" fcm make
29if [[ -d $FCM_HOME/.git ]]; then
30    VERSION="FCM $(git --git-dir=$FCM_HOME/.git describe)"
31else
32    VERSION=$(sed '/FCM\.VERSION/!d; s/^.*="\(.*\)";$/\1/' \
33        $FCM_HOME/doc/etc/fcm-version.js)
34    VERSION="FCM $VERSION"
35fi
36file_grep "${TEST_KEY}.log.version" "\\[info\\] ${VERSION}" '.fcm-make/log'
37file_grep "${TEST_KEY}.log.mode" '\[info\] mode=new' '.fcm-make/log'
38file_grep "${TEST_KEY}.log.description" \
39    '\[info\] description=There is nothing like a good test' '.fcm-make/log'
40if [[ $(ls .fcm-make/log-* | wc -l) == 1 ]]; then
41    pass "$TEST_KEY-n-logs"
42else
43    fail "$TEST_KEY-n-logs"
44fi
45run_pass "$TEST_KEY-symlink-1" \
46    test "$(readlink 'fcm-make.log')" '=' '.fcm-make/log'
47run_pass "$TEST_KEY-symlink-2" \
48    test "$(readlink '.fcm-make/log')" \
49    '=' "$(cd '.fcm-make'; ls 'log-'* | sort | tail -1)"
50#-------------------------------------------------------------------------------
51TEST_KEY="$TEST_KEY_BASE-incr"
52sleep 1
53run_pass "$TEST_KEY" fcm make
54file_grep "$TEST_KEY.log.mode" '\[info\] mode=incremental' .fcm-make/log
55if [[ $(ls .fcm-make/log-* | wc -l) == 2 ]]; then
56    pass "$TEST_KEY-n-logs"
57else
58    fail "$TEST_KEY-n-logs"
59fi
60run_pass "$TEST_KEY-symlink-1" \
61    test "$(readlink 'fcm-make.log')" '=' '.fcm-make/log'
62run_pass "$TEST_KEY-symlink-2" \
63    test "$(readlink '.fcm-make/log')" \
64    '=' "$(cd '.fcm-make'; ls 'log-'* | sort | tail -1)"
65#-------------------------------------------------------------------------------
66exit 0
Note: See TracBrowser for help on using the repository browser.