1
0
mirror of https://github.com/pgbackrest/pgbackrest.git synced 2024-12-12 10:04:14 +02:00

Throw user-friendly error if expire is not run on repository host.

Running the expire command on a non-repository host threw an assertion because the command is not yet configured for remote execution.
This commit is contained in:
Cynthia Shang 2020-04-27 10:49:05 -04:00 committed by David Steele
parent 987df62ec0
commit a5b2630d7c
3 changed files with 27 additions and 4 deletions

View File

@ -23,6 +23,16 @@
<p>Add <cmd>backup</cmd>/<cmd>expire</cmd> running status to the <cmd>info</cmd> command.</p>
</release-item>
</release-feature-list>
<release-improvement-list>
<release-item>
<release-item-contributor-list>
<release-item-contributor id="cynthia.shang"/>
</release-item-contributor-list>
<p>Throw user-friendly error if <cmd>expire</cmd> is not run on repository host.</p>
</release-item>
</release-improvement-list>
</release-core-list>
</release>

View File

@ -12,6 +12,7 @@ Expire Command
#include "info/infoArchive.h"
#include "info/infoBackup.h"
#include "info/manifest.h"
#include "protocol/helper.h"
#include "storage/helper.h"
#include <stdlib.h>
@ -640,11 +641,11 @@ cmdExpire(void)
{
FUNCTION_LOG_VOID(logLevelDebug);
// Verify the repo is local
repoIsLocalVerify();
MEM_CONTEXT_TEMP_BEGIN()
{
// Get the repo storage in case it is remote and encryption settings need to be pulled down
storageRepo();
// Load the backup.info
InfoBackup *infoBackup = infoBackupLoadFileReconstruct(
storageRepo(), INFO_BACKUP_PATH_FILE_STR, cipherType(cfgOptionStr(cfgOptRepoCipherType)),

View File

@ -477,11 +477,23 @@ testRun(void)
// *****************************************************************************************************************************
if (testBegin("removeExpiredArchive() & cmdExpire()"))
{
TEST_TITLE("check repo local");
// Load Parameters
StringList *argList = strLstNew();
strLstAddZ(argList, "--stanza=db");
strLstAddZ(argList, "--repo1-retention-full=1"); // avoid warning
strLstAddZ(argList, "--repo1-host=/repo/not/local");
harnessCfgLoad(cfgCmdExpire, argList);
TEST_ERROR_FMT(
cmdExpire(), HostInvalidError, "expire command must be run on the repository host");
//--------------------------------------------------------------------------------------------------------------------------
TEST_TITLE("retention-archive not set");
// Load Parameters
StringList *argList = strLstDup(argListBase);
argList = strLstDup(argListBase);
harnessCfgLoad(cfgCmdExpire, argList);
// Create backup.info without current backups