test-fib-matching: FIB matching test scenario

Change-Id: Ib309cad378cdfb89e7ddfc0e35d45a98c92ddfd3
refs: #1385
diff --git a/test_fib_matching/test_fib_matching.py b/test_fib_matching/test_fib_matching.py
new file mode 100644
index 0000000..0570f64
--- /dev/null
+++ b/test_fib_matching/test_fib_matching.py
@@ -0,0 +1,240 @@
+#!/usr/bin/python2
+# -*- Mode:python; c-file-style:"gnu"; indent-tabs-mode:nil -*- */
+#
+# Copyright (C) 2014 University of Arizona
+# Author: Jerald Paul Abraham <jeraldabraham@email.arizona.edu>
+# See COPYING for copyright and distribution information.
+#
+
+import os
+import time
+import unittest
+import process_manager
+
+class test_fib_matching(unittest.TestCase, process_manager.ProcessManager):
+    """Test case for testing fib matching"""
+
+    def setUp(self):
+        print "\nTesting FIB Matching"
+        print "********************"
+
+    def tearDown(self):
+        self.killNfd()
+        try:
+            self.killProcess("ndn-traffic-server-1")
+            self.killProcess("ndn-traffic-server-2")
+            self.killProcess("ndn-traffic-server-3")
+            self.killProcess("ndn-traffic-server-4")
+            self.killProcess("ndn-traffic-client-1")
+            self.killProcess("ndn-traffic-client-2")
+            self.killProcess("ndn-traffic-client-3")
+            self.killProcess("ndn-traffic-client-4")
+            self.killProcess("ndn-traffic-client-5")
+            self.killProcess("ndn-traffic-client-6")
+            self.killProcess("ndn-traffic-client-7")
+            self.killProcess("ndn-traffic-client-8")
+            self.killProcess("ndn-traffic-client-9")
+            self.killProcess("ndn-traffic-client-10")
+            self.cleanupProcesses()
+        except IOError as e:
+            self.cleanupProcesses()
+            pass
+
+    def checkAndReportFailure(self, processKey, processName):
+        if self.hasProcessCompleted(processKey):
+            if self.getProcessReturnCode(processKey) != 0:
+                print self.getProcessOutput(processKey)
+                print self.getProcessError(processKey)
+                self.fail(">> TEST FAILED - received non-zero return code from " + processName)
+        else:
+            self.fail(">> TEST FAILED - " + processName + " failed to complete")
+
+    def test_matching(self):
+
+        #Start NFD
+        self.startNfd()
+        time.sleep(1)
+
+        #Start ndn-traffic-server to serve ndn:/ with Content "Z", FreshnessPeriod=10ms
+        #Prefix registration using NFD FibMgmt
+        serverConfigurationFile = os.path.abspath(
+            "test_fib_matching/test-traffic-server-1.conf")
+        self.startProcess("ndn-traffic-server-1",
+            ["ndn-traffic-server", serverConfigurationFile],
+            "-> Starting Traffic Server 1 (Prefix=ndn:/, FreshnessPeriod=10ms, Data=Z)")
+        time.sleep(0.1)
+
+        #Start ndn-traffic-server to serve ndn:/A with Content "A", FreshnessPeriod=10ms
+        #Prefix registration using NFD FibMgmt
+        serverConfigurationFile = os.path.abspath(
+            "test_fib_matching/test-traffic-server-2.conf")
+        self.startProcess("ndn-traffic-server-2",
+            ["ndn-traffic-server", serverConfigurationFile],
+            "-> Starting Traffic Server 2 (Prefix=ndn:/A, FreshnessPeriod=10ms, Data=A)")
+        time.sleep(0.1)
+
+        #Start ndn-traffic-server to serve ndn:/A/B/C with Content "C", FreshnessPeriod=10ms
+        #Prefix registration using NFD FibMgmt
+        serverConfigurationFile = os.path.abspath(
+            "test_fib_matching/test-traffic-server-3.conf")
+        self.startProcess("ndn-traffic-server-3",
+            ["ndn-traffic-server", serverConfigurationFile],
+            "-> Starting Traffic Server 3 (Prefix=ndn:/A/B/C, FreshnessPeriod=10ms, Data=C)")
+        time.sleep(0.1)
+
+        #Start ndn-traffic-server to serve ndn:/D/E with Content "E", FreshnessPeriod=10ms
+        #Prefix registration using NFD FibMgmt
+        serverConfigurationFile = os.path.abspath(
+            "test_fib_matching/test-traffic-server-4.conf")
+        self.startProcess("ndn-traffic-server-4",
+            ["ndn-traffic-server", serverConfigurationFile],
+            "-> Starting Traffic Server 4 (Prefix=ndn:/D/E, FreshnessPeriod=10ms, Data=E)")
+        time.sleep(0.1)
+
+        #Invoke ndn-traffic to request ndn:/ MustBeFresh=yes
+        #Fail if unanswered. Fail if Content is not "Z".
+        clientConfigurationFile = os.path.abspath(
+            "test_fib_matching/test-traffic-client-1.conf")
+        self.startProcess("ndn-traffic-client-1",
+            ["ndn-traffic", "-c 1", clientConfigurationFile],
+            ("-> Starting Traffic Client 1 (Prefix=ndn:/, MustBeFresh=Yes,"
+             " ExpectedContent=Z, MaxSuffixComponents=2)"))
+        self.waitForProcessCompletion("ndn-traffic-client-1", 10)
+        self.checkAndReportFailure("ndn-traffic-client-1", "Traffic Client 1")
+        print "-> Traffic Client 1 received data with Content=Z"
+
+        #Wait 100ms
+        time.sleep(0.1)
+
+        #Invoke ndn-traffic to request ndn:/F MustBeFresh=yes
+        #Fail if unanswered. Fail if Content is not "Z".
+        clientConfigurationFile = os.path.abspath(
+            "test_fib_matching/test-traffic-client-2.conf")
+        self.startProcess("ndn-traffic-client-2",
+            ["ndn-traffic", "-c 1", clientConfigurationFile],
+            "-> Starting Traffic Client 2 (Prefix=ndn:/F, MustBeFresh=Yes, ExpectedContent=Z)")
+        self.waitForProcessCompletion("ndn-traffic-client-2", 10)
+        self.checkAndReportFailure("ndn-traffic-client-2", "Traffic Client 2")
+        print "-> Traffic Client 2 received data with Content=Z"
+
+        #Wait 100ms
+        time.sleep(0.1)
+
+        #Invoke ndn-traffic to request ndn:/A MustBeFresh=yes
+        #Fail if unanswered. Fail if Content is not "A".
+        clientConfigurationFile = os.path.abspath(
+            "test_fib_matching/test-traffic-client-3.conf")
+        self.startProcess("ndn-traffic-client-3",
+            ["ndn-traffic", "-c 1", clientConfigurationFile],
+            "-> Starting Traffic Client 3 (Prefix=ndn:/A, MustBeFresh=Yes, ExpectedContent=A)")
+        self.waitForProcessCompletion("ndn-traffic-client-3", 10)
+        self.checkAndReportFailure("ndn-traffic-client-3", "Traffic Client 3")
+        print "-> Traffic Client 3 received data with Content=A"
+
+        #Wait 100ms
+        time.sleep(0.1)
+
+        #Invoke ndn-traffic to request ndn:/a MustBeFresh=yes
+        #Fail if unanswered. Fail if Content is not "Z".
+        clientConfigurationFile = os.path.abspath(
+            "test_fib_matching/test-traffic-client-4.conf")
+        self.startProcess("ndn-traffic-client-4",
+            ["ndn-traffic", "-c 1", clientConfigurationFile],
+            "-> Starting Traffic Client 4 (Prefix=ndn:/a, MustBeFresh=Yes, ExpectedContent=Z)")
+        self.waitForProcessCompletion("ndn-traffic-client-4", 10)
+        self.checkAndReportFailure("ndn-traffic-client-4", "Traffic Client 4")
+        print "-> Traffic Client 4 received data with Content=Z"
+
+        #Wait 100ms
+        time.sleep(0.1)
+
+        #Invoke ndn-traffic to request ndn:/A/B MustBeFresh=yes
+        #Fail if unanswered. Fail if Content is not "A".
+        clientConfigurationFile = os.path.abspath(
+            "test_fib_matching/test-traffic-client-5.conf")
+        self.startProcess("ndn-traffic-client-5",
+            ["ndn-traffic", "-c 1", clientConfigurationFile],
+            "-> Starting Traffic Client 5 (Prefix=ndn:/A/B, MustBeFresh=Yes, ExpectedContent=A)")
+        self.waitForProcessCompletion("ndn-traffic-client-5", 10)
+        self.checkAndReportFailure("ndn-traffic-client-5", "Traffic Client 5")
+        print "-> Traffic Client 5 received data with Content=A"
+
+        #Wait 100ms
+        time.sleep(0.1)
+
+        #Invoke ndn-traffic to request ndn:/A/B/G MustBeFresh=yes
+        #Fail if unanswered. Fail if Content is not "A".
+        clientConfigurationFile = os.path.abspath(
+            "test_fib_matching/test-traffic-client-6.conf")
+        self.startProcess("ndn-traffic-client-6",
+            ["ndn-traffic", "-c 1", clientConfigurationFile],
+            "-> Starting Traffic Client 6 (Prefix=ndn:/A/B/G, MustBeFresh=Yes, ExpectedContent=A)")
+        self.waitForProcessCompletion("ndn-traffic-client-6", 10)
+        self.checkAndReportFailure("ndn-traffic-client-6", "Traffic Client 6")
+        print "-> Traffic Client 6 received data with Content=A"
+
+        #Wait 100ms
+        time.sleep(0.1)
+
+        #Invoke ndn-traffic to request ndn:/A/B/C MustBeFresh=yes
+        #Fail if unanswered. Fail if Content is not "C".
+        clientConfigurationFile = os.path.abspath(
+            "test_fib_matching/test-traffic-client-7.conf")
+        self.startProcess("ndn-traffic-client-7",
+            ["ndn-traffic", "-c 1", clientConfigurationFile],
+            "-> Starting Traffic Client 7 (Prefix=ndn:/A/B/C, MustBeFresh=Yes, ExpectedContent=C)")
+        self.waitForProcessCompletion("ndn-traffic-client-7", 10)
+        self.checkAndReportFailure("ndn-traffic-client-7", "Traffic Client 7")
+        print "-> Traffic Client 7 received data with Content=C"
+
+        #Wait 100ms
+        time.sleep(0.1)
+
+        #Invoke ndn-traffic to request ndn:/A/B/C/P/Q/R/S/T/U/V/W/X/Y/Z MustBeFresh=yes
+        #Fail if unanswered. Fail if Content is not "C".
+        clientConfigurationFile = os.path.abspath(
+            "test_fib_matching/test-traffic-client-8.conf")
+        self.startProcess("ndn-traffic-client-8",
+            ["ndn-traffic", "-c 1", clientConfigurationFile],
+            ("-> Starting Traffic Client 8 (Prefix=ndn:/A/B/C/P/Q/R/S/T/U/V/W/X/Y/Z,"
+             " MustBeFresh=Yes, ExpectedContent=C)"))
+        self.waitForProcessCompletion("ndn-traffic-client-8", 10)
+        self.checkAndReportFailure("ndn-traffic-client-8", "Traffic Client 8")
+        print "-> Traffic Client 8 received data with Content=C"
+
+        #Wait 100ms
+        time.sleep(0.1)
+
+        #Invoke ndn-traffic to request ndn:/D MustBeFresh=yes Exclude=[,D]
+        #Fail if unanswered. Fail if Content is not "Z".
+        clientConfigurationFile = os.path.abspath(
+            "test_fib_matching/test-traffic-client-9.conf")
+        self.startProcess("ndn-traffic-client-9",
+            ["ndn-traffic", "-c 1", clientConfigurationFile],
+            ("-> Starting Traffic Client 9 (Prefix=ndn:/D, MustBeFresh=Yes,"
+             " ExcludeBefore=D, ExpectedContent=Z)"))
+        self.waitForProcessCompletion("ndn-traffic-client-9", 10)
+        self.checkAndReportFailure("ndn-traffic-client-9", "Traffic Client 9")
+        print "-> Traffic Client 9 received data with Content=Z"
+
+        #Wait 100ms
+        time.sleep(0.1)
+
+        #Invoke ndn-traffic to request ndn:/D MustBeFresh=yes Exclude=[,E].
+        #Fail if unanswered. Fail if Content is not "Z".
+        clientConfigurationFile = os.path.abspath(
+            "test_fib_matching/test-traffic-client-10.conf")
+        self.startProcess("ndn-traffic-client-10",
+            ["ndn-traffic", "-c 1", clientConfigurationFile],
+            ("-> Starting Traffic Client 10 (Prefix=ndn:/E, MustBeFresh=Yes,"
+             " ExcludeBefore=E, ExpectedContent=Z)"))
+        self.waitForProcessCompletion("ndn-traffic-client-10", 10)
+        self.checkAndReportFailure("ndn-traffic-client-10", "Traffic Client 10")
+        print "-> Traffic Client 10 received data with Content=Z"
+
+        #Stop all four traffic servers
+        self.killProcess("ndn-traffic-server-1")
+        self.killProcess("ndn-traffic-server-2")
+        self.killProcess("ndn-traffic-server-3")
+        self.killProcess("ndn-traffic-server-4")
+        print ">> TEST SUCCESSFUL"