Skip to content
This repository has been archived by the owner on Jan 22, 2020. It is now read-only.

Commit

Permalink
Update Ingestion.Transaction to insert empty signatures
Browse files Browse the repository at this point in the history
  • Loading branch information
bartekn committed Jul 4, 2017
1 parent ab417ea commit 64330e9
Show file tree
Hide file tree
Showing 3 changed files with 88 additions and 9 deletions.
16 changes: 16 additions & 0 deletions src/github.com/stellar/horizon/db2/core/transaction_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -39,3 +39,19 @@ func TestMemo(t *testing.T) {

tt.Assert.Equal("1.0.1owerride me", tx.Memo().String)
}

func TestSignatures(t *testing.T) {
tt := test.Start(t).Scenario("base")
defer tt.Finish()

var tx Transaction

// https://github.com/stellar/stellar-core/issues/1225
xdr.SafeUnmarshalBase64("AAAAAMIK9djC7k75ziKOLJcvMAIBG7tnBuoeI34x+Pi6zqcZAAAAZAAZphYAAAABAAAAAAAAAAAAAAABAAAAAAAAAAEAAAAAynnCTTyw53VVRLOWX6XKTva63IM1LslPNW01YB0hz/8AAAAAAAAAAlQL5AAAAAAAAAAAAh0hz/8AAABA8qkkeKaKfsbgInyIkzXJhqJE5/Ufxri2LdxmyKkgkT6I3sPmvrs5cPWQSzEQyhV750IW2ds97xTHqTpOfuZCAnhSuFUAAAAA", &tx.Envelope)

signatures := tx.Base64Signatures()

tt.Assert.Equal(2, len(signatures))
tt.Assert.Equal("8qkkeKaKfsbgInyIkzXJhqJE5/Ufxri2LdxmyKkgkT6I3sPmvrs5cPWQSzEQyhV750IW2ds97xTHqTpOfuZCAg==", signatures[0])
tt.Assert.Equal("", signatures[1])
}
30 changes: 21 additions & 9 deletions src/github.com/stellar/horizon/ingest/ingestion.go
Original file line number Diff line number Diff line change
Expand Up @@ -184,15 +184,17 @@ func (ingest *Ingestion) Start() (err error) {
return
}

