mirror of
https://git.postgresql.org/git/postgresql.git
synced 2024-09-06 20:19:21 +02:00
c538592959
There are a lot of Perl scripts in the tree, mostly code generation and TAP tests. Occasionally, these scripts produce warnings. These are probably always mistakes on the developer side (true positives). Typical examples are warnings from genbki.pl or related when you make a mess in the catalog files during development, or warnings from tests when they massage a config file that looks different on different hosts, or mistakes during merges (e.g., duplicate subroutine definitions), or just mistakes that weren't noticed because there is a lot of output in a verbose build. This changes all warnings into fatal errors, by replacing use warnings; by use warnings FATAL => 'all'; in all Perl files. Discussion: https://www.postgresql.org/message-id/flat/06f899fd-1826-05ab-42d6-adeb1fd5e200%40eisentraut.org
92 lines
1.7 KiB
Perl
Executable File
92 lines
1.7 KiB
Perl
Executable File
#!/usr/bin/perl
|
|
|
|
# Copyright (c) 2021-2023, PostgreSQL Global Development Group
|
|
|
|
# contrib/intarray/bench/create_test.pl
|
|
|
|
use strict;
|
|
use warnings FATAL => 'all';
|
|
|
|
print <<EOT;
|
|
create table message (
|
|
mid int not null,
|
|
sections int[]
|
|
);
|
|
create table message_section_map (
|
|
mid int not null,
|
|
sid int not null
|
|
);
|
|
|
|
EOT
|
|
|
|
open(my $msg, '>', "message.tmp") || die;
|
|
open(my $map, '>', "message_section_map.tmp") || die;
|
|
|
|
srand(1);
|
|
|
|
#foreach my $i ( 1..1778 ) {
|
|
#foreach my $i ( 1..3443 ) {
|
|
#foreach my $i ( 1..5000 ) {
|
|
#foreach my $i ( 1..29362 ) {
|
|
#foreach my $i ( 1..33331 ) {
|
|
#foreach my $i ( 1..83268 ) {
|
|
foreach my $i (1 .. 200000)
|
|
{
|
|
my @sect;
|
|
if (rand() < 0.7)
|
|
{
|
|
$sect[0] = int((rand()**4) * 100);
|
|
}
|
|
else
|
|
{
|
|
my %hash;
|
|
@sect =
|
|
grep { $hash{$_}++; $hash{$_} <= 1 }
|
|
map { int((rand()**4) * 100) } 0 .. (int(rand() * 5));
|
|
}
|
|
if ($#sect < 0 || rand() < 0.1)
|
|
{
|
|
print $msg "$i\t\\N\n";
|
|
}
|
|
else
|
|
{
|
|
print $msg "$i\t{" . join(',', @sect) . "}\n";
|
|
print $map "$i\t$_\n" foreach @sect;
|
|
}
|
|
}
|
|
close $map;
|
|
close $msg;
|
|
|
|
copytable('message');
|
|
copytable('message_section_map');
|
|
|
|
print <<EOT;
|
|
|
|
CREATE unique index message_key on message ( mid );
|
|
--CREATE unique index message_section_map_key1 on message_section_map ( mid, sid );
|
|
CREATE unique index message_section_map_key2 on message_section_map ( sid, mid );
|
|
CREATE INDEX message_rdtree_idx on message using gist ( sections gist__int_ops );
|
|
VACUUM ANALYZE;
|
|
|
|
select count(*) from message;
|
|
select count(*) from message_section_map;
|
|
|
|
|
|
|
|
EOT
|
|
|
|
|
|
unlink 'message.tmp', 'message_section_map.tmp';
|
|
|
|
sub copytable
|
|
{
|
|
my $t = shift;
|
|
|
|
print "COPY $t from stdin;\n";
|
|
open(my $fff, '<', "$t.tmp") || die;
|
|
while (<$fff>) { print; }
|
|
close $fff;
|
|
print "\\.\n";
|
|
return;
|
|
}
|