• Home
  • Features
  • Pricing
  • Docs
  • Announcements
  • Sign In

PowerDNS / pdns / 19269514820

11 Nov 2025 02:56PM UTC coverage: 73.031% (-0.02%) from 73.048%
19269514820

Pull #16296

github

web-flow
Merge d1b7d115f into 3f17c9598
Pull Request #16296: recursordist: remove boost-filesystem

38283 of 63118 branches covered (60.65%)

Branch coverage included in aggregate %.

6 of 8 new or added lines in 1 file covered. (75.0%)

10771 existing lines in 101 files now uncovered.

127532 of 163930 relevant lines covered (77.8%)

5581985.42 hits per line

Source File
Press 'n' to go to next uncovered line, 'b' for previous

53.15
/pdns/statnode.cc
1
#include "statnode.hh"
2

3
StatNode::Stat StatNode::print(unsigned int depth, Stat newstat, bool silent) const
4
{
×
5
  if(!silent) {
×
6
    cout<<string(depth, ' ');
×
7
    cout<<name<<": "<<endl;
×
8
  }
×
9
  Stat childstat;
×
10
  childstat.queries += s.queries;
×
11
  childstat.noerrors += s.noerrors;
×
12
  childstat.nxdomains += s.nxdomains;
×
13
  childstat.servfails += s.servfails;
×
14
  childstat.drops += s.drops;
×
15
  childstat.bytes += s.bytes;
×
16
  childstat.hits += s.hits;
×
17

18
  if(children.size()>1024 && !silent) {
×
19
    cout<<string(depth, ' ')<<name<<": too many to print"<<endl;
×
20
  }
×
21
  for(const children_t::value_type& child :  children) {
×
22
    childstat=child.second.print(depth+8, childstat, silent || children.size()>1024);
×
23
  }
×
24
  if(!silent || children.size()>1)
×
25
    cout<<string(depth, ' ')<<childstat.queries<<" queries, " << 
×
26
      childstat.noerrors<<" noerrors, "<< 
×
27
      childstat.nxdomains<<" nxdomains, "<< 
×
28
      childstat.servfails<<" servfails, "<< 
×
29
      childstat.drops<<" drops, "<<
×
30
      childstat.bytes<<" bytes, "<<
×
31
      childstat.hits<<" hits"<<endl;
×
32

33
  newstat+=childstat;
×
34

35
  return newstat;
×
36
}
×
37

38
void StatNode::visit(const visitor_t& visitor, Stat& newstat, unsigned int depth) const
39
{
1,079✔
40
  Stat childstat(s);
1,079✔
41

42
  for (const auto& child : children) {
1,079✔
43
    child.second.visit(visitor, childstat, depth+8);
1,068✔
44
  }
1,068✔
45

46
  visitor(this, s, childstat);
1,079✔
47

48
  newstat += childstat;
1,079✔
49
}
1,079✔
50

51
void StatNode::submit(const DNSName& domain, int rcode, unsigned int bytes, bool hit, const std::optional<ComboAddress>& remote)
52
{
1,031✔
53
  //  cerr<<"FIRST submit called on '"<<domain<<"'"<<endl;
54
  std::vector<string> tmp = domain.getRawLabels();
1,031✔
55
  if (tmp.empty()) {
1,031!
56
    return;
×
57
  }
×
58

59
  auto last = tmp.end() - 1;
1,031✔
60
  children[*last].submit(last, tmp.begin(), "", rcode, bytes, remote, 1, hit);
1,031✔
61
}
1,031✔
62

63
/* www.powerdns.com. -> 
64
   .                 <- fullnames
65
   com.
66
   powerdns.com
67
   www.powerdns.com. 
68
*/
69

70
void StatNode::submit(std::vector<string>::const_iterator end, std::vector<string>::const_iterator begin, const std::string& domain, int rcode, unsigned int bytes, const std::optional<ComboAddress>& remote, unsigned int count, bool hit)
71
{
4,134✔
72
  //  cerr<<"Submit called for domain='"<<domain<<"': ";
73
  //  for(const std::string& n :  labels) 
74
  //    cerr<<n<<".";
75
  //  cerr<<endl;
76
  if (name.empty()) {
4,134✔
77

78
    name=*end;
1,068✔
79
    //    cerr<<"Set short name to '"<<name<<"'"<<endl;
80
  }
1,068✔
81
  else {
3,066✔
82
    //    cerr<<"Short name was already set to '"<<name<<"'"<<endl;
83
  }
3,066✔
84

85
  if (end == begin) {
4,134✔
86
    if (fullname.empty()) {
1,031✔
87
      size_t needed = name.size() + 1 + domain.size();
1,030✔
88
      if (fullname.capacity() < needed) {
1,030!
89
        fullname.reserve(needed);
1,030✔
90
      }
1,030✔
91
      fullname = name;
1,030✔
92
      fullname.append(".");
1,030✔
93
      fullname.append(domain);
1,030✔
94
      labelsCount = count;
1,030✔
95
    }
1,030✔
96
    //    cerr<<"Hit the end, set our fullname to '"<<fullname<<"'"<<endl<<endl;
97
    s.queries++;
1,031✔
98
    s.bytes += bytes;
1,031✔
99
    if (rcode < 0) {
1,031!
100
      s.drops++;
×
101
    }
×
102
    else if (rcode == RCode::NoError) {
1,031!
103
      s.noerrors++;
1,031✔
104
    }
1,031✔
105
    else if (rcode == RCode::ServFail) {
×
106
      s.servfails++;
×
107
    }
×
108
    else if (rcode == RCode::NXDomain) {
×
109
      s.nxdomains++;
×
110
    }
×
111

112
    if (remote) {
1,031!
113
      s.remotes[*remote]++;
×
114
    }
×
115

116
    if (hit) {
1,031✔
UNCOV
117
      ++s.hits;
3✔
UNCOV
118
    }
3✔
119
  }
1,031✔
120
  else {
3,103✔
121
    if (fullname.empty()) {
3,103✔
122
      size_t needed = name.size() + 1 + domain.size();
38✔
123
      if (fullname.capacity() < needed) {
38✔
124
        fullname.reserve(needed);
18✔
125
      }
18✔
126
      fullname = name;
38✔
127
      fullname.append(".");
38✔
128
      fullname.append(domain);
38✔
129
      labelsCount = count;
38✔
130
    }
38✔
131
    //    cerr<<"Not yet end, set our fullname to '"<<fullname<<"', recursing"<<endl;
132
    --end;
3,103✔
133
    children[*end].submit(end, begin, fullname, rcode, bytes, remote, count+1, hit);
3,103✔
134
  }
3,103✔
135
}
4,134✔
STATUS · Troubleshooting · Open an Issue · Sales · Support · CAREERS · ENTERPRISE · START FREE · SCHEDULE DEMO
ANNOUNCEMENTS · TWITTER · TOS & SLA · Supported CI Services · What's a CI service? · Automated Testing

© 2026 Coveralls, Inc