contrib / remote-helpers / test-hg-hg-git.shon commit split-index: the writing part (96a1d8d)
   1#!/bin/sh
   2#
   3# Copyright (c) 2012 Felipe Contreras
   4#
   5# Base commands from hg-git tests:
   6# https://bitbucket.org/durin42/hg-git/src
   7#
   8
   9test_description='Test remote-hg output compared to hg-git'
  10
  11test -n "$TEST_DIRECTORY" || TEST_DIRECTORY=${0%/*}/../../t
  12. "$TEST_DIRECTORY"/test-lib.sh
  13
  14if ! test_have_prereq PYTHON
  15then
  16        skip_all='skipping remote-hg tests; python not available'
  17        test_done
  18fi
  19
  20if ! python -c 'import mercurial'
  21then
  22        skip_all='skipping remote-hg tests; mercurial not available'
  23        test_done
  24fi
  25
  26if ! python -c 'import hggit'
  27then
  28        skip_all='skipping remote-hg tests; hg-git not available'
  29        test_done
  30fi
  31
  32# clone to a git repo with git
  33git_clone_git () {
  34        git clone -q "hg::$1" $2 &&
  35        (cd $2 && git checkout master && git branch -D default)
  36}
  37
  38# clone to an hg repo with git
  39hg_clone_git () {
  40        (
  41        hg init $2 &&
  42        hg -R $2 bookmark -i master &&
  43        cd $1 &&
  44        git push -q "hg::../$2" 'refs/tags/*:refs/tags/*' 'refs/heads/*:refs/heads/*'
  45        ) &&
  46
  47        (cd $2 && hg -q update)
  48}
  49
  50# clone to a git repo with hg
  51git_clone_hg () {
  52        (
  53        git init -q $2 &&
  54        cd $1 &&
  55        hg bookmark -i -f -r tip master &&
  56        hg -q push -r master ../$2 || true
  57        )
  58}
  59
  60# clone to an hg repo with hg
  61hg_clone_hg () {
  62        hg -q clone $1 $2
  63}
  64
  65# push an hg repo with git
  66hg_push_git () {
  67        (
  68        cd $2
  69        git checkout -q -b tmp &&
  70        git fetch -q "hg::../$1" 'refs/tags/*:refs/tags/*' 'refs/heads/*:refs/heads/*' &&
  71        git branch -D default &&
  72        git checkout -q @{-1} &&
  73        git branch -q -D tmp 2>/dev/null || true
  74        )
  75}
  76
  77# push an hg git repo with hg
  78hg_push_hg () {
  79        (
  80        cd $1 &&
  81        hg -q push ../$2 || true
  82        )
  83}
  84
  85hg_log () {
  86        hg -R $1 log --graph --debug >log &&
  87        grep -v 'tag: *default/' log
  88}
  89
  90git_log () {
  91        git --git-dir=$1/.git fast-export --branches
  92}
  93
  94setup () {
  95        (
  96        echo "[ui]"
  97        echo "username = A U Thor <author@example.com>"
  98        echo "[defaults]"
  99        echo "backout = -d \"0 0\""
 100        echo "commit = -d \"0 0\""
 101        echo "debugrawcommit = -d \"0 0\""
 102        echo "tag = -d \"0 0\""
 103        echo "[extensions]"
 104        echo "hgext.bookmarks ="
 105        echo "hggit ="
 106        echo "graphlog ="
 107        ) >>"$HOME"/.hgrc &&
 108        git config --global receive.denycurrentbranch warn
 109        git config --global remote-hg.hg-git-compat true
 110        git config --global remote-hg.track-branches false
 111
 112        HGEDITOR=true
 113        HGMERGE=true
 114
 115        GIT_AUTHOR_DATE="2007-01-01 00:00:00 +0230"
 116        GIT_COMMITTER_DATE="$GIT_AUTHOR_DATE"
 117        export HGEDITOR HGMERGE GIT_AUTHOR_DATE GIT_COMMITTER_DATE
 118}
 119
 120setup
 121
 122test_expect_success 'executable bit' '
 123        test_when_finished "rm -rf gitrepo* hgrepo*" &&
 124
 125        (
 126        git init -q gitrepo &&
 127        cd gitrepo &&
 128        echo alpha >alpha &&
 129        chmod 0644 alpha &&
 130        git add alpha &&
 131        git commit -m "add alpha" &&
 132        chmod 0755 alpha &&
 133        git add alpha &&
 134        git commit -m "set executable bit" &&
 135        chmod 0644 alpha &&
 136        git add alpha &&
 137        git commit -m "clear executable bit"
 138        ) &&
 139
 140        for x in hg git
 141        do
 142                (
 143                hg_clone_$x gitrepo hgrepo-$x &&
 144                cd hgrepo-$x &&
 145                hg_log . &&
 146                hg manifest -r 1 -v &&
 147                hg manifest -v
 148                ) >"output-$x" &&
 149
 150                git_clone_$x hgrepo-$x gitrepo2-$x &&
 151                git_log gitrepo2-$x >"log-$x"
 152        done &&
 153
 154        test_cmp output-hg output-git &&
 155        test_cmp log-hg log-git
 156'
 157
 158test_expect_success 'symlink' '
 159        test_when_finished "rm -rf gitrepo* hgrepo*" &&
 160
 161        (
 162        git init -q gitrepo &&
 163        cd gitrepo &&
 164        echo alpha >alpha &&
 165        git add alpha &&
 166        git commit -m "add alpha" &&
 167        ln -s alpha beta &&
 168        git add beta &&
 169        git commit -m "add beta"
 170        ) &&
 171
 172        for x in hg git
 173        do
 174                (
 175                hg_clone_$x gitrepo hgrepo-$x &&
 176                cd hgrepo-$x &&
 177                hg_log . &&
 178                hg manifest -v
 179                ) >"output-$x" &&
 180
 181                git_clone_$x hgrepo-$x gitrepo2-$x &&
 182                git_log gitrepo2-$x >"log-$x"
 183        done &&
 184
 185        test_cmp output-hg output-git &&
 186        test_cmp log-hg log-git
 187'
 188
 189test_expect_success 'merge conflict 1' '
 190        test_when_finished "rm -rf gitrepo* hgrepo*" &&
 191
 192        (
 193        hg init hgrepo1 &&
 194        cd hgrepo1 &&
 195        echo A >afile &&
 196        hg add afile &&
 197        hg ci -m "origin" &&
 198
 199        echo B >afile &&
 200        hg ci -m "A->B" &&
 201
 202        hg up -r0 &&
 203        echo C >afile &&
 204        hg ci -m "A->C" &&
 205
 206        hg merge -r1 &&
 207        echo C >afile &&
 208        hg resolve -m afile &&
 209        hg ci -m "merge to C"
 210        ) &&
 211
 212        for x in hg git
 213        do
 214                git_clone_$x hgrepo1 gitrepo-$x &&
 215                hg_clone_$x gitrepo-$x hgrepo2-$x &&
 216                hg_log hgrepo2-$x >"hg-log-$x" &&
 217                git_log gitrepo-$x >"git-log-$x"
 218        done &&
 219
 220        test_cmp hg-log-hg hg-log-git &&
 221        test_cmp git-log-hg git-log-git
 222'
 223
 224test_expect_success 'merge conflict 2' '
 225        test_when_finished "rm -rf gitrepo* hgrepo*" &&
 226
 227        (
 228        hg init hgrepo1 &&
 229        cd hgrepo1 &&
 230        echo A >afile &&
 231        hg add afile &&
 232        hg ci -m "origin" &&
 233
 234        echo B >afile &&
 235        hg ci -m "A->B" &&
 236
 237        hg up -r0 &&
 238        echo C >afile &&
 239        hg ci -m "A->C" &&
 240
 241        hg merge -r1 || true &&
 242        echo B >afile &&
 243        hg resolve -m afile &&
 244        hg ci -m "merge to B"
 245        ) &&
 246
 247        for x in hg git
 248        do
 249                git_clone_$x hgrepo1 gitrepo-$x &&
 250                hg_clone_$x gitrepo-$x hgrepo2-$x &&
 251                hg_log hgrepo2-$x >"hg-log-$x" &&
 252                git_log gitrepo-$x >"git-log-$x"
 253        done &&
 254
 255        test_cmp hg-log-hg hg-log-git &&
 256        test_cmp git-log-hg git-log-git
 257'
 258
 259test_expect_success 'converged merge' '
 260        test_when_finished "rm -rf gitrepo* hgrepo*" &&
 261
 262        (
 263        hg init hgrepo1 &&
 264        cd hgrepo1 &&
 265        echo A >afile &&
 266        hg add afile &&
 267        hg ci -m "origin" &&
 268
 269        echo B >afile &&
 270        hg ci -m "A->B" &&
 271
 272        echo C >afile &&
 273        hg ci -m "B->C" &&
 274
 275        hg up -r0 &&
 276        echo C >afile &&
 277        hg ci -m "A->C" &&
 278
 279        hg merge -r2 || true &&
 280        hg ci -m "merge"
 281        ) &&
 282
 283        for x in hg git
 284        do
 285                git_clone_$x hgrepo1 gitrepo-$x &&
 286                hg_clone_$x gitrepo-$x hgrepo2-$x &&
 287                hg_log hgrepo2-$x >"hg-log-$x" &&
 288                git_log gitrepo-$x >"git-log-$x"
 289        done &&
 290
 291        test_cmp hg-log-hg hg-log-git &&
 292        test_cmp git-log-hg git-log-git
 293'
 294
 295test_expect_success 'encoding' '
 296        test_when_finished "rm -rf gitrepo* hgrepo*" &&
 297
 298        (
 299        git init -q gitrepo &&
 300        cd gitrepo &&
 301
 302        echo alpha >alpha &&
 303        git add alpha &&
 304        git commit -m "add älphà" &&
 305
 306        GIT_AUTHOR_NAME="tést èncödîng" &&
 307        export GIT_AUTHOR_NAME &&
 308        echo beta >beta &&
 309        git add beta &&
 310        git commit -m "add beta" &&
 311
 312        echo gamma >gamma &&
 313        git add gamma &&
 314        git commit -m "add gämmâ" &&
 315
 316        : TODO git config i18n.commitencoding latin-1 &&
 317        echo delta >delta &&
 318        git add delta &&
 319        git commit -m "add déltà"
 320        ) &&
 321
 322        for x in hg git
 323        do
 324                hg_clone_$x gitrepo hgrepo-$x &&
 325                git_clone_$x hgrepo-$x gitrepo2-$x &&
 326
 327                HGENCODING=utf-8 hg_log hgrepo-$x >"hg-log-$x" &&
 328                git_log gitrepo2-$x >"git-log-$x"
 329        done &&
 330
 331        test_cmp hg-log-hg hg-log-git &&
 332        test_cmp git-log-hg git-log-git
 333'
 334
 335test_expect_success 'file removal' '
 336        test_when_finished "rm -rf gitrepo* hgrepo*" &&
 337
 338        (
 339        git init -q gitrepo &&
 340        cd gitrepo &&
 341        echo alpha >alpha &&
 342        git add alpha &&
 343        git commit -m "add alpha" &&
 344        echo beta >beta &&
 345        git add beta &&
 346        git commit -m "add beta"
 347        mkdir foo &&
 348        echo blah >foo/bar &&
 349        git add foo &&
 350        git commit -m "add foo" &&
 351        git rm alpha &&
 352        git commit -m "remove alpha" &&
 353        git rm foo/bar &&
 354        git commit -m "remove foo/bar"
 355        ) &&
 356
 357        for x in hg git
 358        do
 359                (
 360                hg_clone_$x gitrepo hgrepo-$x &&
 361                cd hgrepo-$x &&
 362                hg_log . &&
 363                hg manifest -r 3 &&
 364                hg manifest
 365                ) >"output-$x" &&
 366
 367                git_clone_$x hgrepo-$x gitrepo2-$x &&
 368                git_log gitrepo2-$x >"log-$x"
 369        done &&
 370
 371        test_cmp output-hg output-git &&
 372        test_cmp log-hg log-git
 373'
 374
 375test_expect_success 'git tags' '
 376        test_when_finished "rm -rf gitrepo* hgrepo*" &&
 377
 378        (
 379        git init -q gitrepo &&
 380        cd gitrepo &&
 381        git config receive.denyCurrentBranch ignore &&
 382        echo alpha >alpha &&
 383        git add alpha &&
 384        git commit -m "add alpha" &&
 385        git tag alpha &&
 386
 387        echo beta >beta &&
 388        git add beta &&
 389        git commit -m "add beta" &&
 390        git tag -a -m "added tag beta" beta
 391        ) &&
 392
 393        for x in hg git
 394        do
 395                hg_clone_$x gitrepo hgrepo-$x &&
 396                hg_log hgrepo-$x >"log-$x"
 397        done &&
 398
 399        test_cmp log-hg log-git
 400'
 401
 402test_expect_success 'hg author' '
 403        test_when_finished "rm -rf gitrepo* hgrepo*" &&
 404
 405        for x in hg git
 406        do
 407                (
 408                git init -q gitrepo-$x &&
 409                cd gitrepo-$x &&
 410
 411                echo alpha >alpha &&
 412                git add alpha &&
 413                git commit -m "add alpha" &&
 414                git checkout -q -b not-master
 415                ) &&
 416
 417                (
 418                hg_clone_$x gitrepo-$x hgrepo-$x &&
 419                cd hgrepo-$x &&
 420
 421                hg co master &&
 422                echo beta >beta &&
 423                hg add beta &&
 424                hg commit -u "test" -m "add beta" &&
 425
 426                echo gamma >>beta &&
 427                hg commit -u "test <test@example.com> (comment)" -m "modify beta" &&
 428
 429                echo gamma >gamma &&
 430                hg add gamma &&
 431                hg commit -u "<test@example.com>" -m "add gamma" &&
 432
 433                echo delta >delta &&
 434                hg add delta &&
 435                hg commit -u "name<test@example.com>" -m "add delta" &&
 436
 437                echo epsilon >epsilon &&
 438                hg add epsilon &&
 439                hg commit -u "name <test@example.com" -m "add epsilon" &&
 440
 441                echo zeta >zeta &&
 442                hg add zeta &&
 443                hg commit -u " test " -m "add zeta" &&
 444
 445                echo eta >eta &&
 446                hg add eta &&
 447                hg commit -u "test < test@example.com >" -m "add eta" &&
 448
 449                echo theta >theta &&
 450                hg add theta &&
 451                hg commit -u "test >test@example.com>" -m "add theta" &&
 452
 453                echo iota >iota &&
 454                hg add iota &&
 455                hg commit -u "test <test <at> example <dot> com>" -m "add iota"
 456                ) &&
 457
 458                hg_push_$x hgrepo-$x gitrepo-$x &&
 459                hg_clone_$x gitrepo-$x hgrepo2-$x &&
 460
 461                hg_log hgrepo2-$x >"hg-log-$x" &&
 462                git_log gitrepo-$x >"git-log-$x"
 463        done &&
 464
 465        test_cmp hg-log-hg hg-log-git &&
 466        test_cmp git-log-hg git-log-git
 467'
 468
 469test_expect_success 'hg branch' '
 470        test_when_finished "rm -rf gitrepo* hgrepo*" &&
 471
 472        for x in hg git
 473        do
 474                (
 475                git init -q gitrepo-$x &&
 476                cd gitrepo-$x &&
 477
 478                echo alpha >alpha &&
 479                git add alpha &&
 480                git commit -q -m "add alpha" &&
 481                git checkout -q -b not-master
 482                ) &&
 483
 484                (
 485                hg_clone_$x gitrepo-$x hgrepo-$x &&
 486
 487                cd hgrepo-$x &&
 488                hg -q co master &&
 489                hg mv alpha beta &&
 490                hg -q commit -m "rename alpha to beta" &&
 491                hg branch gamma | grep -v "permanent and global" &&
 492                hg -q commit -m "started branch gamma"
 493                ) &&
 494
 495                hg_push_$x hgrepo-$x gitrepo-$x &&
 496                hg_clone_$x gitrepo-$x hgrepo2-$x &&
 497
 498                hg_log hgrepo2-$x >"hg-log-$x" &&
 499                git_log gitrepo-$x >"git-log-$x"
 500        done &&
 501
 502        test_cmp hg-log-hg hg-log-git &&
 503        test_cmp git-log-hg git-log-git
 504'
 505
 506test_expect_success 'hg tags' '
 507        test_when_finished "rm -rf gitrepo* hgrepo*" &&
 508
 509        for x in hg git
 510        do
 511                (
 512                git init -q gitrepo-$x &&
 513                cd gitrepo-$x &&
 514
 515                echo alpha >alpha &&
 516                git add alpha &&
 517                git commit -m "add alpha" &&
 518                git checkout -q -b not-master
 519                ) &&
 520
 521                (
 522                hg_clone_$x gitrepo-$x hgrepo-$x &&
 523
 524                cd hgrepo-$x &&
 525                hg co master &&
 526                hg tag alpha
 527                ) &&
 528
 529                hg_push_$x hgrepo-$x gitrepo-$x &&
 530                hg_clone_$x gitrepo-$x hgrepo2-$x &&
 531
 532                (
 533                git --git-dir=gitrepo-$x/.git tag -l &&
 534                hg_log hgrepo2-$x &&
 535                cat hgrepo2-$x/.hgtags
 536                ) >"output-$x"
 537        done &&
 538
 539        test_cmp output-hg output-git
 540'
 541
 542test_done