#!/bin/sh
#
# Test reposurgeon branch naming issue with hg repo
#
# This test cannot use the usual hg-to-fi script because we
# want to test the behavior of the actual hg tag command and
# how its results appear to the hg extractor
#
# The REPOSURGEON environment variable can be used to substitute in a
# different implementation.

# shellcheck disable=SC1091
. ./common-setup.sh

need hg

# Required because $PWD seems to be undefined in Gitlab's CI environment
BIN="${BINDIR:-$(realpath ..)}"

build=True
stream=True
cleanup=True

pecho() { printf %s\\n "$*"; }
log() { pecho "$@"; }
error() { log "ERROR: $*" >&2; }
fatal() { error "$@"; exit 1; }
try() { "$@" || fatal "'$*' failed"; }

while getopts nr opt
do
    case $opt in
    n) build=True; stream=False ; cleanup=False ;;
    r) build=False; stream=True  ; cleanup=False ;;
    *) echo "$0: unknown option $opt"; exit 1;;
    esac
done
# shellcheck disable=SC2004
shift $(($OPTIND - 1))

testrepo=${1:-/tmp/test-repo$$}

USER='"J. Random Hacker" <jrh@foobar.com>'

# Should we build the repo?
if [ $build = True ]
then
    # Build hg test repo with multiple hg branches
    try rm -fr "$testrepo"
    try hg init "$testrepo" || exit 1
    try cd "$testrepo" >/dev/null
    # The weird --date incantation in the hg commits is to ensure that the commit
    # timestamps match those in the .fi file; the 18000 is because hg wants the time zone
    # offset in seconds west of UTC, for what reason I know not--I know there are weird
    # time zones in the world but I didn't think any of them got down to one-second
    # granularity in offsets...
    (
        try echo "Test file 1." > testfile1
        try hg add testfile1 >/dev/null
        try hg commit --user "$USER" --date "1456976347 18000" -m "Commit test file 1." >/dev/null
        try echo "Test file 3." > testfile3
        try hg add testfile3 >/dev/null
        try hg commit --user "$USER" --date "1456976408 18000" -m "Commit test file 3." >/dev/null
        try hg tag --local before >/dev/null
        try hg update -r 0 >/dev/null
        try cd "$testrepo" >/dev/null     # Workaround for error getting current working directory
        try echo "Test file 2." > testfile2
        try hg add testfile2 >/dev/null
        try hg commit --user "$USER" --date "1456976475 18000" -m "Commit test file 2." >/dev/null
        try hg tag --local after >/dev/null
        try hg update before >/dev/null
        try cd "$testrepo" >/dev/null     # Workaround for error getting current working directory
        try echo "Second line." >> testfile3
        try hg commit --user "$USER" --date "1456976542 18000" -m "Add line to test file 3." >/dev/null
    ) || exit 1
    try cd - >/dev/null
fi

# Should we stream the repo?
if [ $stream = True ]
then
    echo "#reposurgeon description: from an hg repo with real hg branches; includes a tag."
    # shellcheck disable=SC2086
    "${BIN}/${REPOSURGEON:-reposurgeon}" "${BUILDOPT}" ${TESTOPT} "read $testrepo" "sourcetype git" "write -"
fi

# Should we clean up the test directory
if [ $cleanup = True ]
then
    try rm -fr "$testrepo"
fi
