You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

CleanCommandTest.java 10KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299
  1. /*
  2. * Copyright (C) 2011, Abhishek Bhatnagar <abhatnag@redhat.com>
  3. * and other copyright owners as documented in the project's IP log.
  4. *
  5. * This program and the accompanying materials are made available
  6. * under the terms of the Eclipse Distribution License v1.0 which
  7. * accompanies this distribution, is reproduced below, and is
  8. * available at http://www.eclipse.org/org/documents/edl-v10.php
  9. *
  10. * All rights reserved.
  11. *
  12. * Redistribution and use in source and binary forms, with or
  13. * without modification, are permitted provided that the following
  14. * conditions are met:
  15. *
  16. * - Redistributions of source code must retain the above copyright
  17. * notice, this list of conditions and the following disclaimer.
  18. *
  19. * - Redistributions in binary form must reproduce the above
  20. * copyright notice, this list of conditions and the following
  21. * disclaimer in the documentation and/or other materials provided
  22. * with the distribution.
  23. *
  24. * - Neither the name of the Eclipse Foundation, Inc. nor the
  25. * names of its contributors may be used to endorse or promote
  26. * products derived from this software without specific prior
  27. * written permission.
  28. *
  29. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND
  30. * CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
  31. * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
  32. * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  33. * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
  34. * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  35. * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
  36. * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
  37. * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
  38. * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
  39. * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
  40. * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
  41. * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  42. */
  43. package org.eclipse.jgit.api;
  44. import static org.eclipse.jgit.lib.Constants.DOT_GIT_MODULES;
  45. import static org.junit.Assert.assertEquals;
  46. import static org.junit.Assert.assertFalse;
  47. import static org.junit.Assert.assertTrue;
  48. import java.io.File;
  49. import java.util.Set;
  50. import java.util.TreeSet;
  51. import org.eclipse.jgit.api.errors.GitAPIException;
  52. import org.eclipse.jgit.errors.NoWorkTreeException;
  53. import org.eclipse.jgit.junit.RepositoryTestCase;
  54. import org.eclipse.jgit.lib.Repository;
  55. import org.junit.Before;
  56. import org.junit.Test;
  57. /**
  58. * Tests for CleanCommand
  59. */
  60. public class CleanCommandTest extends RepositoryTestCase {
  61. private Git git;
  62. @Override
  63. @Before
  64. public void setUp() throws Exception {
  65. super.setUp();
  66. git = new Git(db);
  67. // create test files
  68. writeTrashFile("File1.txt", "Hello world");
  69. writeTrashFile("File2.txt", "Delete Me");
  70. writeTrashFile("File3.txt", "Delete Me");
  71. // create files in sub-directories.
  72. writeTrashFile("sub-noclean/File1.txt", "Hello world");
  73. writeTrashFile("sub-noclean/File2.txt", "Delete Me");
  74. writeTrashFile("sub-clean/File4.txt", "Delete Me");
  75. writeTrashFile("sub-noclean/Ignored.txt", "Ignored");
  76. writeTrashFile(".gitignore", "/ignored-dir\n/sub-noclean/Ignored.txt");
  77. writeTrashFile("ignored-dir/Ignored2.txt", "Ignored");
  78. // add and commit first file
  79. git.add().addFilepattern("File1.txt").call();
  80. git.add().addFilepattern("sub-noclean/File1.txt").call();
  81. git.add().addFilepattern(".gitignore").call();
  82. git.commit().setMessage("Initial commit").call();
  83. }
  84. @Test
  85. public void testClean() throws NoWorkTreeException, GitAPIException {
  86. // create status
  87. StatusCommand command = git.status();
  88. Status status = command.call();
  89. Set<String> files = status.getUntracked();
  90. assertTrue(files.size() > 0);
  91. // run clean
  92. Set<String> cleanedFiles = git.clean().call();
  93. status = git.status().call();
  94. files = status.getUntracked();
  95. assertTrue(files.size() == 1); // one remains (directories not cleaned)
  96. assertTrue(cleanedFiles.contains("File2.txt"));
  97. assertTrue(cleanedFiles.contains("File3.txt"));
  98. assertTrue(!cleanedFiles.contains("sub-noclean/File1.txt"));
  99. assertTrue(cleanedFiles.contains("sub-noclean/File2.txt"));
  100. assertTrue(!cleanedFiles.contains("sub-clean/File4.txt"));
  101. }
  102. @Test
  103. public void testCleanDirs() throws NoWorkTreeException, GitAPIException {
  104. // create status
  105. StatusCommand command = git.status();
  106. Status status = command.call();
  107. Set<String> files = status.getUntracked();
  108. assertTrue(files.size() > 0);
  109. // run clean
  110. Set<String> cleanedFiles = git.clean().setCleanDirectories(true).call();
  111. status = git.status().call();
  112. files = status.getUntracked();
  113. assertTrue(files.size() == 0);
  114. assertTrue(cleanedFiles.contains("File2.txt"));
  115. assertTrue(cleanedFiles.contains("File3.txt"));
  116. assertTrue(!cleanedFiles.contains("sub-noclean/File1.txt"));
  117. assertTrue(cleanedFiles.contains("sub-noclean/File2.txt"));
  118. assertTrue(cleanedFiles.contains("sub-clean/"));
  119. }
  120. @Test
  121. public void testCleanWithPaths() throws NoWorkTreeException,
  122. GitAPIException {
  123. // create status
  124. StatusCommand command = git.status();
  125. Status status = command.call();
  126. Set<String> files = status.getUntracked();
  127. assertTrue(files.size() > 0);
  128. // run clean with setPaths
  129. Set<String> paths = new TreeSet<>();
  130. paths.add("File3.txt");
  131. Set<String> cleanedFiles = git.clean().setPaths(paths).call();
  132. status = git.status().call();
  133. files = status.getUntracked();
  134. assertTrue(files.size() == 3);
  135. assertTrue(cleanedFiles.contains("File3.txt"));
  136. assertFalse(cleanedFiles.contains("File2.txt"));
  137. }
  138. @Test
  139. public void testCleanWithDryRun() throws NoWorkTreeException,
  140. GitAPIException {
  141. // create status
  142. StatusCommand command = git.status();
  143. Status status = command.call();
  144. Set<String> files = status.getUntracked();
  145. assertTrue(files.size() > 0);
  146. // run clean
  147. Set<String> cleanedFiles = git.clean().setDryRun(true).call();
  148. status = git.status().call();
  149. files = status.getUntracked();
  150. assertEquals(4, files.size());
  151. assertTrue(cleanedFiles.contains("File2.txt"));
  152. assertTrue(cleanedFiles.contains("File3.txt"));
  153. assertTrue(!cleanedFiles.contains("sub-noclean/File1.txt"));
  154. assertTrue(cleanedFiles.contains("sub-noclean/File2.txt"));
  155. }
  156. @Test
  157. public void testCleanDirsWithDryRun() throws NoWorkTreeException,
  158. GitAPIException {
  159. // create status
  160. StatusCommand command = git.status();
  161. Status status = command.call();
  162. Set<String> files = status.getUntracked();
  163. assertTrue(files.size() > 0);
  164. // run clean
  165. Set<String> cleanedFiles = git.clean().setDryRun(true)
  166. .setCleanDirectories(true).call();
  167. status = git.status().call();
  168. files = status.getUntracked();
  169. assertTrue(files.size() == 4);
  170. assertTrue(cleanedFiles.contains("File2.txt"));
  171. assertTrue(cleanedFiles.contains("File3.txt"));
  172. assertTrue(!cleanedFiles.contains("sub-noclean/File1.txt"));
  173. assertTrue(cleanedFiles.contains("sub-noclean/File2.txt"));
  174. assertTrue(cleanedFiles.contains("sub-clean/"));
  175. }
  176. @Test
  177. public void testCleanWithDryRunAndNoIgnore() throws NoWorkTreeException,
  178. GitAPIException {
  179. // run clean
  180. Set<String> cleanedFiles = git.clean().setDryRun(true).setIgnore(false)
  181. .call();
  182. Status status = git.status().call();
  183. Set<String> files = status.getIgnoredNotInIndex();
  184. assertTrue(files.size() == 2);
  185. assertTrue(cleanedFiles.contains("sub-noclean/Ignored.txt"));
  186. assertTrue(!cleanedFiles.contains("ignored-dir/"));
  187. }
  188. @Test
  189. public void testCleanDirsWithDryRunAndNoIgnore()
  190. throws NoWorkTreeException, GitAPIException {
  191. // run clean
  192. Set<String> cleanedFiles = git.clean().setDryRun(true).setIgnore(false)
  193. .setCleanDirectories(true).call();
  194. Status status = git.status().call();
  195. Set<String> files = status.getIgnoredNotInIndex();
  196. assertTrue(files.size() == 2);
  197. assertTrue(cleanedFiles.contains("sub-noclean/Ignored.txt"));
  198. assertTrue(cleanedFiles.contains("ignored-dir/"));
  199. }
  200. @Test
  201. public void testCleanDirsWithSubmodule() throws Exception {
  202. SubmoduleAddCommand command = new SubmoduleAddCommand(db);
  203. String path = "sub";
  204. command.setPath(path);
  205. String uri = db.getDirectory().toURI().toString();
  206. command.setURI(uri);
  207. Repository repo = command.call();
  208. repo.close();
  209. Status beforeCleanStatus = git.status().call();
  210. assertTrue(beforeCleanStatus.getAdded().contains(DOT_GIT_MODULES));
  211. assertTrue(beforeCleanStatus.getAdded().contains(path));
  212. Set<String> cleanedFiles = git.clean().setCleanDirectories(true).call();
  213. // The submodule should not be cleaned.
  214. assertTrue(!cleanedFiles.contains(path + "/"));
  215. assertTrue(cleanedFiles.contains("File2.txt"));
  216. assertTrue(cleanedFiles.contains("File3.txt"));
  217. assertTrue(!cleanedFiles.contains("sub-noclean/File1.txt"));
  218. assertTrue(cleanedFiles.contains("sub-noclean/File2.txt"));
  219. assertTrue(cleanedFiles.contains("sub-clean/"));
  220. assertTrue(cleanedFiles.size() == 4);
  221. }
  222. @Test
  223. public void testCleanDirsWithRepository() throws Exception {
  224. // Set up a repository inside the outer repository
  225. String innerRepoName = "inner-repo";
  226. File innerDir = new File(trash, innerRepoName);
  227. innerDir.mkdir();
  228. InitCommand initRepoCommand = new InitCommand();
  229. initRepoCommand.setDirectory(innerDir);
  230. initRepoCommand.call();
  231. Status beforeCleanStatus = git.status().call();
  232. Set<String> untrackedFolders = beforeCleanStatus.getUntrackedFolders();
  233. Set<String> untrackedFiles = beforeCleanStatus.getUntracked();
  234. // The inner repository should be listed as an untracked file
  235. assertTrue(untrackedFiles.contains(innerRepoName));
  236. // The inner repository should not be listed as an untracked folder
  237. assertTrue(!untrackedFolders.contains(innerRepoName));
  238. Set<String> cleanedFiles = git.clean().setCleanDirectories(true).call();
  239. // The inner repository should not be cleaned.
  240. assertTrue(!cleanedFiles.contains(innerRepoName + "/"));
  241. assertTrue(cleanedFiles.contains("File2.txt"));
  242. assertTrue(cleanedFiles.contains("File3.txt"));
  243. assertTrue(!cleanedFiles.contains("sub-noclean/File1.txt"));
  244. assertTrue(cleanedFiles.contains("sub-noclean/File2.txt"));
  245. assertTrue(cleanedFiles.contains("sub-clean/"));
  246. assertTrue(cleanedFiles.size() == 4);
  247. Set<String> forceCleanedFiles = git.clean().setCleanDirectories(true)
  248. .setForce(true).call();
  249. // The inner repository should be cleaned this time
  250. assertTrue(forceCleanedFiles.contains(innerRepoName + "/"));
  251. }
  252. }