rib: fix incorrect operator<< output

refs #3423

Change-Id: I22137a1ad2c3b64d74b7ba2fe6b5f7f55486c276
diff --git a/rib/rib.cpp b/rib/rib.cpp
index 97492b2..422de9f 100644
--- a/rib/rib.cpp
+++ b/rib/rib.cpp
@@ -507,7 +507,7 @@
 operator<<(std::ostream& os, const Rib& rib)
 {
   for (const auto& item : rib) {
-    os << item.second << "\n";
+    os << *item.second << "\n";
   }
 
   return os;
diff --git a/tests/rib/rib.t.cpp b/tests/rib/rib.t.cpp
index 9a73ac7..51a8040 100644
--- a/tests/rib/rib.t.cpp
+++ b/tests/rib/rib.t.cpp
@@ -336,6 +336,49 @@
 
 }
 
+BOOST_AUTO_TEST_CASE(Output)
+{
+  rib::Rib rib;
+
+  Route root;
+  Name name1("/");
+  root.faceId = 1;
+  root.origin = 20;
+  root.expires = time::steady_clock::TimePoint::max();
+  rib.insert(name1, root);
+
+  Route route1;
+  Name name2("/hello");
+  route1.faceId = 2;
+  route1.origin = 20;
+  route1.expires = time::steady_clock::TimePoint::max();
+  rib.insert(name2, route1);
+
+  Route route2;
+  Name name3("/hello/world");
+  route2.faceId = 3;
+  route2.origin = 20;
+  route2.expires = time::steady_clock::TimePoint::max();
+  rib.insert(name3, route2);
+
+  const std::string ribStr = std::string(R"TEXT(
+RibEntry {
+	Name: /
+	Route(faceid: 1, origin: 20, cost: 0, flags: 0, never expires)
+}
+RibEntry {
+	Name: /hello
+	Route(faceid: 2, origin: 20, cost: 0, flags: 0, never expires)
+}
+RibEntry {
+	Name: /hello/world
+	Route(faceid: 3, origin: 20, cost: 0, flags: 0, never expires)
+}
+)TEXT").substr(1);
+
+  BOOST_CHECK_EQUAL(boost::lexical_cast<std::string>(rib), ribStr);
+}
+
 BOOST_AUTO_TEST_SUITE_END() // TestRib
 
 } // namespace tests