Hex Artifact Content
Not logged in

Artifact 3dfd51dbc112622ad82683802a692bd1ae42c718:

Attachment "merge-conflict.sh" to ticket [67a47646ea] added by leor 2012-02-10 05:40:55.
0000: 23 21 2f 62 69 6e 2f 62 61 73 68 0a 23 23 23 23  #!/bin/bash.####
0010: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0020: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0030: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0040: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0050: 23 23 23 23 23 23 23 23 23 23 23 23 0a 23 20 44  ############.# D
0060: 65 6d 6f 6e 73 74 72 61 74 65 73 20 22 66 6f 73  emonstrates "fos
0070: 73 69 6c 20 63 6f 6d 6d 69 74 22 20 66 61 69 6c  sil commit" fail
0080: 75 72 65 20 61 66 74 65 72 20 6d 65 72 67 65 2e  ure after merge.
0090: 0a 23 20 57 65 20 68 61 76 65 20 61 20 72 65 70  .# We have a rep
00a0: 6f 20 77 69 74 68 20 74 77 6f 20 66 69 6c 65 73  o with two files
00b0: 20 62 61 72 2c 20 66 6f 6f 20 77 68 69 63 68 20   bar, foo which 
00c0: 69 73 20 62 65 69 6e 67 20 64 65 76 65 6c 6f 70  is being develop
00d0: 65 64 20 69 6e 20 62 72 61 6e 63 68 65 73 20 0a  ed in branches .
00e0: 23 20 74 72 75 6e 6b 20 61 6e 64 20 6e 65 78 74  # trunk and next
00f0: 2e 20 41 74 20 73 6f 6d 65 20 70 6f 69 6e 74 20  . At some point 
0100: 6e 65 78 74 20 69 73 20 6d 65 72 67 65 64 20 69  next is merged i
0110: 6e 74 6f 20 74 72 75 6e 6b 2e 20 62 61 72 20 69  nto trunk. bar i
0120: 73 20 73 75 63 63 65 73 73 66 75 6c 6c 79 20 0a  s successfully .
0130: 23 20 61 75 74 6f 6d 65 72 67 65 64 20 77 68 69  # automerged whi
0140: 6c 65 20 66 6f 6f 20 68 61 73 20 6d 65 72 67 65  le foo has merge
0150: 20 63 6f 6e 66 6c 69 63 74 73 20 72 65 71 75 69   conflicts requi
0160: 72 69 6e 67 20 6d 61 6e 75 61 6c 20 72 65 73 6f  ring manual reso
0170: 6c 75 74 69 6f 6e 2e 20 0a 23 20 46 72 6f 6d 20  lution. .# From 
0180: 69 6e 74 65 72 6e 61 6c 20 6c 6f 67 69 63 20 6f  internal logic o
0190: 66 20 74 68 65 20 70 72 6f 6a 65 63 74 20 72 65  f the project re
01a0: 73 6f 6c 76 69 6e 67 20 63 6f 6e 66 6c 69 63 74  solving conflict
01b0: 73 20 69 6e 20 66 6f 6f 20 72 65 71 75 69 72 65  s in foo require
01c0: 73 20 0a 23 20 6d 6f 64 69 66 69 63 61 74 69 6f  s .# modificatio
01d0: 6e 73 20 74 6f 20 62 61 72 2e 20 41 66 74 65 72  ns to bar. After
01e0: 20 62 61 72 20 69 73 20 65 64 69 74 65 64 20 22   bar is edited "
01f0: 66 6f 73 73 69 6c 20 63 6f 6d 6d 69 74 22 20 66  fossil commit" f
0200: 61 69 6c 73 21 0a 23 23 23 23 23 23 23 23 23 23  ails!.##########
0210: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0220: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0230: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0240: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0250: 23 23 23 23 23 23 0a 0a 23 20 50 72 65 61 6d 62  ######..# Preamb
0260: 6c 65 20 74 6f 20 73 65 74 75 70 20 64 69 72 65  le to setup dire
0270: 63 74 6f 72 69 65 73 20 61 6e 64 20 6f 75 74 70  ctories and outp
0280: 75 74 20 72 65 64 69 72 65 63 74 69 6f 6e 0a 42  ut redirection.B
0290: 4e 41 4d 45 3d 6d 65 72 67 65 2d 63 6f 6e 66 6c  NAME=merge-confl
02a0: 69 63 74 0a 52 54 44 49 52 3d 22 2f 74 6d 70 2f  ict.RTDIR="/tmp/
02b0: 66 6f 73 73 69 6c 2d 74 65 73 74 73 2f 24 42 4e  fossil-tests/$BN
02c0: 41 4d 45 22 0a 72 6d 20 2d 72 66 20 20 20 22 24  AME".rm -rf   "$
02d0: 52 54 44 49 52 22 0a 6d 6b 64 69 72 20 2d 70 20  RTDIR".mkdir -p 
02e0: 22 24 52 54 44 49 52 22 0a 65 78 65 63 20 32 3e  "$RTDIR".exec 2>
02f0: 26 31 0a 65 78 65 63 20 31 3e 26 20 3e 28 74 65  &1.exec 1>& >(te
0300: 65 20 22 24 52 54 44 49 52 2f 54 2e 6c 6f 67 22  e "$RTDIR/T.log"
0310: 29 0a 65 63 68 6f 20 22 2a 2a 2a 2a 2a 2a 2a 2a  ).echo "********
0320: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0330: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0340: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0350: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0360: 2a 2a 22 0a 65 63 68 6f 20 22 2a 2a 20 20 24 52  **".echo "**  $R
0370: 54 44 49 52 2f 54 2e 6c 6f 67 20 20 20 20 20 2d  TDIR/T.log     -
0380: 2d 20 74 68 69 73 20 6c 6f 67 22 0a 65 63 68 6f  - this log".echo
0390: 20 22 2a 2a 20 20 24 52 54 44 49 52 2f 54 2e 66   "**  $RTDIR/T.f
03a0: 6f 73 73 69 6c 20 20 2d 2d 20 74 65 73 74 20 72  ossil  -- test r
03b0: 65 70 6f 22 0a 65 63 68 6f 20 22 2a 2a 20 20 24  epo".echo "**  $
03c0: 52 54 44 49 52 2f 54 20 20 20 20 20 20 20 20 20  RTDIR/T         
03d0: 2d 2d 20 63 68 65 63 6b 6f 75 74 22 0a 65 63 68  -- checkout".ech
03e0: 6f 20 22 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  o "*************
03f0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0400: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0410: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0420: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 22 0a 73  *************".s
0430: 65 74 20 2d 78 0a 0a 23 20 54 65 73 74 20 63 61  et -x..# Test ca
0440: 73 65 0a 63 64 20 22 24 52 54 44 49 52 22 09 09  se.cd "$RTDIR"..
0450: 09 23 20 4e 6f 77 20 69 6e 20 24 52 54 44 49 52  .# Now in $RTDIR
0460: 0a 66 6f 73 73 69 6c 20 6e 65 77 20 54 2e 66 6f  .fossil new T.fo
0470: 73 73 69 6c 0a 6d 6b 64 69 72 20 2d 70 20 54 0a  ssil.mkdir -p T.
0480: 63 64 20 54 09 09 09 09 23 20 4e 6f 77 20 69 6e  cd T....# Now in
0490: 20 24 52 54 44 49 52 2f 54 0a 66 6f 73 73 69 6c   $RTDIR/T.fossil
04a0: 20 6f 70 65 6e 20 2e 2e 2f 54 2e 66 6f 73 73 69   open ../T.fossi
04b0: 6c 0a 65 63 68 6f 20 22 66 6f 6f 20 69 6e 20 74  l.echo "foo in t
04c0: 68 65 20 62 72 61 6e 63 68 20 74 72 75 6e 6b 22  he branch trunk"
04d0: 20 3e 20 66 6f 6f 0a 65 63 68 6f 20 22 62 61 72   > foo.echo "bar
04e0: 20 69 6e 20 74 68 65 20 74 72 75 6e 6b 22 20 3e   in the trunk" >
04f0: 20 62 61 72 0a 66 6f 73 73 69 6c 20 61 64 64 20   bar.fossil add 
0500: 66 6f 6f 20 62 61 72 0a 66 6f 73 73 69 6c 20 63  foo bar.fossil c
0510: 69 20 2d 6d 20 27 61 64 64 65 64 20 66 6f 6f 2c  i -m 'added foo,
0520: 20 62 61 72 20 74 6f 20 74 68 65 20 74 72 75 6e   bar to the trun
0530: 6b 27 0a 65 63 68 6f 20 22 66 6f 6f 20 69 6e 20  k'.echo "foo in 
0540: 74 68 65 20 62 72 61 6e 63 68 20 6e 65 78 74 22  the branch next"
0550: 20 3e 20 66 6f 6f 0a 65 63 68 6f 20 22 6c 69 6e   > foo.echo "lin
0560: 65 20 61 64 64 65 64 20 74 6f 20 62 61 72 20 69  e added to bar i
0570: 6e 20 62 72 61 6e 63 68 20 6e 65 78 74 22 20 3e  n branch next" >
0580: 3e 20 62 61 72 0a 66 6f 73 73 69 6c 20 63 69 20  > bar.fossil ci 
0590: 2d 2d 62 72 61 6e 63 68 20 6e 65 78 74 20 2d 6d  --branch next -m
05a0: 20 27 63 6f 6d 6d 69 74 20 74 6f 20 6e 65 77 6c   'commit to newl
05b0: 79 20 63 72 65 61 74 65 64 20 62 72 61 6e 63 68  y created branch
05c0: 20 6e 65 78 74 27 0a 23 20 67 6f 20 74 6f 20 74   next'.# go to t
05d0: 68 65 20 74 72 75 6e 6b 20 0a 66 6f 73 73 69 6c  he trunk .fossil
05e0: 20 63 6f 20 74 72 75 6e 6b 0a 66 6f 73 73 69 6c   co trunk.fossil
05f0: 20 69 6e 66 0a 23 20 6d 61 6b 65 20 63 68 61 6e   inf.# make chan
0600: 67 65 73 20 74 6f 20 74 72 75 6e 6b 0a 65 63 68  ges to trunk.ech
0610: 6f 20 22 6e 65 77 20 66 6f 6f 20 76 65 72 73 69  o "new foo versi
0620: 6f 6e 20 69 6e 20 74 68 65 20 74 72 75 6e 6b 22  on in the trunk"
0630: 20 3e 20 66 6f 6f 0a 66 6f 73 73 69 6c 20 63 69   > foo.fossil ci
0640: 20 2d 6d 20 27 66 6f 6f 20 63 68 61 6e 67 65 64   -m 'foo changed
0650: 20 69 6e 20 74 72 75 6e 6b 27 0a 23 20 6d 65 72   in trunk'.# mer
0660: 67 65 20 6e 65 78 74 20 69 6e 74 6f 20 74 72 75  ge next into tru
0670: 6e 6b 0a 66 6f 73 73 69 6c 20 6d 65 72 67 65 20  nk.fossil merge 
0680: 2d 2d 64 65 74 61 69 6c 20 6e 65 78 74 0a 66 6f  --detail next.fo
0690: 73 73 69 6c 20 63 68 61 0a 65 63 68 6f 20 22 6d  ssil cha.echo "m
06a0: 65 72 67 65 64 20 76 65 72 73 69 6f 6e 20 6f 66  erged version of
06b0: 20 66 6f 6f 22 20 3e 20 66 6f 6f 0a 65 63 68 6f   foo" > foo.echo
06c0: 20 22 72 65 73 6f 6c 76 69 6e 67 20 6d 65 72 67   "resolving merg
06d0: 65 20 63 6f 6e 66 6c 69 63 74 73 20 69 6e 20 66  e conflicts in f
06e0: 6f 6f 20 72 65 71 75 69 72 65 64 20 63 68 61 6e  oo required chan
06f0: 67 65 73 20 69 6e 20 62 61 72 22 20 3e 20 62 61  ges in bar" > ba
0700: 72 0a 23 20 74 72 79 69 6e 67 20 74 6f 20 63 6f  r.# trying to co
0710: 6d 6d 69 74 2e 20 47 45 54 54 49 4e 47 20 45 52  mmit. GETTING ER
0720: 52 4f 52 53 21 21 21 0a 66 6f 73 73 69 6c 20 63  RORS!!!.fossil c
0730: 69 20 2d 2d 66 6f 72 63 65 20 2d 6d 20 27 72 65  i --force -m 're
0740: 73 6f 6c 76 65 64 20 63 6f 6e 66 6c 69 63 74 73  solved conflicts
0750: 20 69 6e 20 66 6f 6f 27 0a 0a 23 45 6f 46 0a      in foo'..#EoF.