From e9040f2954bc1423a4b2e47883294dce088a12d5 Mon Sep 17 00:00:00 2001
From: Daniel Stenberg <daniel@haxx.se>
Date: Tue, 20 Dec 2011 15:41:43 +0100
Subject: [PATCH] lib500: verify timers relative each other

As commit ce896875f8 fixed a timer that accidentally had been moved in
code and then returned a bad timer, the lib500.c code (used in test 500
and some others) now verifies 5 timers against each other to verify that
they have the correct relative values. We cannot compare against
absolute values as the timings will vary a lot.
---
 tests/libtest/lib500.c | 31 +++++++++++++++++++++++++++++++
 1 file changed, 31 insertions(+)

diff --git a/tests/libtest/lib500.c b/tests/libtest/lib500.c
index 812fb0dd5f..109312b37e 100644
--- a/tests/libtest/lib500.c
+++ b/tests/libtest/lib500.c
@@ -88,7 +88,38 @@ int test(char *URL)
     res = curl_easy_getinfo(curl, CURLINFO_PRIMARY_IP, &ipstr);
     moo = fopen(libtest_arg2, "wb");
     if(moo) {
+      double time_namelookup;
+      double time_connect;
+      double time_pretransfer;
+      double time_starttransfer;
+      double time_total;
       fprintf(moo, "IP: %s\n", ipstr);
+      curl_easy_getinfo(curl, CURLINFO_NAMELOOKUP_TIME, &time_namelookup);
+      curl_easy_getinfo(curl, CURLINFO_CONNECT_TIME, &time_connect);
+      curl_easy_getinfo(curl, CURLINFO_PRETRANSFER_TIME, &time_pretransfer);
+      curl_easy_getinfo(curl, CURLINFO_STARTTRANSFER_TIME,
+                        &time_starttransfer);
+      curl_easy_getinfo(curl, CURLINFO_TOTAL_TIME, &time_total);
+
+      /* since the timing will always vary we only compare relative differences
+         between these 5 times */
+      if(time_namelookup >= time_connect) {
+        fprintf(moo, "namelookup vs connect: %f %f\n",
+                time_namelookup, time_connect);
+      }
+      if(time_connect >= time_pretransfer) {
+        fprintf(moo, "connect vs pretransfer: %f %f\n",
+                time_connect, time_pretransfer);
+      }
+      if(time_pretransfer >= time_starttransfer) {
+        fprintf(moo, "pretransfer vs starttransfer: %f %f\n",
+                time_pretransfer, time_starttransfer);
+      }
+      if(time_starttransfer >= time_total) {
+        fprintf(moo, "starttransfer vs total: %f %f\n",
+                time_starttransfer, time_total);
+      }
+
       fclose(moo);
     }
   }