mirror of
https://github.com/s3fs-fuse/s3fs-fuse.git
synced 2025-01-03 05:00:15 +00:00
Replace dd if=/dev/urandom with junk data generator (#1786)
This reduces test run time for a single flag from 73 to 60 seconds.
This commit is contained in:
parent
473da56abf
commit
86317dd185
2
.gitignore
vendored
2
.gitignore
vendored
@ -77,7 +77,9 @@ src/test_curl_util
|
|||||||
src/test_page_list
|
src/test_page_list
|
||||||
src/test_string_util
|
src/test_string_util
|
||||||
test/chaos-http-proxy-*
|
test/chaos-http-proxy-*
|
||||||
|
test/junk_data
|
||||||
test/s3proxy-*
|
test/s3proxy-*
|
||||||
|
test/write_multiblock
|
||||||
|
|
||||||
#
|
#
|
||||||
# Local variables:
|
# Local variables:
|
||||||
|
@ -30,7 +30,11 @@ EXTRA_DIST = \
|
|||||||
|
|
||||||
testdir = test
|
testdir = test
|
||||||
|
|
||||||
noinst_PROGRAMS = write_multiblock
|
noinst_PROGRAMS = \
|
||||||
|
junk_data \
|
||||||
|
write_multiblock
|
||||||
|
|
||||||
|
junk_data_SOURCES = junk_data.c
|
||||||
write_multiblock_SOURCES = write_multiblock.cc
|
write_multiblock_SOURCES = write_multiblock.cc
|
||||||
|
|
||||||
#
|
#
|
||||||
|
@ -144,8 +144,8 @@ function test_mv_to_exist_file {
|
|||||||
|
|
||||||
BIG_MV_FILE_BLOCK_SIZE=$((BIG_FILE_BLOCK_SIZE + 1))
|
BIG_MV_FILE_BLOCK_SIZE=$((BIG_FILE_BLOCK_SIZE + 1))
|
||||||
|
|
||||||
dd if=/dev/urandom of="${BIG_FILE}" bs=${BIG_FILE_BLOCK_SIZE} count=${BIG_FILE_COUNT}
|
../../junk_data $(($BIG_FILE_BLOCK_SIZE * $BIG_FILE_COUNT)) > "${BIG_FILE}"
|
||||||
dd if=/dev/urandom of="${BIG_FILE}-mv" bs=${BIG_MV_FILE_BLOCK_SIZE} count=${BIG_FILE_COUNT}
|
../../junk_data $(($BIG_FILE_BLOCK_SIZE * $BIG_FILE_COUNT)) > "${BIG_FILE}-mv"
|
||||||
|
|
||||||
mv ${BIG_FILE} ${BIG_FILE}-mv
|
mv ${BIG_FILE} ${BIG_FILE}-mv
|
||||||
|
|
||||||
@ -446,7 +446,7 @@ function test_update_metadata_external_large_object() {
|
|||||||
TEST_SETXATTR_FILE="${TEST_TEXT_FILE}_xattr.${TEST_FILE_EXT}"
|
TEST_SETXATTR_FILE="${TEST_TEXT_FILE}_xattr.${TEST_FILE_EXT}"
|
||||||
TEST_RMXATTR_FILE="${TEST_TEXT_FILE}_xattr.${TEST_FILE_EXT}"
|
TEST_RMXATTR_FILE="${TEST_TEXT_FILE}_xattr.${TEST_FILE_EXT}"
|
||||||
|
|
||||||
dd if=/dev/urandom of="${TEMP_DIR}/${BIG_FILE}" bs=$BIG_FILE_BLOCK_SIZE count=$BIG_FILE_COUNT
|
../../junk_data $(($BIG_FILE_BLOCK_SIZE * $BIG_FILE_COUNT)) > "${TEMP_DIR}/${BIG_FILE}"
|
||||||
|
|
||||||
#
|
#
|
||||||
# chmod
|
# chmod
|
||||||
@ -517,7 +517,7 @@ function test_rename_before_close {
|
|||||||
function test_multipart_upload {
|
function test_multipart_upload {
|
||||||
describe "Testing multi-part upload ..."
|
describe "Testing multi-part upload ..."
|
||||||
|
|
||||||
dd if=/dev/urandom of="${TEMP_DIR}/${BIG_FILE}" bs=$BIG_FILE_BLOCK_SIZE count=$BIG_FILE_COUNT
|
../../junk_data $(($BIG_FILE_BLOCK_SIZE * $BIG_FILE_COUNT)) > "${TEMP_DIR}/${BIG_FILE}"
|
||||||
dd if="${TEMP_DIR}/${BIG_FILE}" of="${BIG_FILE}" bs=$BIG_FILE_BLOCK_SIZE count=$BIG_FILE_COUNT
|
dd if="${TEMP_DIR}/${BIG_FILE}" of="${BIG_FILE}" bs=$BIG_FILE_BLOCK_SIZE count=$BIG_FILE_COUNT
|
||||||
|
|
||||||
# Verify contents of file
|
# Verify contents of file
|
||||||
@ -534,7 +534,7 @@ function test_multipart_upload {
|
|||||||
function test_multipart_copy {
|
function test_multipart_copy {
|
||||||
describe "Testing multi-part copy ..."
|
describe "Testing multi-part copy ..."
|
||||||
|
|
||||||
dd if=/dev/urandom of="${TEMP_DIR}/${BIG_FILE}" bs=$BIG_FILE_BLOCK_SIZE count=$BIG_FILE_COUNT
|
../../junk_data $(($BIG_FILE_BLOCK_SIZE * $BIG_FILE_COUNT)) > "${TEMP_DIR}/${BIG_FILE}"
|
||||||
dd if="${TEMP_DIR}/${BIG_FILE}" of="${BIG_FILE}" bs=$BIG_FILE_BLOCK_SIZE count=$BIG_FILE_COUNT
|
dd if="${TEMP_DIR}/${BIG_FILE}" of="${BIG_FILE}" bs=$BIG_FILE_BLOCK_SIZE count=$BIG_FILE_COUNT
|
||||||
mv "${BIG_FILE}" "${BIG_FILE}-copy"
|
mv "${BIG_FILE}" "${BIG_FILE}-copy"
|
||||||
|
|
||||||
@ -558,7 +558,7 @@ function test_multipart_mix {
|
|||||||
if [ `uname` = "Darwin" ]; then
|
if [ `uname` = "Darwin" ]; then
|
||||||
cat /dev/null > $BIG_FILE
|
cat /dev/null > $BIG_FILE
|
||||||
fi
|
fi
|
||||||
dd if=/dev/urandom of="${TEMP_DIR}/${BIG_FILE}" bs=$BIG_FILE_BLOCK_SIZE count=$BIG_FILE_COUNT
|
../../junk_data $(($BIG_FILE_BLOCK_SIZE * $BIG_FILE_COUNT)) > "${TEMP_DIR}/${BIG_FILE}"
|
||||||
dd if="${TEMP_DIR}/${BIG_FILE}" of="${BIG_FILE}" bs=$BIG_FILE_BLOCK_SIZE count=$BIG_FILE_COUNT
|
dd if="${TEMP_DIR}/${BIG_FILE}" of="${BIG_FILE}" bs=$BIG_FILE_BLOCK_SIZE count=$BIG_FILE_COUNT
|
||||||
|
|
||||||
# (1) Edit the middle of an existing file
|
# (1) Edit the middle of an existing file
|
||||||
@ -638,7 +638,7 @@ function test_multipart_mix {
|
|||||||
function test_utimens_during_multipart {
|
function test_utimens_during_multipart {
|
||||||
describe "Testing utimens calling during multipart copy ..."
|
describe "Testing utimens calling during multipart copy ..."
|
||||||
|
|
||||||
dd if=/dev/urandom of="${TEMP_DIR}/${BIG_FILE}" bs=$BIG_FILE_BLOCK_SIZE count=$BIG_FILE_COUNT
|
../../junk_data $(($BIG_FILE_BLOCK_SIZE * $BIG_FILE_COUNT)) > "${TEMP_DIR}/${BIG_FILE}"
|
||||||
|
|
||||||
cp ${TEMP_DIR}/${BIG_FILE} ${BIG_FILE}
|
cp ${TEMP_DIR}/${BIG_FILE} ${BIG_FILE}
|
||||||
|
|
||||||
@ -1103,7 +1103,7 @@ function test_concurrent_directory_updates {
|
|||||||
|
|
||||||
function test_concurrent_reads {
|
function test_concurrent_reads {
|
||||||
describe "Test concurrent reads from a file ..."
|
describe "Test concurrent reads from a file ..."
|
||||||
dd if=/dev/urandom of="${TEST_TEXT_FILE}" bs=$BIG_FILE_BLOCK_SIZE count=$BIG_FILE_COUNT
|
../../junk_data $(($BIG_FILE_BLOCK_SIZE * $BIG_FILE_COUNT)) > "${TEST_TEXT_FILE}"
|
||||||
for process in `seq 10`; do
|
for process in `seq 10`; do
|
||||||
dd if=${TEST_TEXT_FILE} of=/dev/null seek=$(($RANDOM % $BIG_FILE_LENGTH)) count=16 bs=1024 &
|
dd if=${TEST_TEXT_FILE} of=/dev/null seek=$(($RANDOM % $BIG_FILE_LENGTH)) count=16 bs=1024 &
|
||||||
done
|
done
|
||||||
@ -1113,7 +1113,7 @@ function test_concurrent_reads {
|
|||||||
|
|
||||||
function test_concurrent_writes {
|
function test_concurrent_writes {
|
||||||
describe "Test concurrent writes to a file ..."
|
describe "Test concurrent writes to a file ..."
|
||||||
dd if=/dev/urandom of="${TEST_TEXT_FILE}" bs=$BIG_FILE_BLOCK_SIZE count=$BIG_FILE_COUNT
|
../../junk_data $(($BIG_FILE_BLOCK_SIZE * $BIG_FILE_COUNT)) > "${TEST_TEXT_FILE}"
|
||||||
for process in `seq 10`; do
|
for process in `seq 10`; do
|
||||||
dd if=/dev/zero of=${TEST_TEXT_FILE} seek=$(($RANDOM % $BIG_FILE_LENGTH)) count=16 bs=1024 conv=notrunc &
|
dd if=/dev/zero of=${TEST_TEXT_FILE} seek=$(($RANDOM % $BIG_FILE_LENGTH)) count=16 bs=1024 conv=notrunc &
|
||||||
done
|
done
|
||||||
@ -1152,7 +1152,7 @@ function test_clean_up_cache() {
|
|||||||
mkdir -p $dir
|
mkdir -p $dir
|
||||||
|
|
||||||
for x in $(seq $count); do
|
for x in $(seq $count); do
|
||||||
dd if=/dev/urandom of=$dir/file-$x bs=10485760 count=1
|
../../junk_data 10485760 > $dir/file-$x
|
||||||
done
|
done
|
||||||
|
|
||||||
file_cnt=$(ls $dir | wc -l)
|
file_cnt=$(ls $dir | wc -l)
|
||||||
@ -1227,7 +1227,7 @@ function test_truncate_cache() {
|
|||||||
function test_cache_file_stat() {
|
function test_cache_file_stat() {
|
||||||
describe "Test cache file stat ..."
|
describe "Test cache file stat ..."
|
||||||
|
|
||||||
dd if=/dev/urandom of="${BIG_FILE}" bs=$BIG_FILE_BLOCK_SIZE count=$BIG_FILE_COUNT
|
../../junk_data $(($BIG_FILE_BLOCK_SIZE * $BIG_FILE_COUNT)) > "${BIG_FILE}"
|
||||||
|
|
||||||
#
|
#
|
||||||
# The first argument of the script is "testrun-<random>" the directory name.
|
# The first argument of the script is "testrun-<random>" the directory name.
|
||||||
@ -1383,7 +1383,7 @@ function test_mix_upload_entities() {
|
|||||||
#
|
#
|
||||||
# Make test file
|
# Make test file
|
||||||
#
|
#
|
||||||
dd if=/dev/urandom of="${BIG_FILE}" bs=$BIG_FILE_BLOCK_SIZE count=$BIG_FILE_COUNT
|
../../junk_data $(($BIG_FILE_BLOCK_SIZE * $BIG_FILE_COUNT)) > "${BIG_FILE}"
|
||||||
|
|
||||||
#
|
#
|
||||||
# If the cache option is enabled, delete the cache of uploaded files.
|
# If the cache option is enabled, delete the cache of uploaded files.
|
||||||
@ -1420,7 +1420,7 @@ function test_ensurespace_move_file() {
|
|||||||
# Make test file which is not under mountpoint
|
# Make test file which is not under mountpoint
|
||||||
#
|
#
|
||||||
mkdir -p ${CACHE_DIR}/.s3fs_test_tmpdir
|
mkdir -p ${CACHE_DIR}/.s3fs_test_tmpdir
|
||||||
dd if=/dev/urandom of="${CACHE_DIR}/.s3fs_test_tmpdir/${BIG_FILE}" bs=$BIG_FILE_BLOCK_SIZE count=$BIG_FILE_COUNT
|
../../junk_data $(($BIG_FILE_BLOCK_SIZE * $BIG_FILE_COUNT)) > "${CACHE_DIR}/.s3fs_test_tmpdir/${BIG_FILE}"
|
||||||
|
|
||||||
#
|
#
|
||||||
# Backup file stat
|
# Backup file stat
|
||||||
|
42
test/junk_data.c
Normal file
42
test/junk_data.c
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
/*
|
||||||
|
* s3fs - FUSE-based file system backed by Amazon S3
|
||||||
|
*
|
||||||
|
* Copyright(C) 2021 Andrew Gaul <andrew@gaul.org>
|
||||||
|
*
|
||||||
|
* 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
|
||||||
|
* 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, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
// Generate junk data at high speed. An alternative to dd if=/dev/urandom.
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
|
||||||
|
int main(int argc, char *argv[])
|
||||||
|
{
|
||||||
|
if (argc != 2) {
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
long long count = strtoull(argv[1], NULL, 10);
|
||||||
|
char buf[128 * 1024];
|
||||||
|
long long i;
|
||||||
|
for (i = 0; i < count; i += sizeof(buf)) {
|
||||||
|
long long j;
|
||||||
|
for (j = 0; j < sizeof(buf) / sizeof(i); ++j) {
|
||||||
|
*((long long *)buf + j) = i / sizeof(i) + j;
|
||||||
|
}
|
||||||
|
fwrite(buf, 1, sizeof(buf) > count - i ? count - i : sizeof(buf), stdout);
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user