jeraldabraham | b2a2655 | 2014-04-16 21:08:09 -0700 | [diff] [blame^] | 1 | #!/usr/bin/python2 |
| 2 | # -*- Mode:python; c-file-style:"gnu"; indent-tabs-mode:nil -*- */ |
| 3 | # |
| 4 | # Copyright (C) 2014 University of Arizona |
| 5 | # Author: Jerald Paul Abraham <jeraldabraham@email.arizona.edu> |
| 6 | # See COPYING for copyright and distribution information. |
| 7 | # |
| 8 | |
| 9 | import os |
| 10 | import time |
| 11 | import unittest |
| 12 | import process_manager |
| 13 | |
| 14 | class test_interest_aggregation(unittest.TestCase, process_manager.ProcessManager): |
| 15 | """Test case for testing interest aggregation""" |
| 16 | |
| 17 | def setUp(self): |
| 18 | print "\nTesting Interest Aggregation" |
| 19 | print "****************************" |
| 20 | self.logFolder = "test_interest_aggregation/logs/" |
| 21 | if not os.path.exists(self.logFolder): |
| 22 | os.system("mkdir " + self.logFolder) |
| 23 | |
| 24 | def tearDown(self): |
| 25 | self.killNfd() |
| 26 | self.killProcess("ndn-traffic-server-1") |
| 27 | self.killProcess("ndn-tlv-peek-1") |
| 28 | self.killProcess("ndn-tlv-peek-2") |
| 29 | self.killProcess("ndn-traffic-server-2") |
| 30 | self.killProcess("ndn-tlv-peek-3") |
| 31 | self.killProcess("ndn-tlv-peek-4") |
| 32 | self.killProcess("ndn-traffic-server-3") |
| 33 | self.killProcess("ndn-tlv-peek-5") |
| 34 | self.killProcess("ndn-tlv-peek-6") |
| 35 | self.cleanupProcesses() |
| 36 | |
| 37 | def checkAndReportFailure(self, processKey, processName): |
| 38 | if self.hasProcessCompleted(processKey): |
| 39 | if self.getProcessReturnCode(processKey) != 0: |
| 40 | print self.getProcessOutput(processKey) |
| 41 | print self.getProcessError(processKey) |
| 42 | self.fail(">> TEST FAILED - received non-zero return code from " + processName) |
| 43 | else: |
| 44 | self.fail(">> TEST FAILED - " + processName + " failed to complete") |
| 45 | |
| 46 | |
| 47 | def checkServerReceiveCount(self, processKey, processName, expectedCount): |
| 48 | serverOutput = self.getProcessOutput(processKey).splitlines() |
| 49 | isTestSuccessful = False |
| 50 | receivedCount = 0 |
| 51 | for logLine in serverOutput: |
| 52 | if "Total Interests Received" in logLine: |
| 53 | for value in logLine.split(): |
| 54 | if value.isdigit(): |
| 55 | receivedCount = int(value) |
| 56 | break |
| 57 | if receivedCount == expectedCount: |
| 58 | isTestSuccessful = True |
| 59 | break |
| 60 | if not isTestSuccessful: |
| 61 | self.fail(">> TEST FAILED - " + processName + |
| 62 | " expected to receive only " + str(expectedCount) + |
| 63 | " interest(s) but received " + str(receivedCount) + " interest(s)" ) |
| 64 | else: |
| 65 | print "-> " + processName + " received " + str(receivedCount) + " interest(s)" |
| 66 | |
| 67 | def test_aggregation(self): |
| 68 | |
| 69 | #Start NFD |
| 70 | self.startNfd() |
| 71 | time.sleep(1) |
| 72 | |
| 73 | #Start ndn-traffic-server to serve ndn:/test-agg, with content delay set to 2000ms |
| 74 | serverConfigurationFile = os.path.abspath( |
| 75 | "test_interest_aggregation/test-traffic-server.conf") |
| 76 | self.startProcess("ndn-traffic-server-1", |
| 77 | ["ndn-traffic-server", serverConfigurationFile], |
| 78 | "-> Starting Traffic Server 1 (Prefix=ndn:/test-agg, ContentDelay=2000ms)") |
| 79 | time.sleep(1) |
| 80 | |
| 81 | #Start two instances of ndn-tlv-peek to request ndn:/test-agg/A. Wait until they |
| 82 | #terminate. Fail if either is unanswered. |
| 83 | peekOutputFile = os.path.abspath(self.logFolder + "test-peek-output-1.txt") |
| 84 | self.startProcess("ndn-tlv-peek-1", |
| 85 | ["ndn-tlv-peek", "ndn:/test-agg/A"], |
| 86 | "-> Starting Peek Client 1 (Prefix=ndn:/test-agg/A)", |
| 87 | outputFile=peekOutputFile) |
| 88 | peekOutputFile = os.path.abspath(self.logFolder + "test-peek-output-2.txt") |
| 89 | self.startProcess("ndn-tlv-peek-2", |
| 90 | ["ndn-tlv-peek", "ndn:/test-agg/A"], |
| 91 | "-> Starting Peek Client 2 (Prefix=ndn:/test-agg/A)", |
| 92 | outputFile=peekOutputFile) |
| 93 | self.waitForProcessCompletion("ndn-tlv-peek-1", 10) |
| 94 | self.waitForProcessCompletion("ndn-tlv-peek-2", 10) |
| 95 | |
| 96 | #Stop ndn-traffic-server. Fail if total served Interest does not equal 1. |
| 97 | self.killProcess("ndn-traffic-server-1") |
| 98 | time.sleep(1) |
| 99 | print "-> Stopping Traffic Server 1" |
| 100 | self.checkAndReportFailure("ndn-tlv-peek-1", "Peek Client 1") |
| 101 | self.checkAndReportFailure("ndn-tlv-peek-2", "Peek Client 2") |
| 102 | self.checkServerReceiveCount("ndn-traffic-server-1", "Traffic Server 1", 1) |
| 103 | |
| 104 | #Start ndn-traffic-server to serve ndn:/test-agg, with content delay set to 2000ms |
| 105 | self.startProcess("ndn-traffic-server-2", |
| 106 | ["ndn-traffic-server", serverConfigurationFile], |
| 107 | "-> Starting Traffic Server 2 (Prefix=ndn:/test-agg, ContentDelay=2000ms)") |
| 108 | time.sleep(1) |
| 109 | |
| 110 | #Start ndn-tlv-peek to request ndn:/test-agg/B ChildSelector=leftmost, and another |
| 111 | #instance to request ndn:/test-agg/B ChildSelector=rightmost. Wait until they terminate. |
| 112 | #Fail if either is unanswered. |
| 113 | peekOutputFile = os.path.abspath(self.logFolder + "test-peek-output-3.txt") |
| 114 | self.startProcess("ndn-tlv-peek-3", |
| 115 | ["ndn-tlv-peek", "ndn:/test-agg/B"], |
| 116 | "-> Starting Peek Client 3 (Prefix=ndn:/test-agg/B, ChildSelector=leftmost)", |
| 117 | outputFile=peekOutputFile) |
| 118 | peekOutputFile = os.path.abspath(self.logFolder + "test-peek-output-4.txt") |
| 119 | self.startProcess("ndn-tlv-peek-4", |
| 120 | ["ndn-tlv-peek", "-r", "ndn:/test-agg/B"], |
| 121 | "-> Starting Peek Client 4 (Prefix=ndn:/test-agg/B, ChildSelector=rightmost)", |
| 122 | outputFile=peekOutputFile) |
| 123 | self.waitForProcessCompletion("ndn-tlv-peek-3", 10) |
| 124 | self.waitForProcessCompletion("ndn-tlv-peek-4", 10) |
| 125 | |
| 126 | #Stop ndn-traffic-server. Fail if total served Interest does not equal 2. |
| 127 | self.killProcess("ndn-traffic-server-2") |
| 128 | time.sleep(1) |
| 129 | print "-> Stopping Traffic Server 2" |
| 130 | self.checkAndReportFailure("ndn-tlv-peek-3", "Peek Client 3") |
| 131 | self.checkAndReportFailure("ndn-tlv-peek-4", "Peek Client 4") |
| 132 | self.checkServerReceiveCount("ndn-traffic-server-2", "Traffic Server 2", 2) |
| 133 | |
| 134 | #Start ndn-traffic-server to serve ndn:/test-agg, with content delay set to 2000ms |
| 135 | self.startProcess("ndn-traffic-server-3", |
| 136 | ["ndn-traffic-server", serverConfigurationFile], |
| 137 | "-> Starting Traffic Server 3 (Prefix=ndn:/test-agg, ContentDelay=2000ms)") |
| 138 | time.sleep(1) |
| 139 | |
| 140 | #Start ndn-tlv-peek to request ndn:/test-agg/C InterestLifetime=6000ms, and another |
| 141 | #instance to request ndn:/test-agg/C. InterestLifetime=8000ms. Wait until they terminate. |
| 142 | #Fail if either is unanswered. |
| 143 | peekOutputFile = os.path.abspath(self.logFolder + "test-peek-output-5.txt") |
| 144 | self.startProcess("ndn-tlv-peek-5", |
| 145 | ["ndn-tlv-peek", "-l 6000", "ndn:/test-agg/C"], |
| 146 | "-> Starting Peek Client 5 (Prefix=ndn:/test-agg/C, InterestLifetime=6000ms)", |
| 147 | outputFile=peekOutputFile) |
| 148 | peekOutputFile = os.path.abspath(self.logFolder + "test-peek-output-6.txt") |
| 149 | self.startProcess("ndn-tlv-peek-6", |
| 150 | ["ndn-tlv-peek", "-l 8000", "ndn:/test-agg/C"], |
| 151 | "-> Starting Peek Client 6 (Prefix=ndn:/test-agg/C, InterestLifetime=8000ms)", |
| 152 | outputFile=peekOutputFile) |
| 153 | self.waitForProcessCompletion("ndn-tlv-peek-5", 10) |
| 154 | self.waitForProcessCompletion("ndn-tlv-peek-6", 10) |
| 155 | |
| 156 | #Stop ndn-traffic-server. Fail if total served Interest does not equal 1. |
| 157 | self.killProcess("ndn-traffic-server-3") |
| 158 | time.sleep(1) |
| 159 | print "-> Stopping Traffic Server 3" |
| 160 | self.checkAndReportFailure("ndn-tlv-peek-5", "Peek Client 5") |
| 161 | self.checkAndReportFailure("ndn-tlv-peek-6", "Peek Client 6") |
| 162 | self.checkServerReceiveCount("ndn-traffic-server-3", "Traffic Server 3", 1) |
| 163 | print ">> TEST SUCCESSFUL" |