2015-11-13 22:12:39 +00:00
|
|
|
package serialization
|
|
|
|
|
|
|
|
import contracts.Cash
|
|
|
|
import core.*
|
2015-11-16 19:07:52 +00:00
|
|
|
import org.junit.Before
|
2015-11-13 22:12:39 +00:00
|
|
|
import org.junit.Test
|
2015-11-16 19:36:27 +00:00
|
|
|
import testutils.DUMMY_PUBKEY_1
|
|
|
|
import testutils.MINI_CORP
|
2015-11-13 22:12:39 +00:00
|
|
|
import testutils.TestUtils
|
|
|
|
import java.security.SignatureException
|
|
|
|
import kotlin.test.assertFailsWith
|
|
|
|
|
|
|
|
class TransactionSerializationTests {
|
|
|
|
// Simple TX that takes 1000 pounds from me and sends 600 to someone else (with 400 change).
|
|
|
|
// It refers to a fake TX/state that we don't bother creating here.
|
|
|
|
val depositRef = InstitutionReference(MINI_CORP, OpaqueBytes.of(1))
|
|
|
|
val outputState = Cash.State(depositRef, 600.POUNDS, DUMMY_PUBKEY_1)
|
|
|
|
val changeState = Cash.State(depositRef, 400.POUNDS, TestUtils.keypair.public)
|
|
|
|
|
|
|
|
val fakeStateRef = ContractStateRef(SecureHash.sha256("fake tx id"), 0)
|
2015-11-16 19:07:52 +00:00
|
|
|
lateinit var tx: PartialTransaction
|
|
|
|
|
|
|
|
@Before
|
|
|
|
fun setup() {
|
|
|
|
tx = PartialTransaction(
|
|
|
|
fakeStateRef, outputState, changeState, WireCommand(Cash.Commands.Move, arrayListOf(TestUtils.keypair.public))
|
|
|
|
)
|
|
|
|
}
|
2015-11-13 22:12:39 +00:00
|
|
|
|
|
|
|
@Test
|
|
|
|
fun signWireTX() {
|
2015-11-16 19:07:52 +00:00
|
|
|
tx.signWith(TestUtils.keypair)
|
|
|
|
val signedTX = tx.toSignedTransaction()
|
2015-11-13 22:12:39 +00:00
|
|
|
|
|
|
|
// Now check that the signature we just made verifies.
|
|
|
|
signedTX.verify()
|
|
|
|
|
|
|
|
// Corrupt the data and ensure the signature catches the problem.
|
|
|
|
signedTX.txBits[5] = 0
|
|
|
|
assertFailsWith(SignatureException::class) {
|
|
|
|
signedTX.verify()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
2015-11-16 19:07:52 +00:00
|
|
|
fun tooManyKeys() {
|
|
|
|
assertFailsWith(IllegalStateException::class) {
|
|
|
|
tx.signWith(TestUtils.keypair)
|
|
|
|
tx.signWith(TestUtils.keypair2)
|
|
|
|
tx.toSignedTransaction()
|
2015-11-13 22:12:39 +00:00
|
|
|
}
|
2015-11-16 19:07:52 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
|
|
|
fun wrongKeys() {
|
|
|
|
// Can't convert if we don't have enough signatures.
|
|
|
|
assertFailsWith(IllegalStateException::class) {
|
|
|
|
tx.toSignedTransaction()
|
2015-11-13 22:12:39 +00:00
|
|
|
}
|
|
|
|
|
2015-11-16 19:07:52 +00:00
|
|
|
tx.signWith(TestUtils.keypair)
|
|
|
|
val signedTX = tx.toSignedTransaction()
|
2015-11-13 22:12:39 +00:00
|
|
|
|
2015-11-16 11:29:36 +00:00
|
|
|
// Cannot construct with an empty sigs list.
|
|
|
|
assertFailsWith(IllegalStateException::class) {
|
|
|
|
signedTX.copy(sigs = emptyList())
|
|
|
|
}
|
|
|
|
|
|
|
|
// If the signature was replaced in transit, we don't like it.
|
2015-11-13 22:12:39 +00:00
|
|
|
assertFailsWith(SignatureException::class) {
|
2015-11-16 19:07:52 +00:00
|
|
|
val tx2 = PartialTransaction(fakeStateRef, outputState, changeState,
|
|
|
|
WireCommand(Cash.Commands.Move, arrayListOf(TestUtils.keypair2.public)))
|
|
|
|
tx2.signWith(TestUtils.keypair2)
|
|
|
|
|
|
|
|
signedTX.copy(sigs = tx2.toSignedTransaction().sigs).verify()
|
2015-11-13 22:12:39 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|