Skip to content

Commit

Permalink
Merge pull request #577 from ScorexFoundation/v3.0.1
Browse files Browse the repository at this point in the history
v3.0.1
  • Loading branch information
kushti authored Jul 29, 2019
2 parents 0e75c9b + 2948e67 commit bd48637
Show file tree
Hide file tree
Showing 47 changed files with 805 additions and 2,011 deletions.
3 changes: 3 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -35,3 +35,6 @@ project/plugins/project/

# ergo's checkout location for integration testing
ergo-tests/

# spam test's checkout location
spam-tests/
42 changes: 40 additions & 2 deletions build.sbt
Original file line number Diff line number Diff line change
Expand Up @@ -133,7 +133,7 @@ scalacOptions in(Compile, compile) ++= Seq("-release", "8")
//scalacOptions in Compile ++= Seq("-Xprompt", "-Ydebug", "-verbose" )

parallelExecution in Test := false
publishArtifact in Test := false
publishArtifact in Test := true

pomIncludeRepository := { _ => false }

Expand Down Expand Up @@ -201,7 +201,7 @@ lazy val sigma = (project in file("."))
.settings(commonSettings: _*)

def runErgoTask(task: String, sigmastateVersion: String, log: Logger): Unit = {
val ergoBranch = "master"
val ergoBranch = "ergobox-opt"
val sbtEnvVars = Seq("BUILD_ENV" -> "test", "SIGMASTATE_VERSION" -> sigmastateVersion)

log.info(s"Testing current build in Ergo (branch $ergoBranch):")
Expand Down Expand Up @@ -253,3 +253,41 @@ commands += Command.command("ergoItTest") { state =>
"ergoItTestTask" ::
state
}

def runSpamTestTask(task: String, sigmastateVersion: String, log: Logger): Unit = {
val spamBranch = "master"
val envVars = Seq("SIGMASTATE_VERSION" -> sigmastateVersion,
"SPECIAL_VERSION" -> specialVersion,
// SSH_SPAM_REPO_KEY should be set (see Jenkins Credentials Binding Plugin)
"GIT_SSH_COMMAND" -> "ssh -i $SSH_SPAM_REPO_KEY")

log.info(s"Testing current build with spam tests (branch $spamBranch):")
val cwd = new File("")
val spamPath = new File(cwd.absolutePath + "/spam-tests/")
log.info(s"Cleaning $spamPath")
s"rm -rf ${spamPath.absolutePath}" !

log.info(s"Cloning spam tests branch $spamBranch into ${spamPath.absolutePath}")
Process(Seq("git", "clone", "-b", spamBranch, "--single-branch", "[email protected]:greenhat/sigma-spam.git", spamPath.absolutePath),
cwd.getAbsoluteFile,
envVars: _*) !

log.info(s"Running spam tests in $spamPath with Sigmastate version $sigmastateVersion")
val res = Process(Seq("sbt", task), spamPath, envVars: _*) !

if (res != 0) sys.error(s"Spam $task failed!")
}

lazy val spamTestTask = TaskKey[Unit]("spamTestTask", "run spam tests with current version")
spamTestTask := {
val log = streams.value.log
val sigmastateVersion = version.value
runSpamTestTask("test", sigmastateVersion, log)
}

commands += Command.command("spamTest") { state =>
"clean" ::
"publishLocal" ::
"spamTestTask" ::
state
}
13 changes: 0 additions & 13 deletions docs/PR-review-checklist.md

This file was deleted.

173 changes: 0 additions & 173 deletions docs/TypeSerialization.md

This file was deleted.

115 changes: 115 additions & 0 deletions docs/pr-review-policy.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,115 @@
## Pull Request Review Policy

### Motivation

ErgoScript (working name Sigma) is used in Ergo to validate box spending conditions.
This is part of network consensus protocol and thus critical for long-term survivability
of Ergo blockchain.

From Sigma development point of view, consensus critical part of Ergo
is BlockCandidate validation code. More concretely `ErgoTransaction.validateStateful` method.

To achieve network consensus, block validation should be the same on all the nodes.
If some nodes have different validation results, this may lead to a network fork
(which we call hard-fork here, or HF for short).

To prevent accidental hard forking changes in the code the development process should have
barriers to prevent them from creeping in to the mainnet releases.

It is not possible to prove NO HF with testing alone.
In addition, other software development practices should be employed to decrease
the unfortunate probability of hard forking changes. In particular more
formalized development process can reduce risks.

The developer of Sigma need to understand and know internal working
of the code in `ErgoTransaciton.validateStateful`
method and analyse the impact of all his/her changes on this method behavior.

This part of Ergo should be well known for all sigma developers.
Everything which is used in `ErgoTransaciton.validateStateful` is part of consensus
and hence `red` zone.

### PR Requirements

Before the first mainnet has been released we tried to keep sigma release versions in sync with ergo versions.
Now it doesn’t look possible, since ergo will have more frequent changes.
For example (at the time of writing) `v3.0.1` is next release branch in sigma and `v3.0.5` is next in ergo.
Thus between ergo and sigma we should keep only first two numbers of the version in sync.
So when ergo will switch to `v3.1.x`, sigma will also switch to `3.1.x`, but the last digit may differ.

When creating new PRs, `master` branch should not be used directly in PRs as a base (or target branch).

Use the following branches:
- [v3.0.1](https://github.com/ScorexFoundation/sigmastate-interpreter/tree/v3.0.1) - if you
can PROVE that you don’t have changes leading to hard-fork
- [v4.0](https://github.com/ScorexFoundation/sigmastate-interpreter/tree/v4.0) - if there are
hard-fork changes

Because of the danger of hard forks, the requirement for new developments are
much stronger than in typical software development projects.

The only way a new code can go to mainnet is after the following has been done:
1) the new PR is based on `v3.x` branch
2) the new PR passes all tests in `v3.x` branch (including ergo-unit, ergo-it and spam tests)
3) the PR is reviewed
4) at least 2 approving reviews are presented (@aslesarenko and @kushti are strictly required)
5) the PR is merged into `v3.x` branch
6) the commits are merged into master as part of `v3.x` branch and released after that

