[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [PATCH 3/8] split: add tests
From: |
Jim Meyering |
Subject: |
Re: [PATCH 3/8] split: add tests |
Date: |
Sun, 01 May 2011 11:32:47 +0200 |
Pádraig Brady wrote:
> On 30/04/11 14:31, Jim Meyering wrote:
>> +for total_n_lines in 5 3000 20000; do
>> + for i in 2 51 598; do
>> + # Don't create too many files/processes.
>> + case $i:$total_n_lines in 2:5);; *) continue;; esac
>
> So the other combos are only for developer debug?
> A comment to clariy would be good.
> Perhaps they could be enabled if RUN_VERY_EXPENSIVE_TESTS ?
I've added comments in the new version of that file below.
>> + seq $total_n_lines > in || framework_failure_
>
> The `seq` line should be moved to the outer loop
>
>> + split -l$i --filter='xz > $FILE.xz' in out- || fail=1
>> + xz -dc out-* > out || fail=1
>> + compare in out || fail=1
>> + rm -f in out*
>
> Ditto for `rm -f in`
Thanks. Obviously better that way.
#!/bin/sh
# Exercise split's new --filter option.
# Copyright (C) 2011 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 3 of the License, 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, see <http://www.gnu.org/licenses/>.
. "${srcdir=.}/init.sh"; path_prepend_ ../src
print_ver_ split
for total_n_lines in 5 3000 20000; do
seq $total_n_lines > in || framework_failure_
for i in 2 51 598; do
# Don't create too many files/processes.
# Starting 10k (or even "only" 1500) processes would take a long time,
# and would provide little added benefit.
case $i:$total_n_lines in 2:5);; *) continue;; esac
split -l$i --filter='xz > $FILE.xz' in out- || fail=1
xz -dc out-* > out || fail=1
compare in out || fail=1
rm -f out*
done
rm -f in
done
# Show how --elide-empty-files works with --filter:
# split does not run the command (and effectively elides the file)
# only when the output to that command would have been empty.
split -e -n 10 --filter='xz > $FILE.xz' /dev/null || fail=1
stat x?? 2>/dev/null && fail=1
Exit $fail
[Prev in Thread] |
Current Thread |
[Next in Thread] |
- Re: [PATCH 3/8] split: add tests,
Jim Meyering <=