forked from wavesplatform/Waves
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add unit test for generating balance in Ride (wavesplatform#3963)
- Loading branch information
1 parent
b09948e
commit cbf8193
Showing
2 changed files
with
129 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -3,6 +3,8 @@ | |
.ensime | ||
.ensime_cache/ | ||
.bsp | ||
.bloop | ||
.metals | ||
|
||
# scala build folders and files | ||
target | ||
|
127 changes: 127 additions & 0 deletions
127
node/tests/src/test/scala/com/wavesplatform/state/diffs/ci/RideGeneratingBalanceSpec.scala
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,127 @@ | ||
package com.wavesplatform.state.diffs.ci | ||
|
||
import com.wavesplatform.block.Block | ||
import com.wavesplatform.db.WithDomain | ||
import com.wavesplatform.settings.WavesSettings | ||
import com.wavesplatform.db.WithState.AddrWithBalance | ||
import com.wavesplatform.lang.directives.values.StdLibVersion | ||
import com.wavesplatform.lang.directives.values.* | ||
import com.wavesplatform.lang.v1.compiler.Terms.CONST_LONG | ||
import com.wavesplatform.test.{FreeSpec, NumericExt} | ||
import com.wavesplatform.transaction.TxHelpers | ||
import com.wavesplatform.transaction.smart.InvokeScriptTransaction | ||
|
||
class RideGeneratingBalanceSpec extends FreeSpec with WithDomain { | ||
def testGBAffectedByTxInCurrentBlock(preset: WavesSettings, stdLibVersion: StdLibVersion): Block = { | ||
|
||
val dAppAccount = TxHelpers.signer(999) | ||
val anotherAccount = TxHelpers.signer(1) | ||
|
||
val balances = Seq(AddrWithBalance(dAppAccount.toAddress, 100.01.waves), AddrWithBalance(anotherAccount.toAddress, 500.waves)) | ||
|
||
withDomain(preset, balances) { d => | ||
val dAppScript = TxHelpers.script( | ||
s"""{-# STDLIB_VERSION ${stdLibVersion.value} #-} | ||
|{-# CONTENT_TYPE DAPP #-} | ||
|{-# SCRIPT_TYPE ACCOUNT #-} | ||
| | ||
|@Callable(i) | ||
|func assertBalances( | ||
| expectedRegularBalance: Int, | ||
| expectedAvailableBalance: Int, | ||
| expectedEffectiveBalance: Int, | ||
| expectedGeneratingBalance: Int | ||
|) = { | ||
| let actualRegularBalance = wavesBalance(this).regular | ||
| let actualAvailableBalance = wavesBalance(this).available | ||
| let actualEffectiveBalance = wavesBalance(this).effective | ||
| let actualGeneratingBalance = wavesBalance(this).generating | ||
| | ||
| strict checkRegular = if (actualRegularBalance != expectedRegularBalance) | ||
| then throw("Expected Regular balance to be: " + toString(expectedRegularBalance) + ", But got: " + toString(actualRegularBalance)) | ||
| else unit | ||
| | ||
| strict checkAvailable = if (actualAvailableBalance != expectedAvailableBalance) | ||
| then throw("Expected Available balance to be: " + toString(expectedAvailableBalance) + ", But got: " + toString(actualAvailableBalance)) | ||
| else unit | ||
| | ||
| strict checkEffective = if (actualEffectiveBalance != expectedEffectiveBalance) | ||
| then throw("Expected Effective balance to be: " + toString(expectedEffectiveBalance) + ", But got: " + toString(actualEffectiveBalance)) | ||
| else unit | ||
| | ||
| strict checkGenerating = if (actualGeneratingBalance != expectedGeneratingBalance) | ||
| then throw("Expected Generating balance to be: " + toString(expectedGeneratingBalance) + ", But got: " + toString(actualGeneratingBalance)) | ||
| else unit | ||
| ([], unit) | ||
|}""".stripMargin | ||
) | ||
|
||
def assertBalancesInRide(regular: Long, available: Long, effective: Long, generating: Long): InvokeScriptTransaction = | ||
TxHelpers.invoke( | ||
dAppAccount.toAddress, | ||
Some("assertBalances"), | ||
Seq(CONST_LONG(regular), CONST_LONG(available), CONST_LONG(effective), CONST_LONG(generating)), | ||
payments = Seq(), | ||
invoker = anotherAccount | ||
) | ||
|
||
d.blockchain.height shouldBe 1 | ||
|
||
// Block 2 | ||
d.appendBlock( | ||
TxHelpers.setScript(dAppAccount, dAppScript), // Note: setScript costs 0.01.waves | ||
assertBalancesInRide(100.waves, 100.waves, 100.waves, 100.waves) | ||
) | ||
d.blockchain.height shouldBe 2 | ||
|
||
// Block 3 | ||
d.appendBlock(TxHelpers.transfer(anotherAccount, dAppAccount.toAddress, 10.waves)) | ||
d.blockchain.height shouldBe 3 | ||
|
||
// Fast-forward to block 1000 | ||
Range.inclusive(3, 999).foreach(_ => d.appendBlock()) | ||
d.blockchain.height shouldBe 1000 | ||
|
||
// Block 1001 | ||
// This assertion tells us that the generating balance | ||
// is not being updated until the block 1002, which is expected, | ||
// because `10.waves` was sent on height = 3, | ||
// and until height 1002 the balance is not updated | ||
// (...the lowest of the last 1000 blocks, including 3 and 1002) | ||
d.appendBlock(assertBalancesInRide(110.waves, 110.waves, 110.waves, 100.waves)) | ||
d.blockchain.height shouldBe 1001 | ||
|
||
// Block 1002 | ||
d.appendBlock( | ||
// This assertion tells us that the generating balance | ||
// was already updated after `10.waves` was sent on height = 3 | ||
assertBalancesInRide(110.waves, 110.waves, 110.waves, 110.waves), | ||
TxHelpers.transfer(dAppAccount, anotherAccount.toAddress, 50.waves), | ||
// This assertion tells us that the generating balance | ||
// was updated by a transaction in this block. | ||
assertBalancesInRide(59.99.waves, 59.99.waves, 59.99.waves, 59.99.waves) | ||
) | ||
} | ||
} | ||
|
||
"The generating balance is affected by transactions in the current block" - { | ||
"RideV5, STDLIB_VERSION 5" in | ||
testGBAffectedByTxInCurrentBlock(DomainPresets.RideV5, V5) | ||
|
||
"RideV6, STDLIB_VERSION 6" in | ||
testGBAffectedByTxInCurrentBlock(DomainPresets.RideV6, V6) | ||
|
||
"ConsensusImprovements, STDLIB_VERSION 6" in | ||
testGBAffectedByTxInCurrentBlock(DomainPresets.ConsensusImprovements, V6) | ||
|
||
"ContinuationTransaction, STDLIB_VERSION 6" in | ||
testGBAffectedByTxInCurrentBlock(DomainPresets.ContinuationTransaction, V6) | ||
|
||
"BlockRewardDistribution, STDLIB_VERSION 7" in | ||
testGBAffectedByTxInCurrentBlock(DomainPresets.BlockRewardDistribution, V7) | ||
|
||
"TransactionStateSnapshot, STDLIB_VERSION 8" in | ||
testGBAffectedByTxInCurrentBlock(DomainPresets.TransactionStateSnapshot, V8) | ||
} | ||
|
||
} |