--- a/memcache_test.c Thu Aug 28 01:42:28 2008 +0300
+++ b/memcache_test.c Thu Aug 28 03:12:11 2008 +0300
@@ -9,12 +9,38 @@
static struct memcache *mc;
static struct config_endpoint server_endpoint;
+static char *data_1 = "rei4quohV8Oocio1ua0co8ni4Ae1re4houcheixahchoh3ioghie0aShooShoh6Ahboequ9eiX5eashuu6Chu1quo"
+ "o0suph7cheiyai1ea0ooh7Aevoo4feihubupohDeephahwee2Ooz7chiediec7neit7keTh6xuheash8chaeKa5vi"
+ "ekooqu7ooj6Eezooroi6Nequ9ca2yi6iSoigh3loowaey9eiphaphaiJ0souy7wohpa9eXo5Ahu2sa";
+static char *data_2 = "iefaek7ighi5UpueThageish5ieshohyeil1raiceerahjahng5ui7vuzie9quu4dai5ar2aiXi5ieth4looweigi"
+ "e3fo5ieri1queengaiphuaghaic1xahvoo9joo6baiNaig8puCootheowah4moocohDoiquoh3quieka5ao3aeNg9"
+ "Aimei1soangu4Duch5pho5buu2ohzaich4chahz9iTh3Pei4beep1ongie6au1aafoosh2vierei5E";
-int _memcache_cb (struct memcache_req *req, void *arg) {
- return 0;
+void _memcache_cb (struct memcache_req *req, void *arg) {
+ char *key = arg;
+ const struct memcache_obj *obj;
+ const struct memcache_buf *buf;
+
+ INFO("[%s]: cmd=%15s state=%15s reply=%15s", key,
+ memcache_command_str(memcache_req_cmd(req)),
+ memcache_state_str(memcache_req_state(req)),
+ memcache_reply_str(memcache_req_reply(req))
+ );
+
+ if ((obj = memcache_req_obj(req)))
+ INFO("\tobj: flags=0x%04X exptime=%9zu bytes=%6zu cas=%llu", obj->flags, obj->exptime, obj->bytes, obj->cas);
+
+ if ((buf = memcache_req_buf(req)))
+ INFO("\tbuf: data=%p len=%6zu offset=%6zu", buf->data, buf->len, buf->offset);
+
+ INFO("%s", "");
}
void begin_test () {
+ struct memcache_key key_1, key_2;
+ struct memcache_obj obj_1, obj_2;
+ struct memcache_buf buf_1, buf_2;
+
if ((mc = memcache_alloc(&_memcache_cb)) == NULL)
ERROR("memcache_alloc");
@@ -29,8 +55,38 @@
ERROR("memcache_add_server");
// add a request or two
+ key_1.buf = "memcache_test_k1";
+ key_2.buf = "memcache_test_k2";
+ key_1.len = key_2.len = 0;
+
+ obj_1.flags = 0x1A;
+ obj_2.flags = 0x2B;
+
+ obj_1.exptime = 0;
+ obj_2.exptime = 3600;
+
+ obj_1.bytes = strlen(data_1);
+ obj_2.bytes = strlen(data_2);
+
+ buf_1.data = data_1;
+ buf_1.len = strlen(data_1);
+ buf_1.offset = buf_1.len;
+
+ buf_2.data = data_2;
+ buf_2.len = strlen(data_2);
+ buf_2.offset = buf_2.len;
+
+ if (memcache_store(mc, MEMCACHE_CMD_STORE_SET, &key_1, &obj_1, &buf_1, key_1.buf))
+ ERROR("memcache_store: key_1");
+ if (memcache_store(mc, MEMCACHE_CMD_STORE_ADD, &key_2, &obj_2, &buf_2, key_2.buf))
+ ERROR("memcache_store: key_2");
+ if (memcache_fetch(mc, &key_1, key_1.buf))
+ ERROR("memcache_fetch: key_1");
+
+ if (memcache_fetch(mc, &key_2, key_2.buf))
+ ERROR("memcache_fetch: key_2");
error:
return;