LCOV - code coverage report
Current view: top level - src/backend/access/transam - xlogbackup.c (source / functions) Hit Total Coverage
Test: PostgreSQL 18devel Lines: 33 33 100.0 %
Date: 2025-01-18 04:15:08 Functions: 1 1 100.0 %
Legend: Lines: hit not hit

          Line data    Source code
       1             : /*-------------------------------------------------------------------------
       2             :  *
       3             :  * xlogbackup.c
       4             :  *      Internal routines for base backups.
       5             :  *
       6             :  * Portions Copyright (c) 1996-2025, PostgreSQL Global Development Group
       7             :  * Portions Copyright (c) 1994, Regents of the University of California
       8             :  *
       9             :  * IDENTIFICATION
      10             :  *      src/backend/access/transam/xlogbackup.c
      11             :  *-------------------------------------------------------------------------
      12             :  */
      13             : 
      14             : #include "postgres.h"
      15             : 
      16             : #include "access/xlog.h"
      17             : #include "access/xlog_internal.h"
      18             : #include "access/xlogbackup.h"
      19             : 
      20             : /*
      21             :  * Build contents for backup_label or backup history file.
      22             :  *
      23             :  * When ishistoryfile is true, it creates the contents for a backup history
      24             :  * file, otherwise it creates contents for a backup_label file.
      25             :  *
      26             :  * Returns the result generated as a palloc'd string.
      27             :  */
      28             : char *
      29         608 : build_backup_content(BackupState *state, bool ishistoryfile)
      30             : {
      31             :     char        startstrbuf[128];
      32             :     char        startxlogfile[MAXFNAMELEN]; /* backup start WAL file */
      33             :     XLogSegNo   startsegno;
      34         608 :     StringInfo  result = makeStringInfo();
      35             :     char       *data;
      36             : 
      37             :     Assert(state != NULL);
      38             : 
      39             :     /* Use the log timezone here, not the session timezone */
      40         608 :     pg_strftime(startstrbuf, sizeof(startstrbuf), "%Y-%m-%d %H:%M:%S %Z",
      41         608 :                 pg_localtime(&state->starttime, log_timezone));
      42             : 
      43         608 :     XLByteToSeg(state->startpoint, startsegno, wal_segment_size);
      44         608 :     XLogFileName(startxlogfile, state->starttli, startsegno, wal_segment_size);
      45         608 :     appendStringInfo(result, "START WAL LOCATION: %X/%X (file %s)\n",
      46         608 :                      LSN_FORMAT_ARGS(state->startpoint), startxlogfile);
      47             : 
      48         608 :     if (ishistoryfile)
      49             :     {
      50             :         char        stopxlogfile[MAXFNAMELEN];  /* backup stop WAL file */
      51             :         XLogSegNo   stopsegno;
      52             : 
      53         290 :         XLByteToSeg(state->stoppoint, stopsegno, wal_segment_size);
      54         290 :         XLogFileName(stopxlogfile, state->stoptli, stopsegno, wal_segment_size);
      55         290 :         appendStringInfo(result, "STOP WAL LOCATION: %X/%X (file %s)\n",
      56         290 :                          LSN_FORMAT_ARGS(state->stoppoint), stopxlogfile);
      57             :     }
      58             : 
      59         608 :     appendStringInfo(result, "CHECKPOINT LOCATION: %X/%X\n",
      60         608 :                      LSN_FORMAT_ARGS(state->checkpointloc));
      61         608 :     appendStringInfoString(result, "BACKUP METHOD: streamed\n");
      62         608 :     appendStringInfo(result, "BACKUP FROM: %s\n",
      63         608 :                      state->started_in_recovery ? "standby" : "primary");
      64         608 :     appendStringInfo(result, "START TIME: %s\n", startstrbuf);
      65         608 :     appendStringInfo(result, "LABEL: %s\n", state->name);
      66         608 :     appendStringInfo(result, "START TIMELINE: %u\n", state->starttli);
      67             : 
      68         608 :     if (ishistoryfile)
      69             :     {
      70             :         char        stopstrfbuf[128];
      71             : 
      72             :         /* Use the log timezone here, not the session timezone */
      73         290 :         pg_strftime(stopstrfbuf, sizeof(stopstrfbuf), "%Y-%m-%d %H:%M:%S %Z",
      74         290 :                     pg_localtime(&state->stoptime, log_timezone));
      75             : 
      76         290 :         appendStringInfo(result, "STOP TIME: %s\n", stopstrfbuf);
      77         290 :         appendStringInfo(result, "STOP TIMELINE: %u\n", state->stoptli);
      78             :     }
      79             : 
      80             :     /* either both istartpoint and istarttli should be set, or neither */
      81             :     Assert(XLogRecPtrIsInvalid(state->istartpoint) == (state->istarttli == 0));
      82         608 :     if (!XLogRecPtrIsInvalid(state->istartpoint))
      83             :     {
      84          36 :         appendStringInfo(result, "INCREMENTAL FROM LSN: %X/%X\n",
      85          36 :                          LSN_FORMAT_ARGS(state->istartpoint));
      86          36 :         appendStringInfo(result, "INCREMENTAL FROM TLI: %u\n",
      87             :                          state->istarttli);
      88             :     }
      89             : 
      90         608 :     data = result->data;
      91         608 :     pfree(result);
      92             : 
      93         608 :     return data;
      94             : }

Generated by: LCOV version 1.14