+ return MEMCACHED_FAILURE;
+}
+
+test_return_t test_parse_socket(memcached_st *)
+{
+ char buffer[BUFSIZ];
+
+ memcached_server_fn callbacks[]= { dump_socket_information };
+ {
+ test_compare_got(MEMCACHED_SUCCESS,
+ libmemcached_check_configuration(test_literal_param("--socket=\"/tmp/foo\""), buffer, sizeof(buffer)),
+ buffer);
+
+ memcached_st *memc= memcached(test_literal_param("--socket=\"/tmp/foo\""));
+ test_true(memc);
+ socket_weight_t check= { "/tmp/foo", 1 };
+ test_compare(MEMCACHED_SUCCESS,
+ memcached_server_cursor(memc, callbacks, &check, 1));
+ memcached_free(memc);
+ }
+
+ {
+ test_compare_got(MEMCACHED_SUCCESS,
+ libmemcached_check_configuration(test_literal_param("--socket=\"/tmp/foo\"/?23"), buffer, sizeof(buffer)),
+ buffer);
+
+ memcached_st *memc= memcached(test_literal_param("--socket=\"/tmp/foo\"/?23"));
+ test_true(memc);
+ socket_weight_t check= { "/tmp/foo", 23 };
+ test_compare(MEMCACHED_SUCCESS,
+ memcached_server_cursor(memc, callbacks, &check, 1));
+ memcached_free(memc);
+ }
+
+ return TEST_SUCCESS;
+}
+
+/*
+ By setting the timeout value to zero, we force poll() to return immediatly.
+*/
+test_return_t regression_bug_71231153_connect(memcached_st *)
+{
+ if (libmemcached_util_ping("10.0.2.252", 0, NULL)) // If for whatever reason someone has a host at this address, skip
+ return TEST_SKIPPED;
+
+ { // Test the connect-timeout, on a bad host we should get MEMCACHED_CONNECTION_FAILURE
+ memcached_st *memc= memcached(test_literal_param("--SERVER=10.0.2.252 --CONNECT-TIMEOUT=0"));
+ test_true(memc);
+ test_zero(memc->connect_timeout);
+ test_compare(MEMCACHED_DEFAULT_TIMEOUT, memc->poll_timeout);
+
+ memcached_return_t rc;
+ size_t value_len;
+ char *value= memcached_get(memc, test_literal_param("test"), &value_len, NULL, &rc);
+ test_false(value);
+ test_zero(value_len);
+ test_compare_got(MEMCACHED_TIMEOUT, rc, memcached_last_error_message(memc));
+
+ memcached_free(memc);
+ }
+
+ return TEST_SUCCESS;
+}
+
+test_return_t regression_bug_71231153_poll(memcached_st *)
+{
+ if (libmemcached_util_ping("10.0.2.252", 0, NULL)) // If for whatever reason someone has a host at this address, skip
+ return TEST_SKIPPED;
+
+ { // Test the poll timeout, on a bad host we should get MEMCACHED_CONNECTION_FAILURE
+ memcached_st *memc= memcached(test_literal_param("--SERVER=10.0.2.252 --POLL-TIMEOUT=0"));
+ test_true(memc);
+ test_compare(MEMCACHED_DEFAULT_CONNECT_TIMEOUT, memc->connect_timeout);
+ test_zero(memc->poll_timeout);
+
+ memcached_return_t rc;
+ size_t value_len;
+ char *value= memcached_get(memc, test_literal_param("test"), &value_len, NULL, &rc);
+ test_false(value);
+ test_zero(value_len);
+ test_compare_got(MEMCACHED_TIMEOUT, rc, memcached_last_error_message(memc));
+
+ memcached_free(memc);
+ }