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.

AbstractTreeIteratorTest.java 6.1KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182
  1. /*
  2. * Copyright (C) 2009, Google Inc.
  3. * Copyright (C) 2009, Tor Arne Vestbø <torarnv@gmail.com>
  4. * and other copyright owners as documented in the project's IP log.
  5. *
  6. * This program and the accompanying materials are made available
  7. * under the terms of the Eclipse Distribution License v1.0 which
  8. * accompanies this distribution, is reproduced below, and is
  9. * available at http://www.eclipse.org/org/documents/edl-v10.php
  10. *
  11. * All rights reserved.
  12. *
  13. * Redistribution and use in source and binary forms, with or
  14. * without modification, are permitted provided that the following
  15. * conditions are met:
  16. *
  17. * - Redistributions of source code must retain the above copyright
  18. * notice, this list of conditions and the following disclaimer.
  19. *
  20. * - Redistributions in binary form must reproduce the above
  21. * copyright notice, this list of conditions and the following
  22. * disclaimer in the documentation and/or other materials provided
  23. * with the distribution.
  24. *
  25. * - Neither the name of the Eclipse Foundation, Inc. nor the
  26. * names of its contributors may be used to endorse or promote
  27. * products derived from this software without specific prior
  28. * written permission.
  29. *
  30. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND
  31. * CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
  32. * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
  33. * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  34. * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
  35. * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  36. * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
  37. * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
  38. * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
  39. * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
  40. * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
  41. * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
  42. * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  43. */
  44. package org.eclipse.jgit.treewalk;
  45. import static org.junit.Assert.assertEquals;
  46. import static org.junit.Assert.assertNotNull;
  47. import static org.junit.Assert.assertNotSame;
  48. import static org.junit.Assert.assertSame;
  49. import static org.junit.Assert.assertTrue;
  50. import java.io.IOException;
  51. import org.eclipse.jgit.errors.IncorrectObjectTypeException;
  52. import org.eclipse.jgit.lib.Config;
  53. import org.eclipse.jgit.lib.Constants;
  54. import org.eclipse.jgit.lib.FileMode;
  55. import org.eclipse.jgit.lib.ObjectReader;
  56. import org.junit.Test;
  57. public class AbstractTreeIteratorTest {
  58. private static String prefix(String path) {
  59. final int s = path.lastIndexOf('/');
  60. return s > 0 ? path.substring(0, s) : "";
  61. }
  62. public class FakeTreeIterator extends WorkingTreeIterator {
  63. public FakeTreeIterator(String pathName, FileMode fileMode) {
  64. super(prefix(pathName), new Config().get(WorkingTreeOptions.KEY));
  65. mode = fileMode.getBits();
  66. final int s = pathName.lastIndexOf('/');
  67. final byte[] name = Constants.encode(pathName.substring(s + 1));
  68. ensurePathCapacity(pathOffset + name.length, pathOffset);
  69. System.arraycopy(name, 0, path, pathOffset, name.length);
  70. pathLen = pathOffset + name.length;
  71. }
  72. @Override
  73. public AbstractTreeIterator createSubtreeIterator(ObjectReader reader)
  74. throws IncorrectObjectTypeException, IOException {
  75. return null;
  76. }
  77. }
  78. @Test
  79. public void testPathCompare() throws Exception {
  80. assertTrue(new FakeTreeIterator("a", FileMode.REGULAR_FILE).pathCompare(
  81. new FakeTreeIterator("a", FileMode.TREE)) < 0);
  82. assertTrue(new FakeTreeIterator("a", FileMode.TREE).pathCompare(
  83. new FakeTreeIterator("a", FileMode.REGULAR_FILE)) > 0);
  84. assertTrue(new FakeTreeIterator("a", FileMode.REGULAR_FILE).pathCompare(
  85. new FakeTreeIterator("a", FileMode.REGULAR_FILE)) == 0);
  86. assertTrue(new FakeTreeIterator("a", FileMode.TREE).pathCompare(
  87. new FakeTreeIterator("a", FileMode.TREE)) == 0);
  88. }
  89. @Test
  90. public void testGrowPath() throws Exception {
  91. final FakeTreeIterator i = new FakeTreeIterator("ab", FileMode.TREE);
  92. final byte[] origpath = i.path;
  93. assertEquals(i.path[0], 'a');
  94. assertEquals(i.path[1], 'b');
  95. i.growPath(2);
  96. assertNotSame(origpath, i.path);
  97. assertEquals(origpath.length * 2, i.path.length);
  98. assertEquals(i.path[0], 'a');
  99. assertEquals(i.path[1], 'b');
  100. }
  101. @Test
  102. public void testEnsurePathCapacityFastCase() throws Exception {
  103. final FakeTreeIterator i = new FakeTreeIterator("ab", FileMode.TREE);
  104. final int want = 50;
  105. final byte[] origpath = i.path;
  106. assertEquals(i.path[0], 'a');
  107. assertEquals(i.path[1], 'b');
  108. assertTrue(want < i.path.length);
  109. i.ensurePathCapacity(want, 2);
  110. assertSame(origpath, i.path);
  111. assertEquals(i.path[0], 'a');
  112. assertEquals(i.path[1], 'b');
  113. }
  114. @Test
  115. public void testEnsurePathCapacityGrows() throws Exception {
  116. final FakeTreeIterator i = new FakeTreeIterator("ab", FileMode.TREE);
  117. final int want = 384;
  118. final byte[] origpath = i.path;
  119. assertEquals(i.path[0], 'a');
  120. assertEquals(i.path[1], 'b');
  121. assertTrue(i.path.length < want);
  122. i.ensurePathCapacity(want, 2);
  123. assertNotSame(origpath, i.path);
  124. assertEquals(512, i.path.length);
  125. assertEquals(i.path[0], 'a');
  126. assertEquals(i.path[1], 'b');
  127. }
  128. @Test
  129. public void testEntryFileMode() {
  130. for (FileMode m : new FileMode[] { FileMode.TREE,
  131. FileMode.REGULAR_FILE, FileMode.EXECUTABLE_FILE,
  132. FileMode.GITLINK, FileMode.SYMLINK }) {
  133. final FakeTreeIterator i = new FakeTreeIterator("a", m);
  134. assertEquals(m.getBits(), i.getEntryRawMode());
  135. assertSame(m, i.getEntryFileMode());
  136. }
  137. }
  138. @Test
  139. public void testEntryPath() {
  140. FakeTreeIterator i = new FakeTreeIterator("a/b/cd", FileMode.TREE);
  141. assertEquals("a/b/cd", i.getEntryPathString());
  142. assertEquals(2, i.getNameLength());
  143. byte[] b = new byte[3];
  144. b[0] = 0x0a;
  145. i.getName(b, 1);
  146. assertEquals(0x0a, b[0]);
  147. assertEquals('c', b[1]);
  148. assertEquals('d', b[2]);
  149. }
  150. @Test
  151. public void testCreateEmptyTreeIterator() {
  152. FakeTreeIterator i = new FakeTreeIterator("a/b/cd", FileMode.TREE);
  153. EmptyTreeIterator e = i.createEmptyTreeIterator();
  154. assertNotNull(e);
  155. assertEquals(i.getEntryPathString() + "/", e.getEntryPathString());
  156. }
  157. }