summaryrefslogtreecommitdiffstats
path: root/web/server/h2o/libh2o/deps/libyrmcds/t
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-19 02:57:58 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-19 02:57:58 +0000
commitbe1c7e50e1e8809ea56f2c9d472eccd8ffd73a97 (patch)
tree9754ff1ca740f6346cf8483ec915d4054bc5da2d /web/server/h2o/libh2o/deps/libyrmcds/t
parentInitial commit. (diff)
downloadnetdata-be1c7e50e1e8809ea56f2c9d472eccd8ffd73a97.tar.xz
netdata-be1c7e50e1e8809ea56f2c9d472eccd8ffd73a97.zip
Adding upstream version 1.44.3.upstream/1.44.3upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to '')
-rw-r--r--web/server/h2o/libh2o/deps/libyrmcds/t/t.h75
-rw-r--r--web/server/h2o/libh2o/deps/libyrmcds/t/text.c294
-rw-r--r--web/server/h2o/libh2o/deps/libyrmcds/text_mode.c32
3 files changed, 401 insertions, 0 deletions
diff --git a/web/server/h2o/libh2o/deps/libyrmcds/t/t.h b/web/server/h2o/libh2o/deps/libyrmcds/t/t.h
new file mode 100644
index 00000000..fd79d59c
--- /dev/null
+++ b/web/server/h2o/libh2o/deps/libyrmcds/t/t.h
@@ -0,0 +1,75 @@
+// test utilities
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <unistd.h>
+#include <yrmcds.h>
+
+static int n_failures = 0;
+
+static void check_error(yrmcds_error e) {
+ if( e == YRMCDS_OK )
+ return;
+
+ fprintf(stderr, "yrmcds error: %s\n", yrmcds_strerror(e));
+ exit(1);
+}
+
+static yrmcds* get_yrmcds(yrmcds* c) {
+ const char* host = getenv("YRMCDS_HOST");
+ if( host == NULL ) {
+ return NULL;
+ }
+ uint16_t port = 11211;
+ if( getenv("YRMCDS_PORT") ) {
+ port = (uint16_t)atoi(getenv("YRMCDS_PORT"));
+ }
+
+ check_error( yrmcds_connect(c, host, port) );
+ return c;
+}
+
+static void test_main(yrmcds* c);
+
+#define TEST_MAIN() static void test_main(yrmcds* c)
+
+int main(int argc, char** argv) {
+ yrmcds c_;
+ yrmcds* c = get_yrmcds(&c_);
+ if( c == NULL ) {
+ fprintf(stderr, "No YRMCDS_HOST. Skipped.\n");
+ return 0;
+ }
+
+ test_main(c);
+ yrmcds_close(c);
+
+ if( n_failures > 0 ) {
+ fprintf(stderr, "%d tests failed.\n", n_failures);
+ return 1;
+ }
+ fprintf(stderr, "Passed.\n");
+ return 0;
+}
+
+#define DEF_TEST(name) void test_##name(yrmcds* c)
+
+#define CALL_TEST(name) \
+ fprintf(stderr, "[%s]\n", #name); \
+ test_##name(c); \
+ uint32_t serial_##name; \
+ check_error( yrmcds_flush(c, 0, 0, &serial_##name) ); \
+ while( 1 ) { \
+ yrmcds_response r; \
+ check_error( yrmcds_recv(c, &r) ); \
+ if( r.serial == serial_##name ) break; \
+ } \
+ sleep(1)
+
+#define ASSERT(expr, to_return) \
+ if( ! (expr) ) { \
+ fprintf(stderr, "assertion failure at line %d: %s\n", \
+ __LINE__, #expr); \
+ n_failures++; \
+ if( to_return ) return; \
+ }
diff --git a/web/server/h2o/libh2o/deps/libyrmcds/t/text.c b/web/server/h2o/libh2o/deps/libyrmcds/t/text.c
new file mode 100644
index 00000000..9419cb41
--- /dev/null
+++ b/web/server/h2o/libh2o/deps/libyrmcds/t/text.c
@@ -0,0 +1,294 @@
+#include "t.h"
+#include <string.h>
+#include <yrmcds.h>
+
+DEF_TEST(set) {
+ // quiet cannot be used
+ ASSERT( yrmcds_set(c, "a", 1, "a", 1, 0, 0, 0, 1, NULL) == YRMCDS_BAD_ARGUMENT, 0 );
+
+ uint32_t serial;
+ check_error( yrmcds_set(c, "hoge", 4, "hoge", 4, 1, 0, 0, 0, &serial) );
+
+ yrmcds_response r;
+ check_error( yrmcds_recv(c, &r) );
+ ASSERT( r.serial == serial, 0 );
+ ASSERT( r.status == YRMCDS_STATUS_OK, 1 );
+
+ check_error( yrmcds_get(c, "hoge", 4, 0, &serial) );
+ check_error( yrmcds_recv(c, &r) );
+ ASSERT( r.serial == serial, 0 );
+ ASSERT( r.status == YRMCDS_STATUS_OK, 1 );
+ ASSERT( r.data_len == 4, 0 );
+ ASSERT( memcmp(r.data, "hoge", 4) == 0, 0 );
+ ASSERT( r.flags == 1, 0 );
+
+ // CAS failure
+ check_error( yrmcds_set(c, "hoge", 4, "fu", 2, 2, 0, r.cas_unique+1,
+ 0, &serial) );
+ check_error( yrmcds_recv(c, &r) );
+ ASSERT( r.serial == serial, 0 );
+ ASSERT( r.status == YRMCDS_STATUS_EXISTS, 1 );
+
+ check_error( yrmcds_getk(c, "hoge", 4, 0, &serial) );
+ check_error( yrmcds_recv(c, &r) );
+ ASSERT( r.serial == serial, 0 );
+ ASSERT( r.status == YRMCDS_STATUS_OK, 1 );
+ ASSERT( r.key_len == 4, 0 );
+ ASSERT( memcmp(r.key, "hoge", 4) == 0, 0 );
+ ASSERT( r.data_len == 4, 0 );
+ ASSERT( memcmp(r.data, "hoge", 4) == 0, 0 );
+ ASSERT( r.flags == 1, 0 );
+
+ // CAS success
+ check_error( yrmcds_set(c, "hoge", 4, "fu", 2, 4097, 0, r.cas_unique,
+ 0, &serial) );
+ check_error( yrmcds_recv(c, &r) );
+ ASSERT( r.serial == serial, 0 );
+ ASSERT( r.status == YRMCDS_STATUS_OK, 1 );
+
+ check_error( yrmcds_getk(c, "hoge", 4, 0, &serial) );
+ check_error( yrmcds_recv(c, &r) );
+ ASSERT( r.serial == serial, 0 );
+ ASSERT( r.status == YRMCDS_STATUS_OK, 1 );
+ ASSERT( r.key_len == 4, 0 );
+ ASSERT( memcmp(r.key, "hoge", 4) == 0, 0 );
+ ASSERT( r.data_len == 2, 0 );
+ ASSERT( memcmp(r.data, "fu", 2) == 0, 0 );
+ ASSERT( r.flags == 4097, 0 );
+
+ // set exptime
+ check_error( yrmcds_set(c, "hoge", 4, "999", 3, 0, 1, 0, 0, &serial) );
+ check_error( yrmcds_recv(c, &r) );
+ ASSERT( r.serial == serial, 0 );
+ ASSERT( r.status == YRMCDS_STATUS_OK, 1 );
+
+ sleep(2);
+
+ check_error( yrmcds_getk(c, "hoge", 4, 0, &serial) );
+ check_error( yrmcds_recv(c, &r) );
+ ASSERT( r.serial == serial, 0 );
+ ASSERT( r.status == YRMCDS_STATUS_NOTFOUND, 1 );
+}
+
+DEF_TEST(add) {
+ // quiet cannot be used
+ ASSERT( yrmcds_add(c, "a", 1, "a", 1, 0, 0, 0, 1, NULL) == YRMCDS_BAD_ARGUMENT, 0 );
+
+ uint32_t serial;
+ check_error( yrmcds_add(c, "hoge", 4, "hoge", 4, 1, 0, 0, 0, &serial) );
+
+ yrmcds_response r;
+ check_error( yrmcds_recv(c, &r) );
+ ASSERT( r.serial == serial, 0 );
+ ASSERT( r.status == YRMCDS_STATUS_OK, 1 );
+
+ check_error( yrmcds_add(c, "hoge", 4, "fu", 2, 16, 0, 0, 0, &serial) );
+ check_error( yrmcds_recv(c, &r) );
+ ASSERT( r.serial == serial, 0 );
+ ASSERT( r.status == YRMCDS_STATUS_NOTSTORED, 1 );
+}
+
+DEF_TEST(replace) {
+ // quiet cannot be used
+ ASSERT( yrmcds_replace(c, "a", 1, "a", 1, 0, 0, 0, 1, NULL) == YRMCDS_BAD_ARGUMENT, 0 );
+
+ uint32_t serial;
+ check_error( yrmcds_replace(c, "abc", 3, "hoge", 4, 1, 0, 0, 0, &serial) );
+
+ yrmcds_response r;
+ check_error( yrmcds_recv(c, &r) );
+ ASSERT( r.serial == serial, 0 );
+ ASSERT( r.status == YRMCDS_STATUS_NOTSTORED, 1 );
+
+ check_error( yrmcds_set(c, "abc", 3, "def", 3, 16, 0, 0, 0, &serial) );
+ check_error( yrmcds_recv(c, &r) );
+ ASSERT( r.serial == serial, 0 );
+ ASSERT( r.status == YRMCDS_STATUS_OK, 1 );
+
+ check_error( yrmcds_replace(c, "abc", 3, "hoge", 4, 1, 0, 0, 0, &serial) );
+ check_error( yrmcds_recv(c, &r) );
+ ASSERT( r.serial == serial, 0 );
+ ASSERT( r.status == YRMCDS_STATUS_OK, 1 );
+}
+
+DEF_TEST(append) {
+ uint32_t serial;
+ yrmcds_response r;
+
+ // quiet cannot be used
+ ASSERT( yrmcds_append(c, "a", 1, "a", 1, 1, NULL) == YRMCDS_BAD_ARGUMENT, 0 );
+
+ check_error( yrmcds_append(c, "012", 3, "345", 3, 0, &serial) );
+ check_error( yrmcds_recv(c, &r) );
+ ASSERT( r.serial == serial, 0 );
+ ASSERT( r.status == YRMCDS_STATUS_NOTSTORED, 1 );
+
+ check_error( yrmcds_set(c, "012", 3, "345", 3, 1, 0, 0, 0, &serial) );
+ check_error( yrmcds_recv(c, &r) );
+ ASSERT( r.serial == serial, 0 );
+ ASSERT( r.status == YRMCDS_STATUS_OK, 1 );
+
+ check_error( yrmcds_append(c, "012", 3, "6789", 4, 0, &serial) );
+ check_error( yrmcds_recv(c, &r) );
+ ASSERT( r.serial == serial, 0 );
+ ASSERT( r.status == YRMCDS_STATUS_OK, 1 );
+
+ check_error( yrmcds_getk(c, "012", 3, 0, &serial) );
+ check_error( yrmcds_recv(c, &r) );
+ ASSERT( r.serial == serial, 0 );
+ ASSERT( r.status == YRMCDS_STATUS_OK, 1 );
+ ASSERT( r.data_len == 7, 1 );
+ ASSERT( memcmp(r.data, "3456789", 7) == 0, 0 );
+}
+
+DEF_TEST(prepend) {
+ uint32_t serial;
+ yrmcds_response r;
+
+ // quiet cannot be used
+ ASSERT( yrmcds_prepend(c, "a", 1, "a", 1, 1, NULL) == YRMCDS_BAD_ARGUMENT, 0 );
+
+ check_error( yrmcds_prepend(c, "012", 3, "345", 3, 0, &serial) );
+ check_error( yrmcds_recv(c, &r) );
+ ASSERT( r.serial == serial, 0 );
+ ASSERT( r.status == YRMCDS_STATUS_NOTSTORED, 1 );
+
+ check_error( yrmcds_set(c, "012", 3, "345", 3, 1, 0, 0, 0, &serial) );
+ check_error( yrmcds_recv(c, &r) );
+ ASSERT( r.serial == serial, 0 );
+ ASSERT( r.status == YRMCDS_STATUS_OK, 1 );
+
+ check_error( yrmcds_prepend(c, "012", 3, "6789", 4, 0, &serial) );
+ check_error( yrmcds_recv(c, &r) );
+ ASSERT( r.serial == serial, 0 );
+ ASSERT( r.status == YRMCDS_STATUS_OK, 1 );
+
+ check_error( yrmcds_getk(c, "012", 3, 0, &serial) );
+ check_error( yrmcds_recv(c, &r) );
+ ASSERT( r.serial == serial, 0 );
+ ASSERT( r.status == YRMCDS_STATUS_OK, 1 );
+ ASSERT( r.data_len == 7, 1 );
+ ASSERT( memcmp(r.data, "6789345", 7) == 0, 0 );
+}
+
+DEF_TEST(touch) {
+ uint32_t serial;
+ yrmcds_response r;
+
+ // quiet cannot be used
+ ASSERT( yrmcds_touch(c, "a", 1, 0, 1, NULL) == YRMCDS_BAD_ARGUMENT, 0 );
+
+ check_error( yrmcds_set(c, "a", 1, "345", 3, 0, 1, 0, 0, &serial) );
+ check_error( yrmcds_recv(c, &r) );
+ ASSERT( r.serial == serial, 0 );
+ ASSERT( r.status == YRMCDS_STATUS_OK, 1 );
+
+ check_error( yrmcds_touch(c, "a", 1, 0, 0, &serial) );
+ check_error( yrmcds_recv(c, &r) );
+ ASSERT( r.serial == serial, 0 );
+ ASSERT( r.status == YRMCDS_STATUS_OK, 1 );
+
+ sleep(2);
+
+ check_error( yrmcds_getk(c, "a", 1, 0, &serial) );
+ check_error( yrmcds_recv(c, &r) );
+ ASSERT( r.serial == serial, 0 );
+ ASSERT( r.status == YRMCDS_STATUS_OK, 1 );
+}
+
+DEF_TEST(incdec) {
+ uint32_t serial;
+ yrmcds_response r;
+
+ // quiet cannot be used
+ ASSERT( yrmcds_incr(c, "a", 1, 100, 1, NULL) == YRMCDS_BAD_ARGUMENT, 0 );
+ ASSERT( yrmcds_decr(c, "a", 1, 100, 1, NULL) == YRMCDS_BAD_ARGUMENT, 0 );
+
+ check_error( yrmcds_incr(c, "a", 1, 100, 0, &serial) );
+ check_error( yrmcds_recv(c, &r) );
+ ASSERT( r.serial == serial, 0 );
+ ASSERT( r.status == YRMCDS_STATUS_NOTFOUND, 0 );
+
+ check_error( yrmcds_decr(c, "a", 1, 100, 0, &serial) );
+ check_error( yrmcds_recv(c, &r) );
+ ASSERT( r.serial == serial, 0 );
+ ASSERT( r.status == YRMCDS_STATUS_NOTFOUND, 0 );
+
+ check_error( yrmcds_set(c, "a", 1, "345", 3, 0, 1, 0, 0, &serial) );
+ check_error( yrmcds_recv(c, &r) );
+ ASSERT( r.serial == serial, 0 );
+ ASSERT( r.status == YRMCDS_STATUS_OK, 1 );
+
+ check_error( yrmcds_incr(c, "a", 1, 1000, 0, &serial) );
+ check_error( yrmcds_recv(c, &r) );
+ ASSERT( r.serial == serial, 0 );
+ ASSERT( r.status == YRMCDS_STATUS_OK, 1 );
+ ASSERT( r.value == 1345, 1 );
+
+ check_error( yrmcds_decr(c, "a", 1, 1, 0, &serial) );
+ check_error( yrmcds_recv(c, &r) );
+ ASSERT( r.serial == serial, 0 );
+ ASSERT( r.status == YRMCDS_STATUS_OK, 1 );
+ ASSERT( r.value == 1344, 1 );
+
+ check_error( yrmcds_getk(c, "a", 1, 0, &serial) );
+ check_error( yrmcds_recv(c, &r) );
+ ASSERT( r.serial == serial, 0 );
+ ASSERT( r.status == YRMCDS_STATUS_OK, 1 );
+ ASSERT( r.data_len == 4, 1 );
+ ASSERT( memcmp(r.data, "1344", 4) == 0, 0 );
+}
+
+DEF_TEST(remove) {
+ uint32_t serial;
+ yrmcds_response r;
+
+ // quiet cannot be used
+ ASSERT( yrmcds_remove(c, "a", 1, 1, NULL) == YRMCDS_BAD_ARGUMENT, 0 );
+
+ check_error( yrmcds_remove(c, "uuu", 3, 0, &serial) );
+ check_error( yrmcds_recv(c, &r) );
+ ASSERT( r.serial == serial, 0 );
+ ASSERT( r.status == YRMCDS_STATUS_NOTFOUND, 0 );
+
+ check_error( yrmcds_set(c, "uuu", 3, "345", 3, 111, 0, 0, 0, &serial) );
+ check_error( yrmcds_recv(c, &r) );
+ ASSERT( r.serial == serial, 0 );
+ ASSERT( r.status == YRMCDS_STATUS_OK, 1 );
+
+ check_error( yrmcds_remove(c, "uuu", 3, 0, &serial) );
+ check_error( yrmcds_recv(c, &r) );
+ ASSERT( r.serial == serial, 0 );
+ ASSERT( r.status == YRMCDS_STATUS_OK, 1 );
+
+ check_error( yrmcds_getk(c, "uuu", 3, 0, &serial) );
+ check_error( yrmcds_recv(c, &r) );
+ ASSERT( r.serial == serial, 0 );
+ ASSERT( r.status == YRMCDS_STATUS_NOTFOUND, 1 );
+}
+
+DEF_TEST(version) {
+ uint32_t serial;
+ yrmcds_response r;
+
+ check_error( yrmcds_version(c, &serial) );
+ check_error( yrmcds_recv(c, &r) );
+ ASSERT( r.serial == serial, 0 );
+ ASSERT( r.status == YRMCDS_STATUS_OK, 1 );
+ ASSERT( r.data_len > 0, 1 );
+ fprintf(stderr, "version=%.*s\n", (int)r.data_len, r.data);
+}
+
+TEST_MAIN() {
+ check_error( yrmcds_text_mode(c) );
+
+ CALL_TEST(set);
+ CALL_TEST(add);
+ CALL_TEST(replace);
+ CALL_TEST(append);
+ CALL_TEST(prepend);
+ CALL_TEST(touch);
+ CALL_TEST(incdec);
+ CALL_TEST(remove);
+ CALL_TEST(version);
+}
diff --git a/web/server/h2o/libh2o/deps/libyrmcds/text_mode.c b/web/server/h2o/libh2o/deps/libyrmcds/text_mode.c
new file mode 100644
index 00000000..77f95086
--- /dev/null
+++ b/web/server/h2o/libh2o/deps/libyrmcds/text_mode.c
@@ -0,0 +1,32 @@
+// (C) 2016 Cybozu.
+
+#include "yrmcds.h"
+
+#include <errno.h>
+
+yrmcds_error yrmcds_text_mode(yrmcds* c) {
+ if( c == NULL )
+ return YRMCDS_BAD_ARGUMENT;
+
+#ifndef LIBYRMCDS_NO_INTERNAL_LOCK
+ int e = pthread_mutex_lock(&c->lock);
+ if( e != 0 ) {
+ errno = e;
+ return YRMCDS_SYSTEM_ERROR;
+ }
+#endif // ! LIBYRMCDS_NO_INTERNAL_LOCK
+
+ yrmcds_error ret = YRMCDS_OK;
+ if( c->serial != 0 ) {
+ ret = YRMCDS_IN_BINARY;
+ goto OUT;
+ }
+
+ c->text_mode = 1;
+
+ OUT:
+#ifndef LIBYRMCDS_NO_INTERNAL_LOCK
+ pthread_mutex_unlock(&c->lock);
+#endif
+ return ret;
+}