Nelze vybrat více než 25 témat Téma musí začínat písmenem nebo číslem, může obsahovat pomlčky („-“) a může být dlouhé až 35 znaků.

DirCacheFindTest.java 2.3KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. /*
  2. * Copyright (C) 2008-2009, Google Inc. and others
  3. *
  4. * This program and the accompanying materials are made available under the
  5. * terms of the Eclipse Distribution License v. 1.0 which is available at
  6. * https://www.eclipse.org/org/documents/edl-v10.php.
  7. *
  8. * SPDX-License-Identifier: BSD-3-Clause
  9. */
  10. package org.eclipse.jgit.dircache;
  11. import static org.junit.Assert.assertEquals;
  12. import static org.junit.Assert.assertNotNull;
  13. import static org.junit.Assert.assertSame;
  14. import org.eclipse.jgit.junit.RepositoryTestCase;
  15. import org.eclipse.jgit.lib.FileMode;
  16. import org.junit.Test;
  17. public class DirCacheFindTest extends RepositoryTestCase {
  18. @Test
  19. public void testEntriesWithin() throws Exception {
  20. final DirCache dc = db.readDirCache();
  21. final String[] paths = { "a-", "a/b", "a/c", "a/d", "a0b" };
  22. final DirCacheEntry[] ents = new DirCacheEntry[paths.length];
  23. for (int i = 0; i < paths.length; i++) {
  24. ents[i] = new DirCacheEntry(paths[i]);
  25. ents[i].setFileMode(FileMode.REGULAR_FILE);
  26. }
  27. final int aFirst = 1;
  28. final int aLast = 3;
  29. final DirCacheBuilder b = dc.builder();
  30. for (DirCacheEntry ent : ents) {
  31. b.add(ent);
  32. }
  33. b.finish();
  34. assertEquals(paths.length, dc.getEntryCount());
  35. for (int i = 0; i < ents.length; i++)
  36. assertSame(ents[i], dc.getEntry(i));
  37. {
  38. final DirCacheEntry[] aContents = dc.getEntriesWithin("a");
  39. assertNotNull(aContents);
  40. assertEquals(aLast - aFirst + 1, aContents.length);
  41. for (int i = aFirst, j = 0; i <= aLast; i++, j++)
  42. assertSame(ents[i], aContents[j]);
  43. }
  44. {
  45. final DirCacheEntry[] aContents = dc.getEntriesWithin("a/");
  46. assertNotNull(aContents);
  47. assertEquals(aLast - aFirst + 1, aContents.length);
  48. for (int i = aFirst, j = 0; i <= aLast; i++, j++)
  49. assertSame(ents[i], aContents[j]);
  50. }
  51. {
  52. final DirCacheEntry[] aContents = dc.getEntriesWithin("");
  53. assertNotNull(aContents);
  54. assertEquals(ents.length, aContents.length);
  55. for (int i = 0; i < ents.length; i++)
  56. assertSame(ents[i], aContents[i]);
  57. }
  58. assertNotNull(dc.getEntriesWithin("a-"));
  59. assertEquals(0, dc.getEntriesWithin("a-").length);
  60. assertNotNull(dc.getEntriesWithin("a0b"));
  61. assertEquals(0, dc.getEntriesWithin("a0b-").length);
  62. assertNotNull(dc.getEntriesWithin("zoo"));
  63. assertEquals(0, dc.getEntriesWithin("zoo-").length);
  64. }
  65. }