You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@trafficserver.apache.org by zw...@apache.org on 2015/09/23 00:47:42 UTC

[1/2] trafficserver git commit: Revert "TS-3885: Clang format"

Repository: trafficserver
Updated Branches:
  refs/heads/master 3eec3878c -> f68e950f3


Revert "TS-3885: Clang format"

This reverts commit 9cb0b497b5bd5e209d728a0aaca22d6c6a7ed7a3.

These commits breaks CI in that the regressions can segfault.
See TS-3926 for details.


Project: http://git-wip-us.apache.org/repos/asf/trafficserver/repo
Commit: http://git-wip-us.apache.org/repos/asf/trafficserver/commit/ddadf76d
Tree: http://git-wip-us.apache.org/repos/asf/trafficserver/tree/ddadf76d
Diff: http://git-wip-us.apache.org/repos/asf/trafficserver/diff/ddadf76d

Branch: refs/heads/master
Commit: ddadf76dab5da54e6c42973e4a21b380b683dce4
Parents: 3eec387
Author: Leif Hedstrom <zw...@apache.org>
Authored: Tue Sep 22 16:46:42 2015 -0600
Committer: Leif Hedstrom <zw...@apache.org>
Committed: Tue Sep 22 16:46:42 2015 -0600

----------------------------------------------------------------------
 proxy/InkAPITest.cc | 17 ++++++++++-------
 1 file changed, 10 insertions(+), 7 deletions(-)
----------------------------------------------------------------------


