/************************************************************************* > File Name: single_thread.cpp > Author: pxz > Created Time: Fri 11 Sep 2020 09:52:05 AM CST ************************************************************************/ extern "C" { #include #include #include #include #include #include } #include"hos_client.h" //#define test_times 10000 typedef struct userdata_s { //struct timespec *finished; }userdata_t; // static size_t calc_time(struct timespec start, struct timespec end) // { // return (end.tv_sec * 1000 * 1000 * 1000 + end.tv_nsec - // (start.tv_sec * 1000 * 1000 * 1000 + start.tv_nsec)); // } int file_to_buffer(const char *file, char *buffer, int size) { FILE *fp = fopen(file, "r"); if (fp == NULL) { printf("fopen file failed:%s\n", file); return -1; } do{ int num = fread(buffer, 1, size, fp); if (num < 0) { return -1; } else if (num < size) { return 0; } }while(1); fclose(fp); return 0; } void callback(bool result, const char *bucket, const char *object, const char *errormsg, size_t errorcode, void *userdata) { if (!result) { printf("error:[%zu], %s\n", errorcode, errormsg); } return ; } int main(const int argc, const char *argv[]) { if (argc != 4) { printf("usege: [conf file] [module name] [file name]\n"); return -1; } const char *conf_file = argv[1]; const char *module_name = argv[2]; const char *file_name = argv[3]; struct stat buffer; char *buf = NULL; size_t fd = 0; hos_instance hos_instance = NULL; char object[1024]; const char *bucket = "hos_test_bucket"; if (stat(file_name, &buffer) == -1) { printf("%s not exits.", conf_file); return -1; } buf = (char *)calloc(1, buffer.st_size +1); if (file_to_buffer(file_name, buf, buffer.st_size) == -1) { free(buf); return -1; } printf("hos_init_instance start ...\n"); hos_instance = hos_get_instance(); if (hos_instance == NULL) { hos_instance = hos_init_instance(conf_file, module_name, 1); } if (hos_instance == NULL) { printf("error:hos_init_instance\n"); printf("error:[%d]%s", hos_get_init_instance_errorcode(), hos_get_init_instance_errormsg()); return -1; } printf("hos_init_instance success ... \n"); printf("hos_upload_file start ...\n"); snprintf(object, 1023, "%s_upload_file", file_name); if (hos_upload_file(bucket, file_name, callback, NULL, 0) != HOS_CLIENT_OK) { printf("error: hos_upload_file fialed!\n"); } printf("hos_upload_file end ...\n"); printf("hos_upload_buff start ...\n"); snprintf(object, 1023, "%s_upload_buff", file_name); if (hos_upload_buf(bucket, object, buf, buffer.st_size, callback, NULL, 0) != HOS_CLIENT_OK) { printf("error: hos_upload_buff failed!\n"); } printf("hos_upload_buff end ...\n"); printf("hos_write buff start ...\n"); snprintf(object, 1023, "%s_write_APPEND", file_name); hos_open_fd(bucket, object, callback, NULL, 0, &fd); int ret = hos_write(fd, buf, buffer.st_size); if (ret == HOS_CLIENT_OK) { printf("debug: hos_write successed 1st.\n"); } else if (ret == HOS_IN_CACHE) { printf("debug: hos_write in cache.\n"); } else { printf("error: hos_write failed 1st!\n"); } ret = hos_write(fd, buf, buffer.st_size); if (ret == HOS_CLIENT_OK) { printf("debug: hos_write successed 2nd.\n"); } else if (ret == HOS_IN_CACHE) { printf("debug: hos_write in cache.\n"); } else { printf("error: hos_write failed 2nd!\n"); } ret = hos_close_fd(fd); if (ret == HOS_CLIENT_OK) { printf("debug: hos_close_fd successed.\n"); } else if (ret == HOS_FD_CLOSE_BUT_SEND_FAILED) { printf("debug: hos send fialed, but close fd successed.\n"); } else { printf("error: hos_close_fd failed.\n"); } printf("hos_write buff end ...\n"); printf("hos_shutdown_instance start ...\n"); if (hos_shutdown_instance() != 0) { printf("error: hos_shutdown_instance fialed\n"); } printf("hos_shutdown_instance end ...\n"); free(buf); return 0; }