On Mon, Dec 30, 2024 at 11:05 AM Peter Smith <smithpb2...@gmail.com> wrote:
>
> On Tue, Dec 24, 2024 at 10:37 PM Nisha Moond <nisha.moond...@gmail.com> wrote:
> >
> > On Fri, Dec 20, 2024 at 3:12 PM Amit Kapila <amit.kapil...@gmail.com> wrote:
> >>
> >> On Mon, Dec 16, 2024 at 4:10 PM Nisha Moond <nisha.moond...@gmail.com> 
> >> wrote:
> >> >
> >> > Here is the v56 patch set with the above comments incorporated.
> >> >
> >>
> >> Review comments:
> >> ===============
> >> 1.
> >> + {
> >> + {"idle_replication_slot_timeout", PGC_SIGHUP, REPLICATION_SENDING,
> >> + gettext_noop("Sets the duration a replication slot can remain idle 
> >> before "
> >> + "it is invalidated."),
> >> + NULL,
> >> + GUC_UNIT_MS
> >> + },
> >> + &idle_replication_slot_timeout_ms,
> >>
> >> I think users are going to keep idele_slot timeout at least in hours.
> >> So, millisecond seems the wrong choice to me. I suggest to keep the
> >> units in minutes. I understand that writing a test would be
> >> challenging as spending a minute or more on one test is not advisable.
> >> But I don't see any test testing the other GUCs that are in minutes
> >> (wal_summary_keep_time and log_rotation_age). The default value should
> >> be one day.
> >
> >
> > +1
> > - Changed the GUC unit to "minute".
> >
> > Regarding the tests, we have two potential options:
> >  1) Introduce an additional "debug_xx" GUC parameter with units of seconds 
> > or milliseconds, only for testing purposes.
> >  2) Skip writing tests for this, similar to other GUCs with units in 
> > minutes.
> >
> > IMO, adding an additional GUC just for testing may not be worthwhile. It's 
> > reasonable to proceed without the test.
> >
> > Thoughts?
> >
> > The attached v57 patch-set addresses all the comments. I have kept the test 
> > case in the patch for now, it takes 2-3 minutes to complete.
> >
>
> Hi Nisha.
>
> I think we are often too quick to throw out perfectly good tests.
> Citing that some similar GUCs don't do testing as a reason to skip
> them just seems to me like an example of "two wrongs don't make a
> right".
>
> There is a third option.
>
> Keep the tests. Because they take excessive time to run, that simply
> means you should run them *conditionally* based on the PG_TEST_EXTRA
> environment variable so they don't impact the normal BF execution. The
> documentation [1] says this env var is for "resource intensive" tests
> -- AFAIK this is exactly the scenario we find ourselves in, so is
> exactly what this env var was meant for.
>
> Search other *.pl tests for PG_TEST_EXTRA to see some examples.
>

Thank you for the suggestion! I’ve added the tests under the
PG_TEST_EXTRA condition. Now, the '043_invalidate_inactive_slots.pl'
tests will only be executed when
PG_TEST_EXTRA=idle_replication_slot_timeout is set.

Attached the v58 patch set, addressing the above and the comments in
[1], [2], and [3].

[1] 
https://www.postgresql.org/message-id/CALDaNm14QrW5j6su%2BEAqjwnHbiwXJwO%2Byk73_%3D7yvc5TVY-43g%40mail.gmail.com
[2] 
https://www.postgresql.org/message-id/CAHut%2BPvDsM%3D%2BvTbM-xX6DD-PavONs2kGn03MZbCPGGL2t60TRA%40mail.gmail.com
[3] 
https://www.postgresql.org/message-id/CAHut%2BPs2ecNTfG3vsGb91CYpEzWtffyvkOzk1jqwhqTCwH8HQA%40mail.gmail.com

--
Thanks,
Nisha

Attachment: v58-0001-Enhance-replication-slot-error-handling-slot-inv.patch
Description: Binary data

Attachment: v58-0002-Introduce-inactive_timeout-based-replication-slo.patch
Description: Binary data

Reply via email to