chunks: show correct packet loss stats in AIMD pipeline output

Besides, AIMD pipeline prints a proper message when no RTT
measurements are available.

Change-Id: I9cbda88a005ba33cba753468f8f60f0d39281ab7
refs: #4437, #4551
diff --git a/tests/chunks/pipeline-interests-aimd.t.cpp b/tests/chunks/pipeline-interests-aimd.t.cpp
index 98ba9ea..2deed18 100644
--- a/tests/chunks/pipeline-interests-aimd.t.cpp
+++ b/tests/chunks/pipeline-interests-aimd.t.cpp
@@ -472,6 +472,30 @@
   BOOST_CHECK_EQUAL(hasFailed, false);
 }
 
+BOOST_AUTO_TEST_CASE(PrintSummaryWithNoRttMeasurements)
+{
+  // test the console ouptut when no RTT measurement is available,
+  // to make sure a proper message will be printed out
+
+  std::stringstream ss;
+
+  // change the underlying buffer and save the old buffer
+  auto oldBuf = std::cerr.rdbuf(ss.rdbuf());
+
+  aimdPipeline->printSummary();
+  std::string line;
+
+  bool found = false;
+  while (std::getline(ss, line)) {
+    if (line == "RTT stats unavailable") {
+      found = true;
+      break;
+    }
+  }
+  BOOST_CHECK(found);
+  std::cerr.rdbuf(oldBuf); // reset
+}
+
 BOOST_AUTO_TEST_SUITE_END() // TestPipelineInterestsAimd
 BOOST_AUTO_TEST_SUITE_END() // Chunks
 
diff --git a/tools/chunks/catchunks/pipeline-interests-aimd.cpp b/tools/chunks/catchunks/pipeline-interests-aimd.cpp
index bf530ff..cdf502d 100644
--- a/tools/chunks/catchunks/pipeline-interests-aimd.cpp
+++ b/tools/chunks/catchunks/pipeline-interests-aimd.cpp
@@ -51,6 +51,7 @@
   , m_nLossEvents(0)
   , m_nRetransmitted(0)
   , m_nCongMarks(0)
+  , m_nSent(0)
   , m_cwnd(m_options.initCwnd)
   , m_ssthresh(m_options.initSsthresh)
   , m_hasFailure(false)
@@ -162,6 +163,7 @@
                                            bind(&PipelineInterestsAimd::handleNack, this, _1, _2),
                                            bind(&PipelineInterestsAimd::handleLifetimeExpiration, this, _1));
   m_nInFlight++;
+  m_nSent++;
 
   if (isRetransmission) {
     SegmentInfo& segInfo = m_segmentInfo[segNo];
@@ -437,15 +439,23 @@
 PipelineInterestsAimd::printSummary() const
 {
   PipelineInterests::printSummary();
-  std::cerr << "Total # of packet loss events: " << m_nLossEvents << "\n"
+  std::cerr << "Total # of lost/retransmitted segments: " << m_nRetransmitted
+            << " (caused " << m_nLossEvents << " window decreases)\n"
             << "Packet loss rate: "
-            << static_cast<double>(m_nLossEvents) / static_cast<double>(m_nReceived) << "\n"
-            << "Total # of retransmitted segments: " << m_nRetransmitted << "\n"
+            << (static_cast<double>(m_nRetransmitted) / static_cast<double>(m_nSent)) * 100 << "%\n"
             << "Total # of received congestion marks: " << m_nCongMarks << "\n"
-            << "RTT min/avg/max = " << std::fixed << std::setprecision(3)
-                                    << m_rttEstimator.getMinRtt() << "/"
-                                    << m_rttEstimator.getAvgRtt() << "/"
-                                    << m_rttEstimator.getMaxRtt() << " ms\n";
+            << "RTT ";
+
+  if (m_rttEstimator.getMinRtt() == std::numeric_limits<double>::max() ||
+      m_rttEstimator.getMaxRtt() == std::numeric_limits<double>::min()) {
+     std::cerr << "stats unavailable\n";
+   }
+   else {
+     std::cerr << "min/avg/max = " << std::fixed << std::setprecision(3)
+                                   << m_rttEstimator.getMinRtt() << "/"
+                                   << m_rttEstimator.getAvgRtt() << "/"
+                                   << m_rttEstimator.getMaxRtt() << " ms\n";
+  }
 }
 
 std::ostream&
diff --git a/tools/chunks/catchunks/pipeline-interests-aimd.hpp b/tools/chunks/catchunks/pipeline-interests-aimd.hpp
index bbc9940..0257e7b 100644
--- a/tools/chunks/catchunks/pipeline-interests-aimd.hpp
+++ b/tools/chunks/catchunks/pipeline-interests-aimd.hpp
@@ -1,6 +1,6 @@
 /* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
 /*
- * Copyright (c) 2016-2017, Regents of the University of California,
+ * Copyright (c) 2016-2018, Regents of the University of California,
  *                          Colorado State University,
  *                          University Pierre & Marie Curie, Sorbonne University.
  *
@@ -184,6 +184,7 @@
   void
   cancelInFlightSegmentsGreaterThan(uint64_t segNo);
 
+PUBLIC_WITH_TESTS_ELSE_PRIVATE:
   void
   printSummary() const final;
 
@@ -203,6 +204,7 @@
   int64_t m_nLossEvents; ///< # of loss events occurred
   int64_t m_nRetransmitted; ///< # of segments retransmitted
   int64_t m_nCongMarks; ///< # of data packets with congestion mark
+  int64_t m_nSent; ///< # of interest packets sent out (including retransmissions)
 
   double m_cwnd; ///< current congestion window size (in segments)
   double m_ssthresh; ///< current slow start threshold