2016-12-23 08:22:59 -05:00
|
|
|
####################################################################################################################################
|
2018-04-08 12:57:02 -04:00
|
|
|
# Tests for archive-push command to make sure aync queue limits are implemented correctly
|
2016-12-23 08:22:59 -05:00
|
|
|
####################################################################################################################################
|
2018-04-08 12:57:02 -04:00
|
|
|
package pgBackRestTest::Module::Mock::MockArchiveStopTest;
|
2017-05-12 16:43:04 -04:00
|
|
|
use parent 'pgBackRestTest::Env::HostEnvTest';
|
2016-12-23 08:22:59 -05:00
|
|
|
|
|
|
|
####################################################################################################################################
|
|
|
|
# Perl includes
|
|
|
|
####################################################################################################################################
|
|
|
|
use strict;
|
|
|
|
use warnings FATAL => qw(all);
|
|
|
|
use Carp qw(confess);
|
|
|
|
|
|
|
|
use File::Basename qw(dirname);
|
|
|
|
|
2020-03-10 15:41:56 -04:00
|
|
|
use pgBackRestDoc::Common::Exception;
|
|
|
|
use pgBackRestDoc::Common::Ini;
|
|
|
|
use pgBackRestDoc::Common::Log;
|
2016-12-23 08:22:59 -05:00
|
|
|
|
2020-03-10 15:12:44 -04:00
|
|
|
use pgBackRestTest::Env::ArchiveInfo;
|
|
|
|
use pgBackRestTest::Env::BackupInfo;
|
2017-05-12 16:43:04 -04:00
|
|
|
use pgBackRestTest::Env::HostEnvTest;
|
2020-03-09 17:41:59 -04:00
|
|
|
use pgBackRestTest::Env::Host::HostBackupTest;
|
2020-03-10 15:12:44 -04:00
|
|
|
use pgBackRestTest::Env::Manifest;
|
|
|
|
use pgBackRestTest::Common::DbVersion;
|
2016-12-23 08:22:59 -05:00
|
|
|
use pgBackRestTest::Common::ExecuteTest;
|
|
|
|
use pgBackRestTest::Common::RunTest;
|
2020-03-10 15:12:44 -04:00
|
|
|
use pgBackRestTest::Common::StorageRepo;
|
2019-03-01 17:12:41 +02:00
|
|
|
use pgBackRestTest::Common::VmTest;
|
2020-03-10 15:12:44 -04:00
|
|
|
use pgBackRestTest::Common::Wait;
|
2016-12-23 08:22:59 -05:00
|
|
|
|
|
|
|
####################################################################################################################################
|
|
|
|
# run
|
|
|
|
####################################################################################################################################
|
|
|
|
sub run
|
|
|
|
{
|
|
|
|
my $self = shift;
|
|
|
|
|
2017-11-18 20:02:54 -05:00
|
|
|
# Generate test WAL file
|
|
|
|
my $strWalTestFile = $self->testPath() . '/test-wal-' . PG_VERSION_94;
|
|
|
|
my $strWalHash = $self->walGenerateContentChecksum(PG_VERSION_94);
|
|
|
|
storageTest()->put($strWalTestFile, $self->walGenerateContent(PG_VERSION_94));
|
2016-12-23 08:22:59 -05:00
|
|
|
|
2019-03-01 17:12:41 +02:00
|
|
|
foreach my $rhRun
|
|
|
|
(
|
2020-05-12 18:55:20 -04:00
|
|
|
{vm => VM2, remote => false, storage => S3, encrypt => false, compress => NONE, error => 0},
|
2021-03-05 12:13:51 -05:00
|
|
|
{vm => VM2, remote => true, storage => POSIX, encrypt => true, compress => NONE, error => 0},
|
|
|
|
{vm => VM3, remote => false, storage => GCS, encrypt => true, compress => BZ2, error => 0},
|
2020-07-02 16:24:34 -04:00
|
|
|
{vm => VM3, remote => true, storage => AZURE, encrypt => false, compress => LZ4, error => 1},
|
2021-03-05 12:13:51 -05:00
|
|
|
{vm => VM4, remote => false, storage => S3, encrypt => true, compress => NONE, error => 0},
|
|
|
|
{vm => VM4, remote => true, storage => GCS, encrypt => false, compress => ZST, error => 0},
|
2019-03-01 17:12:41 +02:00
|
|
|
)
|
2016-12-23 08:22:59 -05:00
|
|
|
{
|
2019-03-01 17:12:41 +02:00
|
|
|
# Only run tests for this vm
|
2019-11-02 10:35:48 +01:00
|
|
|
next if ($rhRun->{vm} ne vmTest($self->vm()));
|
2019-03-01 17:12:41 +02:00
|
|
|
|
|
|
|
# Increment the run, log, and decide whether this unit test should be run
|
|
|
|
my $bRemote = $rhRun->{remote};
|
2020-05-12 18:55:20 -04:00
|
|
|
my $strStorage = $rhRun->{storage};
|
2019-03-01 17:12:41 +02:00
|
|
|
my $bEncrypt = $rhRun->{encrypt};
|
2020-03-06 14:41:03 -05:00
|
|
|
my $strCompressType = $rhRun->{compress};
|
2019-03-01 17:12:41 +02:00
|
|
|
my $iError = $rhRun->{error};
|
2017-11-06 12:51:12 -05:00
|
|
|
|
2016-12-23 08:22:59 -05:00
|
|
|
# Increment the run, log, and decide whether this unit test should be run
|
2020-03-06 14:41:03 -05:00
|
|
|
if (!$self->begin(
|
|
|
|
"rmt ${bRemote}, cmp ${strCompressType}, error " . ($iError ? 'connect' : 'version') .
|
2020-05-12 18:55:20 -04:00
|
|
|
", storage ${strStorage}, enc ${bEncrypt}")) {next}
|
2016-12-23 08:22:59 -05:00
|
|
|
|
|
|
|
# Create hosts, file object, and config
|
2020-06-16 14:06:38 -04:00
|
|
|
my ($oHostDbPrimary, $oHostDbStandby, $oHostBackup) = $self->setup(
|
2020-03-06 14:41:03 -05:00
|
|
|
true, $self->expect(), {bHostBackup => $bRemote, strCompressType => $strCompressType, bArchiveAsync => true,
|
2020-05-12 18:55:20 -04:00
|
|
|
strStorage => $strStorage, bRepoEncrypt => $bEncrypt});
|
2016-12-23 08:22:59 -05:00
|
|
|
|
2017-03-02 11:47:23 -05:00
|
|
|
# Create compression extension
|
2020-03-06 14:41:03 -05:00
|
|
|
my $strCompressExt = $strCompressType ne NONE ? ".${strCompressType}" : '';
|
2017-03-02 11:47:23 -05:00
|
|
|
|
2017-09-01 12:29:34 -04:00
|
|
|
# Create the wal path
|
2020-06-16 14:06:38 -04:00
|
|
|
my $strWalPath = $oHostDbPrimary->dbBasePath() . '/pg_xlog';
|
2019-06-26 08:24:58 -04:00
|
|
|
storageTest()->pathCreate($strWalPath, {bCreateParent => true});
|
2016-12-23 08:22:59 -05:00
|
|
|
|
2017-11-18 20:02:54 -05:00
|
|
|
# Create the test path for pg_control and generate pg_control for stanza-create
|
2020-06-16 14:06:38 -04:00
|
|
|
storageTest()->pathCreate($oHostDbPrimary->dbBasePath() . '/' . DB_PATH_GLOBAL, {bCreateParent => true});
|
|
|
|
$self->controlGenerate($oHostDbPrimary->dbBasePath(), PG_VERSION_94);
|
2016-12-23 08:22:59 -05:00
|
|
|
|
|
|
|
# Create the archive info file
|
2020-03-09 17:41:59 -04:00
|
|
|
$oHostBackup->stanzaCreate('create required data for stanza', {strOptionalParam => '--no-online'});
|
2016-12-23 08:22:59 -05:00
|
|
|
|
|
|
|
# Push a WAL segment
|
2019-03-29 13:26:33 +00:00
|
|
|
&log(INFO, ' push first WAL');
|
2020-06-16 14:06:38 -04:00
|
|
|
$oHostDbPrimary->archivePush($strWalPath, $strWalTestFile, 1);
|
2016-12-23 08:22:59 -05:00
|
|
|
|
|
|
|
# Break the database version of the archive info file
|
|
|
|
if ($iError == 0)
|
|
|
|
{
|
|
|
|
$oHostBackup->infoMunge(
|
2020-03-09 17:41:59 -04:00
|
|
|
$oHostBackup->repoArchivePath(ARCHIVE_INFO_FILE),
|
2019-03-29 13:26:33 +00:00
|
|
|
{&INFO_ARCHIVE_SECTION_DB => {&INFO_ARCHIVE_KEY_DB_VERSION => '8.0'},
|
|
|
|
&INFO_ARCHIVE_SECTION_DB_HISTORY => {1 => {&INFO_ARCHIVE_KEY_DB_VERSION => '8.0'}}});
|
2016-12-23 08:22:59 -05:00
|
|
|
}
|
|
|
|
|
2018-04-18 19:37:35 -04:00
|
|
|
# Push two more segments with errors to exceed archive-push-queue-max
|
2019-03-29 13:26:33 +00:00
|
|
|
&log(INFO, ' push second WAL');
|
|
|
|
|
2020-06-16 14:06:38 -04:00
|
|
|
$oHostDbPrimary->archivePush(
|
2021-03-25 12:54:49 -04:00
|
|
|
$strWalPath, $strWalTestFile, 2, ERROR_REPO_INVALID, undef, $iError ? '--repo1-host=bogus' : undef);
|
2019-03-29 13:26:33 +00:00
|
|
|
|
|
|
|
&log(INFO, ' push third WAL');
|
2016-12-23 08:22:59 -05:00
|
|
|
|
2020-06-16 14:06:38 -04:00
|
|
|
$oHostDbPrimary->archivePush(
|
2021-03-25 12:54:49 -04:00
|
|
|
$strWalPath, $strWalTestFile, 3, ERROR_REPO_INVALID, undef, $iError ? '--repo1-host=bogus' : undef);
|
2016-12-23 08:22:59 -05:00
|
|
|
|
|
|
|
# Now this segment will get dropped
|
2019-03-29 13:26:33 +00:00
|
|
|
&log(INFO, ' push fourth WAL');
|
|
|
|
|
2020-06-16 14:06:38 -04:00
|
|
|
$oHostDbPrimary->archivePush($strWalPath, $strWalTestFile, 4, undef, undef, '--repo1-host=bogus');
|
2016-12-23 08:22:59 -05:00
|
|
|
|
|
|
|
# Fix the database version
|
|
|
|
if ($iError == 0)
|
|
|
|
{
|
2020-03-09 17:41:59 -04:00
|
|
|
$oHostBackup->infoRestore($oHostBackup->repoArchivePath(ARCHIVE_INFO_FILE));
|
2016-12-23 08:22:59 -05:00
|
|
|
}
|
|
|
|
|
2017-03-02 11:47:23 -05:00
|
|
|
#---------------------------------------------------------------------------------------------------------------------------
|
|
|
|
$self->testResult(
|
2020-03-09 17:41:59 -04:00
|
|
|
sub {storageRepo()->list($oHostBackup->repoArchivePath(PG_VERSION_94 . '-1/0000000100000001'))},
|
2017-11-18 20:02:54 -05:00
|
|
|
"000000010000000100000001-${strWalHash}${strCompressExt}",
|
2018-10-27 16:57:57 +01:00
|
|
|
'segment 2-4 not pushed', {iWaitSeconds => 5});
|
2016-12-23 08:22:59 -05:00
|
|
|
|
2017-03-02 11:47:23 -05:00
|
|
|
#---------------------------------------------------------------------------------------------------------------------------
|
2020-06-16 14:06:38 -04:00
|
|
|
$oHostDbPrimary->archivePush($strWalPath, $strWalTestFile, 5);
|
2016-12-23 08:22:59 -05:00
|
|
|
|
2017-03-02 11:47:23 -05:00
|
|
|
$self->testResult(
|
2020-03-09 17:41:59 -04:00
|
|
|
sub {storageRepo()->list($oHostBackup->repoArchivePath(PG_VERSION_94 . '-1/0000000100000001'))},
|
2017-11-18 20:02:54 -05:00
|
|
|
"(000000010000000100000001-${strWalHash}${strCompressExt}, " .
|
|
|
|
"000000010000000100000005-${strWalHash}${strCompressExt})",
|
2017-04-05 10:50:32 -04:00
|
|
|
'segment 5 is pushed', {iWaitSeconds => 5});
|
2016-12-23 08:22:59 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
1;
|