2018-12-13 16:22:34 -05:00
|
|
|
/***********************************************************************************************************************************
|
|
|
|
Test Info Command
|
|
|
|
***********************************************************************************************************************************/
|
2019-05-03 15:46:15 -04:00
|
|
|
#include "storage/posix/storage.h"
|
2018-12-13 16:22:34 -05:00
|
|
|
|
|
|
|
#include "common/harnessConfig.h"
|
2019-04-23 14:02:30 -04:00
|
|
|
#include "common/harnessInfo.h"
|
2020-04-24 08:00:00 -04:00
|
|
|
#include "common/harnessFork.h"
|
2018-12-13 16:22:34 -05:00
|
|
|
|
|
|
|
/***********************************************************************************************************************************
|
|
|
|
Test Run
|
|
|
|
***********************************************************************************************************************************/
|
|
|
|
void
|
|
|
|
testRun(void)
|
|
|
|
{
|
|
|
|
FUNCTION_HARNESS_VOID();
|
|
|
|
|
2019-10-10 19:43:42 -04:00
|
|
|
// The tests expect the timezone to be UTC
|
|
|
|
setenv("TZ", "UTC", true);
|
|
|
|
|
2018-12-13 16:22:34 -05:00
|
|
|
// Create the repo directories
|
|
|
|
String *repoPath = strNewFmt("%s/repo", testPath());
|
|
|
|
String *archivePath = strNewFmt("%s/%s", strPtr(repoPath), "archive");
|
|
|
|
String *backupPath = strNewFmt("%s/%s", strPtr(repoPath), "backup");
|
|
|
|
String *archiveStanza1Path = strNewFmt("%s/stanza1", strPtr(archivePath));
|
|
|
|
String *backupStanza1Path = strNewFmt("%s/stanza1", strPtr(backupPath));
|
|
|
|
|
|
|
|
// *****************************************************************************************************************************
|
|
|
|
if (testBegin("infoRender()"))
|
|
|
|
{
|
|
|
|
StringList *argList = strLstNew();
|
2019-03-14 13:48:33 +04:00
|
|
|
strLstAdd(argList, strNewFmt("--repo-path=%s/", strPtr(repoPath)));
|
2018-12-13 16:22:34 -05:00
|
|
|
StringList *argListText = strLstDup(argList);
|
|
|
|
|
|
|
|
strLstAddZ(argList, "--output=json");
|
2019-10-08 12:06:30 -04:00
|
|
|
harnessCfgLoad(cfgCmdInfo, argList);
|
2018-12-13 16:22:34 -05:00
|
|
|
|
|
|
|
// No stanzas have been created
|
|
|
|
//--------------------------------------------------------------------------------------------------------------------------
|
2019-12-26 18:08:27 -07:00
|
|
|
TEST_RESULT_STR_Z(infoRender(), "[]", "json - repo but no stanzas");
|
2018-12-13 16:22:34 -05:00
|
|
|
|
2019-10-08 12:06:30 -04:00
|
|
|
harnessCfgLoad(cfgCmdInfo, argListText);
|
2019-12-26 18:08:27 -07:00
|
|
|
TEST_RESULT_STR_Z(infoRender(), "No stanzas exist in the repository.\n", "text - no stanzas");
|
2019-01-13 22:44:58 +02:00
|
|
|
|
2019-11-17 15:10:40 -05:00
|
|
|
storagePathCreateP(storageLocalWrite(), archivePath);
|
|
|
|
storagePathCreateP(storageLocalWrite(), backupPath);
|
2018-12-13 16:22:34 -05:00
|
|
|
|
|
|
|
// Empty stanza
|
|
|
|
//--------------------------------------------------------------------------------------------------------------------------
|
2019-11-17 15:10:40 -05:00
|
|
|
TEST_RESULT_VOID(storagePathCreateP(storageLocalWrite(), backupStanza1Path), "backup stanza1 directory");
|
|
|
|
TEST_RESULT_VOID(storagePathCreateP(storageLocalWrite(), archiveStanza1Path), "archive stanza1 directory");
|
2019-12-26 18:08:27 -07:00
|
|
|
TEST_RESULT_STR_Z(
|
|
|
|
infoRender(),
|
2018-12-13 16:22:34 -05:00
|
|
|
"stanza: stanza1\n"
|
|
|
|
" status: error (missing stanza data)\n"
|
2019-12-26 18:08:27 -07:00
|
|
|
" cipher: none\n",
|
|
|
|
"text - missing stanza data");
|
2018-12-13 16:22:34 -05:00
|
|
|
|
2019-10-08 12:06:30 -04:00
|
|
|
harnessCfgLoad(cfgCmdInfo, argList);
|
2019-12-26 18:08:27 -07:00
|
|
|
TEST_RESULT_STR_Z(
|
|
|
|
infoRender(),
|
2019-10-11 12:56:03 -04:00
|
|
|
"["
|
|
|
|
"{"
|
|
|
|
"\"archive\":[],"
|
|
|
|
"\"backup\":[],"
|
|
|
|
"\"cipher\":\"none\","
|
|
|
|
"\"db\":[],"
|
|
|
|
"\"name\":\"stanza1\","
|
|
|
|
"\"status\":{"
|
|
|
|
"\"code\":3,"
|
2020-04-24 08:00:00 -04:00
|
|
|
"\"lock\":{\"backup\":{\"held\":false}},"
|
2019-10-11 12:56:03 -04:00
|
|
|
"\"message\":\"missing stanza data\""
|
|
|
|
"}"
|
|
|
|
"}"
|
2019-12-26 18:08:27 -07:00
|
|
|
"]",
|
|
|
|
"json - missing stanza data");
|
2018-12-13 16:22:34 -05:00
|
|
|
|
|
|
|
// backup.info file exists, but archive.info does not
|
|
|
|
//--------------------------------------------------------------------------------------------------------------------------
|
|
|
|
String *content = strNew
|
|
|
|
(
|
2019-01-16 22:16:50 +02:00
|
|
|
"[cipher]\n"
|
2019-04-22 18:41:01 -04:00
|
|
|
"cipher-pass=\"12345\"\n"
|
2019-01-16 22:16:50 +02:00
|
|
|
"\n"
|
2018-12-13 16:22:34 -05:00
|
|
|
"[db]\n"
|
|
|
|
"db-catalog-version=201409291\n"
|
|
|
|
"db-control-version=942\n"
|
|
|
|
"db-id=2\n"
|
|
|
|
"db-system-id=6569239123849665679\n"
|
|
|
|
"db-version=\"9.4\"\n"
|
|
|
|
"\n"
|
|
|
|
"[db:history]\n"
|
|
|
|
"1={\"db-catalog-version\":201306121,\"db-control-version\":937,\"db-system-id\":6569239123849665666,"
|
|
|
|
"\"db-version\":\"9.3\"}\n"
|
|
|
|
"2={\"db-catalog-version\":201409291,\"db-control-version\":942,\"db-system-id\":6569239123849665679,"
|
|
|
|
"\"db-version\":\"9.4\"}\n"
|
|
|
|
);
|
|
|
|
|
|
|
|
TEST_RESULT_VOID(
|
2019-11-17 15:10:40 -05:00
|
|
|
storagePutP(storageNewWriteP(storageLocalWrite(), strNewFmt("%s/backup.info", strPtr(backupStanza1Path))),
|
2019-04-23 14:02:30 -04:00
|
|
|
harnessInfoChecksum(content)), "put backup info to file");
|
2018-12-13 16:22:34 -05:00
|
|
|
|
|
|
|
TEST_ERROR_FMT(infoRender(), FileMissingError,
|
|
|
|
"unable to load info file '%s/archive.info' or '%s/archive.info.copy':\n"
|
2019-05-26 12:41:15 -04:00
|
|
|
"FileMissingError: " STORAGE_ERROR_READ_MISSING "\n"
|
|
|
|
"FileMissingError: " STORAGE_ERROR_READ_MISSING "\n"
|
2018-12-13 16:22:34 -05:00
|
|
|
"HINT: archive.info cannot be opened but is required to push/get WAL segments.\n"
|
|
|
|
"HINT: is archive_command configured correctly in postgresql.conf?\n"
|
|
|
|
"HINT: has a stanza-create been performed?\n"
|
|
|
|
"HINT: use --no-archive-check to disable archive checks during backup if you have an alternate archiving scheme.",
|
2019-05-26 12:41:15 -04:00
|
|
|
strPtr(archiveStanza1Path), strPtr(archiveStanza1Path),
|
|
|
|
strPtr(strNewFmt("%s/archive.info", strPtr(archiveStanza1Path))),
|
|
|
|
strPtr(strNewFmt("%s/archive.info.copy", strPtr(archiveStanza1Path))));
|
2018-12-13 16:22:34 -05:00
|
|
|
|
|
|
|
// backup.info/archive.info files exist, mismatched db ids, no backup:current section so no valid backups
|
|
|
|
// Only the current db information from the db:history will be processed.
|
|
|
|
//--------------------------------------------------------------------------------------------------------------------------
|
|
|
|
content = strNew
|
|
|
|
(
|
|
|
|
"[db]\n"
|
|
|
|
"db-id=1\n"
|
|
|
|
"db-system-id=6569239123849665679\n"
|
|
|
|
"db-version=\"9.4\"\n"
|
|
|
|
"\n"
|
|
|
|
"[db:history]\n"
|
|
|
|
"1={\"db-id\":6569239123849665679,\"db-version\":\"9.4\"}\n"
|
|
|
|
"2={\"db-id\":6569239123849665666,\"db-version\":\"9.3\"}\n"
|
|
|
|
"3={\"db-id\":6569239123849665679,\"db-version\":\"9.4\"}\n"
|
|
|
|
);
|
|
|
|
|
|
|
|
TEST_RESULT_VOID(
|
2019-11-17 15:10:40 -05:00
|
|
|
storagePutP(storageNewWriteP(storageLocalWrite(), strNewFmt("%s/archive.info", strPtr(archiveStanza1Path))),
|
2019-04-23 14:02:30 -04:00
|
|
|
harnessInfoChecksum(content)), "put archive info to file");
|
2018-12-13 16:22:34 -05:00
|
|
|
|
|
|
|
// archive section will cross reference backup db-id 2 to archive db-id 3 but db section will only use the db-ids from
|
|
|
|
// backup.info
|
2019-12-26 18:08:27 -07:00
|
|
|
TEST_RESULT_STR_Z(
|
|
|
|
infoRender(),
|
2019-10-11 12:56:03 -04:00
|
|
|
"["
|
|
|
|
"{"
|
|
|
|
"\"archive\":["
|
|
|
|
"{"
|
|
|
|
"\"database\":{"
|
|
|
|
"\"id\":2"
|
|
|
|
"},"
|
|
|
|
"\"id\":\"9.4-3\","
|
|
|
|
"\"max\":null,"
|
|
|
|
"\"min\":null"
|
|
|
|
"}"
|
|
|
|
"],"
|
|
|
|
"\"backup\":[],"
|
|
|
|
"\"cipher\":\"aes-256-cbc\","
|
|
|
|
"\"db\":["
|
|
|
|
"{"
|
|
|
|
"\"id\":1,"
|
|
|
|
"\"system-id\":6569239123849665666,"
|
|
|
|
"\"version\":\"9.3\""
|
|
|
|
"},"
|
|
|
|
"{"
|
|
|
|
"\"id\":2,"
|
|
|
|
"\"system-id\":6569239123849665679,"
|
|
|
|
"\"version\":\"9.4\""
|
|
|
|
"}"
|
|
|
|
"],"
|
|
|
|
"\"name\":\"stanza1\","
|
|
|
|
"\"status\":{"
|
|
|
|
"\"code\":2,"
|
2020-04-24 08:00:00 -04:00
|
|
|
"\"lock\":{\"backup\":{\"held\":false}},"
|
2019-10-11 12:56:03 -04:00
|
|
|
"\"message\":\"no valid backups\""
|
|
|
|
"}"
|
|
|
|
"}"
|
2019-12-26 18:08:27 -07:00
|
|
|
"]",
|
|
|
|
"json - single stanza, no valid backups");
|
2018-12-13 16:22:34 -05:00
|
|
|
|
2019-10-08 12:06:30 -04:00
|
|
|
harnessCfgLoad(cfgCmdInfo, argListText);
|
2019-12-26 18:08:27 -07:00
|
|
|
TEST_RESULT_STR_Z(
|
|
|
|
infoRender(),
|
2018-12-13 16:22:34 -05:00
|
|
|
"stanza: stanza1\n"
|
|
|
|
" status: error (no valid backups)\n"
|
2019-01-16 22:16:50 +02:00
|
|
|
" cipher: aes-256-cbc\n"
|
2018-12-13 16:22:34 -05:00
|
|
|
"\n"
|
|
|
|
" db (current)\n"
|
|
|
|
" wal archive min/max (9.4-3): none present\n",
|
|
|
|
"text - single stanza, no valid backups");
|
|
|
|
|
2020-04-24 08:00:00 -04:00
|
|
|
// Repeat prior tests while a backup lock is held
|
|
|
|
HARNESS_FORK_BEGIN()
|
|
|
|
{
|
|
|
|
HARNESS_FORK_CHILD_BEGIN(0, false)
|
|
|
|
{
|
|
|
|
TEST_RESULT_INT_NE(
|
|
|
|
lockAcquire(cfgOptionStr(cfgOptLockPath), strNew("stanza1"), lockTypeBackup, 0, true), -1,
|
|
|
|
"create backup/expire lock");
|
|
|
|
|
|
|
|
sleepMSec(1000);
|
|
|
|
lockRelease(true);
|
|
|
|
}
|
|
|
|
HARNESS_FORK_CHILD_END();
|
|
|
|
|
|
|
|
HARNESS_FORK_PARENT_BEGIN()
|
|
|
|
{
|
|
|
|
sleepMSec(250);
|
|
|
|
|
|
|
|
harnessCfgLoad(cfgCmdInfo, argList);
|
|
|
|
TEST_RESULT_STR_Z(
|
|
|
|
infoRender(),
|
|
|
|
"["
|
|
|
|
"{"
|
|
|
|
"\"archive\":["
|
|
|
|
"{"
|
|
|
|
"\"database\":{"
|
|
|
|
"\"id\":2"
|
|
|
|
"},"
|
|
|
|
"\"id\":\"9.4-3\","
|
|
|
|
"\"max\":null,"
|
|
|
|
"\"min\":null"
|
|
|
|
"}"
|
|
|
|
"],"
|
|
|
|
"\"backup\":[],"
|
|
|
|
"\"cipher\":\"aes-256-cbc\","
|
|
|
|
"\"db\":["
|
|
|
|
"{"
|
|
|
|
"\"id\":1,"
|
|
|
|
"\"system-id\":6569239123849665666,"
|
|
|
|
"\"version\":\"9.3\""
|
|
|
|
"},"
|
|
|
|
"{"
|
|
|
|
"\"id\":2,"
|
|
|
|
"\"system-id\":6569239123849665679,"
|
|
|
|
"\"version\":\"9.4\""
|
|
|
|
"}"
|
|
|
|
"],"
|
|
|
|
"\"name\":\"stanza1\","
|
|
|
|
"\"status\":{"
|
|
|
|
"\"code\":2,"
|
|
|
|
"\"lock\":{\"backup\":{\"held\":true}},"
|
|
|
|
"\"message\":\"no valid backups\""
|
|
|
|
"}"
|
|
|
|
"}"
|
|
|
|
"]",
|
|
|
|
"json - single stanza, no valid backups, backup/expire lock detected");
|
|
|
|
|
|
|
|
harnessCfgLoad(cfgCmdInfo, argListText);
|
|
|
|
TEST_RESULT_STR_Z(
|
|
|
|
infoRender(),
|
|
|
|
"stanza: stanza1\n"
|
|
|
|
" status: error (no valid backups, backup/expire running)\n"
|
|
|
|
" cipher: aes-256-cbc\n"
|
|
|
|
"\n"
|
|
|
|
" db (current)\n"
|
|
|
|
" wal archive min/max (9.4-3): none present\n",
|
|
|
|
"text - single stanza, no valid backups, backup/expire lock detected");
|
|
|
|
|
|
|
|
}
|
|
|
|
HARNESS_FORK_PARENT_END();
|
|
|
|
}
|
|
|
|
HARNESS_FORK_END();
|
|
|
|
|
2019-02-21 12:09:12 +02:00
|
|
|
// Add WAL segments
|
|
|
|
//--------------------------------------------------------------------------------------------------------------------------
|
|
|
|
String *archiveDb3 = strNewFmt("%s/9.4-3/0000000100000000", strPtr(archiveStanza1Path));
|
2019-11-17 15:10:40 -05:00
|
|
|
TEST_RESULT_VOID(storagePathCreateP(storageLocalWrite(), archiveDb3), "create db3 archive WAL1 directory");
|
2019-02-21 12:09:12 +02:00
|
|
|
|
|
|
|
String *archiveDb3Wal = strNewFmt(
|
|
|
|
"%s/000000010000000000000004-47dff2b7552a9d66e4bae1a762488a6885e7082c.gz", strPtr(archiveDb3));
|
2019-11-17 15:10:40 -05:00
|
|
|
TEST_RESULT_VOID(storagePutP(storageNewWriteP(storageLocalWrite(), archiveDb3Wal), bufNew(0)), "touch WAL3 file");
|
2019-02-21 12:09:12 +02:00
|
|
|
|
|
|
|
StringList *argList2 = strLstDup(argListText);
|
|
|
|
strLstAddZ(argList2, "--stanza=stanza1");
|
2019-10-08 12:06:30 -04:00
|
|
|
harnessCfgLoad(cfgCmdInfo, argList2);
|
2019-02-21 12:09:12 +02:00
|
|
|
|
2019-12-26 18:08:27 -07:00
|
|
|
TEST_RESULT_STR_Z(
|
|
|
|
infoRender(),
|
2019-02-21 12:09:12 +02:00
|
|
|
"stanza: stanza1\n"
|
|
|
|
" status: error (no valid backups)\n"
|
|
|
|
" cipher: aes-256-cbc\n"
|
|
|
|
"\n"
|
|
|
|
" db (current)\n"
|
|
|
|
" wal archive min/max (9.4-3): 000000010000000000000004/000000010000000000000004\n",
|
|
|
|
"text - single stanza, one wal segment");
|
|
|
|
|
|
|
|
TEST_RESULT_VOID(storageRemoveP(storageLocalWrite(), archiveDb3Wal, .errorOnMissing = true), "remove WAL file");
|
|
|
|
|
2018-12-13 16:22:34 -05:00
|
|
|
// Coverage for stanzaStatus branches
|
|
|
|
//--------------------------------------------------------------------------------------------------------------------------
|
|
|
|
String *archiveDb1_1 = strNewFmt("%s/9.4-1/0000000100000000", strPtr(archiveStanza1Path));
|
2019-11-17 15:10:40 -05:00
|
|
|
TEST_RESULT_VOID(storagePathCreateP(storageLocalWrite(), archiveDb1_1), "create db1 archive WAL1 directory");
|
2018-12-13 16:22:34 -05:00
|
|
|
TEST_RESULT_INT(system(
|
|
|
|
strPtr(strNewFmt("touch %s", strPtr(strNewFmt("%s/000000010000000000000002-ac61b8f1ec7b1e6c3eaee9345214595eb7daa9a1.gz",
|
|
|
|
strPtr(archiveDb1_1)))))), 0, "touch WAL1 file");
|
|
|
|
TEST_RESULT_INT(system(
|
|
|
|
strPtr(strNewFmt("touch %s", strPtr(strNewFmt("%s/000000010000000000000003-37dff2b7552a9d66e4bae1a762488a6885e7082c.gz",
|
|
|
|
strPtr(archiveDb1_1)))))), 0, "touch WAL1 file");
|
|
|
|
|
|
|
|
String *archiveDb1_2 = strNewFmt("%s/9.4-1/0000000200000000", strPtr(archiveStanza1Path));
|
2019-11-17 15:10:40 -05:00
|
|
|
TEST_RESULT_VOID(storagePathCreateP(storageLocalWrite(), archiveDb1_2), "create db1 archive WAL2 directory");
|
2018-12-13 16:22:34 -05:00
|
|
|
TEST_RESULT_INT(system(
|
|
|
|
strPtr(strNewFmt("touch %s", strPtr(strNewFmt("%s/000000020000000000000003-37dff2b7552a9d66e4bae1a762488a6885e7082c.gz",
|
|
|
|
strPtr(archiveDb1_2)))))), 0, "touch WAL2 file");
|
|
|
|
|
|
|
|
String *archiveDb1_3 = strNewFmt("%s/9.4-1/0000000300000000", strPtr(archiveStanza1Path));
|
2019-11-17 15:10:40 -05:00
|
|
|
TEST_RESULT_VOID(storagePathCreateP(storageLocalWrite(), archiveDb1_3), "create db1 archive WAL3 directory");
|
2018-12-13 16:22:34 -05:00
|
|
|
|
2019-10-08 12:06:30 -04:00
|
|
|
harnessCfgLoad(cfgCmdInfo, argList);
|
2018-12-13 16:22:34 -05:00
|
|
|
content = strNew
|
|
|
|
(
|
|
|
|
"[db]\n"
|
|
|
|
"db-catalog-version=201409291\n"
|
|
|
|
"db-control-version=942\n"
|
|
|
|
"db-id=3\n"
|
|
|
|
"db-system-id=6569239123849665679\n"
|
|
|
|
"db-version=\"9.4\"\n"
|
|
|
|
"\n"
|
|
|
|
"[backup:current]\n"
|
|
|
|
"20181116-154756F={\"backrest-format\":5,\"backrest-version\":\"2.04\","
|
|
|
|
"\"backup-archive-start\":null,\"backup-archive-stop\":null,"
|
|
|
|
"\"backup-info-repo-size\":3159776,\"backup-info-repo-size-delta\":3159,\"backup-info-size\":26897030,"
|
|
|
|
"\"backup-info-size-delta\":26897030,\"backup-timestamp-start\":1542383276,\"backup-timestamp-stop\":1542383289,"
|
|
|
|
"\"backup-type\":\"full\",\"db-id\":1,\"option-archive-check\":true,\"option-archive-copy\":false,"
|
|
|
|
"\"option-backup-standby\":false,\"option-checksum-page\":true,\"option-compress\":true,\"option-hardlink\":false,"
|
|
|
|
"\"option-online\":true}\n"
|
|
|
|
"\n"
|
|
|
|
"[db:history]\n"
|
|
|
|
"1={\"db-catalog-version\":201409291,\"db-control-version\":942,\"db-system-id\":6569239123849665679,"
|
|
|
|
"\"db-version\":\"9.4\"}\n"
|
|
|
|
"2={\"db-catalog-version\":201306121,\"db-control-version\":937,\"db-system-id\":6569239123849665666,"
|
|
|
|
"\"db-version\":\"9.3\"}\n"
|
|
|
|
"3={\"db-catalog-version\":201409291,\"db-control-version\":942,\"db-system-id\":6569239123849665679,"
|
|
|
|
"\"db-version\":\"9.4\"}\n"
|
|
|
|
);
|
|
|
|
|
|
|
|
TEST_RESULT_VOID(
|
2019-11-17 15:10:40 -05:00
|
|
|
storagePutP(storageNewWriteP(storageLocalWrite(), strNewFmt("%s/backup.info", strPtr(backupStanza1Path))),
|
2019-04-23 14:02:30 -04:00
|
|
|
harnessInfoChecksum(content)), "put backup info to file");
|
2018-12-13 16:22:34 -05:00
|
|
|
|
2019-12-26 18:08:27 -07:00
|
|
|
TEST_RESULT_STR_Z(
|
|
|
|
infoRender(),
|
2019-10-11 12:56:03 -04:00
|
|
|
"["
|
|
|
|
"{"
|
|
|
|
"\"archive\":["
|
|
|
|
"{"
|
|
|
|
"\"database\":{"
|
|
|
|
"\"id\":1"
|
|
|
|
"},"
|
|
|
|
"\"id\":\"9.4-1\","
|
|
|
|
"\"max\":\"000000020000000000000003\","
|
|
|
|
"\"min\":\"000000010000000000000002\""
|
|
|
|
"},"
|
|
|
|
"{"
|
|
|
|
"\"database\":{"
|
|
|
|
"\"id\":3"
|
|
|
|
"},"
|
|
|
|
"\"id\":\"9.4-3\","
|
|
|
|
"\"max\":null,"
|
|
|
|
"\"min\":null"
|
|
|
|
"}"
|
|
|
|
"],"
|
|
|
|
"\"backup\":["
|
|
|
|
"{"
|
|
|
|
"\"archive\":{"
|
|
|
|
"\"start\":null,"
|
|
|
|
"\"stop\":null"
|
|
|
|
"},"
|
|
|
|
"\"backrest\":{"
|
|
|
|
"\"format\":5,"
|
|
|
|
"\"version\":\"2.04\""
|
|
|
|
"},"
|
|
|
|
"\"database\":{"
|
|
|
|
"\"id\":1"
|
|
|
|
"},"
|
|
|
|
"\"info\":{"
|
|
|
|
"\"delta\":26897030,"
|
|
|
|
"\"repository\":{"
|
|
|
|
"\"delta\":3159,"
|
|
|
|
"\"size\":3159776"
|
|
|
|
"},"
|
|
|
|
"\"size\":26897030"
|
|
|
|
"},"
|
|
|
|
"\"label\":\"20181116-154756F\","
|
|
|
|
"\"prior\":null,"
|
|
|
|
"\"reference\":null,"
|
|
|
|
"\"timestamp\":{"
|
|
|
|
"\"start\":1542383276,"
|
|
|
|
"\"stop\":1542383289"
|
|
|
|
"},"
|
|
|
|
"\"type\":\"full\""
|
|
|
|
"}"
|
|
|
|
"],"
|
|
|
|
"\"cipher\":\"none\","
|
|
|
|
"\"db\":["
|
|
|
|
"{"
|
|
|
|
"\"id\":1,"
|
|
|
|
"\"system-id\":6569239123849665679,"
|
|
|
|
"\"version\":\"9.4\""
|
|
|
|
"},"
|
|
|
|
"{"
|
|
|
|
"\"id\":2,"
|
|
|
|
"\"system-id\":6569239123849665666,"
|
|
|
|
"\"version\":\"9.3\""
|
|
|
|
"},"
|
|
|
|
"{"
|
|
|
|
"\"id\":3,"
|
|
|
|
"\"system-id\":6569239123849665679,"
|
|
|
|
"\"version\":\"9.4\""
|
|
|
|
"}"
|
|
|
|
"],"
|
|
|
|
"\"name\":\"stanza1\","
|
|
|
|
"\"status\":{"
|
|
|
|
"\"code\":0,"
|
2020-04-24 08:00:00 -04:00
|
|
|
"\"lock\":{\"backup\":{\"held\":false}},"
|
2019-10-11 12:56:03 -04:00
|
|
|
"\"message\":\"ok\""
|
|
|
|
"}"
|
|
|
|
"}"
|
2019-12-26 18:08:27 -07:00
|
|
|
"]",
|
|
|
|
"json - single stanza, valid backup, no priors, no archives in latest DB");
|
2018-12-13 16:22:34 -05:00
|
|
|
|
2019-10-08 12:06:30 -04:00
|
|
|
harnessCfgLoad(cfgCmdInfo, argListText);
|
2019-12-26 18:08:27 -07:00
|
|
|
TEST_RESULT_STR_Z(
|
|
|
|
infoRender(),
|
2018-12-13 16:22:34 -05:00
|
|
|
"stanza: stanza1\n"
|
|
|
|
" status: ok\n"
|
|
|
|
" cipher: none\n"
|
|
|
|
"\n"
|
|
|
|
" db (prior)\n"
|
|
|
|
" wal archive min/max (9.4-1): 000000010000000000000002/000000020000000000000003\n"
|
|
|
|
"\n"
|
|
|
|
" full backup: 20181116-154756F\n"
|
|
|
|
" timestamp start/stop: 2018-11-16 15:47:56 / 2018-11-16 15:48:09\n"
|
|
|
|
" wal start/stop: n/a\n"
|
|
|
|
" database size: 25.7MB, backup size: 25.7MB\n"
|
|
|
|
" repository size: 3MB, repository backup size: 3KB\n"
|
2018-12-14 18:25:31 -05:00
|
|
|
"\n"
|
|
|
|
" db (current)\n"
|
2019-12-26 18:08:27 -07:00
|
|
|
" wal archive min/max (9.4-3): none present\n",
|
|
|
|
"text - single stanza, valid backup, no priors, no archives in latest DB");
|
2018-12-13 16:22:34 -05:00
|
|
|
|
2020-04-24 08:00:00 -04:00
|
|
|
// Repeat prior tests while a backup lock is held
|
|
|
|
HARNESS_FORK_BEGIN()
|
|
|
|
{
|
|
|
|
HARNESS_FORK_CHILD_BEGIN(0, false)
|
|
|
|
{
|
|
|
|
TEST_RESULT_INT_NE(
|
|
|
|
lockAcquire(cfgOptionStr(cfgOptLockPath), strNew("stanza1"), lockTypeBackup, 0, true), -1,
|
|
|
|
"create backup/expire lock");
|
|
|
|
|
|
|
|
sleepMSec(1000);
|
|
|
|
lockRelease(true);
|
|
|
|
}
|
|
|
|
HARNESS_FORK_CHILD_END();
|
|
|
|
|
|
|
|
HARNESS_FORK_PARENT_BEGIN()
|
|
|
|
{
|
|
|
|
sleepMSec(250);
|
|
|
|
|
|
|
|
harnessCfgLoad(cfgCmdInfo, argList);
|
|
|
|
TEST_RESULT_STR_Z(
|
|
|
|
infoRender(),
|
|
|
|
"["
|
|
|
|
"{"
|
|
|
|
"\"archive\":["
|
|
|
|
"{"
|
|
|
|
"\"database\":{"
|
|
|
|
"\"id\":1"
|
|
|
|
"},"
|
|
|
|
"\"id\":\"9.4-1\","
|
|
|
|
"\"max\":\"000000020000000000000003\","
|
|
|
|
"\"min\":\"000000010000000000000002\""
|
|
|
|
"},"
|
|
|
|
"{"
|
|
|
|
"\"database\":{"
|
|
|
|
"\"id\":3"
|
|
|
|
"},"
|
|
|
|
"\"id\":\"9.4-3\","
|
|
|
|
"\"max\":null,"
|
|
|
|
"\"min\":null"
|
|
|
|
"}"
|
|
|
|
"],"
|
|
|
|
"\"backup\":["
|
|
|
|
"{"
|
|
|
|
"\"archive\":{"
|
|
|
|
"\"start\":null,"
|
|
|
|
"\"stop\":null"
|
|
|
|
"},"
|
|
|
|
"\"backrest\":{"
|
|
|
|
"\"format\":5,"
|
|
|
|
"\"version\":\"2.04\""
|
|
|
|
"},"
|
|
|
|
"\"database\":{"
|
|
|
|
"\"id\":1"
|
|
|
|
"},"
|
|
|
|
"\"info\":{"
|
|
|
|
"\"delta\":26897030,"
|
|
|
|
"\"repository\":{"
|
|
|
|
"\"delta\":3159,"
|
|
|
|
"\"size\":3159776"
|
|
|
|
"},"
|
|
|
|
"\"size\":26897030"
|
|
|
|
"},"
|
|
|
|
"\"label\":\"20181116-154756F\","
|
|
|
|
"\"prior\":null,"
|
|
|
|
"\"reference\":null,"
|
|
|
|
"\"timestamp\":{"
|
|
|
|
"\"start\":1542383276,"
|
|
|
|
"\"stop\":1542383289"
|
|
|
|
"},"
|
|
|
|
"\"type\":\"full\""
|
|
|
|
"}"
|
|
|
|
"],"
|
|
|
|
"\"cipher\":\"none\","
|
|
|
|
"\"db\":["
|
|
|
|
"{"
|
|
|
|
"\"id\":1,"
|
|
|
|
"\"system-id\":6569239123849665679,"
|
|
|
|
"\"version\":\"9.4\""
|
|
|
|
"},"
|
|
|
|
"{"
|
|
|
|
"\"id\":2,"
|
|
|
|
"\"system-id\":6569239123849665666,"
|
|
|
|
"\"version\":\"9.3\""
|
|
|
|
"},"
|
|
|
|
"{"
|
|
|
|
"\"id\":3,"
|
|
|
|
"\"system-id\":6569239123849665679,"
|
|
|
|
"\"version\":\"9.4\""
|
|
|
|
"}"
|
|
|
|
"],"
|
|
|
|
"\"name\":\"stanza1\","
|
|
|
|
"\"status\":{"
|
|
|
|
"\"code\":0,"
|
|
|
|
"\"lock\":{\"backup\":{\"held\":true}},"
|
|
|
|
"\"message\":\"ok\""
|
|
|
|
"}"
|
|
|
|
"}"
|
|
|
|
"]",
|
|
|
|
"json - single stanza, valid backup, no priors, no archives in latest DB, backup/expire lock detected");
|
|
|
|
|
|
|
|
harnessCfgLoad(cfgCmdInfo, argListText);
|
|
|
|
TEST_RESULT_STR_Z(
|
|
|
|
infoRender(),
|
|
|
|
"stanza: stanza1\n"
|
|
|
|
" status: ok (backup/expire running)\n"
|
|
|
|
" cipher: none\n"
|
|
|
|
"\n"
|
|
|
|
" db (prior)\n"
|
|
|
|
" wal archive min/max (9.4-1): 000000010000000000000002/000000020000000000000003\n"
|
|
|
|
"\n"
|
|
|
|
" full backup: 20181116-154756F\n"
|
|
|
|
" timestamp start/stop: 2018-11-16 15:47:56 / 2018-11-16 15:48:09\n"
|
|
|
|
" wal start/stop: n/a\n"
|
|
|
|
" database size: 25.7MB, backup size: 25.7MB\n"
|
|
|
|
" repository size: 3MB, repository backup size: 3KB\n"
|
|
|
|
"\n"
|
|
|
|
" db (current)\n"
|
|
|
|
" wal archive min/max (9.4-3): none present\n",
|
|
|
|
"text - single stanza, valid backup, no priors, no archives in latest DB, backup/expire lock detected");
|
|
|
|
}
|
|
|
|
HARNESS_FORK_PARENT_END();
|
|
|
|
}
|
|
|
|
HARNESS_FORK_END();
|
|
|
|
|
2018-12-13 16:22:34 -05:00
|
|
|
// backup.info/archive.info files exist, backups exist, archives exist
|
|
|
|
//--------------------------------------------------------------------------------------------------------------------------
|
|
|
|
content = strNew
|
|
|
|
(
|
|
|
|
"[db]\n"
|
|
|
|
"db-id=2\n"
|
|
|
|
"db-system-id=6626363367545678089\n"
|
|
|
|
"db-version=\"9.5\"\n"
|
|
|
|
"\n"
|
|
|
|
"[db:history]\n"
|
|
|
|
"1={\"db-id\":6625592122879095702,\"db-version\":\"9.4\"}\n"
|
|
|
|
"2={\"db-id\":6626363367545678089,\"db-version\":\"9.5\"}\n"
|
|
|
|
);
|
|
|
|
|
|
|
|
TEST_RESULT_VOID(
|
2019-11-17 15:10:40 -05:00
|
|
|
storagePutP(storageNewWriteP(storageLocalWrite(), strNewFmt("%s/archive.info", strPtr(archiveStanza1Path))),
|
2019-04-23 14:02:30 -04:00
|
|
|
harnessInfoChecksum(content)), "put archive info to file - stanza1");
|
2018-12-13 16:22:34 -05:00
|
|
|
|
|
|
|
content = strNew
|
|
|
|
(
|
|
|
|
"[backup:current]\n"
|
|
|
|
"20181119-152138F={"
|
|
|
|
"\"backrest-format\":5,\"backrest-version\":\"2.08dev\","
|
|
|
|
"\"backup-archive-start\":\"000000010000000000000002\",\"backup-archive-stop\":\"000000010000000000000002\","
|
|
|
|
"\"backup-info-repo-size\":2369186,\"backup-info-repo-size-delta\":2369186,"
|
|
|
|
"\"backup-info-size\":20162900,\"backup-info-size-delta\":20162900,"
|
|
|
|
"\"backup-timestamp-start\":1542640898,\"backup-timestamp-stop\":1542640911,\"backup-type\":\"full\","
|
|
|
|
"\"db-id\":1,\"option-archive-check\":true,\"option-archive-copy\":false,\"option-backup-standby\":false,"
|
|
|
|
"\"option-checksum-page\":true,\"option-compress\":true,\"option-hardlink\":false,\"option-online\":true}\n"
|
|
|
|
"20181119-152138F_20181119-152152D={"
|
|
|
|
"\"backrest-format\":5,\"backrest-version\":\"2.08dev\",\"backup-archive-start\":\"000000010000000000000003\","
|
|
|
|
"\"backup-archive-stop\":\"000000010000000000000003\",\"backup-info-repo-size\":2369186,"
|
|
|
|
"\"backup-info-repo-size-delta\":346,\"backup-info-size\":20162900,\"backup-info-size-delta\":8428,"
|
|
|
|
"\"backup-prior\":\"20181119-152138F\",\"backup-reference\":[\"20181119-152138F\"],"
|
|
|
|
"\"backup-timestamp-start\":1542640912,\"backup-timestamp-stop\":1542640915,\"backup-type\":\"diff\","
|
|
|
|
"\"db-id\":1,\"option-archive-check\":true,\"option-archive-copy\":false,\"option-backup-standby\":false,"
|
|
|
|
"\"option-checksum-page\":true,\"option-compress\":true,\"option-hardlink\":false,\"option-online\":true}\n"
|
|
|
|
"20181119-152138F_20181119-152152I={"
|
|
|
|
"\"backrest-format\":5,\"backrest-version\":\"2.08dev\",\"backup-archive-start\":\"000000010000000000000003\","
|
|
|
|
"\"backup-info-repo-size\":2369186,"
|
|
|
|
"\"backup-info-repo-size-delta\":346,\"backup-info-size\":20162900,\"backup-info-size-delta\":8428,"
|
|
|
|
"\"backup-prior\":\"20181119-152138F_20181119-152152D\","
|
|
|
|
"\"backup-reference\":[\"20181119-152138F\",\"20181119-152138F_20181119-152152D\"],"
|
|
|
|
"\"backup-timestamp-start\":1542640912,\"backup-timestamp-stop\":1542640915,\"backup-type\":\"incr\","
|
|
|
|
"\"db-id\":1,\"option-archive-check\":true,\"option-archive-copy\":false,\"option-backup-standby\":false,"
|
|
|
|
"\"option-checksum-page\":true,\"option-compress\":true,\"option-hardlink\":false,\"option-online\":true}\n"
|
|
|
|
"\n"
|
|
|
|
"[db]\n"
|
|
|
|
"db-catalog-version=201510051\n"
|
|
|
|
"db-control-version=942\n"
|
|
|
|
"db-id=2\n"
|
|
|
|
"db-system-id=6626363367545678089\n"
|
|
|
|
"db-version=\"9.5\"\n"
|
|
|
|
"\n"
|
|
|
|
"[db:history]\n"
|
|
|
|
"1={\"db-catalog-version\":201409291,\"db-control-version\":942,\"db-system-id\":6625592122879095702,"
|
|
|
|
"\"db-version\":\"9.4\"}\n"
|
|
|
|
"2={\"db-catalog-version\":201510051,\"db-control-version\":942,\"db-system-id\":6626363367545678089,"
|
|
|
|
"\"db-version\":\"9.5\"}\n"
|
|
|
|
);
|
|
|
|
|
|
|
|
TEST_RESULT_VOID(
|
2019-11-17 15:10:40 -05:00
|
|
|
storagePutP(storageNewWriteP(storageLocalWrite(), strNewFmt("%s/backup.info", strPtr(backupStanza1Path))),
|
2019-04-23 14:02:30 -04:00
|
|
|
harnessInfoChecksum(content)), "put backup info to file - stanza1");
|
2018-12-13 16:22:34 -05:00
|
|
|
|
2019-09-30 12:39:38 -04:00
|
|
|
// Manifest with all features
|
|
|
|
// -------------------------------------------------------------------------------------------------------------------------
|
|
|
|
#define TEST_MANIFEST_HEADER \
|
|
|
|
"[backup]\n" \
|
|
|
|
"backup-archive-start=\"000000030000028500000089\"\n" \
|
|
|
|
"backup-archive-stop=\"000000030000028500000089\"\n" \
|
|
|
|
"backup-label=\"20190818-084502F_20190820-084502D\"\n" \
|
|
|
|
"backup-lsn-start=\"285/89000028\"\n" \
|
|
|
|
"backup-lsn-stop=\"285/89001F88\"\n" \
|
|
|
|
"backup-prior=\"20190818-084502F\"\n" \
|
|
|
|
"backup-timestamp-copy-start=1565282141\n" \
|
|
|
|
"backup-timestamp-start=1565282140\n" \
|
|
|
|
"backup-timestamp-stop=1565282142\n" \
|
|
|
|
"backup-type=\"full\"\n" \
|
|
|
|
"\n" \
|
|
|
|
"[backup:db]\n" \
|
|
|
|
"db-catalog-version=201409291\n" \
|
|
|
|
"db-control-version=942\n" \
|
|
|
|
"db-id=1\n" \
|
|
|
|
"db-system-id=1000000000000000094\n" \
|
|
|
|
"db-version=\"9.4\"\n" \
|
|
|
|
"\n" \
|
|
|
|
"[backup:option]\n" \
|
|
|
|
"option-archive-check=true\n" \
|
|
|
|
"option-archive-copy=true\n" \
|
|
|
|
"option-backup-standby=false\n" \
|
|
|
|
"option-buffer-size=16384\n" \
|
|
|
|
"option-checksum-page=true\n" \
|
|
|
|
"option-compress=false\n" \
|
|
|
|
"option-compress-level=3\n" \
|
|
|
|
"option-compress-level-network=3\n" \
|
|
|
|
"option-delta=false\n" \
|
|
|
|
"option-hardlink=false\n" \
|
|
|
|
"option-online=false\n" \
|
|
|
|
"option-process-max=32\n"
|
|
|
|
|
|
|
|
#define TEST_MANIFEST_TARGET \
|
|
|
|
"\n" \
|
|
|
|
"[backup:target]\n" \
|
|
|
|
"pg_data={\"path\":\"/pg/base\",\"type\":\"path\"}\n" \
|
|
|
|
"pg_data/pg_hba.conf={\"file\":\"pg_hba.conf\",\"path\":\"../pg_config\",\"type\":\"link\"}\n" \
|
|
|
|
"pg_data/pg_stat={\"path\":\"../pg_stat\",\"type\":\"link\"}\n" \
|
|
|
|
"pg_tblspc/1={\"path\":\"/tblspc/ts1\",\"tablespace-id\":\"1\",\"tablespace-name\":\"ts1\",\"type\":\"link\"}\n" \
|
|
|
|
"pg_tblspc/12={\"path\":\"/tblspc/ts12\",\"tablespace-id\":\"12\",\"tablespace-name\":\"ts12\",\"type\":\"link\"}\n"
|
|
|
|
|
|
|
|
#define TEST_MANIFEST_DB \
|
|
|
|
"\n" \
|
|
|
|
"[db]\n" \
|
|
|
|
"mail={\"db-id\":16456,\"db-last-system-id\":12168}\n" \
|
|
|
|
"postgres={\"db-id\":12173,\"db-last-system-id\":12168}\n" \
|
|
|
|
"template0={\"db-id\":12168,\"db-last-system-id\":12168}\n" \
|
|
|
|
"template1={\"db-id\":1,\"db-last-system-id\":12168}\n" \
|
|
|
|
|
|
|
|
#define TEST_MANIFEST_FILE \
|
|
|
|
"\n" \
|
|
|
|
"[target:file]\n" \
|
|
|
|
"pg_data/PG_VERSION={\"checksum\":\"184473f470864e067ee3a22e64b47b0a1c356f29\",\"master\":true" \
|
|
|
|
",\"reference\":\"20190818-084502F_20190819-084506D\",\"size\":4,\"timestamp\":1565282114}\n" \
|
|
|
|
"pg_data/base/16384/17000={\"checksum\":\"e0101dd8ffb910c9c202ca35b5f828bcb9697bed\",\"checksum-page\":false" \
|
|
|
|
",\"checksum-page-error\":[1],\"repo-size\":4096,\"size\":8192,\"timestamp\":1565282114}\n" \
|
|
|
|
"pg_data/base/16384/PG_VERSION={\"checksum\":\"184473f470864e067ee3a22e64b47b0a1c356f29\",\"group\":false,\"size\":4" \
|
|
|
|
",\"timestamp\":1565282115}\n" \
|
|
|
|
"pg_data/base/32768/33000={\"checksum\":\"7a16d165e4775f7c92e8cdf60c0af57313f0bf90\",\"checksum-page\":true" \
|
|
|
|
",\"reference\":\"20190818-084502F\",\"size\":1073741824,\"timestamp\":1565282116}\n" \
|
|
|
|
"pg_data/base/32768/33000.32767={\"checksum\":\"6e99b589e550e68e934fd235ccba59fe5b592a9e\",\"checksum-page\":true" \
|
|
|
|
",\"reference\":\"20190818-084502F\",\"size\":32768,\"timestamp\":1565282114}\n" \
|
|
|
|
"pg_data/postgresql.conf={\"checksum\":\"6721d92c9fcdf4248acff1f9a1377127d9064807\",\"master\":true,\"size\":4457" \
|
|
|
|
",\"timestamp\":1565282114}\n" \
|
|
|
|
"pg_data/special={\"master\":true,\"mode\":\"0640\",\"size\":0,\"timestamp\":1565282120,\"user\":false}\n"
|
|
|
|
|
|
|
|
#define TEST_MANIFEST_FILE_DEFAULT \
|
|
|
|
"\n" \
|
|
|
|
"[target:file:default]\n" \
|
|
|
|
"group=\"group1\"\n" \
|
|
|
|
"master=false\n" \
|
|
|
|
"mode=\"0600\"\n" \
|
|
|
|
"user=\"user1\"\n"
|
|
|
|
|
|
|
|
#define TEST_MANIFEST_LINK \
|
|
|
|
"\n" \
|
|
|
|
"[target:link]\n" \
|
|
|
|
"pg_data/pg_stat={\"destination\":\"../pg_stat\"}\n" \
|
|
|
|
"pg_data/postgresql.conf={\"destination\":\"../pg_config/postgresql.conf\",\"group\":false,\"user\":\"user1\"}\n"
|
|
|
|
|
|
|
|
#define TEST_MANIFEST_LINK_DEFAULT \
|
|
|
|
"\n" \
|
|
|
|
"[target:link:default]\n" \
|
|
|
|
"group=\"group1\"\n" \
|
|
|
|
"user=false\n"
|
|
|
|
|
|
|
|
#define TEST_MANIFEST_PATH \
|
|
|
|
"\n" \
|
|
|
|
"[target:path]\n" \
|
|
|
|
"pg_data={\"user\":\"user2\"}\n" \
|
|
|
|
"pg_data/base={\"group\":\"group2\"}\n" \
|
|
|
|
"pg_data/base/16384={\"mode\":\"0750\"}\n" \
|
|
|
|
"pg_data/base/32768={}\n" \
|
|
|
|
"pg_data/base/65536={\"user\":false}\n"
|
|
|
|
|
|
|
|
#define TEST_MANIFEST_PATH_DEFAULT \
|
|
|
|
"\n" \
|
|
|
|
"[target:path:default]\n" \
|
|
|
|
"group=false\n" \
|
|
|
|
"mode=\"0700\"\n" \
|
|
|
|
"user=\"user1\"\n"
|
|
|
|
|
|
|
|
const Buffer *contentLoad = harnessInfoChecksumZ
|
|
|
|
(
|
|
|
|
TEST_MANIFEST_HEADER
|
|
|
|
TEST_MANIFEST_TARGET
|
|
|
|
TEST_MANIFEST_DB
|
|
|
|
TEST_MANIFEST_FILE
|
|
|
|
TEST_MANIFEST_FILE_DEFAULT
|
|
|
|
TEST_MANIFEST_LINK
|
|
|
|
TEST_MANIFEST_LINK_DEFAULT
|
|
|
|
TEST_MANIFEST_PATH
|
|
|
|
TEST_MANIFEST_PATH_DEFAULT
|
|
|
|
);
|
|
|
|
|
|
|
|
TEST_RESULT_VOID(
|
2019-11-17 15:10:40 -05:00
|
|
|
storagePutP(storageNewWriteP(storageLocalWrite(),
|
2019-09-30 12:39:38 -04:00
|
|
|
strNewFmt("%s/20181119-152138F_20181119-152152I/" BACKUP_MANIFEST_FILE, strPtr(backupStanza1Path))), contentLoad),
|
|
|
|
"write manifest - stanza1");
|
|
|
|
|
2018-12-13 16:22:34 -05:00
|
|
|
String *archiveStanza2Path = strNewFmt("%s/stanza2", strPtr(archivePath));
|
|
|
|
String *backupStanza2Path = strNewFmt("%s/stanza2", strPtr(backupPath));
|
2019-11-17 15:10:40 -05:00
|
|
|
TEST_RESULT_VOID(storagePathCreateP(storageLocalWrite(), backupStanza1Path), "backup stanza2 directory");
|
|
|
|
TEST_RESULT_VOID(storagePathCreateP(storageLocalWrite(), archiveStanza1Path), "archive stanza2 directory");
|
2018-12-13 16:22:34 -05:00
|
|
|
|
|
|
|
content = strNew
|
|
|
|
(
|
|
|
|
"[db]\n"
|
|
|
|
"db-id=1\n"
|
|
|
|
"db-system-id=6625633699176220261\n"
|
|
|
|
"db-version=\"9.4\"\n"
|
|
|
|
"\n"
|
|
|
|
"[db:history]\n"
|
|
|
|
"1={\"db-id\":6625633699176220261,\"db-version\":\"9.4\"}\n"
|
|
|
|
);
|
|
|
|
|
|
|
|
TEST_RESULT_VOID(
|
2019-11-17 15:10:40 -05:00
|
|
|
storagePutP(storageNewWriteP(storageLocalWrite(), strNewFmt("%s/archive.info", strPtr(archiveStanza2Path))),
|
2019-04-23 14:02:30 -04:00
|
|
|
harnessInfoChecksum(content)), "put archive info to file - stanza2");
|
2018-12-13 16:22:34 -05:00
|
|
|
|
|
|
|
content = strNew
|
|
|
|
(
|
|
|
|
"[db]\n"
|
|
|
|
"db-catalog-version=201409291\n"
|
|
|
|
"db-control-version=942\n"
|
|
|
|
"db-id=1\n"
|
|
|
|
"db-system-id=6625633699176220261\n"
|
|
|
|
"db-version=\"9.4\"\n"
|
|
|
|
"\n"
|
|
|
|
"[db:history]\n"
|
|
|
|
"1={\"db-catalog-version\":201409291,\"db-control-version\":942,\"db-system-id\":6625633699176220261,"
|
|
|
|
"\"db-version\":\"9.4\"}\n"
|
|
|
|
);
|
|
|
|
|
|
|
|
TEST_RESULT_VOID(
|
2019-11-17 15:10:40 -05:00
|
|
|
storagePutP(storageNewWriteP(storageLocalWrite(), strNewFmt("%s/backup.info", strPtr(backupStanza2Path))),
|
2019-04-23 14:02:30 -04:00
|
|
|
harnessInfoChecksum(content)), "put backup info to file - stanza2");
|
2018-12-13 16:22:34 -05:00
|
|
|
|
2019-10-08 12:06:30 -04:00
|
|
|
harnessCfgLoad(cfgCmdInfo, argList);
|
2019-12-26 18:08:27 -07:00
|
|
|
TEST_RESULT_STR_Z(
|
|
|
|
infoRender(),
|
2019-10-11 12:56:03 -04:00
|
|
|
"["
|
|
|
|
"{"
|
|
|
|
"\"archive\":["
|
|
|
|
"{"
|
|
|
|
"\"database\":{"
|
|
|
|
"\"id\":1"
|
|
|
|
"},"
|
|
|
|
"\"id\":\"9.4-1\","
|
|
|
|
"\"max\":\"000000020000000000000003\","
|
|
|
|
"\"min\":\"000000010000000000000002\""
|
|
|
|
"},"
|
|
|
|
"{"
|
|
|
|
"\"database\":{"
|
|
|
|
"\"id\":2"
|
|
|
|
"},"
|
|
|
|
"\"id\":\"9.5-2\","
|
|
|
|
"\"max\":null,"
|
|
|
|
"\"min\":null"
|
|
|
|
"}"
|
|
|
|
"],"
|
|
|
|
"\"backup\":["
|
|
|
|
"{"
|
|
|
|
"\"archive\":{"
|
|
|
|
"\"start\":\"000000010000000000000002\","
|
|
|
|
"\"stop\":\"000000010000000000000002\""
|
|
|
|
"},"
|
|
|
|
"\"backrest\":{"
|
|
|
|
"\"format\":5,"
|
|
|
|
"\"version\":\"2.08dev\""
|
|
|
|
"},"
|
|
|
|
"\"database\":{"
|
|
|
|
"\"id\":1"
|
|
|
|
"},"
|
|
|
|
"\"info\":{"
|
|
|
|
"\"delta\":20162900,"
|
|
|
|
"\"repository\":{"
|
|
|
|
"\"delta\":2369186,"
|
|
|
|
"\"size\":2369186"
|
|
|
|
"},"
|
|
|
|
"\"size\":20162900"
|
|
|
|
"},"
|
|
|
|
"\"label\":\"20181119-152138F\","
|
|
|
|
"\"prior\":null,"
|
|
|
|
"\"reference\":null,"
|
|
|
|
"\"timestamp\":{"
|
|
|
|
"\"start\":1542640898,"
|
|
|
|
"\"stop\":1542640911"
|
|
|
|
"},"
|
|
|
|
"\"type\":\"full\""
|
|
|
|
"},"
|
|
|
|
"{"
|
|
|
|
"\"archive\":{"
|
|
|
|
"\"start\":\"000000010000000000000003\","
|
|
|
|
"\"stop\":\"000000010000000000000003\""
|
|
|
|
"},"
|
|
|
|
"\"backrest\":{"
|
|
|
|
"\"format\":5,"
|
|
|
|
"\"version\":\"2.08dev\""
|
|
|
|
"},"
|
|
|
|
"\"database\":{"
|
|
|
|
"\"id\":1"
|
|
|
|
"},"
|
|
|
|
"\"info\":{"
|
|
|
|
"\"delta\":8428,"
|
|
|
|
"\"repository\":{"
|
|
|
|
"\"delta\":346,"
|
|
|
|
"\"size\":2369186"
|
|
|
|
"},"
|
|
|
|
"\"size\":20162900"
|
|
|
|
"},"
|
|
|
|
"\"label\":\"20181119-152138F_20181119-152152D\","
|
|
|
|
"\"prior\":\"20181119-152138F\","
|
|
|
|
"\"reference\":["
|
|
|
|
"\"20181119-152138F\""
|
|
|
|
"],"
|
|
|
|
"\"timestamp\":{"
|
|
|
|
"\"start\":1542640912,"
|
|
|
|
"\"stop\":1542640915"
|
|
|
|
"},"
|
|
|
|
"\"type\":\"diff\""
|
|
|
|
"},"
|
|
|
|
"{"
|
|
|
|
"\"archive\":{"
|
|
|
|
"\"start\":\"000000010000000000000003\","
|
|
|
|
"\"stop\":null"
|
|
|
|
"},"
|
|
|
|
"\"backrest\":{"
|
|
|
|
"\"format\":5,"
|
|
|
|
"\"version\":\"2.08dev\""
|
|
|
|
"},"
|
|
|
|
"\"database\":{"
|
|
|
|
"\"id\":1"
|
|
|
|
"},"
|
|
|
|
"\"info\":{"
|
|
|
|
"\"delta\":8428,"
|
|
|
|
"\"repository\":{"
|
|
|
|
"\"delta\":346,"
|
|
|
|
"\"size\":2369186"
|
|
|
|
"},"
|
|
|
|
"\"size\":20162900"
|
|
|
|
"},"
|
|
|
|
"\"label\":\"20181119-152138F_20181119-152152I\","
|
|
|
|
"\"prior\":\"20181119-152138F_20181119-152152D\","
|
|
|
|
"\"reference\":["
|
|
|
|
"\"20181119-152138F\","
|
|
|
|
"\"20181119-152138F_20181119-152152D\""
|
|
|
|
"],"
|
|
|
|
"\"timestamp\":{"
|
|
|
|
"\"start\":1542640912,"
|
|
|
|
"\"stop\":1542640915"
|
|
|
|
"},"
|
|
|
|
"\"type\":\"incr\""
|
|
|
|
"}"
|
|
|
|
"],"
|
|
|
|
"\"cipher\":\"none\","
|
|
|
|
"\"db\":["
|
|
|
|
"{"
|
|
|
|
"\"id\":1,"
|
|
|
|
"\"system-id\":6625592122879095702,"
|
|
|
|
"\"version\":\"9.4\""
|
|
|
|
"},"
|
|
|
|
"{"
|
|
|
|
"\"id\":2,"
|
|
|
|
"\"system-id\":6626363367545678089,"
|
|
|
|
"\"version\":\"9.5\""
|
|
|
|
"}"
|
|
|
|
"],"
|
|
|
|
"\"name\":\"stanza1\","
|
|
|
|
"\"status\":{"
|
|
|
|
"\"code\":0,"
|
2020-04-24 08:00:00 -04:00
|
|
|
"\"lock\":{\"backup\":{\"held\":false}},"
|
2019-10-11 12:56:03 -04:00
|
|
|
"\"message\":\"ok\""
|
|
|
|
"}"
|
|
|
|
"},"
|
|
|
|
"{"
|
|
|
|
"\"archive\":["
|
|
|
|
"{"
|
|
|
|
"\"database\":{"
|
|
|
|
"\"id\":1"
|
|
|
|
"},"
|
|
|
|
"\"id\":\"9.4-1\","
|
|
|
|
"\"max\":null,"
|
|
|
|
"\"min\":null"
|
|
|
|
"}"
|
|
|
|
"],"
|
|
|
|
"\"backup\":[],"
|
|
|
|
"\"cipher\":\"none\","
|
|
|
|
"\"db\":["
|
|
|
|
"{"
|
|
|
|
"\"id\":1,"
|
|
|
|
"\"system-id\":6625633699176220261,"
|
|
|
|
"\"version\":\"9.4\""
|
|
|
|
"}"
|
|
|
|
"],"
|
|
|
|
"\"name\":\"stanza2\","
|
|
|
|
"\"status\":{"
|
|
|
|
"\"code\":2,"
|
2020-04-24 08:00:00 -04:00
|
|
|
"\"lock\":{\"backup\":{\"held\":false}},"
|
2019-10-11 12:56:03 -04:00
|
|
|
"\"message\":\"no valid backups\""
|
|
|
|
"}"
|
|
|
|
"}"
|
2019-12-26 18:08:27 -07:00
|
|
|
"]",
|
|
|
|
"json - multiple stanzas, one with valid backups, archives in latest DB");
|
2018-12-13 16:22:34 -05:00
|
|
|
|
2019-10-08 12:06:30 -04:00
|
|
|
harnessCfgLoad(cfgCmdInfo, argListText);
|
2019-12-26 18:08:27 -07:00
|
|
|
TEST_RESULT_STR_Z(
|
|
|
|
infoRender(),
|
2018-12-13 16:22:34 -05:00
|
|
|
"stanza: stanza1\n"
|
|
|
|
" status: ok\n"
|
|
|
|
" cipher: none\n"
|
|
|
|
"\n"
|
|
|
|
" db (prior)\n"
|
|
|
|
" wal archive min/max (9.4-1): 000000010000000000000002/000000020000000000000003\n"
|
|
|
|
"\n"
|
|
|
|
" full backup: 20181119-152138F\n"
|
|
|
|
" timestamp start/stop: 2018-11-19 15:21:38 / 2018-11-19 15:21:51\n"
|
|
|
|
" wal start/stop: 000000010000000000000002 / 000000010000000000000002\n"
|
|
|
|
" database size: 19.2MB, backup size: 19.2MB\n"
|
|
|
|
" repository size: 2.3MB, repository backup size: 2.3MB\n"
|
|
|
|
"\n"
|
|
|
|
" diff backup: 20181119-152138F_20181119-152152D\n"
|
|
|
|
" timestamp start/stop: 2018-11-19 15:21:52 / 2018-11-19 15:21:55\n"
|
|
|
|
" wal start/stop: 000000010000000000000003 / 000000010000000000000003\n"
|
|
|
|
" database size: 19.2MB, backup size: 8.2KB\n"
|
|
|
|
" repository size: 2.3MB, repository backup size: 346B\n"
|
|
|
|
" backup reference list: 20181119-152138F\n"
|
|
|
|
"\n"
|
|
|
|
" incr backup: 20181119-152138F_20181119-152152I\n"
|
|
|
|
" timestamp start/stop: 2018-11-19 15:21:52 / 2018-11-19 15:21:55\n"
|
|
|
|
" wal start/stop: n/a\n"
|
|
|
|
" database size: 19.2MB, backup size: 8.2KB\n"
|
|
|
|
" repository size: 2.3MB, repository backup size: 346B\n"
|
|
|
|
" backup reference list: 20181119-152138F, 20181119-152138F_20181119-152152D\n"
|
|
|
|
"\n"
|
2018-12-14 18:25:31 -05:00
|
|
|
" db (current)\n"
|
|
|
|
" wal archive min/max (9.5-2): none present\n"
|
|
|
|
"\n"
|
2018-12-13 16:22:34 -05:00
|
|
|
"stanza: stanza2\n"
|
|
|
|
" status: error (no valid backups)\n"
|
|
|
|
" cipher: none\n"
|
|
|
|
"\n"
|
|
|
|
" db (current)\n"
|
2019-12-26 18:08:27 -07:00
|
|
|
" wal archive min/max (9.4-1): none present\n",
|
|
|
|
"text - multiple stanzas, one with valid backups, archives in latest DB");
|
2018-12-13 16:22:34 -05:00
|
|
|
|
2019-09-30 12:39:38 -04:00
|
|
|
// Backup set requested
|
|
|
|
//--------------------------------------------------------------------------------------------------------------------------
|
|
|
|
argList2 = strLstDup(argListText);
|
|
|
|
strLstAddZ(argList2, "--stanza=stanza1");
|
|
|
|
strLstAddZ(argList2, "--set=20181119-152138F_20181119-152152I");
|
2019-10-08 12:06:30 -04:00
|
|
|
harnessCfgLoad(cfgCmdInfo, argList2);
|
2019-09-30 12:39:38 -04:00
|
|
|
|
2019-12-26 18:08:27 -07:00
|
|
|
TEST_RESULT_STR_Z(
|
|
|
|
infoRender(),
|
2019-09-30 12:39:38 -04:00
|
|
|
"stanza: stanza1\n"
|
|
|
|
" status: ok\n"
|
|
|
|
" cipher: none\n"
|
|
|
|
"\n"
|
|
|
|
" db (prior)\n"
|
|
|
|
" wal archive min/max (9.4-1): 000000010000000000000002/000000020000000000000003\n"
|
|
|
|
"\n"
|
|
|
|
" incr backup: 20181119-152138F_20181119-152152I\n"
|
|
|
|
" timestamp start/stop: 2018-11-19 15:21:52 / 2018-11-19 15:21:55\n"
|
|
|
|
" wal start/stop: n/a\n"
|
|
|
|
" database size: 19.2MB, backup size: 8.2KB\n"
|
|
|
|
" repository size: 2.3MB, repository backup size: 346B\n"
|
|
|
|
" backup reference list: 20181119-152138F, 20181119-152138F_20181119-152152D\n"
|
|
|
|
" database list: mail (16456), postgres (12173)\n"
|
|
|
|
" symlinks:\n"
|
|
|
|
" pg_hba.conf => ../pg_config/pg_hba.conf\n"
|
|
|
|
" pg_stat => ../pg_stat\n"
|
|
|
|
" tablespaces:\n"
|
|
|
|
" ts1 (1) => /tblspc/ts1\n"
|
2019-12-26 18:08:27 -07:00
|
|
|
" ts12 (12) => /tblspc/ts12\n",
|
|
|
|
"text - backup set requested");
|
2019-09-30 12:39:38 -04:00
|
|
|
|
|
|
|
strLstAddZ(argList2, "--output=json");
|
2019-10-08 12:06:30 -04:00
|
|
|
harnessCfgLoad(cfgCmdInfo, argList2);
|
2019-09-30 12:39:38 -04:00
|
|
|
|
|
|
|
TEST_ERROR(strPtr(infoRender()), ConfigError, "option 'set' is currently only valid for text output");
|
|
|
|
|
|
|
|
// Backup set requested but no links
|
|
|
|
//--------------------------------------------------------------------------------------------------------------------------
|
|
|
|
argList2 = strLstDup(argListText);
|
|
|
|
strLstAddZ(argList2, "--stanza=stanza1");
|
|
|
|
strLstAddZ(argList2, "--set=20181119-152138F_20181119-152152I");
|
2019-10-08 12:06:30 -04:00
|
|
|
harnessCfgLoad(cfgCmdInfo, argList2);
|
2019-09-30 12:39:38 -04:00
|
|
|
|
|
|
|
#define TEST_MANIFEST_TARGET_NO_LINK \
|
|
|
|
"\n" \
|
|
|
|
"[backup:target]\n" \
|
|
|
|
"pg_data={\"path\":\"/pg/base\",\"type\":\"path\"}\n" \
|
|
|
|
|
|
|
|
contentLoad = harnessInfoChecksumZ
|
|
|
|
(
|
|
|
|
TEST_MANIFEST_HEADER
|
|
|
|
TEST_MANIFEST_TARGET_NO_LINK
|
|
|
|
TEST_MANIFEST_DB
|
|
|
|
TEST_MANIFEST_FILE
|
|
|
|
TEST_MANIFEST_FILE_DEFAULT
|
|
|
|
TEST_MANIFEST_LINK
|
|
|
|
TEST_MANIFEST_LINK_DEFAULT
|
|
|
|
TEST_MANIFEST_PATH
|
|
|
|
TEST_MANIFEST_PATH_DEFAULT
|
|
|
|
);
|
|
|
|
|
|
|
|
TEST_RESULT_VOID(
|
2019-11-17 15:10:40 -05:00
|
|
|
storagePutP(
|
|
|
|
storageNewWriteP(
|
2019-09-30 12:39:38 -04:00
|
|
|
storageRepoWrite(), strNew(STORAGE_REPO_BACKUP "/20181119-152138F_20181119-152152I/" BACKUP_MANIFEST_FILE)),
|
|
|
|
contentLoad),
|
|
|
|
"write manifest");
|
|
|
|
|
2019-12-26 18:08:27 -07:00
|
|
|
TEST_RESULT_STR_Z(
|
|
|
|
infoRender(),
|
2019-09-30 12:39:38 -04:00
|
|
|
"stanza: stanza1\n"
|
|
|
|
" status: ok\n"
|
|
|
|
" cipher: none\n"
|
|
|
|
"\n"
|
|
|
|
" db (prior)\n"
|
|
|
|
" wal archive min/max (9.4-1): 000000010000000000000002/000000020000000000000003\n"
|
|
|
|
"\n"
|
|
|
|
" incr backup: 20181119-152138F_20181119-152152I\n"
|
|
|
|
" timestamp start/stop: 2018-11-19 15:21:52 / 2018-11-19 15:21:55\n"
|
|
|
|
" wal start/stop: n/a\n"
|
|
|
|
" database size: 19.2MB, backup size: 8.2KB\n"
|
|
|
|
" repository size: 2.3MB, repository backup size: 346B\n"
|
|
|
|
" backup reference list: 20181119-152138F, 20181119-152138F_20181119-152152D\n"
|
2019-12-26 18:08:27 -07:00
|
|
|
" database list: mail (16456), postgres (12173)\n",
|
|
|
|
"text - backup set requested, no links");
|
2019-09-30 12:39:38 -04:00
|
|
|
|
|
|
|
// Backup set requested but no databases
|
|
|
|
//--------------------------------------------------------------------------------------------------------------------------
|
|
|
|
argList2 = strLstDup(argListText);
|
|
|
|
strLstAddZ(argList2, "--stanza=stanza1");
|
|
|
|
strLstAddZ(argList2, "--set=20181119-152138F_20181119-152152I");
|
2019-10-08 12:06:30 -04:00
|
|
|
harnessCfgLoad(cfgCmdInfo, argList2);
|
2019-09-30 12:39:38 -04:00
|
|
|
|
|
|
|
#define TEST_MANIFEST_NO_DB \
|
|
|
|
"\n" \
|
|
|
|
"[db]\n" \
|
|
|
|
"template0={\"db-id\":12168,\"db-last-system-id\":12168}\n" \
|
|
|
|
"template1={\"db-id\":1,\"db-last-system-id\":12168}\n" \
|
|
|
|
|
|
|
|
contentLoad = harnessInfoChecksumZ
|
|
|
|
(
|
|
|
|
TEST_MANIFEST_HEADER
|
|
|
|
TEST_MANIFEST_TARGET_NO_LINK
|
|
|
|
TEST_MANIFEST_NO_DB
|
|
|
|
TEST_MANIFEST_FILE
|
|
|
|
TEST_MANIFEST_FILE_DEFAULT
|
|
|
|
TEST_MANIFEST_LINK
|
|
|
|
TEST_MANIFEST_LINK_DEFAULT
|
|
|
|
TEST_MANIFEST_PATH
|
|
|
|
TEST_MANIFEST_PATH_DEFAULT
|
|
|
|
);
|
|
|
|
|
|
|
|
TEST_RESULT_VOID(
|
2019-11-17 15:10:40 -05:00
|
|
|
storagePutP(
|
|
|
|
storageNewWriteP(
|
2019-09-30 12:39:38 -04:00
|
|
|
storageRepoWrite(), strNew(STORAGE_REPO_BACKUP "/20181119-152138F_20181119-152152I/" BACKUP_MANIFEST_FILE)),
|
|
|
|
contentLoad),
|
|
|
|
"write manifest");
|
|
|
|
|
2019-12-26 18:08:27 -07:00
|
|
|
TEST_RESULT_STR_Z(
|
|
|
|
infoRender(),
|
2019-09-30 12:39:38 -04:00
|
|
|
"stanza: stanza1\n"
|
|
|
|
" status: ok\n"
|
|
|
|
" cipher: none\n"
|
|
|
|
"\n"
|
|
|
|
" db (prior)\n"
|
|
|
|
" wal archive min/max (9.4-1): 000000010000000000000002/000000020000000000000003\n"
|
|
|
|
"\n"
|
|
|
|
" incr backup: 20181119-152138F_20181119-152152I\n"
|
|
|
|
" timestamp start/stop: 2018-11-19 15:21:52 / 2018-11-19 15:21:55\n"
|
|
|
|
" wal start/stop: n/a\n"
|
|
|
|
" database size: 19.2MB, backup size: 8.2KB\n"
|
|
|
|
" repository size: 2.3MB, repository backup size: 346B\n"
|
|
|
|
" backup reference list: 20181119-152138F, 20181119-152138F_20181119-152152D\n"
|
2019-12-26 18:08:27 -07:00
|
|
|
" database list: none\n",
|
|
|
|
"text - backup set requested, no db");
|
2019-09-30 12:39:38 -04:00
|
|
|
|
2018-12-13 16:22:34 -05:00
|
|
|
// Stanza not found
|
|
|
|
//--------------------------------------------------------------------------------------------------------------------------
|
2019-02-21 12:09:12 +02:00
|
|
|
argList2 = strLstDup(argList);
|
2018-12-13 16:22:34 -05:00
|
|
|
strLstAddZ(argList2, "--stanza=silly");
|
2019-10-08 12:06:30 -04:00
|
|
|
harnessCfgLoad(cfgCmdInfo, argList2);
|
2019-12-26 18:08:27 -07:00
|
|
|
TEST_RESULT_STR_Z(
|
|
|
|
infoRender(),
|
2019-10-11 12:56:03 -04:00
|
|
|
"["
|
|
|
|
"{"
|
|
|
|
"\"backup\":[],"
|
|
|
|
"\"db\":[],"
|
|
|
|
"\"name\":\"silly\","
|
|
|
|
"\"status\":{"
|
|
|
|
"\"code\":1,"
|
2020-04-24 08:00:00 -04:00
|
|
|
"\"lock\":{\"backup\":{\"held\":false}},"
|
2019-10-11 12:56:03 -04:00
|
|
|
"\"message\":\"missing stanza path\""
|
|
|
|
"}"
|
|
|
|
"}"
|
2019-12-26 18:08:27 -07:00
|
|
|
"]",
|
|
|
|
"json - missing stanza path");
|
2018-12-13 16:22:34 -05:00
|
|
|
|
|
|
|
StringList *argListText2 = strLstDup(argListText);
|
|
|
|
strLstAddZ(argListText2, "--stanza=silly");
|
2019-10-08 12:06:30 -04:00
|
|
|
harnessCfgLoad(cfgCmdInfo, argListText2);
|
2019-12-26 18:08:27 -07:00
|
|
|
TEST_RESULT_STR_Z(
|
|
|
|
infoRender(),
|
|
|
|
"stanza: silly\n"
|
|
|
|
" status: error (missing stanza path)\n",
|
|
|
|
"text - missing stanza path");
|
2018-12-13 16:22:34 -05:00
|
|
|
|
|
|
|
// Stanza found
|
|
|
|
//--------------------------------------------------------------------------------------------------------------------------
|
|
|
|
strLstAddZ(argList, "--stanza=stanza2");
|
2019-10-08 12:06:30 -04:00
|
|
|
harnessCfgLoad(cfgCmdInfo, argList);
|
2019-12-26 18:08:27 -07:00
|
|
|
TEST_RESULT_STR_Z(
|
|
|
|
infoRender(),
|
2019-10-11 12:56:03 -04:00
|
|
|
"["
|
|
|
|
"{"
|
|
|
|
"\"archive\":["
|
|
|
|
"{"
|
|
|
|
"\"database\":{"
|
|
|
|
"\"id\":1"
|
|
|
|
"},"
|
|
|
|
"\"id\":\"9.4-1\","
|
|
|
|
"\"max\":null,"
|
|
|
|
"\"min\":null"
|
|
|
|
"}"
|
|
|
|
"],"
|
|
|
|
"\"backup\":[],"
|
|
|
|
"\"cipher\":\"none\","
|
|
|
|
"\"db\":["
|
|
|
|
"{"
|
|
|
|
"\"id\":1,"
|
|
|
|
"\"system-id\":6625633699176220261,"
|
|
|
|
"\"version\":\"9.4\""
|
|
|
|
"}"
|
|
|
|
"],"
|
|
|
|
"\"name\":\"stanza2\","
|
|
|
|
"\"status\":{"
|
|
|
|
"\"code\":2,"
|
2020-04-24 08:00:00 -04:00
|
|
|
"\"lock\":{\"backup\":{\"held\":false}},"
|
2019-10-11 12:56:03 -04:00
|
|
|
"\"message\":\"no valid backups\""
|
|
|
|
"}"
|
|
|
|
"}"
|
2019-12-26 18:08:27 -07:00
|
|
|
"]",
|
|
|
|
"json - multiple stanzas - selected found");
|
2018-12-13 16:22:34 -05:00
|
|
|
|
|
|
|
strLstAddZ(argListText, "--stanza=stanza2");
|
2019-10-08 12:06:30 -04:00
|
|
|
harnessCfgLoad(cfgCmdInfo, argListText);
|
2019-12-26 18:08:27 -07:00
|
|
|
TEST_RESULT_STR_Z(
|
|
|
|
infoRender(),
|
2018-12-13 16:22:34 -05:00
|
|
|
"stanza: stanza2\n"
|
|
|
|
" status: error (no valid backups)\n"
|
|
|
|
" cipher: none\n"
|
|
|
|
"\n"
|
|
|
|
" db (current)\n"
|
2019-12-26 18:08:27 -07:00
|
|
|
" wal archive min/max (9.4-1): none present\n",
|
|
|
|
"text - multiple stanzas - selected found");
|
2018-12-13 16:22:34 -05:00
|
|
|
|
|
|
|
// Crypto error
|
|
|
|
//--------------------------------------------------------------------------------------------------------------------------
|
|
|
|
content = strNew
|
|
|
|
(
|
|
|
|
"[global]\n"
|
|
|
|
"repo-cipher-pass=123abc\n"
|
|
|
|
);
|
|
|
|
|
|
|
|
TEST_RESULT_VOID(
|
2019-11-17 15:10:40 -05:00
|
|
|
storagePutP(storageNewWriteP(storageLocalWrite(), strNewFmt("%s/pgbackrest.conf", testPath())),
|
2019-04-20 08:16:17 -04:00
|
|
|
BUFSTR(content)), "put pgbackrest.conf file");
|
2018-12-13 16:22:34 -05:00
|
|
|
strLstAddZ(argListText, "--repo-cipher-type=aes-256-cbc");
|
|
|
|
strLstAdd(argListText, strNewFmt("--config=%s/pgbackrest.conf", testPath()));
|
2019-10-08 12:06:30 -04:00
|
|
|
harnessCfgLoad(cfgCmdInfo, argListText);
|
2018-12-13 16:22:34 -05:00
|
|
|
TEST_ERROR_FMT(
|
|
|
|
infoRender(), CryptoError,
|
|
|
|
"unable to load info file '%s/backup.info' or '%s/backup.info.copy':\n"
|
2019-09-06 13:48:28 -04:00
|
|
|
"CryptoError: cipher header invalid\n"
|
|
|
|
"HINT: is or was the repo encrypted?\n"
|
2019-05-26 12:41:15 -04:00
|
|
|
"FileMissingError: " STORAGE_ERROR_READ_MISSING "\n"
|
2018-12-13 16:22:34 -05:00
|
|
|
"HINT: backup.info cannot be opened and is required to perform a backup.\n"
|
|
|
|
"HINT: has a stanza-create been performed?\n"
|
2019-09-14 12:21:08 -04:00
|
|
|
"HINT: use option --stanza if encryption settings are different for the stanza than the global settings.",
|
2019-09-06 13:48:28 -04:00
|
|
|
strPtr(backupStanza2Path), strPtr(backupStanza2Path), strPtr(strNewFmt("%s/backup.info.copy",
|
|
|
|
strPtr(backupStanza2Path))));
|
2018-12-13 16:22:34 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
//******************************************************************************************************************************
|
|
|
|
if (testBegin("formatTextDb()"))
|
|
|
|
{
|
|
|
|
// These tests cover branches not covered in other tests
|
|
|
|
KeyValue *stanzaInfo = kvNew();
|
|
|
|
VariantList *dbSection = varLstNew();
|
2019-04-22 16:04:04 -04:00
|
|
|
Variant *pgInfo = varNewKv(kvNew());
|
2019-04-19 11:40:39 -04:00
|
|
|
kvPut(varKv(pgInfo), DB_KEY_ID_VAR, varNewUInt(1));
|
2019-04-17 08:04:22 -04:00
|
|
|
kvPut(varKv(pgInfo), DB_KEY_SYSTEM_ID_VAR, varNewUInt64(6625633699176220261));
|
|
|
|
kvPut(varKv(pgInfo), DB_KEY_VERSION_VAR, VARSTR(pgVersionToStr(90500)));
|
2018-12-13 16:22:34 -05:00
|
|
|
|
|
|
|
varLstAdd(dbSection, pgInfo);
|
|
|
|
|
|
|
|
// Add the database history, backup and archive sections to the stanza info
|
2019-04-17 08:04:22 -04:00
|
|
|
kvPut(stanzaInfo, STANZA_KEY_DB_VAR, varNewVarLst(dbSection));
|
2018-12-13 16:22:34 -05:00
|
|
|
|
|
|
|
VariantList *backupSection = varLstNew();
|
2019-04-22 16:04:04 -04:00
|
|
|
Variant *backupInfo = varNewKv(kvNew());
|
2018-12-13 16:22:34 -05:00
|
|
|
|
2019-04-17 08:04:22 -04:00
|
|
|
kvPut(varKv(backupInfo), BACKUP_KEY_LABEL_VAR, VARSTRDEF("20181119-152138F"));
|
|
|
|
kvPut(varKv(backupInfo), BACKUP_KEY_TYPE_VAR, VARSTRDEF("full"));
|
|
|
|
kvPutKv(varKv(backupInfo), KEY_ARCHIVE_VAR);
|
|
|
|
KeyValue *infoInfo = kvPutKv(varKv(backupInfo), BACKUP_KEY_INFO_VAR);
|
|
|
|
kvPut(infoInfo, KEY_SIZE_VAR, varNewUInt64(0));
|
|
|
|
kvPut(infoInfo, KEY_DELTA_VAR, varNewUInt64(0));
|
|
|
|
KeyValue *repoInfo = kvPutKv(infoInfo, INFO_KEY_REPOSITORY_VAR);
|
|
|
|
kvAdd(repoInfo, KEY_SIZE_VAR, varNewUInt64(0));
|
|
|
|
kvAdd(repoInfo, KEY_DELTA_VAR, varNewUInt64(0));
|
|
|
|
KeyValue *databaseInfo = kvPutKv(varKv(backupInfo), KEY_DATABASE_VAR);
|
2019-04-19 11:40:39 -04:00
|
|
|
kvAdd(databaseInfo, DB_KEY_ID_VAR, varNewUInt(1));
|
2019-04-17 08:04:22 -04:00
|
|
|
KeyValue *timeInfo = kvPutKv(varKv(backupInfo), BACKUP_KEY_TIMESTAMP_VAR);
|
|
|
|
kvAdd(timeInfo, KEY_START_VAR, varNewUInt64(1542383276));
|
|
|
|
kvAdd(timeInfo, KEY_STOP_VAR, varNewUInt64(1542383289));
|
2018-12-13 16:22:34 -05:00
|
|
|
|
|
|
|
varLstAdd(backupSection, backupInfo);
|
|
|
|
|
2019-04-17 08:04:22 -04:00
|
|
|
kvPut(stanzaInfo, STANZA_KEY_BACKUP_VAR, varNewVarLst(backupSection));
|
|
|
|
kvPut(stanzaInfo, KEY_ARCHIVE_VAR, varNewVarLst(varLstNew()));
|
2018-12-13 16:22:34 -05:00
|
|
|
|
|
|
|
String *result = strNew("");
|
2019-09-30 12:39:38 -04:00
|
|
|
formatTextDb(stanzaInfo, result, NULL);
|
2018-12-13 16:22:34 -05:00
|
|
|
|
2019-12-26 18:08:27 -07:00
|
|
|
TEST_RESULT_STR_Z(
|
|
|
|
result,
|
2018-12-13 16:22:34 -05:00
|
|
|
"\n"
|
|
|
|
" db (current)\n"
|
|
|
|
" full backup: 20181119-152138F\n"
|
|
|
|
" timestamp start/stop: 2018-11-16 15:47:56 / 2018-11-16 15:48:09\n"
|
|
|
|
" wal start/stop: n/a\n"
|
|
|
|
" database size: 0B, backup size: 0B\n"
|
2019-12-26 18:08:27 -07:00
|
|
|
" repository size: 0B, repository backup size: 0B\n",
|
|
|
|
"formatTextDb only backup section (code coverage only)");
|
2018-12-13 16:22:34 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
//******************************************************************************************************************************
|
|
|
|
if (testBegin("cmdInfo()"))
|
|
|
|
{
|
|
|
|
StringList *argList = strLstNew();
|
|
|
|
strLstAdd(argList, strNewFmt("--repo-path=%s", strPtr(repoPath)));
|
2019-10-08 12:06:30 -04:00
|
|
|
harnessCfgLoad(cfgCmdInfo, argList);
|
2018-12-13 16:22:34 -05:00
|
|
|
|
2019-11-17 15:10:40 -05:00
|
|
|
storagePathCreateP(storageLocalWrite(), archivePath);
|
|
|
|
storagePathCreateP(storageLocalWrite(), backupPath);
|
2018-12-13 16:22:34 -05:00
|
|
|
|
|
|
|
// Redirect stdout to a file
|
|
|
|
int stdoutSave = dup(STDOUT_FILENO);
|
|
|
|
String *stdoutFile = strNewFmt("%s/stdout.info", testPath());
|
|
|
|
|
2019-04-29 18:36:57 -04:00
|
|
|
THROW_ON_SYS_ERROR(freopen(strPtr(stdoutFile), "w", stdout) == NULL, FileWriteError, "unable to reopen stdout");
|
2018-12-13 16:22:34 -05:00
|
|
|
|
|
|
|
// Not in a test wrapper to avoid writing to stdout
|
|
|
|
cmdInfo();
|
|
|
|
|
|
|
|
// Restore normal stdout
|
|
|
|
dup2(stdoutSave, STDOUT_FILENO);
|
|
|
|
|
2020-04-30 11:01:38 -04:00
|
|
|
Storage *storage = storagePosixNewP(strNew(testPath()));
|
2019-12-26 18:08:27 -07:00
|
|
|
TEST_RESULT_STR_Z(
|
|
|
|
strNewBuf(storageGetP(storageNewReadP(storage, stdoutFile))), "No stanzas exist in the repository.\n",
|
2019-01-16 19:23:10 +02:00
|
|
|
" check text");
|
2019-09-30 12:39:38 -04:00
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------------------------------
|
|
|
|
strLstAddZ(argList, "--set=bogus");
|
|
|
|
|
|
|
|
TEST_ERROR_FMT(
|
2019-10-08 12:06:30 -04:00
|
|
|
harnessCfgLoad(cfgCmdInfo, argList), OptionInvalidError, "option 'set' not valid without option 'stanza'");
|
2019-09-30 12:39:38 -04:00
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------------------------------
|
|
|
|
strLstAddZ(argList, "--stanza=stanza1");
|
2019-10-08 12:06:30 -04:00
|
|
|
harnessCfgLoad(cfgCmdInfo, argList);
|
2019-09-30 12:39:38 -04:00
|
|
|
|
|
|
|
TEST_ERROR_FMT(
|
|
|
|
cmdInfo(), FileMissingError, "manifest does not exist for backup 'bogus'\n"
|
|
|
|
"HINT: is the backup listed when running the info command with --stanza option only?");
|
2018-12-13 16:22:34 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
FUNCTION_HARNESS_RESULT_VOID();
|
|
|
|
}
|