This strict requirements are only for `v3.x` branches, because we need to guarantee
that we don’t accidentally introduce hard-forks.

### PR Review Requirements

During review all the changes should be examined for hard fork. In case of any suspicious change
the conversation should be opened during PR review and addressed by PR authors.

*NOTE: PR authors shouldn't resolve opened conversations
(by pressing `Resolve conversation` button), this can be done by reviewers, after the
questions are resolved.*

It is a responsibility of an author to identify suspicious changes and whether to avoid them
altogether or provide NO-HF-PROOF comment (see below) in advance, without request.
The responsibility of reviewer is to catch suspicious changes, not proved by the author, and
raise a conversation.
The responsibility of the author is to dispel those suspicions by providing a NO-HF-PROOF comment
in the source code (not in github PR comment).

Reviewers should request NO-HF-PROOF comment for ALL suspicious changes
in the code.

The example (and a template) for a comment is as the following:
```scala
/* NO HF PROOF:
Changed: the `if (spendingTransaction == null)` condition was removed
Motivation: to improve performance of hotspot code
Safety:
It is safe to remove this spendingTransaction == null check because v3.0.5 version of ergo
never create ErgoLikeContext instance with spendingTransaction = null.
Examined ergo code: ErgoTransaction.validateStatefull and all code paths started from it.
*/
```
The proof should be based on the analysis of the code.

Upon receiving of NO-HF-PROOF comment, reviewers should verify the NO-HF-PROOF themselves and never assume the author did it correctly.

Because of this added complexity of v3.x review process the developer
is strongly advised to minimize changes to a minimum which is absolutely required.

If the change is semantic the author need to have strong reasons,
which should be motivated in the NO-HF-PROOF comment.

Even if suspicious change is approved, there is still a chance that some
negative impact has been overlooked.
Thus, by default, we allow only one such change per release, to simplify root cause analysis
in case of any errors.

### PR Review Checklist

1. PR is based on `v3.x` branch
2. ergoBranch is correct and PR passes all tests (including ergo-unit, ergo-it and spam tests)
3. Every change is motivated
4. Every change preserves consensus
5. Every suspicious change comes with NO-HF-PROOF
6. Every NO-HF-PROOF is verified

File renamed without changes.
7 changes: 5 additions & 2 deletions sigma-impl/src/main/scala/sigma/util/Extensions.scala
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,6 @@ import java.nio.ByteBuffer

import special.collection.{Coll, Builder}
import com.google.common.primitives.Ints
import scalan.{Nullable, RType}

import scala.language.higherKinds

Expand All @@ -17,8 +16,12 @@ object Extensions {
def toByte: Byte = if (b) 1 else 0
}

/** @hotspot it is used in deserialization so we avoid allocation by any means. */
@inline final def toUByte(b: Byte) = b & 0xFF

implicit class ByteOps(val b: Byte) extends AnyVal {
@inline def toUByte: Int = b & 0xFF
@inline def toUByte: Int = Extensions.toUByte(b)

def addExact(b2: Byte): Byte = {
val r = b + b2
if (r < Byte.MinValue || r > Byte.MaxValue)
Expand Down
Loading

0 comments on commit bd48637

Please sign in to comment.