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.

AbbreviatedObjectIdTest.java 13KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419
  1. /*
  2. * Copyright (C) 2008, Google Inc.
  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.lib;
  44. import static org.junit.Assert.assertEquals;
  45. import static org.junit.Assert.assertFalse;
  46. import static org.junit.Assert.assertNotNull;
  47. import static org.junit.Assert.assertNotSame;
  48. import static org.junit.Assert.assertNull;
  49. import static org.junit.Assert.assertTrue;
  50. import org.junit.Test;
  51. public class AbbreviatedObjectIdTest {
  52. @Test
  53. public void testEmpty_FromByteArray() {
  54. final AbbreviatedObjectId i;
  55. i = AbbreviatedObjectId.fromString(new byte[] {}, 0, 0);
  56. assertNotNull(i);
  57. assertEquals(0, i.length());
  58. assertFalse(i.isComplete());
  59. assertEquals("", i.name());
  60. }
  61. @Test
  62. public void testEmpty_FromString() {
  63. final AbbreviatedObjectId i = AbbreviatedObjectId.fromString("");
  64. assertNotNull(i);
  65. assertEquals(0, i.length());
  66. assertFalse(i.isComplete());
  67. assertEquals("", i.name());
  68. }
  69. @Test
  70. public void testFull_FromByteArray() {
  71. final String s = "7b6e8067ec96acef9a4184b43210d583b6d2f99a";
  72. final byte[] b = Constants.encodeASCII(s);
  73. final AbbreviatedObjectId i = AbbreviatedObjectId.fromString(b, 0,
  74. b.length);
  75. assertNotNull(i);
  76. assertEquals(s.length(), i.length());
  77. assertTrue(i.isComplete());
  78. assertEquals(s, i.name());
  79. final ObjectId f = i.toObjectId();
  80. assertNotNull(f);
  81. assertEquals(ObjectId.fromString(s), f);
  82. }
  83. @Test
  84. public void testFull_FromString() {
  85. final String s = "7b6e8067ec96acef9a4184b43210d583b6d2f99a";
  86. final AbbreviatedObjectId i = AbbreviatedObjectId.fromString(s);
  87. assertNotNull(i);
  88. assertEquals(s.length(), i.length());
  89. assertTrue(i.isComplete());
  90. assertEquals(s, i.name());
  91. final ObjectId f = i.toObjectId();
  92. assertNotNull(f);
  93. assertEquals(ObjectId.fromString(s), f);
  94. }
  95. @Test
  96. public void test1_FromString() {
  97. final String s = "7";
  98. final AbbreviatedObjectId i = AbbreviatedObjectId.fromString(s);
  99. assertNotNull(i);
  100. assertEquals(s.length(), i.length());
  101. assertFalse(i.isComplete());
  102. assertEquals(s, i.name());
  103. assertNull(i.toObjectId());
  104. }
  105. @Test
  106. public void test2_FromString() {
  107. final String s = "7b";
  108. final AbbreviatedObjectId i = AbbreviatedObjectId.fromString(s);
  109. assertNotNull(i);
  110. assertEquals(s.length(), i.length());
  111. assertFalse(i.isComplete());
  112. assertEquals(s, i.name());
  113. assertNull(i.toObjectId());
  114. }
  115. @Test
  116. public void test3_FromString() {
  117. final String s = "7b6";
  118. final AbbreviatedObjectId i = AbbreviatedObjectId.fromString(s);
  119. assertNotNull(i);
  120. assertEquals(s.length(), i.length());
  121. assertFalse(i.isComplete());
  122. assertEquals(s, i.name());
  123. assertNull(i.toObjectId());
  124. }
  125. @Test
  126. public void test4_FromString() {
  127. final String s = "7b6e";
  128. final AbbreviatedObjectId i = AbbreviatedObjectId.fromString(s);
  129. assertNotNull(i);
  130. assertEquals(s.length(), i.length());
  131. assertFalse(i.isComplete());
  132. assertEquals(s, i.name());
  133. assertNull(i.toObjectId());
  134. }
  135. @Test
  136. public void test5_FromString() {
  137. final String s = "7b6e8";
  138. final AbbreviatedObjectId i = AbbreviatedObjectId.fromString(s);
  139. assertNotNull(i);
  140. assertEquals(s.length(), i.length());
  141. assertFalse(i.isComplete());
  142. assertEquals(s, i.name());
  143. assertNull(i.toObjectId());
  144. }
  145. @Test
  146. public void test6_FromString() {
  147. final String s = "7b6e80";
  148. final AbbreviatedObjectId i = AbbreviatedObjectId.fromString(s);
  149. assertNotNull(i);
  150. assertEquals(s.length(), i.length());
  151. assertFalse(i.isComplete());
  152. assertEquals(s, i.name());
  153. assertNull(i.toObjectId());
  154. }
  155. @Test
  156. public void test7_FromString() {
  157. final String s = "7b6e806";
  158. final AbbreviatedObjectId i = AbbreviatedObjectId.fromString(s);
  159. assertNotNull(i);
  160. assertEquals(s.length(), i.length());
  161. assertFalse(i.isComplete());
  162. assertEquals(s, i.name());
  163. assertNull(i.toObjectId());
  164. }
  165. @Test
  166. public void test8_FromString() {
  167. final String s = "7b6e8067";
  168. final AbbreviatedObjectId i = AbbreviatedObjectId.fromString(s);
  169. assertNotNull(i);
  170. assertEquals(s.length(), i.length());
  171. assertFalse(i.isComplete());
  172. assertEquals(s, i.name());
  173. assertNull(i.toObjectId());
  174. }
  175. @Test
  176. public void test9_FromString() {
  177. final String s = "7b6e8067e";
  178. final AbbreviatedObjectId i = AbbreviatedObjectId.fromString(s);
  179. assertNotNull(i);
  180. assertEquals(s.length(), i.length());
  181. assertFalse(i.isComplete());
  182. assertEquals(s, i.name());
  183. assertNull(i.toObjectId());
  184. }
  185. @Test
  186. public void test17_FromString() {
  187. final String s = "7b6e8067ec96acef9";
  188. final AbbreviatedObjectId i = AbbreviatedObjectId.fromString(s);
  189. assertNotNull(i);
  190. assertEquals(s.length(), i.length());
  191. assertFalse(i.isComplete());
  192. assertEquals(s, i.name());
  193. assertNull(i.toObjectId());
  194. }
  195. @Test
  196. public void testEquals_Short8() {
  197. final String s = "7b6e8067";
  198. final AbbreviatedObjectId a = AbbreviatedObjectId.fromString(s);
  199. final AbbreviatedObjectId b = AbbreviatedObjectId.fromString(s);
  200. assertNotSame(a, b);
  201. assertTrue(a.hashCode() == b.hashCode());
  202. assertEquals(b, a);
  203. assertEquals(a, b);
  204. }
  205. @Test
  206. public void testEquals_Short4() {
  207. final String s = "7b6e";
  208. final AbbreviatedObjectId a = AbbreviatedObjectId.fromString(s);
  209. final AbbreviatedObjectId b = AbbreviatedObjectId.fromString(s);
  210. assertNotSame(a, b);
  211. assertTrue(a.hashCode() != 0);
  212. assertTrue(a.hashCode() == b.hashCode());
  213. assertEquals(b, a);
  214. assertEquals(a, b);
  215. }
  216. @Test
  217. public void testEquals_Full() {
  218. final String s = "7b6e8067ec96acef9a4184b43210d583b6d2f99a";
  219. final AbbreviatedObjectId a = AbbreviatedObjectId.fromString(s);
  220. final AbbreviatedObjectId b = AbbreviatedObjectId.fromString(s);
  221. assertNotSame(a, b);
  222. assertTrue(a.hashCode() == b.hashCode());
  223. assertEquals(b, a);
  224. assertEquals(a, b);
  225. }
  226. @Test
  227. public void testNotEquals_SameLength() {
  228. final String sa = "7b6e8067";
  229. final String sb = "7b6e806e";
  230. final AbbreviatedObjectId a = AbbreviatedObjectId.fromString(sa);
  231. final AbbreviatedObjectId b = AbbreviatedObjectId.fromString(sb);
  232. assertFalse(a.equals(b));
  233. assertFalse(b.equals(a));
  234. }
  235. @Test
  236. public void testNotEquals_DiffLength() {
  237. final String sa = "7b6e8067abcd";
  238. final String sb = "7b6e8067";
  239. final AbbreviatedObjectId a = AbbreviatedObjectId.fromString(sa);
  240. final AbbreviatedObjectId b = AbbreviatedObjectId.fromString(sb);
  241. assertFalse(a.equals(b));
  242. assertFalse(b.equals(a));
  243. }
  244. @Test
  245. public void testPrefixCompare_Full() {
  246. final String s1 = "7b6e8067ec96acef9a4184b43210d583b6d2f99a";
  247. final AbbreviatedObjectId a = AbbreviatedObjectId.fromString(s1);
  248. final ObjectId i1 = ObjectId.fromString(s1);
  249. assertEquals(0, a.prefixCompare(i1));
  250. assertTrue(i1.startsWith(a));
  251. final String s2 = "7b6e8067ec96acef9a4184b43210d583b6d2f99b";
  252. final ObjectId i2 = ObjectId.fromString(s2);
  253. assertTrue(a.prefixCompare(i2) < 0);
  254. assertFalse(i2.startsWith(a));
  255. final String s3 = "7b6e8067ec96acef9a4184b43210d583b6d2f999";
  256. final ObjectId i3 = ObjectId.fromString(s3);
  257. assertTrue(a.prefixCompare(i3) > 0);
  258. assertFalse(i3.startsWith(a));
  259. }
  260. @Test
  261. public void testPrefixCompare_1() {
  262. final String sa = "7";
  263. final AbbreviatedObjectId a = AbbreviatedObjectId.fromString(sa);
  264. final String s1 = "7b6e8067ec96acef9a4184b43210d583b6d2f99a";
  265. final ObjectId i1 = ObjectId.fromString(s1);
  266. assertEquals(0, a.prefixCompare(i1));
  267. assertTrue(i1.startsWith(a));
  268. final String s2 = "8b6e8067ec96acef9a4184b43210d583b6d2f99a";
  269. final ObjectId i2 = ObjectId.fromString(s2);
  270. assertTrue(a.prefixCompare(i2) < 0);
  271. assertFalse(i2.startsWith(a));
  272. final String s3 = "6b6e8067ec96acef9a4184b43210d583b6d2f99a";
  273. final ObjectId i3 = ObjectId.fromString(s3);
  274. assertTrue(a.prefixCompare(i3) > 0);
  275. assertFalse(i3.startsWith(a));
  276. }
  277. @Test
  278. public void testPrefixCompare_7() {
  279. final String sa = "7b6e806";
  280. final AbbreviatedObjectId a = AbbreviatedObjectId.fromString(sa);
  281. final String s1 = "7b6e8067ec96acef9a4184b43210d583b6d2f99a";
  282. final ObjectId i1 = ObjectId.fromString(s1);
  283. assertEquals(0, a.prefixCompare(i1));
  284. assertTrue(i1.startsWith(a));
  285. final String s2 = "7b6e8167ec86acef9a4184b43210d583b6d2f99a";
  286. final ObjectId i2 = ObjectId.fromString(s2);
  287. assertTrue(a.prefixCompare(i2) < 0);
  288. assertFalse(i2.startsWith(a));
  289. final String s3 = "7b6e8057eca6acef9a4184b43210d583b6d2f99a";
  290. final ObjectId i3 = ObjectId.fromString(s3);
  291. assertTrue(a.prefixCompare(i3) > 0);
  292. assertFalse(i3.startsWith(a));
  293. }
  294. @Test
  295. public void testPrefixCompare_8() {
  296. final String sa = "7b6e8067";
  297. final AbbreviatedObjectId a = AbbreviatedObjectId.fromString(sa);
  298. final String s1 = "7b6e8067ec96acef9a4184b43210d583b6d2f99a";
  299. final ObjectId i1 = ObjectId.fromString(s1);
  300. assertEquals(0, a.prefixCompare(i1));
  301. assertTrue(i1.startsWith(a));
  302. final String s2 = "7b6e8167ec86acef9a4184b43210d583b6d2f99a";
  303. final ObjectId i2 = ObjectId.fromString(s2);
  304. assertTrue(a.prefixCompare(i2) < 0);
  305. assertFalse(i2.startsWith(a));
  306. final String s3 = "7b6e8057eca6acef9a4184b43210d583b6d2f99a";
  307. final ObjectId i3 = ObjectId.fromString(s3);
  308. assertTrue(a.prefixCompare(i3) > 0);
  309. assertFalse(i3.startsWith(a));
  310. }
  311. @Test
  312. public void testPrefixCompare_9() {
  313. final String sa = "7b6e8067e";
  314. final AbbreviatedObjectId a = AbbreviatedObjectId.fromString(sa);
  315. final String s1 = "7b6e8067ec96acef9a4184b43210d583b6d2f99a";
  316. final ObjectId i1 = ObjectId.fromString(s1);
  317. assertEquals(0, a.prefixCompare(i1));
  318. assertTrue(i1.startsWith(a));
  319. final String s2 = "7b6e8167ec86acef9a4184b43210d583b6d2f99a";
  320. final ObjectId i2 = ObjectId.fromString(s2);
  321. assertTrue(a.prefixCompare(i2) < 0);
  322. assertFalse(i2.startsWith(a));
  323. final String s3 = "7b6e8057eca6acef9a4184b43210d583b6d2f99a";
  324. final ObjectId i3 = ObjectId.fromString(s3);
  325. assertTrue(a.prefixCompare(i3) > 0);
  326. assertFalse(i3.startsWith(a));
  327. }
  328. @Test
  329. public void testPrefixCompare_17() {
  330. final String sa = "7b6e8067ec96acef9";
  331. final AbbreviatedObjectId a = AbbreviatedObjectId.fromString(sa);
  332. final String s1 = "7b6e8067ec96acef9a4184b43210d583b6d2f99a";
  333. final ObjectId i1 = ObjectId.fromString(s1);
  334. assertEquals(0, a.prefixCompare(i1));
  335. assertTrue(i1.startsWith(a));
  336. final String s2 = "7b6e8067eca6acef9a4184b43210d583b6d2f99a";
  337. final ObjectId i2 = ObjectId.fromString(s2);
  338. assertTrue(a.prefixCompare(i2) < 0);
  339. assertFalse(i2.startsWith(a));
  340. final String s3 = "7b6e8067ec86acef9a4184b43210d583b6d2f99a";
  341. final ObjectId i3 = ObjectId.fromString(s3);
  342. assertTrue(a.prefixCompare(i3) > 0);
  343. assertFalse(i3.startsWith(a));
  344. }
  345. @Test
  346. public void testIsId() {
  347. // These are all too short.
  348. assertFalse(AbbreviatedObjectId.isId(""));
  349. assertFalse(AbbreviatedObjectId.isId("a"));
  350. // These are too long.
  351. assertFalse(AbbreviatedObjectId.isId(ObjectId.fromString(
  352. "7b6e8067ec86acef9a4184b43210d583b6d2f99a").name()
  353. + "0"));
  354. assertFalse(AbbreviatedObjectId.isId(ObjectId.fromString(
  355. "7b6e8067ec86acef9a4184b43210d583b6d2f99a").name()
  356. + "c0ffee"));
  357. // These contain non-hex characters.
  358. assertFalse(AbbreviatedObjectId.isId("01notahexstring"));
  359. // These should all work.
  360. assertTrue(AbbreviatedObjectId.isId("ab"));
  361. assertTrue(AbbreviatedObjectId.isId("abc"));
  362. assertTrue(AbbreviatedObjectId.isId("abcd"));
  363. assertTrue(AbbreviatedObjectId.isId("abcd0"));
  364. assertTrue(AbbreviatedObjectId.isId("abcd09"));
  365. assertTrue(AbbreviatedObjectId.isId(ObjectId.fromString(
  366. "7b6e8067ec86acef9a4184b43210d583b6d2f99a").name()));
  367. }
  368. }