113498266Sopenharmony_ci/***************************************************************************
213498266Sopenharmony_ci *                                  _   _ ____  _
313498266Sopenharmony_ci *  Project                     ___| | | |  _ \| |
413498266Sopenharmony_ci *                             / __| | | | |_) | |
513498266Sopenharmony_ci *                            | (__| |_| |  _ <| |___
613498266Sopenharmony_ci *                             \___|\___/|_| \_\_____|
713498266Sopenharmony_ci *
813498266Sopenharmony_ci * Copyright (C) Daniel Stenberg, <daniel@haxx.se>, et al.
913498266Sopenharmony_ci *
1013498266Sopenharmony_ci * This software is licensed as described in the file COPYING, which
1113498266Sopenharmony_ci * you should have received as part of this distribution. The terms
1213498266Sopenharmony_ci * are also available at https://curl.se/docs/copyright.html.
1313498266Sopenharmony_ci *
1413498266Sopenharmony_ci * You may opt to use, copy, modify, merge, publish, distribute and/or sell
1513498266Sopenharmony_ci * copies of the Software, and permit persons to whom the Software is
1613498266Sopenharmony_ci * furnished to do so, under the terms of the COPYING file.
1713498266Sopenharmony_ci *
1813498266Sopenharmony_ci * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
1913498266Sopenharmony_ci * KIND, either express or implied.
2013498266Sopenharmony_ci *
2113498266Sopenharmony_ci * SPDX-License-Identifier: curl
2213498266Sopenharmony_ci *
2313498266Sopenharmony_ci ***************************************************************************/
2413498266Sopenharmony_ci#include "test.h"
2513498266Sopenharmony_ci
2613498266Sopenharmony_ci#include <fcntl.h>
2713498266Sopenharmony_ci
2813498266Sopenharmony_ci#include "testutil.h"
2913498266Sopenharmony_ci#include "warnless.h"
3013498266Sopenharmony_ci#include "memdebug.h"
3113498266Sopenharmony_ci
3213498266Sopenharmony_ci#define TEST_HANG_TIMEOUT 30 * 1000
3313498266Sopenharmony_ci
3413498266Sopenharmony_ci/* 500 milliseconds allowed. An extreme number but lets be really conservative
3513498266Sopenharmony_ci   to allow old and slow machines to run this test too */
3613498266Sopenharmony_ci#define MAX_BLOCKED_TIME_MS 500
3713498266Sopenharmony_ci
3813498266Sopenharmony_ciint test(char *URL)
3913498266Sopenharmony_ci{
4013498266Sopenharmony_ci  CURL *handle = NULL;
4113498266Sopenharmony_ci  CURLM *mhandle = NULL;
4213498266Sopenharmony_ci  int res = 0;
4313498266Sopenharmony_ci  int still_running = 0;
4413498266Sopenharmony_ci
4513498266Sopenharmony_ci  start_test_timing();
4613498266Sopenharmony_ci
4713498266Sopenharmony_ci  global_init(CURL_GLOBAL_ALL);
4813498266Sopenharmony_ci
4913498266Sopenharmony_ci  easy_init(handle);
5013498266Sopenharmony_ci
5113498266Sopenharmony_ci  easy_setopt(handle, CURLOPT_URL, URL);
5213498266Sopenharmony_ci  easy_setopt(handle, CURLOPT_VERBOSE, 1L);
5313498266Sopenharmony_ci
5413498266Sopenharmony_ci  multi_init(mhandle);
5513498266Sopenharmony_ci
5613498266Sopenharmony_ci  multi_add_handle(mhandle, handle);
5713498266Sopenharmony_ci
5813498266Sopenharmony_ci  multi_perform(mhandle, &still_running);
5913498266Sopenharmony_ci
6013498266Sopenharmony_ci  abort_on_test_timeout();
6113498266Sopenharmony_ci
6213498266Sopenharmony_ci  while(still_running) {
6313498266Sopenharmony_ci    struct timeval timeout;
6413498266Sopenharmony_ci    fd_set fdread;
6513498266Sopenharmony_ci    fd_set fdwrite;
6613498266Sopenharmony_ci    fd_set fdexcep;
6713498266Sopenharmony_ci    int maxfd = -99;
6813498266Sopenharmony_ci    struct timeval before;
6913498266Sopenharmony_ci    struct timeval after;
7013498266Sopenharmony_ci    long e;
7113498266Sopenharmony_ci
7213498266Sopenharmony_ci    timeout.tv_sec = 0;
7313498266Sopenharmony_ci    timeout.tv_usec = 100000L; /* 100 ms */
7413498266Sopenharmony_ci
7513498266Sopenharmony_ci    FD_ZERO(&fdread);
7613498266Sopenharmony_ci    FD_ZERO(&fdwrite);
7713498266Sopenharmony_ci    FD_ZERO(&fdexcep);
7813498266Sopenharmony_ci
7913498266Sopenharmony_ci    multi_fdset(mhandle, &fdread, &fdwrite, &fdexcep, &maxfd);
8013498266Sopenharmony_ci
8113498266Sopenharmony_ci    /* At this point, maxfd is guaranteed to be greater or equal than -1. */
8213498266Sopenharmony_ci
8313498266Sopenharmony_ci    select_test(maxfd + 1, &fdread, &fdwrite, &fdexcep, &timeout);
8413498266Sopenharmony_ci
8513498266Sopenharmony_ci    abort_on_test_timeout();
8613498266Sopenharmony_ci
8713498266Sopenharmony_ci    fprintf(stderr, "ping\n");
8813498266Sopenharmony_ci    before = tutil_tvnow();
8913498266Sopenharmony_ci
9013498266Sopenharmony_ci    multi_perform(mhandle, &still_running);
9113498266Sopenharmony_ci
9213498266Sopenharmony_ci    abort_on_test_timeout();
9313498266Sopenharmony_ci
9413498266Sopenharmony_ci    after = tutil_tvnow();
9513498266Sopenharmony_ci    e = tutil_tvdiff(after, before);
9613498266Sopenharmony_ci    fprintf(stderr, "pong = %ld\n", e);
9713498266Sopenharmony_ci
9813498266Sopenharmony_ci    if(e > MAX_BLOCKED_TIME_MS) {
9913498266Sopenharmony_ci      res = 100;
10013498266Sopenharmony_ci      break;
10113498266Sopenharmony_ci    }
10213498266Sopenharmony_ci  }
10313498266Sopenharmony_ci
10413498266Sopenharmony_citest_cleanup:
10513498266Sopenharmony_ci
10613498266Sopenharmony_ci  /* undocumented cleanup sequence - type UA */
10713498266Sopenharmony_ci
10813498266Sopenharmony_ci  curl_multi_cleanup(mhandle);
10913498266Sopenharmony_ci  curl_easy_cleanup(handle);
11013498266Sopenharmony_ci  curl_global_cleanup();
11113498266Sopenharmony_ci
11213498266Sopenharmony_ci  return res;
11313498266Sopenharmony_ci}
114