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.

HistogramDiffTest.java 3.1KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. /*
  2. * Copyright (C) 2010, 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.diff;
  11. import static org.junit.Assert.assertEquals;
  12. import org.junit.Test;
  13. public class HistogramDiffTest extends AbstractDiffTestCase {
  14. @Override
  15. protected HistogramDiff algorithm() {
  16. HistogramDiff hd = new HistogramDiff();
  17. hd.setFallbackAlgorithm(null);
  18. return hd;
  19. }
  20. @Test
  21. public void testEdit_NoUniqueMiddleSide_FlipBlocks() {
  22. EditList r = diff(t("aRRSSz"), t("aSSRRz"));
  23. assertEquals(2, r.size());
  24. assertEquals(new Edit(1, 3, 1, 1), r.get(0)); // DELETE "RR"
  25. assertEquals(new Edit(5, 5, 3, 5), r.get(1)); // INSERT "RR
  26. }
  27. @Test
  28. public void testEdit_NoUniqueMiddleSide_Insert2() {
  29. EditList r = diff(t("aRSz"), t("aRRSSz"));
  30. assertEquals(1, r.size());
  31. assertEquals(new Edit(2, 2, 2, 4), r.get(0));
  32. }
  33. @Test
  34. public void testEdit_NoUniqueMiddleSide_FlipAndExpand() {
  35. EditList r = diff(t("aRSz"), t("aSSRRz"));
  36. assertEquals(2, r.size());
  37. assertEquals(new Edit(1, 2, 1, 1), r.get(0)); // DELETE "R"
  38. assertEquals(new Edit(3, 3, 2, 5), r.get(1)); // INSERT "SRR"
  39. }
  40. @Test
  41. public void testEdit_LcsContainsUnique() {
  42. EditList r = diff(t("nqnjrnjsnm"), t("AnqnjrnjsnjTnmZ"));
  43. assertEquals(new Edit(0, 0, 0, 1), r.get(0)); // INSERT "A";
  44. assertEquals(new Edit(9, 9, 10, 13), r.get(1)); // INSERT "jTn";
  45. assertEquals(new Edit(10, 10, 14, 15), r.get(2)); // INSERT "Z";
  46. assertEquals(3, r.size());
  47. }
  48. @Test
  49. public void testExceedsChainLength_DuringScanOfA() {
  50. HistogramDiff hd = new HistogramDiff();
  51. hd.setFallbackAlgorithm(null);
  52. hd.setMaxChainLength(3);
  53. SequenceComparator<RawText> cmp = new SequenceComparator<RawText>() {
  54. @Override
  55. public boolean equals(RawText a, int ai, RawText b, int bi) {
  56. return RawTextComparator.DEFAULT.equals(a, ai, b, bi);
  57. }
  58. @Override
  59. public int hash(RawText a, int ai) {
  60. return 1;
  61. }
  62. };
  63. EditList r = hd.diff(cmp, t("RabS"), t("QabT"));
  64. assertEquals(1, r.size());
  65. assertEquals(new Edit(0, 4, 0, 4), r.get(0));
  66. }
  67. @Test
  68. public void testExceedsChainLength_DuringScanOfB() {
  69. HistogramDiff hd = new HistogramDiff();
  70. hd.setFallbackAlgorithm(null);
  71. hd.setMaxChainLength(1);
  72. EditList r = hd.diff(RawTextComparator.DEFAULT, t("RaaS"), t("QaaT"));
  73. assertEquals(1, r.size());
  74. assertEquals(new Edit(0, 4, 0, 4), r.get(0));
  75. }
  76. @Test
  77. public void testFallbackToMyersDiff() {
  78. HistogramDiff hd = new HistogramDiff();
  79. hd.setMaxChainLength(4);
  80. RawTextComparator cmp = RawTextComparator.DEFAULT;
  81. RawText ac = t("bbbbb");
  82. RawText bc = t("AbCbDbEFbZ");
  83. EditList r;
  84. // Without fallback our results are limited due to collisions.
  85. hd.setFallbackAlgorithm(null);
  86. r = hd.diff(cmp, ac, bc);
  87. assertEquals(1, r.size());
  88. // Results go up when we add a fallback for the high collision regions.
  89. hd.setFallbackAlgorithm(MyersDiff.INSTANCE);
  90. r = hd.diff(cmp, ac, bc);
  91. assertEquals(5, r.size());
  92. }
  93. }