GCC Code Coverage Report


Directory: cvmfs/
File: cvmfs/ingestion/task_write.cc
Date: 2025-06-29 02:35:41
Exec Total Coverage
Lines: 35 39 89.7%
Branches: 21 35 60.0%

Line Branch Exec Source
1 /**
2 * This file is part of the CernVM File System.
3 */
4
5
6 #include "task_write.h"
7
8 #include <cstdlib>
9
10 #include "upload_facility.h"
11 #include "util/exception.h"
12 #include "util/logging.h"
13
14
15 16564324 void TaskWrite::OnBlockComplete(const upload::UploaderResults &results,
16 BlockItem *block_item) {
17
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 16564324 times.
16564324 if (results.return_code != 0) {
18 PANIC(kLogStderr, "block upload failed (code: %d)", results.return_code);
19 }
20
21
1/2
✓ Branch 0 taken 16564324 times.
✗ Branch 1 not taken.
16564324 delete block_item;
22 16564324 }
23
24
25 9769614 void TaskWrite::OnChunkComplete(const upload::UploaderResults &results,
26 ChunkItem *chunk_item) {
27
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 9769614 times.
9769614 if (results.return_code != 0) {
28 PANIC(kLogStderr, "chunk upload failed (code: %d)", results.return_code);
29 }
30
31 9769614 FileItem *file_item = chunk_item->file_item();
32
1/2
✓ Branch 3 taken 9769614 times.
✗ Branch 4 not taken.
19539228 file_item->RegisterChunk(FileChunk(
33 9769614 *chunk_item->hash_ptr(), chunk_item->offset(), chunk_item->size()));
34
1/2
✓ Branch 0 taken 9769614 times.
✗ Branch 1 not taken.
9769614 delete chunk_item;
35
36
2/2
✓ Branch 1 taken 9752276 times.
✓ Branch 2 taken 17338 times.
9769614 if (file_item->IsProcessed()) {
37 9752276 tubes_out_->DispatchAny(file_item);
38 }
39 9769614 }
40
41
42 26314672 void TaskWrite::Process(BlockItem *input_block) {
43 26314672 ChunkItem *chunk_item = input_block->chunk_item();
44
45 26315530 upload::UploadStreamHandle *handle = chunk_item->upload_handle();
46
2/2
✓ Branch 0 taken 9765558 times.
✓ Branch 1 taken 16547983 times.
26313541 if (handle == NULL) {
47 // The closure passed here, is called by the AbstractUploader as soon as
48 // it successfully committed the complete chunk
49 29297103 handle = uploader_->InitStreamedUpload(
50
2/4
✓ Branch 1 taken 9765207 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 9766338 times.
✗ Branch 5 not taken.
9765558 upload::AbstractUploader::MakeClosure(
51 &TaskWrite::OnChunkComplete, this, chunk_item));
52
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 9766338 times.
9766338 assert(handle != NULL);
53 9766338 chunk_item->set_upload_handle(handle);
54 }
55
56
2/3
✓ Branch 1 taken 16553677 times.
✓ Branch 2 taken 9766260 times.
✗ Branch 3 not taken.
26313463 switch (input_block->type()) {
57 16553677 case BlockItem::kBlockData:
58
1/2
✓ Branch 2 taken 16562881 times.
✗ Branch 3 not taken.
16549738 uploader_->ScheduleUpload(
59 handle,
60 16549348 upload::AbstractUploader::UploadBuffer(input_block->size(),
61 16550947 input_block->data()),
62
1/2
✓ Branch 1 taken 16550947 times.
✗ Branch 2 not taken.
16553677 upload::AbstractUploader::MakeClosure(
63 &TaskWrite::OnBlockComplete, this, input_block));
64 16562881 break;
65 9766260 case BlockItem::kBlockStop:
66 // If there is a sole piece and a legacy bulk chunk, two times the same
67 // chunk is being uploaded. Well. It doesn't hurt.
68
2/2
✓ Branch 1 taken 46 times.
✓ Branch 2 taken 9766058 times.
9766260 if (chunk_item->IsSolePiece()) {
69
1/2
✓ Branch 1 taken 46 times.
✗ Branch 2 not taken.
46 chunk_item->MakeBulkChunk();
70 }
71
1/2
✓ Branch 2 taken 9768366 times.
✗ Branch 3 not taken.
9766104 uploader_->ScheduleCommit(handle, *chunk_item->hash_ptr());
72
1/2
✓ Branch 0 taken 9768405 times.
✗ Branch 1 not taken.
9768366 delete input_block;
73 9769458 break;
74 default:
75 PANIC(NULL);
76 }
77 26332339 }
78