Bug fix for tab completion of ALTER TABLE ... VALIDATE CONSTRAINT ...

Started by David Fetteralmost 5 years ago10 messageshackers
Jump to latest
#1David Fetter
david@fetter.org

Folks,

I noticed that $subject completes with already valid constraints,
please find attached a patch that fixes it. I noticed that there are
other places constraints can be validated, but didn't check whether
similar bugs exist there yet.

Best,
David.
--
David Fetter <david(at)fetter(dot)org> http://fetter.org/
Phone: +1 415 235 3778

Remember to vote!
Consider donating to Postgres: http://www.postgresql.org/about/donate

Attachments:

v1-0001-tab-completion-of-ALTER-TABLE.VALIDATE-CONSTRAINT.patchtext/x-diff; charset=us-asciiDownload+15-1
#2Aleksander Alekseev
aleksander@timescale.com
In reply to: David Fetter (#1)
Re: Bug fix for tab completion of ALTER TABLE ... VALIDATE CONSTRAINT ...

Hi David,

I noticed that $subject completes with already valid constraints,
please find attached a patch that fixes it. I noticed that there are
other places constraints can be validated, but didn't check whether
similar bugs exist there yet.

There was a typo in the patch ("... and and not convalidated"). I've fixed
it. Otherwise the patch passes all the tests and works as expected:

eax=# create table foo (x int);
CREATE TABLE
eax=# alter table foo add constraint bar check (x < 3) not valid;
ALTER TABLE
eax=# alter table foo add constraint baz check (x <> 5) not valid;
ALTER TABLE
eax=# alter table foo validate constraint ba
bar baz
eax=# alter table foo validate constraint bar;
ALTER TABLE

--
Best regards,
Aleksander Alekseev

Attachments:

v2-0001-tab-completion-of-ALTER-TABLE.VALIDATE-CONSTRAINT.patchapplication/octet-stream; name=v2-0001-tab-completion-of-ALTER-TABLE.VALIDATE-CONSTRAINT.patchDownload+15-1
#3Aleksander Alekseev
aleksander@timescale.com
In reply to: Aleksander Alekseev (#2)
Re: Bug fix for tab completion of ALTER TABLE ... VALIDATE CONSTRAINT ...

Hi hackers,

Otherwise the patch passes all the tests and works as expected

I've noticed there is no tab completion for ALTER TABLE xxx ADD. Here
is an alternative version of the patch that fixes this as well. Not
sure if this should be in the same commit though.

--
Best regards,
Aleksander Alekseev

Attachments:

v3-0001-tab-completion-of-ALTER-TABLE.VALIDATE-CONSTRAINT.patchapplication/octet-stream; name=v3-0001-tab-completion-of-ALTER-TABLE.VALIDATE-CONSTRAINT.patchDownload+17-3
#4David Fetter
david@fetter.org
In reply to: Aleksander Alekseev (#2)
Re: Bug fix for tab completion of ALTER TABLE ... VALIDATE CONSTRAINT ...

On Tue, Apr 27, 2021 at 12:33:25PM +0300, Aleksander Alekseev wrote:

Hi David,

I noticed that $subject completes with already valid constraints,
please find attached a patch that fixes it. I noticed that there are
other places constraints can be validated, but didn't check whether
similar bugs exist there yet.

There was a typo in the patch ("... and and not convalidated"). I've fixed
it. Otherwise the patch passes all the tests and works as expected:

eax=# create table foo (x int);
CREATE TABLE
eax=# alter table foo add constraint bar check (x < 3) not valid;
ALTER TABLE
eax=# alter table foo add constraint baz check (x <> 5) not valid;
ALTER TABLE
eax=# alter table foo validate constraint ba
bar baz
eax=# alter table foo validate constraint bar;
ALTER TABLE

Sorry about that typo, and thanks for poking at this!

Best,
David.
--
David Fetter <david(at)fetter(dot)org> http://fetter.org/
Phone: +1 415 235 3778

Remember to vote!
Consider donating to Postgres: http://www.postgresql.org/about/donate

#5Michael Paquier
michael@paquier.xyz
In reply to: Aleksander Alekseev (#3)
Re: Bug fix for tab completion of ALTER TABLE ... VALIDATE CONSTRAINT ...

On Tue, Apr 27, 2021 at 12:58:52PM +0300, Aleksander Alekseev wrote:

I've noticed there is no tab completion for ALTER TABLE xxx ADD. Here
is an alternative version of the patch that fixes this as well. Not
sure if this should be in the same commit though.

-   /* If we have ALTER TABLE <sth> DROP, provide COLUMN or CONSTRAINT */
-   else if (Matches("ALTER", "TABLE", MatchAny, "DROP"))
+   /* If we have ALTER TABLE <sth> ADD|DROP, provide COLUMN or CONSTRAINT */
+   else if (Matches("ALTER", "TABLE", MatchAny, "ADD|DROP"))
Seems to me that the behavior to not complete with COLUMN or
CONSTRAINT for ADD is intentional, as it is possible to specify a
constraint or column name without the object type first.  This
introduces a inconsistent behavior with what we do for columns with
ADD, for one.  So a more consistent approach would be to list columns,
constraints, COLUMN and CONSTRAINT in the list of options available
after ADD.
+   else if (Matches("ALTER", "TABLE", MatchAny, "VALIDATE", "CONSTRAINT"))
+   {
+       completion_info_charp = prev3_wd;
+       COMPLETE_WITH_QUERY(Query_for_nonvalid_constraint_of_table);
+   }
Specifying valid constraints is an authorized grammar, so it does not
seem that bad to keep things as they are, either.  I would leave that
alone.
--
Michael
#6Daniel Gustafsson
daniel@yesql.se
In reply to: Michael Paquier (#5)
Re: Bug fix for tab completion of ALTER TABLE ... VALIDATE CONSTRAINT ...

On 19 May 2021, at 09:53, Michael Paquier <michael@paquier.xyz> wrote:

On Tue, Apr 27, 2021 at 12:58:52PM +0300, Aleksander Alekseev wrote:

I've noticed there is no tab completion for ALTER TABLE xxx ADD. Here
is an alternative version of the patch that fixes this as well. Not
sure if this should be in the same commit though.

-   /* If we have ALTER TABLE <sth> DROP, provide COLUMN or CONSTRAINT */
-   else if (Matches("ALTER", "TABLE", MatchAny, "DROP"))
+   /* If we have ALTER TABLE <sth> ADD|DROP, provide COLUMN or CONSTRAINT */
+   else if (Matches("ALTER", "TABLE", MatchAny, "ADD|DROP"))
Seems to me that the behavior to not complete with COLUMN or
CONSTRAINT for ADD is intentional, as it is possible to specify a
constraint or column name without the object type first.  This
introduces a inconsistent behavior with what we do for columns with
ADD, for one.  So a more consistent approach would be to list columns,
constraints, COLUMN and CONSTRAINT in the list of options available
after ADD.
+   else if (Matches("ALTER", "TABLE", MatchAny, "VALIDATE", "CONSTRAINT"))
+   {
+       completion_info_charp = prev3_wd;
+       COMPLETE_WITH_QUERY(Query_for_nonvalid_constraint_of_table);
+   }
Specifying valid constraints is an authorized grammar, so it does not
seem that bad to keep things as they are, either.  I would leave that
alone.

This has stalled being marked Waiting on Author since May, and reading the
above it sounds like marking it Returned with Feedback is the logical next step
(patch also no longer applies).

--
Daniel Gustafsson https://vmware.com/

#7David Fetter
david@fetter.org
In reply to: Daniel Gustafsson (#6)
Re: Bug fix for tab completion of ALTER TABLE ... VALIDATE CONSTRAINT ...

On Fri, Sep 03, 2021 at 08:27:55PM +0200, Daniel Gustafsson wrote:

On 19 May 2021, at 09:53, Michael Paquier <michael@paquier.xyz> wrote:

On Tue, Apr 27, 2021 at 12:58:52PM +0300, Aleksander Alekseev wrote:

I've noticed there is no tab completion for ALTER TABLE xxx ADD. Here
is an alternative version of the patch that fixes this as well. Not
sure if this should be in the same commit though.

-   /* If we have ALTER TABLE <sth> DROP, provide COLUMN or CONSTRAINT */
-   else if (Matches("ALTER", "TABLE", MatchAny, "DROP"))
+   /* If we have ALTER TABLE <sth> ADD|DROP, provide COLUMN or CONSTRAINT */
+   else if (Matches("ALTER", "TABLE", MatchAny, "ADD|DROP"))
Seems to me that the behavior to not complete with COLUMN or
CONSTRAINT for ADD is intentional, as it is possible to specify a
constraint or column name without the object type first.  This
introduces a inconsistent behavior with what we do for columns with
ADD, for one.  So a more consistent approach would be to list columns,
constraints, COLUMN and CONSTRAINT in the list of options available
after ADD.
+   else if (Matches("ALTER", "TABLE", MatchAny, "VALIDATE", "CONSTRAINT"))
+   {
+       completion_info_charp = prev3_wd;
+       COMPLETE_WITH_QUERY(Query_for_nonvalid_constraint_of_table);
+   }
Specifying valid constraints is an authorized grammar, so it does not
seem that bad to keep things as they are, either.  I would leave that
alone.

This has stalled being marked Waiting on Author since May, and reading the
above it sounds like marking it Returned with Feedback is the logical next step
(patch also no longer applies).

Please find attached the next revision :)

Best,
David.
--
David Fetter <david(at)fetter(dot)org> http://fetter.org/
Phone: +1 415 235 3778

Remember to vote!
Consider donating to Postgres: http://www.postgresql.org/about/donate

Attachments:

v4-0001-psql-Fix-tab-completion-for-ALTER-TABLE.patchtext/x-diff; charset=us-asciiDownload+19-3
#8Aleksander Alekseev
aleksander@timescale.com
In reply to: David Fetter (#7)
Re: Bug fix for tab completion of ALTER TABLE ... VALIDATE CONSTRAINT ...

Hi David,

Please find attached the next revision :)

The patch didn't apply and couldn't pass cfbot [1]http://cfbot.cputube.org/patch_34_3113.log. The (hopefully)
corrected patch is attached. Other than that it looks OK to me but let's
see what cfbot will tell.

[1]: http://cfbot.cputube.org/patch_34_3113.log

--
Best regards,
Aleksander Alekseev

Attachments:

v5-0001-psql-Fix-tab-completion-for-ALTER-TABLE.patchapplication/octet-stream; name=v5-0001-psql-Fix-tab-completion-for-ALTER-TABLE.patchDownload+19-2
#9Aleksander Alekseev
aleksander@timescale.com
In reply to: Aleksander Alekseev (#8)
Re: Bug fix for tab completion of ALTER TABLE ... VALIDATE CONSTRAINT ...

The following review has been posted through the commitfest application:
make installcheck-world: tested, passed
Implements feature: tested, passed
Spec compliant: tested, passed
Documentation: tested, passed

The cfbot seems to be happy with the updated patch.

The new status of this patch is: Ready for Committer

#10Tom Lane
tgl@sss.pgh.pa.us
In reply to: Aleksander Alekseev (#9)
Re: Bug fix for tab completion of ALTER TABLE ... VALIDATE CONSTRAINT ...

Aleksander Alekseev <afiskon@gmail.com> writes:

The cfbot seems to be happy with the updated patch.
The new status of this patch is: Ready for Committer

Pushed.

regards, tom lane