Tarantool development patches archive
 help / color / mirror / Atom feed
From: Sergey Ostanevich <sergos@tarantool.org>
To: Oleg Babin <olegrok@tarantool.org>
Cc: tarantool-patches@dev.tarantool.org, alexander.turenko@tarantool.org
Subject: Re: [Tarantool-patches] [PATCH] lua: handle fiber cancellation for fiber.cond
Date: Thu, 29 Oct 2020 20:14:37 +0300	[thread overview]
Message-ID: <20201029171437.GA517@tarantool.org> (raw)
In-Reply-To: <c5737a81-bfab-91f9-e0de-81956e7010c2@tarantool.org>

Hi Oleg!

Thanks for the comment, I believe I have to resend the patch along with
C API changes.

What I see at the moment - failures like 

[076]  test_run:wait_upstream(1, {message_re = 'Missing %.xlog file',
status = 'loading'})
[076]  ---
[076] -- true
[076] +- false

which incurred by the intended behavior change, AFAIU. We no longer
return 'true' in case the fiber is cancelled. The wait_upstream returns
the cond wait result, hence the output differs.

Did you observe any other failures?

Regards,
Sergos


On 28 окт 20:14, Oleg Babin wrote:
> Hi! Thanks for the patch!
> 
> The main reason I didn't send this patch is inconsistency between Lua and C
> API.
> 
> To eliminate such inconsistency [1] was implemented. Unfortunately some test
> fails and I've failed to find root of the problem.
> 
> However I still believe that the problem should be solved at "core" level.
> 
> Anyway, it would be great if some solution will be pushed to upstream.
> 
> 
> [1] https://github.com/tarantool/tarantool/commit/e7a5120603f362364953315d31aa529342263e0b
> 
> 
> On 28/10/2020 19:22, sergos@tarantool.org wrote:
> > From: Sergey Ostanevich <sergos@tarantool.org>
> > 
> > Before this patch fiber.cond():wait() just returns for cancelled
> > fiber. In contrast fiber.channel():get() threw "fiber is
> > canceled" error.
> > This patch unify behaviour of channels and condvars and also fixes
> > related net.box module problem - it was impossible to interrupt
> > net.box call with fiber.cancel because it used fiber.cond under
> > the hood. Test cases for both bugs are added.
> > 
> > Closes #4834
> > Closes #5013
> > 
> > Co-authored-by: Oleg Babin <olegrok@tarantool.org>
> > 
> > @TarantoolBot document
> > Title: fiber.cond():wait() throws if fiber is cancelled
> > 
> > Currently fiber.cond():wait() throws an error if waiting fiber is
> > cancelled like in case with fiber.channel():get().
> > ---
> > 

  reply	other threads:[~2020-10-29 17:14 UTC|newest]

Thread overview: 5+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2020-10-28 16:22 sergos
2020-10-28 17:14 ` Oleg Babin
2020-10-29 17:14   ` Sergey Ostanevich [this message]
2020-10-29 18:06     ` Alexander Turenko
2020-10-30  6:47     ` Oleg Babin

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20201029171437.GA517@tarantool.org \
    --to=sergos@tarantool.org \
    --cc=alexander.turenko@tarantool.org \
    --cc=olegrok@tarantool.org \
    --cc=tarantool-patches@dev.tarantool.org \
    --subject='Re: [Tarantool-patches] [PATCH] lua: handle fiber cancellation for fiber.cond' \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox