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.

MergeHeadMsgTest.java 3.0KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. /*
  2. * Copyright (C) 2010-2012 Christian Halstrick <christian.halstrick@sap.com> 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.lib;
  11. import static java.nio.charset.StandardCharsets.UTF_8;
  12. import static org.junit.Assert.assertEquals;
  13. import static org.junit.Assert.assertFalse;
  14. import java.io.File;
  15. import java.io.FileOutputStream;
  16. import java.io.IOException;
  17. import java.util.Arrays;
  18. import java.util.Collections;
  19. import org.eclipse.jgit.junit.RepositoryTestCase;
  20. import org.junit.Test;
  21. public class MergeHeadMsgTest extends RepositoryTestCase {
  22. private static final String mergeMsg = "merge a and b";
  23. private static final String sampleId = "1c6db447abdbb291b25f07be38ea0b1bf94947c5";
  24. @Test
  25. public void testReadWriteMergeHeads() throws IOException {
  26. assertEquals(db.readMergeHeads(), null);
  27. db.writeMergeHeads(Arrays.asList(ObjectId.zeroId(),
  28. ObjectId.fromString(sampleId)));
  29. assertEquals(read(new File(db.getDirectory(), "MERGE_HEAD")), "0000000000000000000000000000000000000000\n1c6db447abdbb291b25f07be38ea0b1bf94947c5\n");
  30. assertEquals(db.readMergeHeads().size(), 2);
  31. assertEquals(db.readMergeHeads().get(0), ObjectId.zeroId());
  32. assertEquals(db.readMergeHeads().get(1), ObjectId.fromString(sampleId));
  33. // same test again, this time with lower-level io
  34. try (FileOutputStream fos = new FileOutputStream(
  35. new File(db.getDirectory(), "MERGE_HEAD"));) {
  36. fos.write(
  37. "0000000000000000000000000000000000000000\n1c6db447abdbb291b25f07be38ea0b1bf94947c5\n"
  38. .getBytes(UTF_8));
  39. }
  40. assertEquals(db.readMergeHeads().size(), 2);
  41. assertEquals(db.readMergeHeads().get(0), ObjectId.zeroId());
  42. assertEquals(db.readMergeHeads().get(1), ObjectId.fromString(sampleId));
  43. db.writeMergeHeads(Collections.<ObjectId> emptyList());
  44. assertEquals(read(new File(db.getDirectory(), "MERGE_HEAD")), "");
  45. assertEquals(db.readMergeHeads(), null);
  46. try (FileOutputStream fos = new FileOutputStream(
  47. new File(db.getDirectory(), "MERGE_HEAD"))) {
  48. fos.write(sampleId.getBytes(UTF_8));
  49. }
  50. assertEquals(db.readMergeHeads().size(), 1);
  51. assertEquals(db.readMergeHeads().get(0), ObjectId.fromString(sampleId));
  52. }
  53. @Test
  54. public void testReadWriteMergeMsg() throws IOException {
  55. assertEquals(db.readMergeCommitMsg(), null);
  56. assertFalse(new File(db.getDirectory(), "MERGE_MSG").exists());
  57. db.writeMergeCommitMsg(mergeMsg);
  58. assertEquals(db.readMergeCommitMsg(), mergeMsg);
  59. assertEquals(read(new File(db.getDirectory(), "MERGE_MSG")), mergeMsg);
  60. db.writeMergeCommitMsg(null);
  61. assertEquals(db.readMergeCommitMsg(), null);
  62. assertFalse(new File(db.getDirectory(), "MERGE_MSG").exists());
  63. try (FileOutputStream fos = new FileOutputStream(
  64. new File(db.getDirectory(), Constants.MERGE_MSG))) {
  65. fos.write(mergeMsg.getBytes(UTF_8));
  66. }
  67. assertEquals(db.readMergeCommitMsg(), mergeMsg);
  68. }
  69. }