GCC Code Coverage Report


Directory: cvmfs/
File: cvmfs/ingestion/task_read.cc
Date: 2026-05-19 11:45:12
Exec Total Coverage
Lines: 36 40 90.0%
Branches: 37 66 56.1%

Line Branch Exec Source
1 /**
2 * This file is part of the CernVM File System.
3 */
4
5 #include "ingestion/task_read.h"
6
7 #include <errno.h>
8 #include <fcntl.h>
9 #include <unistd.h>
10
11 #include <cstring>
12
13 #include "backoff.h"
14 #include "util/exception.h"
15 #include "util/logging.h"
16 #include "util/platform.h"
17 #include "util/posix.h"
18 #include "util/smalloc.h"
19
20
21 atomic_int64 TaskRead::tag_seq_ = 0;
22
23
24 7000406 void TaskRead::Process(FileItem *item) {
25
1/2
✓ Branch 1 taken 6999790 times.
✗ Branch 2 not taken.
7000406 BackoffThrottle throttle(kThrottleInitMs, kThrottleMaxMs, kThrottleResetMs);
26
6/6
✓ Branch 0 taken 6999699 times.
✓ Branch 1 taken 91 times.
✓ Branch 3 taken 49 times.
✓ Branch 4 taken 7000014 times.
✓ Branch 5 taken 49 times.
✓ Branch 6 taken 7000105 times.
6999790 if ((high_watermark_ > 0) && (BlockItem::managed_bytes() > high_watermark_)) {
27 49 atomic_inc64(&n_block_);
28 do {
29
1/2
✓ Branch 1 taken 343 times.
✗ Branch 2 not taken.
343 throttle.Throttle();
30
2/2
✓ Branch 1 taken 294 times.
✓ Branch 2 taken 49 times.
343 } while (BlockItem::managed_bytes() > low_watermark_);
31 }
32
33
2/4
✓ Branch 1 taken 6998698 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✓ Branch 4 taken 6998698 times.
7000154 if (item->Open() == false) {
34 PANIC(kLogStderr, "failed to open %s (%d)", item->path().c_str(), errno);
35 }
36 uint64_t size;
37
2/4
✓ Branch 1 taken 6997550 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✓ Branch 4 taken 6997550 times.
6998698 if (item->GetSize(&size) == false) {
38 PANIC(kLogStderr, "failed to fstat %s (%d)", item->path().c_str(), errno);
39 }
40 6997550 item->set_size(size);
41
42
2/2
✓ Branch 1 taken 6995331 times.
✓ Branch 2 taken 2023 times.
6997186 if (item->may_have_chunks()) {
43 13990578 item->set_may_have_chunks(
44
1/2
✓ Branch 3 taken 6995247 times.
✗ Branch 4 not taken.
6995331 item->chunk_detector()->MightFindChunks(item->size()));
45 }
46
47 unsigned char *buffer[kBlockSize];
48 6996738 const uint64_t tag = atomic_xadd64(&tag_seq_, 1);
49 7002086 ssize_t nbytes = -1;
50 7002086 unsigned cnt = 0;
51 do {
52
1/2
✓ Branch 1 taken 15484951 times.
✗ Branch 2 not taken.
15467731 nbytes = item->Read(buffer, kBlockSize);
53
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 15484951 times.
15484951 if (nbytes < 0) {
54 PANIC(kLogStderr, "failed to read %s (%d)", item->path().c_str(), errno);
55 }
56
57
2/4
✓ Branch 1 taken 15483215 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 15448019 times.
✗ Branch 5 not taken.
15484951 BlockItem *block_item = new BlockItem(tag, allocator_);
58
1/2
✓ Branch 1 taken 15445023 times.
✗ Branch 2 not taken.
15448019 block_item->SetFileItem(item);
59
2/2
✓ Branch 0 taken 6989598 times.
✓ Branch 1 taken 8455425 times.
15445023 if (nbytes == 0) {
60
1/2
✓ Branch 1 taken 6989962 times.
✗ Branch 2 not taken.
6989598 item->Close();
61
1/2
✓ Branch 1 taken 6989402 times.
✗ Branch 2 not taken.
6989962 block_item->MakeStop();
62 } else {
63
1/2
✓ Branch 1 taken 8507701 times.
✗ Branch 2 not taken.
8455425 block_item->MakeDataCopy(reinterpret_cast<unsigned char *>(buffer),
64 nbytes);
65 }
66
1/2
✓ Branch 1 taken 15453255 times.
✗ Branch 2 not taken.
15497103 tubes_out_->Dispatch(block_item);
67
68 15453255 cnt++;
69
2/2
✓ Branch 0 taken 47236 times.
✓ Branch 1 taken 15406019 times.
15453255 if ((cnt % 32) == 0) {
70 94500 if ((high_watermark_ > 0)
71
3/6
✓ Branch 0 taken 47236 times.
✗ Branch 1 not taken.
✗ Branch 3 not taken.
✓ Branch 4 taken 47264 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 47264 times.
47236 && (BlockItem::managed_bytes() > high_watermark_)) {
72 throttle.Throttle();
73 }
74 }
75
2/2
✓ Branch 0 taken 8465645 times.
✓ Branch 1 taken 6987638 times.
15453283 } while (nbytes > 0);
76 6987638 }
77
78
79 84401 void TaskRead::SetWatermarks(uint64_t low, uint64_t high) {
80
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 84401 times.
84401 assert(high > low);
81
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 84401 times.
84401 assert(low > 0);
82 84401 low_watermark_ = low;
83 84401 high_watermark_ = high;
84 84401 }
85