mirror of
https://github.com/s3fs-fuse/s3fs-fuse.git
synced 2025-01-05 05:52:11 +00:00
Fixed a bug upload boundary calculation in StreamUpload
This commit is contained in:
parent
645c10a3c3
commit
cbc33cd7ae
@ -979,7 +979,7 @@ bool PseudoFdInfo::ExtractUploadPartsFromAllArea(UntreatedParts& untreated_list,
|
|||||||
|
|
||||||
if( (copy_riter->start + copy_riter->size) == tmp_cur_start &&
|
if( (copy_riter->start + copy_riter->size) == tmp_cur_start &&
|
||||||
(copy_riter->size + (tmp_cur_untreated_iter->start - tmp_cur_start)) <= FIVE_GB &&
|
(copy_riter->size + (tmp_cur_untreated_iter->start - tmp_cur_start)) <= FIVE_GB &&
|
||||||
((tmp_cur_start + tmp_cur_size) - (tmp_cur_untreated_iter->start - tmp_cur_start)) >= MIN_MULTIPART_SIZE )
|
((tmp_cur_start + tmp_cur_size) - tmp_cur_untreated_iter->start) >= MIN_MULTIPART_SIZE )
|
||||||
{
|
{
|
||||||
//
|
//
|
||||||
// Unify to this area to previouse copy area.
|
// Unify to this area to previouse copy area.
|
||||||
|
@ -2453,6 +2453,76 @@ function test_write_data_with_skip() {
|
|||||||
rm_test_file "${_TMP_SKIPWRITE_FILE}"
|
rm_test_file "${_TMP_SKIPWRITE_FILE}"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function test_not_boundary_writes {
|
||||||
|
describe "Test non-boundary write ..."
|
||||||
|
|
||||||
|
# [MEMO]
|
||||||
|
# Files used in this test, multipart related sizes, etc.
|
||||||
|
#
|
||||||
|
# Test file size: 25MB(25 * 1024 * 1024)
|
||||||
|
# Multipart size: 10MB
|
||||||
|
# Multipart minimum upload size: 5MB
|
||||||
|
#
|
||||||
|
# The multipart upload part that should be executed here is as follows:
|
||||||
|
# Part number 1: 0 - 10,485,759 (size = 10MB)
|
||||||
|
# Part number 2: 10,485,760 - 20,971,519 (size = 10MB)
|
||||||
|
# Part number 3: 20,971,520 - 26,214,399 (size = 5MB)
|
||||||
|
#
|
||||||
|
local BOUNDAY_TEST_FILE_SIZE; BOUNDAY_TEST_FILE_SIZE=$((BIG_FILE_BLOCK_SIZE * BIG_FILE_COUNT))
|
||||||
|
|
||||||
|
../../junk_data "${BOUNDAY_TEST_FILE_SIZE}" > "${TEST_TEXT_FILE}"
|
||||||
|
|
||||||
|
#
|
||||||
|
# Write in First boundary
|
||||||
|
#
|
||||||
|
# Write 0 - 3,145,727(3MB) : less than the multipart minimum size from the beginning
|
||||||
|
dd if=/dev/zero of="${TEST_TEXT_FILE}" seek=0 count=3072 bs=1024 conv=notrunc
|
||||||
|
|
||||||
|
# Write 0 - 7,340,031(7MB) : multipart exceeding the minimum size from the beginning
|
||||||
|
dd if=/dev/zero of="${TEST_TEXT_FILE}" seek=0 count=7168 bs=1024 conv=notrunc
|
||||||
|
|
||||||
|
# Write 0 - 12,582,911(12MB) : beyond the multipart size boundary from the beginning
|
||||||
|
dd if=/dev/zero of="${TEST_TEXT_FILE}" seek=0 count=12288 bs=1024 conv=notrunc
|
||||||
|
|
||||||
|
#
|
||||||
|
# Write in First and second boundary
|
||||||
|
#
|
||||||
|
# Write 3,145,728 - 4,194,303(1MB) : less than the minimum multipart size from the middle of the first multipart area
|
||||||
|
dd if=/dev/zero of="${TEST_TEXT_FILE}" seek=3072 count=1024 bs=1024 conv=notrunc
|
||||||
|
|
||||||
|
# Write 3,145,728 - 9,437,183(6MB) : exceeding the minimum multipart size from the middle of the first multipart area
|
||||||
|
dd if=/dev/zero of="${TEST_TEXT_FILE}" seek=3072 count=6144 bs=1024 conv=notrunc
|
||||||
|
|
||||||
|
# Write 3,145,728 - 12,582,911(9MB) : beyond the multipart boundary from the middle of the first multipart area
|
||||||
|
dd if=/dev/zero of="${TEST_TEXT_FILE}" seek=3072 count=9216 bs=1024 conv=notrunc
|
||||||
|
|
||||||
|
#
|
||||||
|
# Write in Second boundary
|
||||||
|
#
|
||||||
|
# Write 12,582,912 - 14,680,063(2MB) : below the minimum multipart size from the middle of the multipart area
|
||||||
|
dd if=/dev/zero of="${TEST_TEXT_FILE}" seek=12288 count=2048 bs=1024 conv=notrunc
|
||||||
|
|
||||||
|
# Write 12,582,912 - 18,874,367(6MB) : data exceeding the minimum multipart size from the middle of the multipart area
|
||||||
|
dd if=/dev/zero of="${TEST_TEXT_FILE}" seek=12288 count=6144 bs=1024 conv=notrunc
|
||||||
|
|
||||||
|
# Write 12,582,912 - 23,068,671(10MB) : beyond the multipart boundary from the middle of the multipart area
|
||||||
|
dd if=/dev/zero of="${TEST_TEXT_FILE}" seek=12288 count=10240 bs=1024 conv=notrunc
|
||||||
|
|
||||||
|
# Write 12,582,912 - 26,214,399(13MB) : beyond the multipart boundary(last) from the middle of the multipart area
|
||||||
|
dd if=/dev/zero of="${TEST_TEXT_FILE}" seek=12288 count=13312 bs=1024 conv=notrunc
|
||||||
|
|
||||||
|
#
|
||||||
|
# Write in Last boundary
|
||||||
|
#
|
||||||
|
# Write 23,068,672 - 24,117,247(1MB) : below the minimum multipart size from the middle of the final multipart area
|
||||||
|
dd if=/dev/zero of="${TEST_TEXT_FILE}" seek=22528 count=1024 bs=1024 conv=notrunc
|
||||||
|
|
||||||
|
# Write 23,068,672 - 26,214,399(3MB) : beyond the multipart boundary(last) from the middle of the final multipart area
|
||||||
|
dd if=/dev/zero of="${TEST_TEXT_FILE}" seek=22528 count=3072 bs=1024 conv=notrunc
|
||||||
|
|
||||||
|
rm_test_file
|
||||||
|
}
|
||||||
|
|
||||||
function test_chmod_mountpoint {
|
function test_chmod_mountpoint {
|
||||||
describe "Testing chmod to mount point..."
|
describe "Testing chmod to mount point..."
|
||||||
|
|
||||||
@ -2673,6 +2743,7 @@ function add_all_tests {
|
|||||||
add_tests test_ensurespace_move_file
|
add_tests test_ensurespace_move_file
|
||||||
fi
|
fi
|
||||||
add_tests test_write_data_with_skip
|
add_tests test_write_data_with_skip
|
||||||
|
add_tests test_not_boundary_writes
|
||||||
|
|
||||||
# [NOTE]
|
# [NOTE]
|
||||||
# The test on CI will fail depending on the permissions, so skip these(chmod/chown).
|
# The test on CI will fail depending on the permissions, so skip these(chmod/chown).
|
||||||
|
Loading…
Reference in New Issue
Block a user