Greetings,

* Amit Langote (langote_amit...@lab.ntt.co.jp) wrote:
> On 2017/05/08 12:42, Stephen Frost wrote:
> > * Amit Langote (langote_amit...@lab.ntt.co.jp) wrote:
> >> Thanks for committing the patch after improving it quite a bit, and sorry
> >> that I couldn't reply promptly during the last week due to vacation.
> > 
> > No worries, hopefully you have an opportunity to review the additional
> > changes I made and understand why they were necessary.  Certainly, feel
> > free to reach out if you have any questions or notice anything else
> > which should be improved.
> 
> Do you intend to push the other patch to add regression tests for the
> non-inherited constraints?  Here it is attached again for you to look over.

In a blast from the past, I had a long-lost note about trying to push
this that I just stumbled over.

Apologies for it getting lost in the cracks.  I've rebased it and will
plan to push it later this weekend, barring objections.

Thanks!

Stephen
diff --git a/src/bin/pg_dump/t/002_pg_dump.pl b/src/bin/pg_dump/t/002_pg_dump.pl
new file mode 100644
index 2afd950..8f4bb55
*** a/src/bin/pg_dump/t/002_pg_dump.pl
--- b/src/bin/pg_dump/t/002_pg_dump.pl
*************** my %tests = (
*** 2246,2257 ****
  		create_order => 91,
  		create_sql =>
  		  'CREATE TABLE dump_test_second_schema.measurement_y2006m2
! 					   PARTITION OF dump_test.measurement FOR VALUES
! 					   FROM (\'2006-02-01\') TO (\'2006-03-01\');',
  		regexp => qr/^
  			\Q-- Name: measurement_y2006m2;\E.*\n
  			\Q--\E\n\n
! 			\QCREATE TABLE dump_test_second_schema.measurement_y2006m2 PARTITION OF dump_test.measurement\E\n
  			\QFOR VALUES FROM ('2006-02-01') TO ('2006-03-01');\E\n
  			/xm,
  		like => {
--- 2246,2261 ----
  		create_order => 91,
  		create_sql =>
  		  'CREATE TABLE dump_test_second_schema.measurement_y2006m2
! 						PARTITION OF dump_test.measurement (
! 							unitsales DEFAULT 0 CHECK (unitsales >= 0)
! 						)
! 						FOR VALUES FROM (\'2006-02-01\') TO (\'2006-03-01\');',
  		regexp => qr/^
  			\Q-- Name: measurement_y2006m2;\E.*\n
  			\Q--\E\n\n
! 			\QCREATE TABLE dump_test_second_schema.measurement_y2006m2 PARTITION OF dump_test.measurement (\E\n
! 			\s+\QCONSTRAINT measurement_y2006m2_unitsales_check CHECK ((unitsales >= 0))\E\n
! 			\)\n
  			\QFOR VALUES FROM ('2006-02-01') TO ('2006-03-01');\E\n
  			/xm,
  		like => {
diff --git a/src/test/regress/expected/create_table.out b/src/test/regress/expected/create_table.out
new file mode 100644
index b26b4e7..7e52c27
*** a/src/test/regress/expected/create_table.out
--- b/src/test/regress/expected/create_table.out
*************** CREATE TABLE part_b PARTITION OF parted
*** 703,718 ****
  ) FOR VALUES IN ('b');
  ERROR:  column "b" specified more than once
  CREATE TABLE part_b PARTITION OF parted (
! 	b NOT NULL DEFAULT 1 CHECK (b >= 0),
! 	CONSTRAINT check_a CHECK (length(a) > 0)
  ) FOR VALUES IN ('b');
  NOTICE:  merging constraint "check_a" with inherited definition
! -- conislocal should be false for any merged constraints
! SELECT conislocal, coninhcount FROM pg_constraint WHERE conrelid = 'part_b'::regclass AND conname = 'check_a';
   conislocal | coninhcount 
  ------------+-------------
   f          |           1
! (1 row)
  
  -- specify PARTITION BY for a partition
  CREATE TABLE fail_part_col_not_found PARTITION OF parted FOR VALUES IN ('c') PARTITION BY RANGE (c);
--- 703,744 ----
  ) FOR VALUES IN ('b');
  ERROR:  column "b" specified more than once
  CREATE TABLE part_b PARTITION OF parted (
! 	b NOT NULL DEFAULT 1,
! 	CONSTRAINT check_a CHECK (length(a) > 0),
! 	CONSTRAINT check_b CHECK (b >= 0)
  ) FOR VALUES IN ('b');
  NOTICE:  merging constraint "check_a" with inherited definition
! -- conislocal should be false for any merged constraints, true otherwise
! SELECT conislocal, coninhcount FROM pg_constraint WHERE conrelid = 'part_b'::regclass ORDER BY conislocal, coninhcount;
   conislocal | coninhcount 
  ------------+-------------
   f          |           1
!  t          |           0
! (2 rows)
! 
! -- Once check_b is added to the parent, it should be made non-local for part_b
! ALTER TABLE parted ADD CONSTRAINT check_b CHECK (b >= 0);
! NOTICE:  merging constraint "check_b" with inherited definition
! SELECT conislocal, coninhcount FROM pg_constraint WHERE conrelid = 'part_b'::regclass;
!  conislocal | coninhcount 
! ------------+-------------
!  f          |           1
!  f          |           1
! (2 rows)
! 
! -- Neither check_a nor check_b are droppable from part_b
! ALTER TABLE part_b DROP CONSTRAINT check_a;
! ERROR:  cannot drop inherited constraint "check_a" of relation "part_b"
! ALTER TABLE part_b DROP CONSTRAINT check_b;
! ERROR:  cannot drop inherited constraint "check_b" of relation "part_b"
! -- And dropping it from parted should leave no trace of them on part_b, unlike
! -- traditional inheritance where they will be left behind, because they would
! -- be local constraints.
! ALTER TABLE parted DROP CONSTRAINT check_a, DROP CONSTRAINT check_b;
! SELECT conislocal, coninhcount FROM pg_constraint WHERE conrelid = 'part_b'::regclass;
!  conislocal | coninhcount 
! ------------+-------------
! (0 rows)
  
  -- specify PARTITION BY for a partition
  CREATE TABLE fail_part_col_not_found PARTITION OF parted FOR VALUES IN ('c') PARTITION BY RANGE (c);
*************** drop table parted_collate_must_match;
*** 757,765 ****
   b      | integer |           | not null | 1       | plain    |              | 
  Partition of: parted FOR VALUES IN ('b')
  Partition constraint: ((a IS NOT NULL) AND (a = 'b'::text))
- Check constraints:
-     "check_a" CHECK (length(a) > 0)
-     "part_b_b_check" CHECK (b >= 0)
  
  -- Both partition bound and partition key in describe output
  \d+ part_c
--- 783,788 ----
*************** Check constraints:
*** 771,778 ****
  Partition of: parted FOR VALUES IN ('c')
  Partition constraint: ((a IS NOT NULL) AND (a = 'c'::text))
  Partition key: RANGE (b)
- Check constraints:
-     "check_a" CHECK (length(a) > 0)
  Partitions: part_c_1_10 FOR VALUES FROM (1) TO (10)
  
  -- a level-2 partition's constraint will include the parent's expressions
--- 794,799 ----
*************** Partitions: part_c_1_10 FOR VALUES FROM
*** 784,791 ****
   b      | integer |           | not null | 0       | plain    |              | 
  Partition of: part_c FOR VALUES FROM (1) TO (10)
  Partition constraint: ((a IS NOT NULL) AND (a = 'c'::text) AND (b IS NOT NULL) AND (b >= 1) AND (b < 10))
- Check constraints:
-     "check_a" CHECK (length(a) > 0)
  
  -- Show partition count in the parent's describe output
  -- Tempted to include \d+ output listing partitions with bound info but
--- 805,810 ----
*************** Check constraints:
*** 798,805 ****
   a      | text    |           |          | 
   b      | integer |           | not null | 0
  Partition key: LIST (a)
- Check constraints:
-     "check_a" CHECK (length(a) > 0)
  Number of partitions: 3 (Use \d+ to list them.)
  
  \d hash_parted
--- 817,822 ----
diff --git a/src/test/regress/sql/create_table.sql b/src/test/regress/sql/create_table.sql
new file mode 100644
index c6f048f..a2cae96
*** a/src/test/regress/sql/create_table.sql
--- b/src/test/regress/sql/create_table.sql
*************** CREATE TABLE part_b PARTITION OF parted
*** 639,649 ****
  ) FOR VALUES IN ('b');
  
  CREATE TABLE part_b PARTITION OF parted (
! 	b NOT NULL DEFAULT 1 CHECK (b >= 0),
! 	CONSTRAINT check_a CHECK (length(a) > 0)
  ) FOR VALUES IN ('b');
! -- conislocal should be false for any merged constraints
! SELECT conislocal, coninhcount FROM pg_constraint WHERE conrelid = 'part_b'::regclass AND conname = 'check_a';
  
  -- specify PARTITION BY for a partition
  CREATE TABLE fail_part_col_not_found PARTITION OF parted FOR VALUES IN ('c') PARTITION BY RANGE (c);
--- 639,664 ----
  ) FOR VALUES IN ('b');
  
  CREATE TABLE part_b PARTITION OF parted (
! 	b NOT NULL DEFAULT 1,
! 	CONSTRAINT check_a CHECK (length(a) > 0),
! 	CONSTRAINT check_b CHECK (b >= 0)
  ) FOR VALUES IN ('b');
! -- conislocal should be false for any merged constraints, true otherwise
! SELECT conislocal, coninhcount FROM pg_constraint WHERE conrelid = 'part_b'::regclass ORDER BY conislocal, coninhcount;
! 
! -- Once check_b is added to the parent, it should be made non-local for part_b
! ALTER TABLE parted ADD CONSTRAINT check_b CHECK (b >= 0);
! SELECT conislocal, coninhcount FROM pg_constraint WHERE conrelid = 'part_b'::regclass;
! 
! -- Neither check_a nor check_b are droppable from part_b
! ALTER TABLE part_b DROP CONSTRAINT check_a;
! ALTER TABLE part_b DROP CONSTRAINT check_b;
! 
! -- And dropping it from parted should leave no trace of them on part_b, unlike
! -- traditional inheritance where they will be left behind, because they would
! -- be local constraints.
! ALTER TABLE parted DROP CONSTRAINT check_a, DROP CONSTRAINT check_b;
! SELECT conislocal, coninhcount FROM pg_constraint WHERE conrelid = 'part_b'::regclass;
  
  -- specify PARTITION BY for a partition
  CREATE TABLE fail_part_col_not_found PARTITION OF parted FOR VALUES IN ('c') PARTITION BY RANGE (c);

Attachment: signature.asc
Description: PGP signature

Reply via email to