http://git-wip-us.apache.org/repos/asf/trafficserver/blob/ddadf76d/proxy/InkAPITest.cc
----------------------------------------------------------------------
diff --git a/proxy/InkAPITest.cc b/proxy/InkAPITest.cc
index fae5f9e..6cc2ab9 100644
--- a/proxy/InkAPITest.cc
+++ b/proxy/InkAPITest.cc
@@ -251,8 +251,7 @@ REGRESSION_TEST(SDK_API_TSConfig)(RegressionTest *test, int /* atype ATS_UNUSED
 //////////////////////////////////////////////
 
 struct SDK_NetVConn_Params {
-  SDK_NetVConn_Params(const char *_a, RegressionTest *_t, int *_p)
-    : buffer(NULL), api(_a), port(0), test(_t), pstatus(_p), server_vc(NULL), client_vc(NULL)
+  SDK_NetVConn_Params(const char *_a, RegressionTest *_t, int *_p) : buffer(NULL), api(_a), port(0), test(_t), pstatus(_p), server_vc(NULL), client_vc(NULL)
   {
     this->status.client = this->status.server = REGRESSION_TEST_INPROGRESS;
   }
@@ -373,8 +372,9 @@ client_handler(TSCont contp, TSEvent event, void *data)
     char *ptr_block = TSIOBufferBlockWriteStart(block, &avail);
 
     if (avail <= 0) {
-      SDK_RPRINT(params->test, params->api, "TSIOBufferBlockWriteStart", TC_FAIL, "No space available to write in buffer, "
-                                                                                  "expected %lldd",
+      SDK_RPRINT(params->test, params->api, "TSIOBufferBlockWriteStart", 
+                 TC_FAIL, "No space available to write in buffer, "
+                 "expected %lldd",
                  avail);
       TSContDestroy(contp);
       return 1;
@@ -385,12 +385,15 @@ client_handler(TSCont contp, TSEvent event, void *data)
 
     params->vio = TSVConnWrite((TSVConn)(data), contp, readerp, 1);
     return 0;
-  } else if (event == TS_EVENT_VCONN_WRITE_COMPLETE) {
+  }
+  else if (event == TS_EVENT_VCONN_WRITE_COMPLETE) {
     TSVConnShutdown((TSVConn)params->client_vc, 0, 1);
     TSContDestroy(contp);
     return 0;
-  } else {
-    SDK_RPRINT(params->test, params->api, "ClientConnect", TC_FAIL, "received unexpected event %d", event);
+  }
+  else {
+    SDK_RPRINT(params->test, params->api, "ClientConnect", TC_FAIL, 
+               "received unexpected event %d", event);
   }
 
   TSContDestroy(contp);


[2/2] trafficserver git commit: Revert "TS-3885: Write data on the client socket to fix test hang."

Posted by zw...@apache.org.
Revert "TS-3885: Write data on the client socket to fix test hang."

This reverts commit 72f73aa3cbb05d58fb671f91177f357b8f1a7737.

These commits breaks CI in that the regressions can segfault.
See TS-3926 for details.


Project: http://git-wip-us.apache.org/repos/asf/trafficserver/repo
Commit: http://git-wip-us.apache.org/repos/asf/trafficserver/commit/f68e950f
Tree: http://git-wip-us.apache.org/repos/asf/trafficserver/tree/f68e950f
Diff: http://git-wip-us.apache.org/repos/asf/trafficserver/diff/f68e950f

Branch: refs/heads/master
Commit: f68e950f38f2a7099154d88d2355364126855985
Parents: ddadf76
Author: Leif Hedstrom <zw...@apache.org>
Authored: Tue Sep 22 16:47:20 2015 -0600
Committer: Leif Hedstrom <zw...@apache.org>
Committed: Tue Sep 22 16:47:20 2015 -0600

----------------------------------------------------------------------
 proxy/InkAPITest.cc | 72 +++++++++++++-----------------------------------
 1 file changed, 19 insertions(+), 53 deletions(-)
----------------------------------------------------------------------


http://git-wip-us.apache.org/repos/asf/trafficserver/blob/f68e950f/proxy/InkAPITest.cc
----------------------------------------------------------------------
diff --git a/proxy/InkAPITest.cc b/proxy/InkAPITest.cc
index 6cc2ab9..68cfb92 100644
--- a/proxy/InkAPITest.cc
+++ b/proxy/InkAPITest.cc
@@ -251,7 +251,7 @@ REGRESSION_TEST(SDK_API_TSConfig)(RegressionTest *test, int /* atype ATS_UNUSED
 //////////////////////////////////////////////
 
 struct SDK_NetVConn_Params {
-  SDK_NetVConn_Params(const char *_a, RegressionTest *_t, int *_p) : buffer(NULL), api(_a), port(0), test(_t), pstatus(_p), server_vc(NULL), client_vc(NULL)
+  SDK_NetVConn_Params(const char *_a, RegressionTest *_t, int *_p) : buffer(NULL), api(_a), port(0), test(_t), pstatus(_p), vc(NULL)
   {
     this->status.client = this->status.server = REGRESSION_TEST_INPROGRESS;
   }
@@ -261,11 +261,8 @@ struct SDK_NetVConn_Params {
     if (this->buffer) {
       TSIOBufferDestroy(this->buffer);
     }
-    if (this->server_vc) {
-      TSVConnClose(this->server_vc);
-    }
-    if (this->client_vc) {
-      TSVConnClose(this->client_vc);
+    if (this->vc) {
+      TSVConnClose(this->vc);
     }
   }
 
@@ -274,9 +271,7 @@ struct SDK_NetVConn_Params {
   unsigned short port;
   RegressionTest *test;
   int *pstatus;
-  TSVConn server_vc;
-  TSVConn client_vc;
-  TSVIO vio;
+  TSVConn vc;
   struct {
     int client;
     int server;
@@ -289,29 +284,27 @@ server_handler(TSCont contp, TSEvent event, void *data)
   SDK_NetVConn_Params *params = (SDK_NetVConn_Params *)TSContDataGet(contp);
 
   if (event == TS_EVENT_NET_ACCEPT) {
-    // Kick off a read so that we can receive a READ_COMPLETE event.
+    // Kick off a read so that we can receive an EOS event.
     SDK_RPRINT(params->test, params->api, "ServerEvent NET_ACCEPT", TC_PASS, "ok");
     params->buffer = TSIOBufferCreate();
-    params->server_vc = (TSVConn)data;
-    TSVConnRead((TSVConn)data, contp, params->buffer, 1);
-  } else if (event == TS_EVENT_VCONN_READ_COMPLETE) {
-    TSVConnShutdown((TSVConn)params->server_vc, 1, 0);
+    params->vc = (TSVConn)data;
+    TSVConnRead((TSVConn)data, contp, params->buffer, 100);
+  } else if (event == TS_EVENT_VCONN_EOS) {
+    // The server end of the test passes if it receives an EOF event. This means that it must have
+    // connected to the endpoint. Since this always happens *after* the accept, we know that it is
+    // safe to delete the params.
     TSContDestroy(contp);
 
-    SDK_RPRINT(params->test, params->api, "ServerEvent READ_COMPLETE", TC_PASS, "ok");
+    SDK_RPRINT(params->test, params->api, "ServerEvent EOS", TC_PASS, "ok");
     *params->pstatus = REGRESSION_TEST_PASSED;
     delete params;
   } else {
     SDK_RPRINT(params->test, params->api, "ServerEvent", TC_FAIL, "received unexpected event %d", event);
     *params->pstatus = REGRESSION_TEST_FAILED;
-
-    TSContDestroy(contp);
     delete params;
-
-    return 1;
   }
 
-  return 0;
+  return 1;
 }
 
 int
@@ -328,12 +321,12 @@ client_handler(TSCont contp, TSEvent event, void *data)
     // Fix me: how to deal with server side cont?
     TSContDestroy(contp);
     return 1;
-  } else if (event == TS_EVENT_NET_CONNECT) {
-    params->client_vc = (TSVConn)data;
-
+  } else {
     sockaddr const *addr = TSNetVConnRemoteAddrGet(static_cast<TSVConn>(data));
     uint16_t input_server_port = ats_ip_port_host_order(addr);
 
+    sleep(1); // XXX this sleep ensures the server end gets the accept event.
+
     if (ats_is_ip_loopback(addr)) {
       SDK_RPRINT(params->test, params->api, "TSNetVConnRemoteIPGet", TC_PASS, "ok");
     } else {
@@ -363,37 +356,10 @@ client_handler(TSCont contp, TSEvent event, void *data)
 
     SDK_RPRINT(params->test, params->api, "TSNetConnect", TC_PASS, "ok");
 
-    TSIOBuffer bufp = TSIOBufferCreate();
-    TSIOBufferReader readerp = TSIOBufferReaderAlloc(bufp);
-    TSIOBufferBlock block;
-    int64_t avail;
+    // XXX We really ought to do a write/read exchange with the server. The sleep above works around this.
 
-    block = TSIOBufferStart(bufp);
-    char *ptr_block = TSIOBufferBlockWriteStart(block, &avail);
-
-    if (avail <= 0) {
-      SDK_RPRINT(params->test, params->api, "TSIOBufferBlockWriteStart", 
-                 TC_FAIL, "No space available to write in buffer, "
-                 "expected %lldd",
-                 avail);
-      TSContDestroy(contp);
-      return 1;
-    }
-
-    memset(ptr_block, 0xff, 1);
-    TSIOBufferProduce(bufp, 1);
-
-    params->vio = TSVConnWrite((TSVConn)(data), contp, readerp, 1);
-    return 0;
-  }
-  else if (event == TS_EVENT_VCONN_WRITE_COMPLETE) {
-    TSVConnShutdown((TSVConn)params->client_vc, 0, 1);
-    TSContDestroy(contp);
-    return 0;
-  }
-  else {
-    SDK_RPRINT(params->test, params->api, "ClientConnect", TC_FAIL, 
-               "received unexpected event %d", event);
+    // Looks good from the client end. Next we disconnect so that the server end can set the final test status.
+    TSVConnClose((TSVConn)data);
   }
 
   TSContDestroy(contp);