mirror of
https://github.com/git/git.git
synced 2024-11-05 16:52:59 +01:00
db0ff2c032
The Git CodingGuidelines prefer the $(...) construct for command substitution instead of using the backquotes `...`. The backquoted form is the traditional method for command substitution, and is supported by POSIX. However, all but the simplest uses become complicated quickly. In particular, embedded command substitutions and/or the use of double quotes require careful escaping with the backslash character. The patch was generated by: for _f in $(find . -name "*.sh") do perl -i -pe 'BEGIN{undef $/;} s/`(.+?)`/\$(\1)/smg' "${_f}" done and then carefully proof-read. Signed-off-by: Elia Pinto <gitter.spiros@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
81 lines
1.8 KiB
Bash
Executable file
81 lines
1.8 KiB
Bash
Executable file
#!/bin/sh
|
|
#
|
|
# Copyright (c) 2009, Red Hat Inc, Author: Michael S. Tsirkin (mst@redhat.com)
|
|
#
|
|
|
|
test_description='test clone --reference'
|
|
. ./test-lib.sh
|
|
|
|
base_dir=$(pwd)
|
|
|
|
U=$base_dir/UPLOAD_LOG
|
|
|
|
test_expect_success 'preparing first repository' \
|
|
'test_create_repo A && cd A &&
|
|
echo first > file1 &&
|
|
git add file1 &&
|
|
git commit -m A-initial'
|
|
|
|
cd "$base_dir"
|
|
|
|
test_expect_success 'preparing second repository' \
|
|
'git clone A B && cd B &&
|
|
echo second > file2 &&
|
|
git add file2 &&
|
|
git commit -m B-addition &&
|
|
git repack -a -d &&
|
|
git prune'
|
|
|
|
cd "$base_dir"
|
|
|
|
test_expect_success 'preparing superproject' \
|
|
'test_create_repo super && cd super &&
|
|
echo file > file &&
|
|
git add file &&
|
|
git commit -m B-super-initial'
|
|
|
|
cd "$base_dir"
|
|
|
|
test_expect_success 'submodule add --reference' \
|
|
'cd super && git submodule add --reference ../B "file://$base_dir/A" sub &&
|
|
git commit -m B-super-added'
|
|
|
|
cd "$base_dir"
|
|
|
|
test_expect_success 'after add: existence of info/alternates' \
|
|
'test_line_count = 1 super/.git/modules/sub/objects/info/alternates'
|
|
|
|
cd "$base_dir"
|
|
|
|
test_expect_success 'that reference gets used with add' \
|
|
'cd super/sub &&
|
|
echo "0 objects, 0 kilobytes" > expected &&
|
|
git count-objects > current &&
|
|
diff expected current'
|
|
|
|
cd "$base_dir"
|
|
|
|
test_expect_success 'cloning superproject' \
|
|
'git clone super super-clone'
|
|
|
|
cd "$base_dir"
|
|
|
|
test_expect_success 'update with reference' \
|
|
'cd super-clone && git submodule update --init --reference ../B'
|
|
|
|
cd "$base_dir"
|
|
|
|
test_expect_success 'after update: existence of info/alternates' \
|
|
'test_line_count = 1 super-clone/.git/modules/sub/objects/info/alternates'
|
|
|
|
cd "$base_dir"
|
|
|
|
test_expect_success 'that reference gets used with update' \
|
|
'cd super-clone/sub &&
|
|
echo "0 objects, 0 kilobytes" > expected &&
|
|
git count-objects > current &&
|
|
diff expected current'
|
|
|
|
cd "$base_dir"
|
|
|
|
test_done
|