Final bits for options in parser for behaviors.
[awesomized/libmemcached] / tests / parser.cc
index e7a4414fdce53af07d554e16227bd9fc94dcb45d..3ee37a2c2e6628a6ed32ce2aa4e0378b55cb93d9 100644 (file)
@@ -84,7 +84,7 @@ test_return_t servers_test(memcached_st *junk)
 
   scanner_string_st test_strings[]= {
     { STRING_WITH_LEN("--servers=localhost:11221,localhost:11222,localhost:11223,localhost:11224,localhost:11225") },
-    { STRING_WITH_LEN("--servers=a.example.com:80,localhost:80,b.example.com") },
+    { STRING_WITH_LEN("--servers=a.example.com:81,localhost:82,b.example.com") },
     { STRING_WITH_LEN("--servers=localhost,localhost:80") },
     { NULL, 0}
   };
@@ -98,11 +98,167 @@ test_return_t servers_test(memcached_st *junk)
 
     memcached_server_fn callbacks[1];
     callbacks[0]= server_print_callback;
-    memcached_server_cursor(memc, callbacks, memc,  1);
+    memcached_server_cursor(memc, callbacks, NULL,  1);
 
     memcached_servers_reset(memc);
   }
 
+  scanner_string_st bad_test_strings[]= {
+    { STRING_WITH_LEN("-servers=localhost:11221,localhost:11222,localhost:11223,localhost:11224,localhost:11225") },
+    { STRING_WITH_LEN("-- servers=a.example.com:81,localhost:82,b.example.com") },
+    { STRING_WITH_LEN("--servers=localhost80") },
+    { NULL, 0}
+  };
+
+  for (scanner_string_st *ptr= bad_test_strings; ptr->size; ptr++)
+  {
+    memcached_return_t rc;
+    rc= memcached_parse_options(memc, ptr->c_ptr, ptr->size);
+
+    test_false_with(rc == MEMCACHED_SUCCESS, ptr->c_ptr);
+
+    memcached_server_fn callbacks[1];
+    callbacks[0]= server_print_callback;
+    memcached_server_cursor(memc, callbacks, NULL,  1);
+
+    memcached_servers_reset(memc);
+  }
+
+  memcached_free(memc);
+
+  return TEST_SUCCESS;
+}
+
+scanner_string_st test_number_options[]= {
+  { STRING_WITH_LEN("--CONNECT_TIMEOUT=456") },
+  { STRING_WITH_LEN("--IO_MSG_WATERMARK=456") },
+  { STRING_WITH_LEN("--IO_BYTES_WATERMARK=456") },
+  { STRING_WITH_LEN("--IO_KEY_PREFETCH=456") },
+  { STRING_WITH_LEN("--NUMBER_OF_REPLICAS=456") },
+  { STRING_WITH_LEN("--POLL_TIMEOUT=456") },
+  { STRING_WITH_LEN("--RCV_TIMEOUT=456") },
+  { STRING_WITH_LEN("--RETRY_TIMEOUT=456") },
+  { STRING_WITH_LEN("--SERVER_FAILURE_LIMIT=456") },
+  { STRING_WITH_LEN("--SND_TIMEOUT=456") },
+  { STRING_WITH_LEN("--SOCKET_RECV_SIZE=456") },
+  { STRING_WITH_LEN("--SOCKET_SEND_SIZE=456") },
+  { NULL, 0}
+};
+
+scanner_string_st test_boolean_options[]= {
+  { STRING_WITH_LEN("--AUTO_EJECT_HOSTS") },
+  { STRING_WITH_LEN("--BINARY_PROTOCOL") },
+  { STRING_WITH_LEN("--BUFFER_REQUESTS") },
+  { STRING_WITH_LEN("--CACHE_LOOKUPS") },
+  { STRING_WITH_LEN("--CORK") },
+  { STRING_WITH_LEN("--HASH_WITH_PREFIX_KEY") },
+  { STRING_WITH_LEN("--KETAMA") },
+  { STRING_WITH_LEN("--KETAMA_WEIGHTED") },
+  { STRING_WITH_LEN("--NOREPLY") },
+  { STRING_WITH_LEN("--RANDOMIZE_REPLICA_READ") },
+  { STRING_WITH_LEN("--SORT_HOSTS") },
+  { STRING_WITH_LEN("--SUPPORT_CAS") },
+  { STRING_WITH_LEN("--TCP_NODELAY") },
+  { STRING_WITH_LEN("--TCP_KEEPALIVE") },
+  { STRING_WITH_LEN("--TCP_KEEPIDLE") },
+  { STRING_WITH_LEN("--USE_UDP") },
+  { STRING_WITH_LEN("--VERIFY_KEY") },
+  { NULL, 0}
+};
+
+test_return_t parser_number_options_test(memcached_st *junk)
+{
+  (void)junk;
+  memcached_st *memc;
+  memc= memcached_create(NULL);
+
+  for (scanner_string_st *ptr= test_number_options; ptr->size; ptr++)
+  {
+    memcached_return_t rc;
+    rc= memcached_parse_options(memc, ptr->c_ptr, ptr->size);
+    test_true_got(rc == MEMCACHED_SUCCESS, ptr->c_ptr);
+  }
+
+  memcached_free(memc);
+
+  return TEST_SUCCESS;
+}
+
+test_return_t parser_boolean_options_test(memcached_st *junk)
+{
+  (void)junk;
+  memcached_st *memc;
+  memc= memcached_create(NULL);
+
+  for (scanner_string_st *ptr= test_boolean_options; ptr->size; ptr++)
+  {
+    memcached_return_t rc;
+    rc= memcached_parse_options(memc, ptr->c_ptr, ptr->size);
+    test_true_got(rc == MEMCACHED_SUCCESS, ptr->c_ptr);
+  }
+
+  memcached_free(memc);
+
+  return TEST_SUCCESS;
+}
+
+test_return_t behavior_parser_test(memcached_st *junk)
+{
+  (void)junk;
+  return TEST_SUCCESS;
+}
+
+test_return_t parser_hash_test(memcached_st *junk)
+{
+  (void)junk;
+  memcached_return_t rc;
+  memcached_st *memc;
+  memc= memcached_create(NULL);
+
+  scanner_string_st test_strings[]= {
+    { STRING_WITH_LEN("--HASH=MD5") },
+    { STRING_WITH_LEN("--HASH=CRC") },
+    { STRING_WITH_LEN("--HASH=FNV1_64") },
+    { STRING_WITH_LEN("--HASH=FNV1A_64") },
+    { STRING_WITH_LEN("--HASH=FNV1_32") },
+    { STRING_WITH_LEN("--HASH=FNV1A_32") },
+    { STRING_WITH_LEN("--HASH=HSIEH") },
+    { STRING_WITH_LEN("--HASH=MURMUR") },
+    { STRING_WITH_LEN("--HASH=JENKINS") },
+    { NULL, 0}
+  };
+
+  for (scanner_string_st *ptr= test_strings; ptr->size; ptr++)
+  {
+    rc= memcached_parse_options(memc, ptr->c_ptr, ptr->size);
+    test_true_got(rc == MEMCACHED_SUCCESS, ptr->c_ptr);
+  }
+
+  memcached_free(memc);
+
+  return TEST_SUCCESS;
+}
+
+test_return_t parser_distribution_test(memcached_st *junk)
+{
+  (void)junk;
+  memcached_return_t rc;
+  memcached_st *memc;
+  memc= memcached_create(NULL);
+
+  scanner_string_st test_strings[]= {
+    { STRING_WITH_LEN("--DISTRIBUTION=consistent") },
+    { STRING_WITH_LEN("--DISTRIBUTION=random") },
+    { STRING_WITH_LEN("--DISTRIBUTION=modula") },
+    { NULL, 0}
+  };
+
+  for (scanner_string_st *ptr= test_strings; ptr->size; ptr++)
+  {
+    rc= memcached_parse_options(memc, ptr->c_ptr, ptr->size);
+    test_true_got(rc == MEMCACHED_SUCCESS, ptr->c_ptr);
+  }
+
   memcached_free(memc);
 
   return TEST_SUCCESS;