We skip t7407 because a patch series is cooking that uses is. Signed-off-by: Johannes Sixt <j6t@kdbg.org> Signed-off-by: Junio C Hamano <gitster@pobox.com>
		
			
				
	
	
		
			82 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			82 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 supermodule' \
 | 
						|
'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 `wc -l <super/sub/.git/objects/info/alternates` = 1'
 | 
						|
 | 
						|
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 supermodule' \
 | 
						|
'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 `wc -l <super-clone/sub/.git/objects/info/alternates` = 1'
 | 
						|
 | 
						|
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
 |