derohe-miniblock-mod/cmd/simulator/blockchain_sim_deviation_test.go
2021-11-27 04:25:17 +00:00

191 lines
6.9 KiB
Go

// Copyright 2017-2018 DERO Project. All rights reserved.
// Use of this source code in any form is governed by RESEARCH license.
// license can be found in the LICENSE file.
// GPG: 0F39 E425 8C65 3947 702A 8234 08B2 0360 A03A 9DE8
//
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY
// EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
// MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
// THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
// STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
// THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
package main
import "os"
import "fmt"
import "time"
import "testing"
import "path/filepath"
import "github.com/deroproject/derohe/globals"
import "github.com/deroproject/derohe/config"
import "github.com/deroproject/derohe/transaction"
import "github.com/deroproject/derohe/walletapi"
import "github.com/deroproject/derohe/blockchain"
//import "github.com/deroproject/derohe/cryptography/crypto"
// this will test that the keys are placed properly and thus can be decoded by recievers
func Test_Blockchain_Deviation(t *testing.T) {
time.Sleep(time.Millisecond)
walletapi.Initialize_LookupTable(1, 1<<17)
wsrc_temp_db := filepath.Join(os.TempDir(), "dero_temporary_test_wallet_src.db")
wdst_temp_db := filepath.Join(os.TempDir(), "dero_temporary_test_wallet_dst.db")
os.Remove(wsrc_temp_db)
os.Remove(wdst_temp_db)
wsrc, err := walletapi.Create_Encrypted_Wallet_From_Recovery_Words(wsrc_temp_db, "QWER", "sequence atlas unveil summon pebbles tuesday beer rudely snake rockets different fuselage woven tagged bested dented vegan hover rapid fawns obvious muppet randomly seasons randomly")
if err != nil {
t.Fatalf("Cannot create encrypted wallet, err %s", err)
}
wdst, err := walletapi.Create_Encrypted_Wallet_From_Recovery_Words(wdst_temp_db, "QWER", "Dekade Spagat Bereich Radclub Yeti Dialekt Unimog Nomade Anlage Hirte Besitz Märzluft Krabbe Nabel Halsader Chefarzt Hering tauchen Neuerung Reifen Umgang Hürde Alchimie Amnesie Reifen")
if err != nil {
t.Fatalf("Cannot create encrypted wallet, err %s", err)
}
wgenesis, err := walletapi.Create_Encrypted_Wallet_From_Recovery_Words(wdst_temp_db, "QWER", "perfil lujo faja puma favor pedir detalle doble carbón neón paella cuarto ánimo cuento conga correr dental moneda león donar entero logro realidad acceso doble")
if err != nil {
t.Fatalf("Cannot create encrypted wallet, err %s", err)
}
// fix genesis tx and genesis tx hash
genesis_tx := transaction.Transaction{Transaction_Prefix: transaction.Transaction_Prefix{Version: 1, Value: 2012345}}
copy(genesis_tx.MinerAddress[:], wgenesis.GetAddress().PublicKey.EncodeCompressed())
config.Testnet.Genesis_Tx = fmt.Sprintf("%x", genesis_tx.Serialize())
config.Mainnet.Genesis_Tx = fmt.Sprintf("%x", genesis_tx.Serialize())
genesis_block := blockchain.Generate_Genesis_Block()
config.Testnet.Genesis_Block_Hash = genesis_block.GetHash()
config.Mainnet.Genesis_Block_Hash = genesis_block.GetHash()
chain, rpcserver, _ := simulator_chain_start()
defer simulator_chain_stop(chain, rpcserver)
globals.Arguments["--daemon-address"] = rpcport_test
t.Logf("src %s\n", wsrc.GetAddress())
t.Logf("dst %s\n", wdst.GetAddress())
if err := chain.Add_TX_To_Pool(wsrc.GetRegistrationTX()); err != nil {
t.Fatalf("Cannot add regtx to pool err %s", err)
}
if err := chain.Add_TX_To_Pool(wdst.GetRegistrationTX()); err != nil {
t.Fatalf("Cannot add regtx to pool err %s", err)
}
simulator_chain_mineblock(chain, wgenesis.GetAddress(), t) // mine a block at tip
defer os.Remove(wsrc_temp_db) // cleanup after test
defer os.Remove(wdst_temp_db) // cleanup after test
// we do not need wallets any more, start the tests
cbl1, _, err := chain.Create_new_miner_block(wgenesis.GetAddress())
if err != nil {
panic(err)
}
cbl2, _, err := chain.Create_new_miner_block(wgenesis.GetAddress())
if err != nil {
panic(err)
}
cbl3, _, err := chain.Create_new_miner_block(wgenesis.GetAddress())
if err != nil {
panic(err)
}
_ = cbl3
cbl1.Bl.MiniBlocks = append(cbl1.Bl.MiniBlocks, blockchain.ConvertBlockToMiniblock(*cbl1.Bl, wgenesis.GetAddress()))
cbl2.Bl.MiniBlocks = append(cbl2.Bl.MiniBlocks, blockchain.ConvertBlockToMiniblock(*cbl2.Bl, wgenesis.GetAddress()))
//cbl3.Bl.MiniBlocks = append(cbl3.Bl.MiniBlocks, blockchain.ConvertBlockToMiniblock(*cbl3.Bl, wgenesis.GetAddress()))
if err, _ = chain.Add_Complete_Block(cbl1); err != nil {
t.Fatalf("error adding block %s", err)
}
for i := 0; i < 4; i++ {
cbl_next, _, err := chain.Create_new_miner_block(wgenesis.GetAddress())
if err != nil {
panic(err)
}
mbl := blockchain.ConvertBlockToMiniblock(*cbl_next.Bl, wgenesis.GetAddress())
if mbl.PastCount != 1 {
t.Fatalf("miniblock should have 1 tips but has %d past", mbl.PastCount)
}
if len(cbl_next.Bl.MiniBlocks) != i {
t.Fatalf("Expecting %d blocks but have %d", i, len(cbl_next.Bl.MiniBlocks))
}
if err, ok := chain.InsertMiniBlock(mbl); !ok || err != nil {
t.Fatalf("miniblock should be inserted")
}
}
if err, _ = chain.Add_Complete_Block(cbl2); err != nil {
t.Fatalf("error adding block %s", err)
}
t.Logf("chain height %d tips %+v", chain.Get_Height(), chain.Get_TIPS())
// at this point chain has forked and we should have 2 tips
if len(chain.Get_TIPS()) != 2 {
t.Fatalf("cannot fork successfully, tips %d", len(chain.Get_TIPS()))
}
cbl, _, err := chain.Create_new_miner_block(wgenesis.GetAddress())
if err != nil {
panic(err)
}
mbl := blockchain.ConvertBlockToMiniblock(*cbl.Bl, wgenesis.GetAddress())
if mbl.PastCount != 1 {
t.Fatalf("miniblock should have 1 tips but has %d past", mbl.PastCount)
}
for i := 0; i < 4; i++ {
cbl_next, _, err := chain.Create_new_miner_block(wgenesis.GetAddress())
if err != nil {
panic(err)
}
if cbl_next.Bl.Height != 3 {
t.Fatalf("Height Expected %d Actuak %d", 3, cbl_next.Bl.Height)
}
mbl := blockchain.ConvertBlockToMiniblock(*cbl_next.Bl, wgenesis.GetAddress())
t.Logf("mbl %+v\n", mbl)
if i == 0 {
}
if len(cbl_next.Bl.MiniBlocks) != 4+i {
t.Fatalf("Expecting %d blocks but have %d", 4+i, len(cbl_next.Bl.MiniBlocks))
}
precount := chain.MiniBlocks.Count()
if err, ok := chain.InsertMiniBlock(mbl); !ok || err != nil {
t.Fatalf("miniblock should be inserted")
}
if precount+1 != chain.MiniBlocks.Count() {
t.Fatalf("miniblock count not increased.")
}
if tips := chain.MiniBlocks.GetAllKeys(int64(cbl_next.Bl.Height)); len(tips) != 1 {
t.Fatalf("Tip count Expected %d Actuak %d", 1, len(tips))
}
}
}