Skip to content

Commit

Permalink
No more assertion on 0 retries options
Browse files Browse the repository at this point in the history
This commit changes meanging of the `retry_count` option: now it means
amount of attempts to connect after the first one, not overall attempts
count.

Closes #83
  • Loading branch information
bigbes authored and Totktonada committed Jul 14, 2020
1 parent e67cb23 commit 8585fd3
Show file tree
Hide file tree
Showing 3 changed files with 30 additions and 4 deletions.
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -67,7 +67,7 @@ Place it into project library path in your IDE.

* `tarantool.persistent` - Enable persistent connections (don't close connections between sessions) (defaults: True, **can't be changed in runtime**)
* `tarantool.timeout` - Connection timeout (defaults: 10 seconds, can be changed in runtime)
* `tarantool.retry_count` - Count of retries for connecting (defaults: 1, can be changed in runtime)
* `tarantool.retry_count` - Count of retries for connecting (defaults: 0, can be changed in runtime). 0 means do not retry in case the connection was failed the first time.
* `tarantool.retry_sleep` - Sleep between connecting retries (defaults: 0.1 second, can be changed in runtime)
* `tarantool.request_timeout` - Read/write timeout for requests (defaults: 10 second, can be changed in runtime)

Expand Down
11 changes: 8 additions & 3 deletions src/tarantool.c
Original file line number Diff line number Diff line change
Expand Up @@ -117,7 +117,7 @@ PHP_INI_BEGIN()
STD_PHP_INI_ENTRY("tarantool.request_timeout", "3600.0", PHP_INI_ALL,
OnUpdateReal, request_timeout, zend_tarantool_globals,
tarantool_globals)
STD_PHP_INI_ENTRY("tarantool.retry_count", "1", PHP_INI_ALL,
STD_PHP_INI_ENTRY("tarantool.retry_count", "0", PHP_INI_ALL,
OnUpdateLong, retry_count, zend_tarantool_globals,
tarantool_globals)
STD_PHP_INI_ENTRY("tarantool.retry_sleep", "10", PHP_INI_ALL,
Expand Down Expand Up @@ -252,7 +252,12 @@ static int __tarantool_connect(tarantool_object *t_obj) {
TSRMLS_FETCH();
tarantool_connection *obj = t_obj->obj;
int status = SUCCESS;
long count = TARANTOOL_G(retry_count);
/*
* Amount of connection attempts is always 1 more than
* `retry_count` option value, since the option means
* amount of attempts after the first one.
*/
long count = TARANTOOL_G(retry_count) + 1;
struct timespec sleep_time = {0};
double_to_ts(INI_FLT("retry_sleep"), &sleep_time);
char *err = NULL;
Expand Down Expand Up @@ -962,7 +967,7 @@ PHP_RINIT_FUNCTION(tarantool) {

static void php_tarantool_init_globals(zend_tarantool_globals *tarantool_globals) {
tarantool_globals->sync_counter = 0;
tarantool_globals->retry_count = 1;
tarantool_globals->retry_count = 0;
tarantool_globals->retry_sleep = 10;
tarantool_globals->timeout = 3600.0;
tarantool_globals->request_timeout = 3600.0;
Expand Down
21 changes: 21 additions & 0 deletions test/CreateTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -163,5 +163,26 @@ public static function provideGoodCredentials()
['guest', null],
];
}

public function test_10_zero_retry_exception() {
/*
* gh-83: An attempt to connection with `retry_count = 0`
* gives the following error:
*
* | Uncaught TarantoolIOException: (null)
*
* Now the option means amount of attempts to connect
* after the first one, not an overall attempts to
* connect. So zero becomes valid value.
*/

$saved_retry_count = ini_get('tarantool.retry_count');
ini_set('tarantool.retry_count', 0);

$c = new Tarantool('localhost', self::$port);
$this->assertEquals($c->ping(), true);

ini_set('tarantool.retry_count', $saved_retry_count);
}
}

0 comments on commit 8585fd3

Please sign in to comment.