Миграция PVCS в SVN - Как записать метки PVCS в сообщение SVN Log Msg - PullRequest
2 голосов
/ 18 марта 2011

Мы находимся в процессе перехода от PVCS к Subversion. Я продемонстрировал импорт PVCS export => SVN, который отлично подходит для нас, но у нас есть одна проблема.

Мы широко использовали этикетки из ПВХ, и они дают нам четкую и последовательную ссылку на наши номера рабочих запросов (W.R.). Когда мы переходим на SVN, эти метки становятся тегами (что само по себе хорошо), НО мы также внедряем JIRA и поэтому должны связать соответствующую версию SVN с номером выпуска JIRA. Это делается путем записи номера проблемы JIRA в сообщение журнала SVN.

Пока; во время импорта SVN я читаю каждое сообщение журнала SVN и, где я нахожу номер рабочего запроса, добавляю соответствующий номер вопроса JIRA к сообщению журнала SVN (используя сценарий пост-фиксации в SVN). Однако практика записи W.R. в описание фиксации PVCS была необязательной, тогда как использование меток PVCS было обязательным. Поэтому многие из версий не имеют номера W.R. в журнале, только в метке PVCS (или как она становится меткой SVN).

Есть ли способ найти метку версии PVCS во время импорта SVN? Я могу видеть их в файле дампа, созданном экспортом PVCS, где они становятся частью пути узла.

Или, альтернативно, есть отчет или запрос, который я могу выполнить, который даст мне список ревизий для каждого тега?

С уважением Karl

1 Ответ

2 голосов
/ 06 апреля 2011

Я закончил сортировать это сам. Если у кого-то есть такая же проблема, я обнаружил, что можно получить список всех тегов, используя

svn ls <repo URL including tags location>

и затем получите версии в этих тегах, используя

svn info ...

И AWK вывод SVN INFO, используя следующее. Заметьте, что мне пришлось уменьшить номер версии на 1, чтобы получить актуальную версию, которая меня интересовала. Я думаю, это связано с тем, что во время импорта SVN копирует правильную версию в папку тегов после создания версии, и это считается версией.

BEGIN { RS="";
    FS = "\n"; }
/^Path:/ { n1 = split($1,path,":");
           n3 = split($6,nodeKind, ":");
           n2 = split($9,lastRev,":");
           theRev = lastRev[2] -1;
printf("%8s %10s, %-75s\n", theRev, nodeKind[2], path[2]); }

WRKEYFILE и PTKEYFILE - это просто файлы поиска .csv, с которыми нужно сопоставить формат

PT_TICKET,PKEY,Issue Title

Тогда я написал сценарий следующим образом ...

REPO=svn://vuwunicocsagfg1/Banner/tags
REPOPATH=/var/subversion/Banner
WRKEYFILE=workReq_pKey.unix
PTKEYFILE=ptTicket_pKey.unix

# working variables
TEMPFILE=$$.tmp
TAGLIST=$$.tags
REVISIONS=$$.revisions
SVNINFO=$$.info
SVNLOOK=/usr/bin/svnlook


# look up details in Subversion
svn info -R $REPO | awk -f new_svn_report.awk > $SVNINFO
svn ls $REPO > $TAGLIST

cat $TAGLIST | awk '{ print $1}' | while read LINE
do

   JIRAISSUE=""
   WRNUM=""
   PTNUM=""
   UWRNUM=""
   UPTNUM=""

   # Find Work Request or Perfect Tracker number
   WRNUM=$(echo "$LINE" | sed -n -e "s:.*\([wW][rR][0-9# -][0-9]\+\).*:\1:p")
   PTNUM=$(echo "$LINE" | sed -n -e "s:.*\([pP][tT][0-9# -][0-9]\+\).*:\1:p")

   # upper case the strings found and remove unwanted chars
   UWRNUM=`echo $WRNUM| tr 'a-z' 'A-Z' | tr --delete '# -'`
   UPTNUM=`echo $PTNUM| tr 'a-z' 'A-Z' | tr --delete '# -'`
   # Debug
   # echo "=============================="
   # echo "Line is: $LINE,  WRNUM is: $WRNUM, PTNUM is: $PTNUM"

   if [[ -n "$UWRNUM" ]]
   then

      # Find the JIRA issue number
      awk -F',' '/'"$UWRNUM"'/ {print $2}' $WRKEYFILE | awk '{if (NR==1) {print $0}}'  > $TEMPFILE
      JIRAISSUE=`cat $TEMPFILE`

      awk -F',' '/'"$UWRNUM"'/ {print $2,"; " $3}' $WRKEYFILE | tr '"' '_' | awk '{if (NR==1) {print $0}}' > $TEMPFILE
      NEWLOG=`cat $TEMPFILE`

      # all revisions in this Tag which are not directories
      grep $UWRNUM $SVNINFO | grep -v "directory" > $REVISIONS
   fi

   if [[ -n "$UPTNUM" ]]
   then
      # Find the JIRA issue number
      awk -F',' '/'"$UPTNUM"'/ {print $2}' $PTKEYFILE | awk '{if (NR==1) {print $0}}'  > $TEMPFILE
      JIRAISSUE=`cat $TEMPFILE`

      awk -F',' '/'"$UPTNUM"'/ {print $2,"; " $3}' $PTKEYFILE | tr '"' '_' | awk '{if (NR==1) {print $0}}' > $TEMPFILE
      NEWLOG=`cat $TEMPFILE`

      # all revisions in this Tag which are not directories
      grep $UPTNUM $SVNINFO | grep -v "directory" > $REVISIONS
   fi

   if [[ -n "$JIRAISSUE"  ]]
   then
      cat $REVISIONS | awk '{ print $1}' | while read REVLINE
      do

         $SVNLOOK log -r "$REVLINE" "$REPOPATH" | tr '"' '_' > $TEMPFILE
         OLDLOG=`cat $TEMPFILE `

         if `echo $OLDLOG | grep "$JIRAISSUE" 1>/dev/null 2>&1`
         then
            LOGMSG=$OLDLOG
         else
            LOGMSG="$OLDLOG  $NEWLOG"
         fi
        # Debug
         # echo "Jira issue is: $JIRAISSUE"
         # echo "update the log message for Revision $REVLINE"
         # echo "New log message is: $LOGMSG"
         # echo "***********************************"

         echo "svn propset --revprop -r "$REVLINE" svn:log \""$LOGMSG"\" $REPO"
         svn propset --revprop -r "$REVLINE" svn:log \""$LOGMSG"\" $REPO
         echo ""

       done
   fi
done
...