mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	Add new simple TAP test for tablespaces, attempt II.
See commit message for d1511fe1b0.  This
new version attempts to fix path translation problem on MSYS/Windows.
Discussion: https://postgr.es/m/20220117055326.GD756210%40rfd.leadboat.com
			
			
This commit is contained in:
		
							
								
								
									
										99
									
								
								src/test/modules/test_misc/t/002_tablespace.pl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										99
									
								
								src/test/modules/test_misc/t/002_tablespace.pl
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,99 @@ | |||||||
|  | # Simple tablespace tests that can't be replicated on the same host | ||||||
|  | # due to the use of absolute paths, so we keep them out of the regular | ||||||
|  | # regression tests. | ||||||
|  |  | ||||||
|  | use strict; | ||||||
|  | use warnings; | ||||||
|  | use PostgreSQL::Test::Cluster; | ||||||
|  | use PostgreSQL::Test::Utils; | ||||||
|  | use Test::More tests => 20; | ||||||
|  |  | ||||||
|  | my $node = PostgreSQL::Test::Cluster->new('main'); | ||||||
|  | $node->init; | ||||||
|  | $node->start; | ||||||
|  |  | ||||||
|  | # Create a couple of directories to use as tablespaces. | ||||||
|  | my $basedir = $node->basedir(); | ||||||
|  | my $TS1_LOCATION = PostgreSQL::Test::Utils::perl2host("$basedir/ts1"); | ||||||
|  | $TS1_LOCATION =~ s/\/\.\//\//g; # collapse foo/./bar to foo/bar | ||||||
|  | mkdir($TS1_LOCATION); | ||||||
|  | my $TS2_LOCATION = PostgreSQL::Test::Utils::perl2host("$basedir/ts2"); | ||||||
|  | $TS2_LOCATION =~ s/\/\.\//\//g; | ||||||
|  | mkdir($TS2_LOCATION); | ||||||
|  |  | ||||||
|  | my $result; | ||||||
|  |  | ||||||
|  | # Create a tablespace with an absolute path | ||||||
|  | $result = $node->psql('postgres', | ||||||
|  | 	"CREATE TABLESPACE regress_ts1 LOCATION '$TS1_LOCATION'"); | ||||||
|  | ok($result == 0, 'create tablespace with absolute path'); | ||||||
|  |  | ||||||
|  | # Can't create a tablespace where there is one already | ||||||
|  | $result = $node->psql('postgres', | ||||||
|  | 	"CREATE TABLESPACE regress_ts1 LOCATION '$TS1_LOCATION'"); | ||||||
|  | ok($result != 0, 'clobber tablespace with absolute path'); | ||||||
|  |  | ||||||
|  | # Create table in it | ||||||
|  | $result = $node->psql('postgres', | ||||||
|  | 	"CREATE TABLE t () TABLESPACE regress_ts1"); | ||||||
|  | ok($result == 0, 'create table in tablespace with absolute path'); | ||||||
|  |  | ||||||
|  | # Can't drop a tablespace that still has a table in it | ||||||
|  | $result = $node->psql('postgres', | ||||||
|  | 	"DROP TABLESPACE regress_ts1"); | ||||||
|  | ok($result != 0, 'drop tablespace with absolute path'); | ||||||
|  |  | ||||||
|  | # Drop the table | ||||||
|  | $result = $node->psql('postgres', "DROP TABLE t"); | ||||||
|  | ok($result == 0, 'drop table in tablespace with absolute path'); | ||||||
|  |  | ||||||
|  | # Drop the tablespace | ||||||
|  | $result = $node->psql('postgres', "DROP TABLESPACE regress_ts1"); | ||||||
|  | ok($result == 0, 'drop tablespace with absolute path'); | ||||||
|  |  | ||||||
|  | # Create two absolute tablespaces and two in-place tablespaces, so we can | ||||||
|  | # testing various kinds of tablespace moves. | ||||||
|  | $result = $node->psql('postgres', | ||||||
|  | 	"CREATE TABLESPACE regress_ts1 LOCATION '$TS1_LOCATION'"); | ||||||
|  | ok($result == 0, 'create tablespace 1 with absolute path'); | ||||||
|  | $result = $node->psql('postgres', | ||||||
|  | 	"CREATE TABLESPACE regress_ts2 LOCATION '$TS2_LOCATION'"); | ||||||
|  | ok($result == 0, 'create tablespace 2 with absolute path'); | ||||||
|  | $result = $node->psql('postgres', | ||||||
|  | 	"SET allow_in_place_tablespaces=on; CREATE TABLESPACE regress_ts3 LOCATION ''"); | ||||||
|  | ok($result == 0, 'create tablespace 3 with in-place directory'); | ||||||
|  | $result = $node->psql('postgres', | ||||||
|  | 	"SET allow_in_place_tablespaces=on; CREATE TABLESPACE regress_ts4 LOCATION ''"); | ||||||
|  | ok($result == 0, 'create tablespace 4 with in-place directory'); | ||||||
|  |  | ||||||
|  | # Create a table and test moving between absolute and in-place tablespaces | ||||||
|  | $result = $node->psql('postgres', | ||||||
|  | 	"CREATE TABLE t () TABLESPACE regress_ts1"); | ||||||
|  | ok($result == 0, 'create table in tablespace 1'); | ||||||
|  | $result = $node->psql('postgres', | ||||||
|  | 	"ALTER TABLE t SET tablespace regress_ts2"); | ||||||
|  | ok($result == 0, 'move table abs->abs'); | ||||||
|  | $result = $node->psql('postgres', | ||||||
|  | 	"ALTER TABLE t SET tablespace regress_ts3"); | ||||||
|  | ok($result == 0, 'move table abs->in-place'); | ||||||
|  | $result = $node->psql('postgres', | ||||||
|  | 	"ALTER TABLE t SET tablespace regress_ts4"); | ||||||
|  | ok($result == 0, 'move table in-place->in-place'); | ||||||
|  | $result = $node->psql('postgres', | ||||||
|  | 	"ALTER TABLE t SET tablespace regress_ts1"); | ||||||
|  | ok($result == 0, 'move table in-place->abs'); | ||||||
|  |  | ||||||
|  | # Drop everything | ||||||
|  | $result = $node->psql('postgres', | ||||||
|  | 	"DROP TABLE t"); | ||||||
|  | ok($result == 0, 'create table in tablespace 1'); | ||||||
|  | $result = $node->psql('postgres', "DROP TABLESPACE regress_ts1"); | ||||||
|  | ok($result == 0, 'drop tablespace 1'); | ||||||
|  | $result = $node->psql('postgres', "DROP TABLESPACE regress_ts2"); | ||||||
|  | ok($result == 0, 'drop tablespace 2'); | ||||||
|  | $result = $node->psql('postgres', "DROP TABLESPACE regress_ts3"); | ||||||
|  | ok($result == 0, 'drop tablespace 3'); | ||||||
|  | $result = $node->psql('postgres', "DROP TABLESPACE regress_ts4"); | ||||||
|  | ok($result == 0, 'drop tablespace 4'); | ||||||
|  |  | ||||||
|  | $node->stop; | ||||||
		Reference in New Issue
	
	Block a user