Skip to content

Commit

Permalink
chore: AENS integration test generalize to name as a variable, do not…
Browse files Browse the repository at this point in the history
… use stdin n as prompt to continue. use aeternity helpers instead
  • Loading branch information
randomshinichi committed Apr 30, 2019
1 parent 72e28be commit ffc4f8a
Showing 1 changed file with 21 additions and 17 deletions.
38 changes: 21 additions & 17 deletions integration_test/integration_test.go
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
package integration_test

import (
"bufio"
"fmt"
"math/big"
"os"
Expand Down Expand Up @@ -54,11 +53,11 @@ func TestSpendTxWithNode(t *testing.T) {
fmt.Println(base64TxMsg)

// sign the transaction, output params for debugging
signedBase64TxMsg, _, _, err := aeternity.SignEncodeTxStr(senderAccount, base64TxMsg, aeternity.Config.Node.NetworkID)
signedBase64TxMsg, hash, signature, err := aeternity.SignEncodeTxStr(senderAccount, base64TxMsg, aeternity.Config.Node.NetworkID)
if err != nil {
t.Error(err)
}
fmt.Println(signedBase64TxMsg)
fmt.Println(signedBase64TxMsg, hash, signature)

// send the signed transaction to the node
err = aeCli.BroadcastTransaction(signedBase64TxMsg)
Expand Down Expand Up @@ -155,22 +154,23 @@ func signBroadcast(tx string, acc *aeternity.Account, aeClient *aeternity.Ae) (h

}

func printHeight(aeClient *aeternity.Ae) {
func getHeight(aeClient *aeternity.Ae) (h uint64) {
h, err := aeClient.APIGetHeight()
if err != nil {
fmt.Println("Could not retrieve chain height")
return
}
fmt.Println("Current Height:", h)
return
}

func promptContinue() {
fmt.Print("Continue?")
reader := bufio.NewReader(os.Stdin)
_, _, _ = reader.ReadRune()
func waitForTransaction(aeClient *aeternity.Ae, height uint64, hash string) {
height, blockHash, microBlockHash, _, err := aeClient.WaitForTransactionUntilHeight(height+10, hash)
fmt.Println("Transaction was found at", height, "blockhash", blockHash, "microBlockHash", microBlockHash, "err", err)
}

func TestAENSWorkflow(t *testing.T) {
name := "fdsa.test"
acc, err := aeternity.AccountFromHexString(senderPrivateKey)
if err != nil {
fmt.Println(err)
Expand All @@ -181,7 +181,7 @@ func TestAENSWorkflow(t *testing.T) {

// Preclaim the name
fmt.Println("PreclaimTx")
preclaimTx, salt, err := aeClient.Aens.NamePreclaimTx("fdsa.test", aeternity.Config.Client.Fee)
preclaimTx, salt, err := aeClient.Aens.NamePreclaimTx(name, aeternity.Config.Client.Fee)
if err != nil {
fmt.Println(err)
return
Expand All @@ -195,29 +195,34 @@ func TestAENSWorkflow(t *testing.T) {
return
}
fmt.Println("Signed & Broadcasted NamePreclaimTx", hash)
printHeight(aeClient)
height := getHeight(aeClient)

// Wait for a bit
waitForTransaction(aeClient, height, hash)

// Claim the name
promptContinue()
fmt.Println("NameClaimTx")
claimTx, err := aeClient.Aens.NameClaimTx("fdsa.test", *salt, aeternity.Config.Client.Fee)
claimTx, err := aeClient.Aens.NameClaimTx(name, *salt, aeternity.Config.Client.Fee)
if err != nil {
fmt.Println(err)
return
}
claimTxStr, _ := aeternity.BaseEncodeTx(&claimTx)
fmt.Println("ClaimTx:", claimTxStr)

_, err = signBroadcast(claimTxStr, acc, aeClient)
hash, err = signBroadcast(claimTxStr, acc, aeClient)
if err != nil {
fmt.Println(err)
return
}
fmt.Println("Signed & Broadcasted NameClaimTx")
printHeight(aeClient)
height = getHeight(aeClient)

// Wait for a bit
waitForTransaction(aeClient, height, hash)

// Verify that the name exists
nameEntry, err := aeClient.APIGetNameEntryByName("fdsa.test")
nameEntry, err := aeClient.APIGetNameEntryByName(name)
if err != nil {
fmt.Println(err)
return
Expand All @@ -226,9 +231,8 @@ func TestAENSWorkflow(t *testing.T) {
fmt.Println(string(nameEntryJSON))

// Update the name, make it point to something
promptContinue()
fmt.Println("NameUpdateTx")
updateTx, err := aeClient.Aens.NameUpdateTx("fdsa.test", acc.Address)
updateTx, err := aeClient.Aens.NameUpdateTx(name, acc.Address)
updateTxStr, _ := aeternity.BaseEncodeTx(&updateTx)
fmt.Println("UpdateTx:", updateTxStr)

Expand Down

0 comments on commit ffc4f8a

Please sign in to comment.