/* * Copyright (C) 1996-2017 The Squid Software Foundation and contributors * * Squid software is distributed under GPLv2+ license and includes * contributions from numerous individuals and organizations. * Please see the COPYING and CONTRIBUTORS files for details. */ #define SQUID_HELPER 1 #include "squid.h" #include "tests/testIcmp.h" #include "unitTestMain.h" #include CPPUNIT_TEST_SUITE_REGISTRATION( testIcmp ); void testIcmp::testChecksum() { #if USE_ICMP stubIcmp icmp; uint16_t buf[10], tmpval; for (tmpval=0; tmpval < 10; ++tmpval) buf[tmpval]=htons(1+tmpval); // NULL data CPPUNIT_ASSERT_EQUAL((int)htons(0xffff), icmp.testChecksum(NULL,0)); // NULL data with length!! CPPUNIT_ASSERT_EQUAL((int)htons(0xffff), icmp.testChecksum(NULL,1)); // data with 0 length CPPUNIT_ASSERT_EQUAL((int)htons(0xffff), icmp.testChecksum(buf,0)); // data with invalid length (low) CPPUNIT_ASSERT_EQUAL((int)htons(0xffff), icmp.testChecksum(buf,1)); CPPUNIT_ASSERT_EQUAL((int)htons(0xfffe), icmp.testChecksum(buf,2)); // 1 CPPUNIT_ASSERT_EQUAL((int)htons(0xfffe), icmp.testChecksum(buf,3)); CPPUNIT_ASSERT_EQUAL((int)htons(0xfffc), icmp.testChecksum(buf,4)); // 1+2 CPPUNIT_ASSERT_EQUAL((int)htons(0xfffc), icmp.testChecksum(buf,5)); CPPUNIT_ASSERT_EQUAL((int)htons(0xfff9), icmp.testChecksum(buf,6)); // 1+2+3 CPPUNIT_ASSERT_EQUAL((int)htons(0xfff9), icmp.testChecksum(buf,7)); CPPUNIT_ASSERT_EQUAL((int)htons(0xfff5), icmp.testChecksum(buf,8)); // 1+2+3+4 CPPUNIT_ASSERT_EQUAL((int)htons(0xfff5), icmp.testChecksum(buf,9)); CPPUNIT_ASSERT_EQUAL((int)htons(0xfff0), icmp.testChecksum(buf,10)); // 1+2...+5 CPPUNIT_ASSERT_EQUAL((int)htons(0xfff0), icmp.testChecksum(buf,11)); CPPUNIT_ASSERT_EQUAL((int)htons(0xffea), icmp.testChecksum(buf,12)); // 1+2...+6 CPPUNIT_ASSERT_EQUAL((int)htons(0xffea), icmp.testChecksum(buf,13)); CPPUNIT_ASSERT_EQUAL((int)htons(0xffe3), icmp.testChecksum(buf,14)); // 1+2...+7 CPPUNIT_ASSERT_EQUAL((int)htons(0xffe3), icmp.testChecksum(buf,15)); CPPUNIT_ASSERT_EQUAL((int)htons(0xffdb), icmp.testChecksum(buf,16)); // 1+2...+8 CPPUNIT_ASSERT_EQUAL((int)htons(0xffdb), icmp.testChecksum(buf,17)); CPPUNIT_ASSERT_EQUAL((int)htons(0xffd2), icmp.testChecksum(buf,18)); // 1+2...+9 CPPUNIT_ASSERT_EQUAL((int)htons(0xffd2), icmp.testChecksum(buf,19)); // data with accurate length CPPUNIT_ASSERT_EQUAL((int)htons(0xffc8), icmp.testChecksum(buf,20)); // 1+2...+10 // data with invalid length (overrun) ==> Garbage checksum... #endif } void testIcmp::testHops() { #if USE_ICMP stubIcmp icmp; /* test invalid -(under values) */ // negative : n > 33 CPPUNIT_ASSERT_EQUAL(34, icmp.testHops(-1)); // zero CPPUNIT_ASSERT_EQUAL(33, icmp.testHops(0)); /* test each valid case boundary */ // n(1...32) : 32 >= n >= 1 CPPUNIT_ASSERT_EQUAL(32, icmp.testHops(1)); CPPUNIT_ASSERT_EQUAL(1, icmp.testHops(32)); // n(33...62) : 30 >= n >= 1 CPPUNIT_ASSERT_EQUAL(30, icmp.testHops(33)); CPPUNIT_ASSERT_EQUAL(1, icmp.testHops(62)); // n(63...64) : 2 >= n >= 1 CPPUNIT_ASSERT_EQUAL(2, icmp.testHops(63)); CPPUNIT_ASSERT_EQUAL(1, icmp.testHops(64)); // n(65...128) : 64 >= n >= 1 CPPUNIT_ASSERT_EQUAL(64, icmp.testHops(65)); CPPUNIT_ASSERT_EQUAL(1, icmp.testHops(128)); // n(129...192) : 64 >= n >= 1 CPPUNIT_ASSERT_EQUAL(64, icmp.testHops(129)); CPPUNIT_ASSERT_EQUAL(1, icmp.testHops(192)); // n(193...) : n < 63 CPPUNIT_ASSERT_EQUAL(63, icmp.testHops(193)); CPPUNIT_ASSERT_EQUAL(1, icmp.testHops(255)); /* test invalid (over values) */ // 256 - produces zero CPPUNIT_ASSERT_EQUAL(0, icmp.testHops(256)); // 257 - produces negative hops CPPUNIT_ASSERT_EQUAL(-1, icmp.testHops(257)); #endif }