eac_git 0.1.0 → 0.3.3

Sign up to get free protection for your applications and to get access to all the features.
Files changed (192) hide show
  1. checksums.yaml +4 -4
  2. data/lib/eac_git/executables.rb +24 -4
  3. data/lib/eac_git/local.rb +5 -1
  4. data/lib/eac_git/local/dirty_files.rb +37 -0
  5. data/lib/eac_git/rspec.rb +17 -0
  6. data/lib/eac_git/version.rb +1 -1
  7. data/vendor/git-subrepo/Changes +110 -0
  8. data/vendor/git-subrepo/Intro.pod +509 -0
  9. data/vendor/git-subrepo/License +21 -0
  10. data/vendor/git-subrepo/Makefile +82 -0
  11. data/vendor/git-subrepo/Meta +28 -0
  12. data/vendor/git-subrepo/ReadMe.pod +698 -0
  13. data/vendor/git-subrepo/doc/comparison.swim +35 -0
  14. data/vendor/git-subrepo/doc/git-subrepo.swim +608 -0
  15. data/vendor/git-subrepo/doc/intro-to-subrepo.swim +387 -0
  16. data/vendor/git-subrepo/ext/bashplus/Changes +15 -0
  17. data/vendor/git-subrepo/ext/bashplus/License +21 -0
  18. data/vendor/git-subrepo/ext/bashplus/Makefile +45 -0
  19. data/vendor/git-subrepo/ext/bashplus/Meta +28 -0
  20. data/vendor/git-subrepo/ext/bashplus/ReadMe.pod +77 -0
  21. data/vendor/git-subrepo/ext/bashplus/bin/bash+ +43 -0
  22. data/vendor/git-subrepo/ext/bashplus/doc/bash+.swim +61 -0
  23. data/vendor/git-subrepo/ext/bashplus/lib/bash+.bash +92 -0
  24. data/vendor/git-subrepo/ext/bashplus/man/man1/bash+.1 +134 -0
  25. data/vendor/git-subrepo/ext/bashplus/man/man3/bash+.3 +134 -0
  26. data/vendor/git-subrepo/ext/bashplus/test/base.t +12 -0
  27. data/vendor/git-subrepo/ext/bashplus/test/fcopy.t +22 -0
  28. data/vendor/git-subrepo/ext/bashplus/test/lib/foo/bar.bash +3 -0
  29. data/vendor/git-subrepo/ext/bashplus/test/lib/foo/foo.bash +3 -0
  30. data/vendor/git-subrepo/ext/bashplus/test/source-bash+-std.t +18 -0
  31. data/vendor/git-subrepo/ext/bashplus/test/source-bash+.t +23 -0
  32. data/vendor/git-subrepo/ext/bashplus/test/test.bash +70 -0
  33. data/vendor/git-subrepo/ext/bashplus/test/use.t +19 -0
  34. data/vendor/git-subrepo/ext/test-more-bash/Changes +15 -0
  35. data/vendor/git-subrepo/ext/test-more-bash/License +21 -0
  36. data/vendor/git-subrepo/ext/test-more-bash/Makefile +20 -0
  37. data/vendor/git-subrepo/ext/test-more-bash/Meta +30 -0
  38. data/vendor/git-subrepo/ext/test-more-bash/ReadMe.pod +115 -0
  39. data/vendor/git-subrepo/ext/test-more-bash/doc/test-more.swim +89 -0
  40. data/vendor/git-subrepo/ext/test-more-bash/ext/bashplus/Changes +15 -0
  41. data/vendor/git-subrepo/ext/test-more-bash/ext/bashplus/License +21 -0
  42. data/vendor/git-subrepo/ext/test-more-bash/ext/bashplus/Makefile +45 -0
  43. data/vendor/git-subrepo/ext/test-more-bash/ext/bashplus/Meta +28 -0
  44. data/vendor/git-subrepo/ext/test-more-bash/ext/bashplus/ReadMe.pod +77 -0
  45. data/vendor/git-subrepo/ext/test-more-bash/ext/bashplus/bin/bash+ +43 -0
  46. data/vendor/git-subrepo/ext/test-more-bash/ext/bashplus/doc/bash+.swim +61 -0
  47. data/vendor/git-subrepo/ext/test-more-bash/ext/bashplus/lib/bash+.bash +92 -0
  48. data/vendor/git-subrepo/ext/test-more-bash/ext/bashplus/man/man1/bash+.1 +134 -0
  49. data/vendor/git-subrepo/ext/test-more-bash/ext/bashplus/man/man3/bash+.3 +134 -0
  50. data/vendor/git-subrepo/ext/test-more-bash/ext/bashplus/test/base.t +12 -0
  51. data/vendor/git-subrepo/ext/test-more-bash/ext/bashplus/test/fcopy.t +22 -0
  52. data/vendor/git-subrepo/ext/test-more-bash/ext/bashplus/test/lib/foo/bar.bash +3 -0
  53. data/vendor/git-subrepo/ext/test-more-bash/ext/bashplus/test/lib/foo/foo.bash +3 -0
  54. data/vendor/git-subrepo/ext/test-more-bash/ext/bashplus/test/source-bash+-std.t +18 -0
  55. data/vendor/git-subrepo/ext/test-more-bash/ext/bashplus/test/source-bash+.t +23 -0
  56. data/vendor/git-subrepo/ext/test-more-bash/ext/bashplus/test/test.bash +70 -0
  57. data/vendor/git-subrepo/ext/test-more-bash/ext/bashplus/test/use.t +19 -0
  58. data/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/Changes +15 -0
  59. data/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/License +21 -0
  60. data/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/Makefile +37 -0
  61. data/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/Meta +28 -0
  62. data/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/ReadMe.pod +66 -0
  63. data/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/doc/test-tap.swim +48 -0
  64. data/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/lib/test/tap.bash +153 -0
  65. data/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/man/man3/test-tap.3 +119 -0
  66. data/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/test/bail_out.t +13 -0
  67. data/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/test/done.t +10 -0
  68. data/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/test/fail.t +20 -0
  69. data/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/test/fail_fast.t +15 -0
  70. data/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/test/helper.bash +9 -0
  71. data/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/test/pass.t +9 -0
  72. data/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/test/plan.t +10 -0
  73. data/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/test/skip_all.t +20 -0
  74. data/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/test/tap.t +13 -0
  75. data/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/test/test/bail.t +14 -0
  76. data/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/test/test/fail.t +7 -0
  77. data/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/test/test/fail_fast.t +12 -0
  78. data/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/test/test/skip-all-init.t +8 -0
  79. data/vendor/git-subrepo/ext/test-more-bash/ext/test-tap-bash/test/test/skip-all-plan.t +9 -0
  80. data/vendor/git-subrepo/ext/test-more-bash/lib/test/more.bash +95 -0
  81. data/vendor/git-subrepo/ext/test-more-bash/man/man3/test-more.3 +173 -0
  82. data/vendor/git-subrepo/ext/test-more-bash/test/fail.t +20 -0
  83. data/vendor/git-subrepo/ext/test-more-bash/test/more.t +20 -0
  84. data/vendor/git-subrepo/ext/test-more-bash/test/pass.t +9 -0
  85. data/vendor/git-subrepo/ext/test-more-bash/test/setup +8 -0
  86. data/vendor/git-subrepo/ext/test-more-bash/test/skip_all.t +11 -0
  87. data/vendor/git-subrepo/ext/test-more-bash/test/test/fail1.t +12 -0
  88. data/vendor/git-subrepo/ext/test-more-bash/test/test/skip_all.t +10 -0
  89. data/vendor/git-subrepo/lib/git-subrepo +1903 -0
  90. data/vendor/git-subrepo/lib/git-subrepo.d/bash+.bash +1 -0
  91. data/vendor/git-subrepo/lib/git-subrepo.d/help-functions.bash +339 -0
  92. data/vendor/git-subrepo/man/man1/git-subrepo.1 +743 -0
  93. data/vendor/git-subrepo/note/0.4.0 +12 -0
  94. data/vendor/git-subrepo/note/AllGitCmds +148 -0
  95. data/vendor/git-subrepo/note/Cases +32 -0
  96. data/vendor/git-subrepo/note/Commands +33 -0
  97. data/vendor/git-subrepo/note/Dags +199 -0
  98. data/vendor/git-subrepo/note/Gists +7 -0
  99. data/vendor/git-subrepo/note/Links +25 -0
  100. data/vendor/git-subrepo/note/Plugins +10 -0
  101. data/vendor/git-subrepo/note/Spec +39 -0
  102. data/vendor/git-subrepo/note/Story1 +57 -0
  103. data/vendor/git-subrepo/note/ToDo +55 -0
  104. data/vendor/git-subrepo/note/design.swim +137 -0
  105. data/vendor/git-subrepo/note/design2.swim +85 -0
  106. data/vendor/git-subrepo/note/init-test +38 -0
  107. data/vendor/git-subrepo/note/pull-dance.txt +18 -0
  108. data/vendor/git-subrepo/note/recreate-rebase-conflict.sh +56 -0
  109. data/vendor/git-subrepo/note/subtree-rebase-fail-example/test.bash +29 -0
  110. data/vendor/git-subrepo/note/test-subrepo-push.sh +69 -0
  111. data/vendor/git-subrepo/note/test.sh +58 -0
  112. data/vendor/git-subrepo/pkg/bin/generate-completion.pl +210 -0
  113. data/vendor/git-subrepo/pkg/bin/generate-help-functions.pl +89 -0
  114. data/vendor/git-subrepo/share/completion.bash +42 -0
  115. data/vendor/git-subrepo/share/enable-completion.sh +50 -0
  116. data/vendor/git-subrepo/share/git-completion.bash +2738 -0
  117. data/vendor/git-subrepo/share/zsh-completion/_git-subrepo +81 -0
  118. data/vendor/git-subrepo/test/branch-all.t +41 -0
  119. data/vendor/git-subrepo/test/branch-rev-list-one-path.t +43 -0
  120. data/vendor/git-subrepo/test/branch-rev-list.t +47 -0
  121. data/vendor/git-subrepo/test/branch.t +52 -0
  122. data/vendor/git-subrepo/test/clean.t +43 -0
  123. data/vendor/git-subrepo/test/clone-annotated-tag.t +45 -0
  124. data/vendor/git-subrepo/test/clone.t +107 -0
  125. data/vendor/git-subrepo/test/compile.t +19 -0
  126. data/vendor/git-subrepo/test/config.t +58 -0
  127. data/vendor/git-subrepo/test/encode.t +91 -0
  128. data/vendor/git-subrepo/test/error.t +171 -0
  129. data/vendor/git-subrepo/test/fetch.t +43 -0
  130. data/vendor/git-subrepo/test/gitignore.t +61 -0
  131. data/vendor/git-subrepo/test/init.t +64 -0
  132. data/vendor/git-subrepo/test/issue29.t +98 -0
  133. data/vendor/git-subrepo/test/issue95.t +98 -0
  134. data/vendor/git-subrepo/test/issue96.t +96 -0
  135. data/vendor/git-subrepo/test/pull-all.t +38 -0
  136. data/vendor/git-subrepo/test/pull-merge.t +113 -0
  137. data/vendor/git-subrepo/test/pull-message.t +88 -0
  138. data/vendor/git-subrepo/test/pull-new-branch.t +58 -0
  139. data/vendor/git-subrepo/test/pull-ours.t +90 -0
  140. data/vendor/git-subrepo/test/pull-theirs.t +82 -0
  141. data/vendor/git-subrepo/test/pull-twice.t +44 -0
  142. data/vendor/git-subrepo/test/pull-worktree.t +40 -0
  143. data/vendor/git-subrepo/test/pull.t +99 -0
  144. data/vendor/git-subrepo/test/push-after-init.t +51 -0
  145. data/vendor/git-subrepo/test/push-force.t +56 -0
  146. data/vendor/git-subrepo/test/push-new-branch.t +61 -0
  147. data/vendor/git-subrepo/test/push-no-changes.t +29 -0
  148. data/vendor/git-subrepo/test/push-squash.t +56 -0
  149. data/vendor/git-subrepo/test/push.t +176 -0
  150. data/vendor/git-subrepo/test/reclone.t +45 -0
  151. data/vendor/git-subrepo/test/repo/bar/HEAD +1 -0
  152. data/vendor/git-subrepo/test/repo/bar/config +4 -0
  153. data/vendor/git-subrepo/test/repo/bar/objects/1f/0c4b264caed0126814a0ede851a1e0b4e16ae6 +0 -0
  154. data/vendor/git-subrepo/test/repo/bar/objects/87/46903fdb1b9c2101377880125917c2e05b4d69 +0 -0
  155. data/vendor/git-subrepo/test/repo/bar/objects/94/c86ffc745232d89f78c6f895e11e71272518db +0 -0
  156. data/vendor/git-subrepo/test/repo/bar/objects/c6/76c57b6576743fa56278527aa60ebd2e202a7c +0 -0
  157. data/vendor/git-subrepo/test/repo/bar/objects/e6/9de29bb2d1d6434b8b29ae775ad8c2e48c5391 +0 -0
  158. data/vendor/git-subrepo/test/repo/bar/objects/f6/2a8ff3feadf39b0a98f1a86ec6d1eb33858ee9 +0 -0
  159. data/vendor/git-subrepo/test/repo/bar/refs/heads/master +1 -0
  160. data/vendor/git-subrepo/test/repo/bar/refs/tags/A +1 -0
  161. data/vendor/git-subrepo/test/repo/foo/HEAD +1 -0
  162. data/vendor/git-subrepo/test/repo/foo/config +4 -0
  163. data/vendor/git-subrepo/test/repo/foo/objects/a0/f4cdaaf533a936296cdebbed8206c3b9ededa8 +0 -0
  164. data/vendor/git-subrepo/test/repo/foo/objects/e2/1291a1ad392a9d4c51dd9586804f1467b28afd +0 -0
  165. data/vendor/git-subrepo/test/repo/foo/objects/e6/9de29bb2d1d6434b8b29ae775ad8c2e48c5391 +0 -0
  166. data/vendor/git-subrepo/test/repo/foo/refs/heads/master +1 -0
  167. data/vendor/git-subrepo/test/repo/init/HEAD +1 -0
  168. data/vendor/git-subrepo/test/repo/init/config +5 -0
  169. data/vendor/git-subrepo/test/repo/init/objects/11/523f5dcf03b4c89b592dc8a3d0308f68da2386 +0 -0
  170. data/vendor/git-subrepo/test/repo/init/objects/14/2addf8ec5f37334e837440122c62f2c68a29ad +0 -0
  171. data/vendor/git-subrepo/test/repo/init/objects/32/5180321750a21cd7a4e7ecda319e557a4f6a09 +2 -0
  172. data/vendor/git-subrepo/test/repo/init/objects/3d/918c6901c02f43af5d31779dd5e1f9166aeb36 +0 -0
  173. data/vendor/git-subrepo/test/repo/init/objects/3e/4cb596066dce63ba4d047abddb677389b65e19 +0 -0
  174. data/vendor/git-subrepo/test/repo/init/objects/4b/6e53022e7a04f07887697e4f3d7c377fd9822b +0 -0
  175. data/vendor/git-subrepo/test/repo/init/objects/58/931fc1bd559b59c41ea738fc7ad04f9ad01bd3 +0 -0
  176. data/vendor/git-subrepo/test/repo/init/objects/5e/c0c28e1b806f25efdca18fcf7a74b49c3755bd +0 -0
  177. data/vendor/git-subrepo/test/repo/init/objects/75/fa6584e748f57eff06eebdc55e9ac21d4fcbf2 +1 -0
  178. data/vendor/git-subrepo/test/repo/init/objects/80/2d5edbd5e1cb7fca82b5bd38e7c8a0a496fb20 +0 -0
  179. data/vendor/git-subrepo/test/repo/init/objects/94/7b3d714c38791e95ad6f928b48c98bb8708acd +0 -0
  180. data/vendor/git-subrepo/test/repo/init/objects/95/e1f2df3f4d5f3d7a60588c25a7ca8a913d3c2a +1 -0
  181. data/vendor/git-subrepo/test/repo/init/objects/b1/5f4a7666baf40d949548ead946a3370e273479 +0 -0
  182. data/vendor/git-subrepo/test/repo/init/objects/c3/ee8978c4c5d84c3b7d00ba8e5906933d027882 +0 -0
  183. data/vendor/git-subrepo/test/repo/init/objects/c8/b0bffbc405ef3fad7354ff833fbec36d67ddfa +3 -0
  184. data/vendor/git-subrepo/test/repo/init/objects/dd/8bdb934ec848137f011fe423b185505c343626 +2 -0
  185. data/vendor/git-subrepo/test/repo/init/objects/e2/9be58c767cfeb27235c995d293a7d71aac0135 +2 -0
  186. data/vendor/git-subrepo/test/repo/init/objects/ee/1224401fc6aac595145fa727dcf6706ac8aec1 +1 -0
  187. data/vendor/git-subrepo/test/repo/init/objects/f1/cc1a657b2e805c400f5dcaaa76bd29c6178b1b +0 -0
  188. data/vendor/git-subrepo/test/repo/init/refs/heads/master +1 -0
  189. data/vendor/git-subrepo/test/setup +205 -0
  190. data/vendor/git-subrepo/test/status.t +68 -0
  191. data/vendor/git-subrepo/test/submodule.t +45 -0
  192. metadata +190 -4
