From: Sergey Poznyakoff Date: Fri, 2 Jun 2006 15:06:10 +0000 (+0000) Subject: Add incr04.at X-Git-Url: https://git.dogcows.com/gitweb?p=chaz%2Ftar;a=commitdiff_plain;h=7cb01d37bb9660bc25bdc66824c82f8bfc1909e8 Add incr04.at --- diff --git a/tests/Makefile.am b/tests/Makefile.am index ea055e3..004814d 100644 --- a/tests/Makefile.am +++ b/tests/Makefile.am @@ -67,6 +67,7 @@ TESTSUITE_AT = \ incr01.at\ incr02.at\ incr03.at\ + incr04.at\ ignfail.at\ link01.at\ listed01.at\ diff --git a/tests/incr04.at b/tests/incr04.at new file mode 100644 index 0000000..42bb781 --- /dev/null +++ b/tests/incr04.at @@ -0,0 +1,63 @@ +# Process this file with autom4te to create testsuite. -*- Autotest -*- + +# Test suite for GNU tar. +# Copyright (C) 2006 Free Software Foundation, Inc. + +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 2, or (at your option) +# any later version. + +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. + +# You should have received a copy of the GNU General Public License +# along with this program; if not, write to the Free Software +# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA +# 02110-1301, USA. + +# Description: Rewritten incremental backup support (2006-05-08) +# missed initialization of all struct directory members in make_directory, +# which lead to random core dumps. +# Reported by Sergey Myasnikov . This testcase uses original +# script provided by him. +# References: <1148669592.5127.81.camel@tigra.sw.ru> +# http://lists.gnu.org/archive/html/bug-tar/2006-05/msg00038.html + +AT_SETUP([proper icontents initialization]) +AT_KEYWORDS([incremental incr04 icontents]) + +m4_define([NAME_PREFIX],[a/b/one_31_chars_long_file_name_]) + +AT_TAR_CHECK([ +AT_TAR_MKHIER(a/b) +awk 'BEGIN { + for (i=1;i<=142;i++) + printf("NAME_PREFIX[%03d]\n", i); + }' < /dev/null | genfile --files-from - + +echo "Initial dump" +tar cvf a0.tar -g a.sna a +mv a/b a/c +echo "Incremental dump" +tar cvf a1.tar -g a.sna a +], +[0], +[Initial dump +a/ +a/b/ +m4_for(I,1,142,1,[NAME_PREFIX[]m4_if(m4_len(I),1,00,m4_len(I),2,0)I +])dnl +Incremental dump +a/ +a/c/ +], +[tar: a/b: Directory is new +tar: a/c: Directory has been renamed from `a/b' +],[],[],[gnu, oldgnu, posix]) + +AT_CLEANUP + +# End of incr04.at diff --git a/tests/testsuite.at b/tests/testsuite.at index 42e90a4..b3a9f32 100644 --- a/tests/testsuite.at +++ b/tests/testsuite.at @@ -85,7 +85,7 @@ test $result -eq 0 && AT_SKIP_TEST m4_define([AT_TAR_MKHIER],[ mkinstalldirs $1 >/dev/null -genfile --file $1/$2]) +m4_if([$2],,,genfile --file [$1]/[$2])]) AT_INIT @@ -122,6 +122,7 @@ m4_include([incr02.at]) m4_include([listed01.at]) m4_include([listed02.at]) m4_include([incr03.at]) +m4_include([incr04.at]) m4_include([rename01.at]) m4_include([rename02.at]) m4_include([rename03.at])