// Transaction ingests the provided transaction data into a new row in the
// `history_transactions` table
func (ingest *Ingestion) Transaction(
id int64,
tx *core.Transaction,
fee *core.TransactionFee,
) error {
// transactionInsertBuilder returns sql.InsertBuilder for a single transaction
func (ingest *Ingestion) transactionInsertBuilder(id int64, tx *core.Transaction, fee *core.TransactionFee) sq.InsertBuilder {
// Enquote empty signatures
signatures := tx.Base64Signatures()
for i, sig := range signatures {
if len(sig) == 0 {
signatures[i] = `""`
}
}

sql := ingest.transactions.Values(
return ingest.transactions.Values(
id,
tx.TransactionHash,
tx.LedgerSequence,
Expand All @@ -205,14 +207,24 @@ func (ingest *Ingestion) Transaction(
tx.ResultXDR(),
tx.ResultMetaXDR(),
fee.ChangesXDR(),
sqx.StringArray(tx.Base64Signatures()),
sqx.StringArray(signatures),
ingest.formatTimeBounds(tx.Envelope.Tx.TimeBounds),
tx.MemoType(),
tx.Memo(),
time.Now().UTC(),
time.Now().UTC(),
)
}

// Transaction ingests the provided transaction data into a new row in the
// `history_transactions` table
func (ingest *Ingestion) Transaction(
id int64,
tx *core.Transaction,
fee *core.TransactionFee,
) error {

sql := ingest.transactionInsertBuilder(id, tx, fee)
_, err := ingest.DB.Exec(sql)
if err != nil {
return err
Expand Down
51 changes: 51 additions & 0 deletions src/github.com/stellar/horizon/ingest/ingestion_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,51 @@
package ingest

import (
"testing"

"github.com/stellar/go/support/db"
"github.com/stellar/go/xdr"
"github.com/stellar/horizon/db2/core"
testDB "github.com/stellar/horizon/test/db"
"github.com/stretchr/testify/assert"
)

func TestEmptySignature(t *testing.T) {
ingestion := Ingestion{
DB: &db.Session{
DB: testDB.Horizon(),
},
}
ingestion.Start()

envelope := xdr.TransactionEnvelope{}
resultPair := xdr.TransactionResultPair{}
meta := xdr.TransactionMeta{}

xdr.SafeUnmarshalBase64("AAAAAMIK9djC7k75ziKOLJcvMAIBG7tnBuoeI34x+Pi6zqcZAAAAZAAZphYAAAABAAAAAAAAAAAAAAABAAAAAAAAAAEAAAAAynnCTTyw53VVRLOWX6XKTva63IM1LslPNW01YB0hz/8AAAAAAAAAAlQL5AAAAAAAAAAAAh0hz/8AAABA8qkkeKaKfsbgInyIkzXJhqJE5/Ufxri2LdxmyKkgkT6I3sPmvrs5cPWQSzEQyhV750IW2ds97xTHqTpOfuZCAnhSuFUAAAAA", &envelope)
xdr.SafeUnmarshalBase64("AAAAAAAAAGQAAAAAAAAAAQAAAAAAAAABAAAAAAAAAAA=", &resultPair.Result)
xdr.SafeUnmarshalBase64("AAAAAAAAAAEAAAADAAAAAQAZphoAAAAAAAAAAMIK9djC7k75ziKOLJcvMAIBG7tnBuoeI34x+Pi6zqcZAAAAF0h255wAGaYWAAAAAQAAAAMAAAAAAAAAAAAAAAADBQUFAAAAAwAAAAAtkqVYLPLYhqNMmQLPc+T9eTWp8LIE8eFlR5K4wNJKTQAAAAMAAAAAynnCTTyw53VVRLOWX6XKTva63IM1LslPNW01YB0hz/8AAAADAAAAAuOwxEKY/BwUmvv0yJlvuSQnrkHkZJuTTKSVmRt4UrhVAAAAAwAAAAAAAAAAAAAAAwAZphYAAAAAAAAAAMp5wk08sOd1VUSzll+lyk72utyDNS7JTzVtNWAdIc//AAAAF0h26AAAGaYWAAAAAAAAAAAAAAAAAAAAAAAAAAABAAAAAAAAAAAAAAAAAAAAAAAAAQAZphoAAAAAAAAAAMp5wk08sOd1VUSzll+lyk72utyDNS7JTzVtNWAdIc//AAAAGZyCzAAAGaYWAAAAAAAAAAAAAAAAAAAAAAAAAAABAAAAAAAAAAAAAAAAAAAA", &meta)

transaction := &core.Transaction{
TransactionHash: "1939a8de30981e4171e1aaeca54a058a7fb06684864facba0620ab8cc5076d4f",
LedgerSequence: 1680922,
Index: 1,
Envelope: envelope,
Result: resultPair,
ResultMeta: meta,
}

transactionFee := &core.TransactionFee{}

builder := ingestion.transactionInsertBuilder(1, transaction, transactionFee)
sql, args, err := builder.ToSql()
assert.Equal(t, "INSERT INTO history_transactions (id,transaction_hash,ledger_sequence,application_order,account,account_sequence,fee_paid,operation_count,tx_envelope,tx_result,tx_meta,tx_fee_meta,signatures,time_bounds,memo_type,memo,created_at,updated_at) VALUES (?,?,?,?,?,?,?,?,?,?,?,?,?::character varying[],?,?,?,?,?)", sql)
assert.Equal(t, `{8qkkeKaKfsbgInyIkzXJhqJE5/Ufxri2LdxmyKkgkT6I3sPmvrs5cPWQSzEQyhV750IW2ds97xTHqTpOfuZCAg==,""}`, args[12])
assert.NoError(t, err)

err = ingestion.Transaction(1, transaction, transactionFee)
assert.NoError(t, err)

err = ingestion.Close()
assert.NoError(t, err)
}

0 comments on commit 64330e9

Please sign in to comment.