mirror of
https://github.com/s3fs-fuse/s3fs-fuse.git
synced 2024-11-05 04:17:52 +00:00
6a8a2e4800
Example command line: S3FS_CREDENTIALS_FILE=keyfile \ TEST_BUCKET_1=somebucket \ S3PROXY_BINARY="" \ URL="http://s3.amazonaws.com" ./small-integration-test.sh
94 lines
2.2 KiB
Bash
Executable File
94 lines
2.2 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
#
|
|
# By default tests run against a local s3proxy instance. To run against
|
|
# Amazon S3, specify the following variables:
|
|
#
|
|
# S3FS_CREDENTIALS_FILE=keyfile s3fs format key file
|
|
# TEST_BUCKET_1=bucket Name of bucket to use
|
|
# S3PROXY_BINARY="" Leave empty
|
|
# S3_URL="http://s3.amazonaws.com" Specify Amazon server
|
|
#
|
|
# Example:
|
|
#
|
|
# S3FS_CREDENTIALS_FILE=keyfile TEST_BUCKET_1=bucket S3PROXY_BINARY="" S3_URL="http://s3.amazonaws.com" ./small-integration-test.sh
|
|
#
|
|
|
|
set -o xtrace
|
|
set -o errexit
|
|
|
|
: ${S3_URL:="http://127.0.0.1:8080"}
|
|
|
|
# Require root
|
|
REQUIRE_ROOT=require-root.sh
|
|
#source $REQUIRE_ROOT
|
|
source integration-test-common.sh
|
|
|
|
function retry {
|
|
set +o errexit
|
|
N=$1; shift;
|
|
status=0
|
|
for i in $(seq $N); do
|
|
$@
|
|
status=$?
|
|
if [ $status == 0 ]; then
|
|
break
|
|
fi
|
|
sleep 1
|
|
done
|
|
|
|
if [ $status != 0 ]; then
|
|
echo "timeout waiting for $@"
|
|
fi
|
|
set -o errexit
|
|
return $status
|
|
}
|
|
|
|
function exit_handler {
|
|
if [ -n "${S3PROXY_PID}" ]
|
|
then
|
|
kill $S3PROXY_PID
|
|
fi
|
|
retry 30 fusermount -u $TEST_BUCKET_MOUNT_POINT_1
|
|
}
|
|
trap exit_handler EXIT
|
|
|
|
if [ -n "${S3PROXY_BINARY}" ]
|
|
then
|
|
stdbuf -oL -eL java -jar "$S3PROXY_BINARY" --properties s3proxy.conf | stdbuf -oL -eL sed -u "s/^/s3proxy: /" &
|
|
|
|
# wait for S3Proxy to start
|
|
for i in $(seq 30);
|
|
do
|
|
if exec 3<>"/dev/tcp/localhost/8080";
|
|
then
|
|
exec 3<&- # Close for read
|
|
exec 3>&- # Close for write
|
|
break
|
|
fi
|
|
sleep 1
|
|
done
|
|
|
|
S3PROXY_PID=$(netstat -lpnt | grep :8080 | awk '{ print $7 }' | sed -u 's|/java||')
|
|
fi
|
|
|
|
# Mount the bucket
|
|
if [ ! -d $TEST_BUCKET_MOUNT_POINT_1 ]
|
|
then
|
|
mkdir -p $TEST_BUCKET_MOUNT_POINT_1
|
|
fi
|
|
stdbuf -oL -eL $S3FS $TEST_BUCKET_1 $TEST_BUCKET_MOUNT_POINT_1 \
|
|
-o createbucket \
|
|
-o enable_content_md5 \
|
|
-o passwd_file=$S3FS_CREDENTIALS_FILE \
|
|
-o sigv2 \
|
|
-o singlepart_copy_limit=$((10 * 1024)) \
|
|
-o url=${S3_URL} \
|
|
-o use_path_request_style -f -o f2 -d -d |& stdbuf -oL -eL sed -u "s/^/s3fs: /" &
|
|
|
|
retry 30 grep $TEST_BUCKET_MOUNT_POINT_1 /proc/mounts || exit 1
|
|
|
|
./integration-test-main.sh $TEST_BUCKET_MOUNT_POINT_1
|
|
|
|
echo "All tests complete."
|