New URL for NEMO forge!   http://forge.nemo-ocean.eu

Since March 2022 along with NEMO 4.2 release, the code development moved to a self-hosted GitLab.
This present forge is now archived and remained online for history.
00-tree-add-add.t in vendors/t/fcm-conflicts – NEMO

source: vendors/t/fcm-conflicts/00-tree-add-add.t @ 10669

Last change on this file since 10669 was 10669, checked in by nicolasmartin, 5 years ago

Import latest FCM release from Github into the repository for testing

File size: 6.0 KB
Line 
1#!/bin/bash
2# ------------------------------------------------------------------------------
3# (C) British Crown Copyright 2006-17 Met Office.
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# Basic tests for "fcm conflicts" (tree conflict mode).
21#-------------------------------------------------------------------------------
22. $(dirname $0)/test_header
23#-------------------------------------------------------------------------------
24check_svn_version
25tests 24
26#-------------------------------------------------------------------------------
27setup
28init_repos
29init_branch ctrl $REPOS_URL
30init_branch_wc add_add $REPOS_URL
31cd $TEST_DIR/wc
32#-------------------------------------------------------------------------------
33# Tests fcm conflicts: add, add, discard local   
34TEST_KEY=$TEST_KEY_BASE-discard
35svn switch -q $ROOT_URL/branches/dev/Share/ctrl
36echo "Local contents (1)" > new_file
37svn add -q new_file
38svn commit -q -m "Added duplicate-name copy of conflict file"
39svn update -q
40svn switch -q $ROOT_URL/branches/dev/Share/add_add
41echo "Merge contents (1)" >new_file
42echo "Merge contents (2)" >>new_file
43svn add -q new_file
44svn commit -q -m "Added duplicated-name copy of conflict file"
45svn update -q
46svn switch -q $ROOT_URL/branches/dev/Share/ctrl
47fcm merge --non-interactive $ROOT_URL/branches/dev/Share/add_add >/dev/null
48run_pass "$TEST_KEY" fcm conflicts <<__IN__
49n
50__IN__
51file_cmp "$TEST_KEY.out" "$TEST_KEY.out" <<__OUT__
52[info] new_file: in tree conflict.
53Locally: added.
54Externally: added.
55Answer (y) to keep the local file filename.
56Answer (n) to keep the external file filename.
57Keep the local version?
58Enter "y" or "n" (or just press <return> for "n") Resolved conflicted state of 'new_file'
59__OUT__
60file_cmp "$TEST_KEY.err" "$TEST_KEY.err" </dev/null
61#-------------------------------------------------------------------------------
62# Tests fcm conflicts: add, add, discard local (status)
63TEST_KEY=$TEST_KEY_BASE-discard-status
64run_pass "$TEST_KEY" svn status --config-dir=$TEST_DIR/.subversion/
65file_cmp "$TEST_KEY.out" "$TEST_KEY.out" <<__OUT__
66 M      .
67M       new_file
68__OUT__
69file_cmp "$TEST_KEY.err" "$TEST_KEY.err" </dev/null
70#-------------------------------------------------------------------------------
71# Tests fcm conflicts: add, add, discard local (info)
72TEST_KEY=$TEST_KEY_BASE-discard-info
73run_pass "$TEST_KEY" svn info new_file
74sed -i "/Date:\|Updated:\|UUID:\|Checksum\|Relative URL:\|Working Copy Root Path:/d" $TEST_DIR/"$TEST_KEY.out"
75file_cmp "$TEST_KEY.out" "$TEST_KEY.out" <<__OUT__
76Path: new_file
77Name: new_file
78URL: $ROOT_URL/branches/dev/Share/ctrl/new_file
79Repository Root: $REPOS_URL
80Revision: 7
81Node Kind: file
82Schedule: normal
83Last Changed Author: $LOGNAME
84Last Changed Rev: 6
85
86__OUT__
87file_cmp "$TEST_KEY.err" "$TEST_KEY.err" </dev/null
88#-------------------------------------------------------------------------------
89# Tests fcm conflicts: add, add, discard local (cat)
90TEST_KEY=$TEST_KEY_BASE-discard-cat
91run_pass "$TEST_KEY" cat new_file
92file_cmp "$TEST_KEY.out" "$TEST_KEY.out" <<__OUT__
93Merge contents (1)
94Merge contents (2)
95__OUT__
96file_cmp "$TEST_KEY.err" "$TEST_KEY.err" </dev/null
97#-------------------------------------------------------------------------------
98cd $TEST_DIR
99rm -rf $TEST_DIR/wc
100mkdir $TEST_DIR/wc
101svn checkout -q $ROOT_URL/branches/dev/Share/ctrl $TEST_DIR/wc
102cd $TEST_DIR/wc
103#-------------------------------------------------------------------------------
104# Tests fcm conflicts: add, add, keep local
105TEST_KEY=$TEST_KEY_BASE-keep
106fcm merge --non-interactive $ROOT_URL/branches/dev/Share/add_add >/dev/null
107run_pass "$TEST_KEY" fcm conflicts <<__IN__
108y
109__IN__
110file_cmp "$TEST_KEY.out" "$TEST_KEY.out" <<__OUT__
111[info] new_file: in tree conflict.
112Locally: added.
113Externally: added.
114Answer (y) to keep the local file filename.
115Answer (n) to keep the external file filename.
116Keep the local version?
117Enter "y" or "n" (or just press <return> for "n") Resolved conflicted state of 'new_file'
118__OUT__
119file_cmp "$TEST_KEY.err" "$TEST_KEY.err" </dev/null
120#-------------------------------------------------------------------------------
121# Tests fcm conflicts: add, add, keep local (status)
122TEST_KEY=$TEST_KEY_BASE-keep-status
123run_pass "$TEST_KEY" svn status --config-dir=$TEST_DIR/.subversion/
124file_cmp "$TEST_KEY.out" "$TEST_KEY.out" <<__OUT__
125 M      .
126__OUT__
127file_cmp "$TEST_KEY.err" "$TEST_KEY.err" </dev/null
128#-------------------------------------------------------------------------------
129# Tests fcm conflicts: add, add, keep local (info)
130TEST_KEY=$TEST_KEY_BASE-keep-info
131run_pass "$TEST_KEY" svn info new_file
132sed -i "/Date:\|Updated:\|UUID:\|Checksum\|Relative URL:\|Working Copy Root Path:/d" $TEST_DIR/"$TEST_KEY.out"
133file_cmp "$TEST_KEY.out" "$TEST_KEY.out" <<__OUT__
134Path: new_file
135Name: new_file
136URL: $ROOT_URL/branches/dev/Share/ctrl/new_file
137Repository Root: $REPOS_URL
138Revision: 7
139Node Kind: file
140Schedule: normal
141Last Changed Author: $LOGNAME
142Last Changed Rev: 6
143
144__OUT__
145file_cmp "$TEST_KEY.err" "$TEST_KEY.err" </dev/null
146#-------------------------------------------------------------------------------
147# Tests fcm conflicts: add, add, keep local (cat)
148TEST_KEY=$TEST_KEY_BASE-keep-cat
149run_pass "$TEST_KEY" cat new_file
150file_cmp "$TEST_KEY.out" "$TEST_KEY.out" <<__OUT__
151Local contents (1)
152__OUT__
153file_cmp "$TEST_KEY.err" "$TEST_KEY.err" </dev/null
154teardown
155#-------------------------------------------------------------------------------
Note: See TracBrowser for help on using the repository browser.