@@ -0,0 +1,64 @@
1
+ #!/usr/bin/env bash
2
+
3
+ set -e
4
+
5
+ source test/setup
6
+
7
+ use Test::More
8
+
9
+ git clone $UPSTREAM/init $OWNER/init &>/dev/null
10
+
11
+ gitrepo=$OWNER/init/doc/.gitrepo
12
+
13
+ # Test that the initial repo look ok:
14
+ {
15
+ test-exists \
16
+ "$OWNER/init/.git/" \
17
+ "$OWNER/init/ReadMe" \
18
+ "$OWNER/init/doc/" \
19
+ "$OWNER/init/doc/init.swim" \
20
+ "!$gitrepo"
21
+ }
22
+
23
+ output="$(
24
+ cd "$OWNER/init"
25
+ git subrepo init doc
26
+ )"
27
+
28
+ is "$output" "Subrepo created from 'doc' (with no remote)." \
29
+ 'Command output is correct'
30
+
31
+ {
32
+ test-exists \
33
+ "$gitrepo"
34
+ }
35
+
36
+ # Test init/doc/.gitrepo file contents:
37
+ {
38
+ init_clone_commit="$(cd $OWNER/init; git rev-parse HEAD^)"
39
+ test-gitrepo-comment-block
40
+ test-gitrepo-field "remote" "none"
41
+ test-gitrepo-field "branch" "master"
42
+ test-gitrepo-field "commit" ""
43
+ test-gitrepo-field "parent" ""
44
+ test-gitrepo-field "method" "merge"
45
+ test-gitrepo-field "cmdver" "`git subrepo --version`"
46
+ }
47
+
48
+ rm -fr "$OWNER/init"
49
+ git clone $UPSTREAM/init $OWNER/init &>/dev/null
50
+ (
51
+ cd "$OWNER/init"
52
+ git subrepo init doc -r git@github.com:user/repo -b foo -M rebase
53
+ ) >/dev/null
54
+
55
+ test-gitrepo-field "remote" "git@github.com:user/repo"
56
+ test-gitrepo-field "branch" "foo"
57
+ test-gitrepo-field "commit" ""
58
+ test-gitrepo-field "parent" ""
59
+ test-gitrepo-field "method" "rebase"
60
+ test-gitrepo-field "cmdver" "`git subrepo --version`"
61
+
62
+ done_testing
63
+
64
+ teardown
@@ -0,0 +1,98 @@
1
+ #!/usr/bin/env bash
2
+
3
+ set -e
4
+
5
+ source test/setup
6
+
7
+ use Test::More
8
+
9
+ # if [[ $1 == ReRun ]]; then
10
+ # set -x
11
+ # else
12
+ # "$0" ReRun 2>&1 | tee log
13
+ # exit 0
14
+ # fi
15
+
16
+ cd "$TMP"
17
+
18
+ # Make 3 new repos:
19
+ (
20
+ mkdir share main1 main2
21
+ git init share
22
+ git init main1
23
+ git init main2
24
+ ) > /dev/null
25
+
26
+ # Add an empty 'readme' to the share repo:
27
+ (
28
+ cd share
29
+ echo '* text eol=lf' > .gitattributes
30
+ touch readme
31
+ git add readme .gitattributes
32
+ git commit -m "Initial share"
33
+ # To push into here later we must not have working copy on master branch:
34
+ git checkout -b temp
35
+ ) &> /dev/null
36
+
37
+ # `subrepo clone` the share repo into main1:
38
+ (
39
+ cd main1
40
+ touch main1
41
+ git add main1
42
+ git commit -m "Initial main1"
43
+ git subrepo clone ../share share -b master
44
+ ) > /dev/null
45
+
46
+ # `subrepo clone` the share repo into main2:
47
+ (
48
+ cd main2
49
+ touch main2
50
+ git add main2
51
+ git commit -m "Initial main2"
52
+ git subrepo clone ../share share -b master
53
+ ) > /dev/null
54
+
55
+
56
+ # Make a change to the main1 subrepo and push it:
57
+ msg_main1="main1 initial add to subrepo"
58
+ ( set -x
59
+ cd main1
60
+ echo "$msg_main1" >> share/readme
61
+ git add share/readme
62
+ git commit -m "$msg_main1"
63
+
64
+ git subrepo push share
65
+ ) &> /dev/null
66
+
67
+ ok "`! git:branch-exists "subrepo-push/share"`" \
68
+ "The subrepo-push/share branch was deleted after push"
69
+
70
+ # TODO Check the state of refs made
71
+
72
+ # Pull in the subrepo changes from above into main2.
73
+ # Make a local change to the main2 subrepo and push it:
74
+ msg_main2="main2 initial add to subrepo"
75
+ ( set -x
76
+ cd main2
77
+ git subrepo pull share
78
+ echo "$msg_main2" >> share/readme
79
+ git add share/readme
80
+ git commit -m "$msg_main2"
81
+
82
+ git subrepo push share
83
+ ) &> /dev/null || die
84
+
85
+ # Go back into main1 and pull the subrepo updates:
86
+ ( set -x
87
+ cd main1
88
+ git subrepo pull share
89
+ ) &> /dev/null || die
90
+
91
+ # The readme file should have both changes:
92
+ is "$(cat main1/share/readme)" \
93
+ "$msg_main1"$'\n'"$msg_main2" \
94
+ "The readme file in the share repo has both subrepo commits"
95
+
96
+ done_testing
97
+
98
+ teardown
@@ -0,0 +1,98 @@
1
+ #!/usr/bin/env bash
2
+
3
+ set -e
4
+
5
+ source test/setup
6
+
7
+ use Test::More
8
+
9
+ {
10
+ cd "$TMP"
11
+
12
+ # Make two new repos
13
+ (
14
+ mkdir host sub
15
+ git init host
16
+ git init sub
17
+ ) > /dev/null
18
+
19
+ # Initialize host repo
20
+ (
21
+ cd host
22
+ touch host
23
+ git add host
24
+ git commit -m "host initial commit"
25
+ ) > /dev/null
26
+
27
+ # Initialize sub repo
28
+ (
29
+ cd sub
30
+ git init
31
+ touch subrepo
32
+ git add subrepo
33
+ git commit -m "subrepo initial commit"
34
+ ) > /dev/null
35
+
36
+ # Make sub a subrepo of host
37
+ (
38
+ cd host
39
+ git subrepo clone ../sub sub
40
+ ) > /dev/null
41
+
42
+ # Create a branch in host and make some changes in it
43
+ (
44
+ cd host
45
+ git checkout -b feature
46
+ touch feature
47
+ git add feature
48
+ git commit -m "feature added"
49
+ git checkout master
50
+ ) &> /dev/null
51
+
52
+ # Commit directly to subrepo
53
+ (
54
+ cd sub
55
+ echo "direct change in sub" >> subrepo
56
+ git commit -a -m "direct change in sub"
57
+ ) > /dev/null
58
+
59
+ # pull subrepo changes
60
+ (
61
+ cd host
62
+ git subrepo pull sub
63
+ ) > /dev/null
64
+
65
+ # commit directly to subrepo
66
+ (
67
+ cd sub
68
+ echo "another direct change in sub" >> subrepo
69
+ git commit -a -m "another direct change in sub"
70
+ ) > /dev/null
71
+
72
+ # commit to host/sub
73
+ (
74
+ cd host
75
+ echo "change from host" >> sub/subrepo-host
76
+ git add sub/subrepo-host
77
+ git commit -m "change from host"
78
+ ) > /dev/null
79
+
80
+ # merge previously created feature branch
81
+ (
82
+ cd host
83
+ git merge --no-ff --no-edit feature
84
+ ) > /dev/null
85
+
86
+ # pull subrepo changes
87
+ # expected: successful pull without conflicts
88
+ is "$(
89
+ cd host
90
+ git subrepo pull sub
91
+ )" \
92
+ "Subrepo 'sub' pulled from '../sub' (master)."
93
+
94
+ }
95
+
96
+ done_testing 1
97
+
98
+ teardown
@@ -0,0 +1,96 @@
1
+ #!/usr/bin/env bash
2
+
3
+ set -e
4
+
5
+ source test/setup
6
+
7
+ use Test::More
8
+
9
+ cd "$TMP"
10
+
11
+ # Make two new repos
12
+ (
13
+ mkdir host sub
14
+ git init host
15
+ git init sub
16
+ ) > /dev/null
17
+
18
+ # Initialize host repo
19
+ (
20
+ cd host
21
+ touch host
22
+ git add host
23
+ git commit -m "host initial commit"
24
+ ) > /dev/null
25
+
26
+ # Initialize sub repo
27
+ (
28
+ cd sub
29
+ git init
30
+ touch subrepo
31
+ git add subrepo
32
+ git commit -m "subrepo initial commit"
33
+ ) > /dev/null
34
+
35
+ # Make sub a subrepo of host
36
+ (
37
+ cd host
38
+ git subrepo clone ../sub sub
39
+ ) > /dev/null
40
+
41
+ # Commit some changes to the host repo
42
+ (
43
+ cd host
44
+ touch feature
45
+ git add feature
46
+ git commit -m "feature added"
47
+ ) &> /dev/null
48
+
49
+ # Commit directly to subrepo
50
+ (
51
+ cd sub
52
+ echo "direct change in sub" >> subrepo
53
+ git commit -a -m "direct change in sub"
54
+ ) > /dev/null
55
+
56
+ # Pull subrepo changes
57
+ (
58
+ cd host
59
+ git subrepo pull sub
60
+ ) > /dev/null
61
+
62
+ # Commit directly to subrepo
63
+ (
64
+ cd sub
65
+ echo "another direct change in sub" >> subrepo
66
+ git commit -a -m "another direct change in sub"
67
+ git checkout -b temp # otherwise push to master will fail
68
+ ) &> /dev/null
69
+
70
+ # Commit to host/sub
71
+ (
72
+ cd host
73
+ echo "change from host" >> sub/subrepo-host
74
+ git add sub/subrepo-host
75
+ git commit -m "change from host"
76
+ ) > /dev/null
77
+
78
+ # Pull subrepo changes
79
+ # expected: successful pull without conflicts
80
+ is "$(
81
+ cd host
82
+ git subrepo pull sub
83
+ )" \
84
+ "Subrepo 'sub' pulled from '../sub' (master)."
85
+
86
+ # Push subrepo changes
87
+ # expected: successful push without conflicts
88
+ is "$(
89
+ cd host
90
+ git subrepo push sub -b master -u
91
+ )" \
92
+ "Subrepo 'sub' pushed to '../sub' (master)."
93
+
94
+ done_testing 2
95
+
96
+ teardown
@@ -0,0 +1,38 @@
1
+ #!/usr/bin/env bash
2
+
3
+ set -e
4
+
5
+ source test/setup
6
+
7
+ use Test::More
8
+
9
+ clone-foo-and-bar
10
+
11
+ (
12
+ cd $OWNER/foo
13
+ git subrepo clone ../bar bar1
14
+ git subrepo clone ../bar bar2
15
+ ) &> /dev/null || die
16
+
17
+ (
18
+ cd $OWNER/bar
19
+ modify-files Bar
20
+ ) &> /dev/null || die
21
+
22
+ (
23
+ cd $OWNER/foo
24
+ git subrepo pull --all
25
+ ) &> /dev/null || die
26
+
27
+ {
28
+ is "$(cat $OWNER/foo/bar1/Bar)" \
29
+ "a new line" \
30
+ 'bar1/Bar content correct'
31
+ is "$(cat $OWNER/foo/bar2/Bar)" \
32
+ "a new line" \
33
+ 'bar2/Bar content correct'
34
+ }
35
+
36
+ done_testing
37
+
38
+ teardown
@@ -0,0 +1,113 @@
1
+ #!/usr/bin/env bash
2
+
3
+ set -e
4
+
5
+ source test/setup
6
+
7
+ use Test::More
8
+
9
+ clone-foo-and-bar
10
+
11
+ subrepo-clone-bar-into-foo
12
+
13
+ note "Pull - Conflict - Merge ours/theirs - Push"
14
+
15
+ (
16
+ cd $OWNER/bar
17
+ add-new-files Bar2
18
+ git push
19
+ ) &> /dev/null || die
20
+
21
+ gitrepo=$OWNER/foo/bar/.gitrepo
22
+ # Test foo/bar/.gitrepo file contents:
23
+ {
24
+ foo_pull_commit="$(cd $OWNER/foo; git rev-parse HEAD^)"
25
+ bar_head_commit="$(cd $OWNER/bar; git rev-parse HEAD^)"
26
+ test-gitrepo-field "commit" "$bar_head_commit"
27
+ test-gitrepo-field "parent" "$foo_pull_commit"
28
+ }
29
+
30
+ foo_pull_commit="$(cd $OWNER/foo; git rev-parse HEAD)"
31
+
32
+ (
33
+ cd $OWNER/foo
34
+ git subrepo pull bar
35
+ modify-files-ex bar/Bar2
36
+ git push
37
+ ) &> /dev/null || die
38
+
39
+ (
40
+ cd $OWNER/bar
41
+ modify-files-ex Bar2
42
+ git push
43
+ ) &> /dev/null || die
44
+
45
+ (
46
+ cd $OWNER/foo
47
+ git subrepo pull bar || {
48
+ cd .git/tmp/subrepo/bar
49
+ echo "Merged Bar2" > Bar2
50
+ git add Bar2
51
+ git commit --file ../../../../.git/worktrees/bar/MERGE_MSG
52
+ cd ../../../..
53
+ git subrepo commit bar
54
+ git subrepo clean bar
55
+ }
56
+ ) &> /dev/null || die
57
+
58
+ test-exists \
59
+ "$OWNER/foo/bar/Bar2" \
60
+ "$OWNER/bar/Bar2" \
61
+
62
+ is "$(cat $OWNER/foo/bar/Bar2)" \
63
+ "Merged Bar2" \
64
+ "The readme file in the mainrepo is merged"
65
+
66
+ # Check commit messages
67
+ {
68
+ foo_new_commit_message="$(cd $OWNER/foo; git log --format=%B -n 1)"
69
+ like "$foo_new_commit_message" \
70
+ "git subrepo commit \(merge\) bar" \
71
+ "subrepo pull should have merge message"
72
+ }
73
+
74
+ # Test foo/bar/.gitrepo file contents:
75
+ {
76
+ bar_head_commit="$(cd $OWNER/bar; git rev-parse HEAD)"
77
+ test-gitrepo-field "commit" "$bar_head_commit"
78
+ test-gitrepo-field "parent" "$foo_pull_commit"
79
+ }
80
+
81
+ (
82
+ cd $OWNER/foo
83
+ git subrepo push bar
84
+ ) &> /dev/null || die
85
+
86
+ # Check commit messages
87
+ {
88
+ foo_new_commit_message="$(cd $OWNER/foo; git log --format=%B -n 1)"
89
+ like "$foo_new_commit_message" \
90
+ "git subrepo push bar" \
91
+ "subrepo push should not have merge message"
92
+ }
93
+
94
+ (
95
+ cd $OWNER/bar
96
+ git pull
97
+ ) &> /dev/null || die
98
+
99
+ test-exists \
100
+ "$OWNER/foo/bar/Bar2" \
101
+ "$OWNER/bar/Bar2" \
102
+
103
+ is "$(cat $OWNER/foo/bar/Bar2)" \
104
+ "Merged Bar2" \
105
+ "The readme file in the mainrepo is merged"
106
+
107
+ is "$(cat $OWNER/bar/Bar2)" \
108
+ "Merged Bar2" \
109
+ "The readme file in the subrepo is merged"
110
+
111
+ done_testing
112
+
113
+ teardown