~jan0sch/smederee
Showing details for patch 88d48a1b68ad90b96135d8fa9b245eddc044443d.
diff -rN -u old-smederee/modules/darcs/src/main/scala/de/smederee/darcs/DarcsCommands.scala new-smederee/modules/darcs/src/main/scala/de/smederee/darcs/DarcsCommands.scala --- old-smederee/modules/darcs/src/main/scala/de/smederee/darcs/DarcsCommands.scala 2025-01-08 21:34:56.037801029 +0000 +++ new-smederee/modules/darcs/src/main/scala/de/smederee/darcs/DarcsCommands.scala 2025-01-08 21:34:56.041801038 +0000 @@ -16,6 +16,11 @@ import scala.util.matching.Regex +/** A type representing a "darcs patch hash" which according to documentation is: a hash (SHA1) of patch info (name, + * author name, timestamp, log, random seed) and is used as an identifier for patches independently of their context + * and also shown in the darcs log output. This hash never changes, even if the patch commutes. But it changes if the + * patch is amended to (random seed is changed). + */ opaque type DarcsHash = String object DarcsHash { val Format: Regex = "^[a-f0-9]{40}$".r diff -rN -u old-smederee/modules/darcs/src/test/scala/de/smederee/darcs/DarcsHashTest.scala new-smederee/modules/darcs/src/test/scala/de/smederee/darcs/DarcsHashTest.scala --- old-smederee/modules/darcs/src/test/scala/de/smederee/darcs/DarcsHashTest.scala 1970-01-01 00:00:00.000000000 +0000 +++ new-smederee/modules/darcs/src/test/scala/de/smederee/darcs/DarcsHashTest.scala 2025-01-08 21:34:56.041801038 +0000 @@ -0,0 +1,34 @@ +/* + * Copyright (c) 2022 Contributors as noted in the AUTHORS.md file + * + * Licensed under the EUPL + */ + +package de.smederee.darcs + +import java.nio.charset.StandardCharsets +import java.security.MessageDigest + +import munit.* + +import org.scalacheck.* +import org.scalacheck.Prop.* + +final class DarcsHashTest extends ScalaCheckSuite { + private val hasher = MessageDigest.getInstance("SHA1") + + private val genSha1String: Gen[String] = + Gen.alphaNumStr + .map(string => + hasher.digest(string.getBytes(StandardCharsets.UTF_8)).map(byte => "%02x".format(byte)).mkString("") + ) + + property("from must work for correctly formatted hash strings") { + forAll(genSha1String) { (hashedString: String) => + DarcsHash.from(hashedString) match { + case None => fail(s"No darcs hash generated from given SHA1 hash: $hashedString!") + case Some(hash) => assertEquals(hash, DarcsHash(hashedString)) + } + } + } +}