From ef9c23592f659472dd7a8a22368668b6df010b1c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E5=A4=8F=E5=A5=87=E6=A5=A0?= Date: Wed, 28 Jun 2023 19:49:27 +0800 Subject: [PATCH 1/2] add Side field to NoMDEntries of MarketDataSnapshotFullRefresh --- ...MarketDataSnapshotFullRefresh.generated.go | 24 +++++++- ...tDataSnapshotFullRefresh.generated_test.go | 57 +++++++++++++++++++ 2 files changed, 79 insertions(+), 2 deletions(-) create mode 100644 marketdatasnapshotfullrefresh/MarketDataSnapshotFullRefresh.generated_test.go diff --git a/marketdatasnapshotfullrefresh/MarketDataSnapshotFullRefresh.generated.go b/marketdatasnapshotfullrefresh/MarketDataSnapshotFullRefresh.generated.go index 55f4a75..9a1b851 100644 --- a/marketdatasnapshotfullrefresh/MarketDataSnapshotFullRefresh.generated.go +++ b/marketdatasnapshotfullrefresh/MarketDataSnapshotFullRefresh.generated.go @@ -1,9 +1,10 @@ package marketdatasnapshotfullrefresh import ( - "github.com/shopspring/decimal" "time" + "github.com/shopspring/decimal" + "github.com/quickfixgo/enum" "github.com/quickfixgo/field" "github.com/quickfixgo/fix44" @@ -1186,6 +1187,11 @@ func (m NoMDEntries) SetEncodedText(v string) { m.Set(field.NewEncodedText(v)) } +//SetSide sets Side, Tag 54 +func (m NoMDEntries) SetSide(v enum.Side) { + m.Set(field.NewSide(v)) +} + //GetMDEntryType gets MDEntryType, Tag 269 func (m NoMDEntries) GetMDEntryType() (v enum.MDEntryType, err quickfix.MessageRejectError) { var f field.MDEntryTypeField @@ -1483,6 +1489,15 @@ func (m NoMDEntries) GetEncodedText() (v string, err quickfix.MessageRejectError return } +//GetSide gets Side, Tag 54 +func (m NoMDEntries) GetSide() (v enum.Side, err quickfix.MessageRejectError) { + var f field.SideField + if err = m.Get(&f); err == nil { + v = f.Value() + } + return +} + //HasMDEntryType returns true if MDEntryType is present, Tag 269 func (m NoMDEntries) HasMDEntryType() bool { return m.Has(tag.MDEntryType) @@ -1648,6 +1663,11 @@ func (m NoMDEntries) HasEncodedText() bool { return m.Has(tag.EncodedText) } +//HasSide returns true if Side is present, Tag 54 +func (m NoMDEntries) HasSide() bool { + return m.Has(tag.Side) +} + //NoMDEntriesRepeatingGroup is a repeating group, Tag 268 type NoMDEntriesRepeatingGroup struct { *quickfix.RepeatingGroup @@ -1657,7 +1677,7 @@ type NoMDEntriesRepeatingGroup struct { func NewNoMDEntriesRepeatingGroup() NoMDEntriesRepeatingGroup { return NoMDEntriesRepeatingGroup{ quickfix.NewRepeatingGroup(tag.NoMDEntries, - quickfix.GroupTemplate{quickfix.GroupElement(tag.MDEntryType), quickfix.GroupElement(tag.MDEntryPx), quickfix.GroupElement(tag.Currency), quickfix.GroupElement(tag.MDEntrySize), quickfix.GroupElement(tag.MDEntryDate), quickfix.GroupElement(tag.MDEntryTime), quickfix.GroupElement(tag.TickDirection), quickfix.GroupElement(tag.MDMkt), quickfix.GroupElement(tag.TradingSessionID), quickfix.GroupElement(tag.TradingSessionSubID), quickfix.GroupElement(tag.QuoteCondition), quickfix.GroupElement(tag.TradeCondition), quickfix.GroupElement(tag.MDEntryOriginator), quickfix.GroupElement(tag.LocationID), quickfix.GroupElement(tag.DeskID), quickfix.GroupElement(tag.OpenCloseSettlFlag), quickfix.GroupElement(tag.TimeInForce), quickfix.GroupElement(tag.ExpireDate), quickfix.GroupElement(tag.ExpireTime), quickfix.GroupElement(tag.MinQty), quickfix.GroupElement(tag.ExecInst), quickfix.GroupElement(tag.SellerDays), quickfix.GroupElement(tag.OrderID), quickfix.GroupElement(tag.QuoteEntryID), quickfix.GroupElement(tag.MDEntryBuyer), quickfix.GroupElement(tag.MDEntrySeller), quickfix.GroupElement(tag.NumberOfOrders), quickfix.GroupElement(tag.MDEntryPositionNo), quickfix.GroupElement(tag.Scope), quickfix.GroupElement(tag.PriceDelta), quickfix.GroupElement(tag.Text), quickfix.GroupElement(tag.EncodedTextLen), quickfix.GroupElement(tag.EncodedText)})} + quickfix.GroupTemplate{quickfix.GroupElement(tag.MDEntryType), quickfix.GroupElement(tag.MDEntryPx), quickfix.GroupElement(tag.Currency), quickfix.GroupElement(tag.MDEntrySize), quickfix.GroupElement(tag.MDEntryDate), quickfix.GroupElement(tag.MDEntryTime), quickfix.GroupElement(tag.TickDirection), quickfix.GroupElement(tag.MDMkt), quickfix.GroupElement(tag.TradingSessionID), quickfix.GroupElement(tag.TradingSessionSubID), quickfix.GroupElement(tag.QuoteCondition), quickfix.GroupElement(tag.TradeCondition), quickfix.GroupElement(tag.MDEntryOriginator), quickfix.GroupElement(tag.LocationID), quickfix.GroupElement(tag.DeskID), quickfix.GroupElement(tag.OpenCloseSettlFlag), quickfix.GroupElement(tag.TimeInForce), quickfix.GroupElement(tag.ExpireDate), quickfix.GroupElement(tag.ExpireTime), quickfix.GroupElement(tag.MinQty), quickfix.GroupElement(tag.ExecInst), quickfix.GroupElement(tag.SellerDays), quickfix.GroupElement(tag.OrderID), quickfix.GroupElement(tag.QuoteEntryID), quickfix.GroupElement(tag.MDEntryBuyer), quickfix.GroupElement(tag.MDEntrySeller), quickfix.GroupElement(tag.NumberOfOrders), quickfix.GroupElement(tag.MDEntryPositionNo), quickfix.GroupElement(tag.Scope), quickfix.GroupElement(tag.PriceDelta), quickfix.GroupElement(tag.Text), quickfix.GroupElement(tag.EncodedTextLen), quickfix.GroupElement(tag.EncodedText), quickfix.GroupElement(tag.Side)})} } //Add create and append a new NoMDEntries to this group diff --git a/marketdatasnapshotfullrefresh/MarketDataSnapshotFullRefresh.generated_test.go b/marketdatasnapshotfullrefresh/MarketDataSnapshotFullRefresh.generated_test.go new file mode 100644 index 0000000..ee0c9fc --- /dev/null +++ b/marketdatasnapshotfullrefresh/MarketDataSnapshotFullRefresh.generated_test.go @@ -0,0 +1,57 @@ +package marketdatasnapshotfullrefresh + +import ( + "bytes" + "testing" + + "github.com/quickfixgo/enum" + "github.com/quickfixgo/quickfix" + . "github.com/smartystreets/goconvey/convey" +) + +func Test_MarketDataSnapshotFullRefresh(t *testing.T) { + Convey("NoMDEntriesRepeatingGroup", t, func() { + Convey("Group data with side field", func() { + rowData := bytes.NewBufferString("8=FIX.4.49=20835=W34=53949=SenderCompID52=20230628-08:29:47.30056=TargetCompID55=ETHUSD262=staging-1687940826268=2269=2270=1857.1271=2.019273=08:29:47336=CONTINUOUS54=1269=B271=31767.82357346336=CONTINUOUS10=165") + + msg := quickfix.NewMessage() + err := quickfix.ParseMessage(msg, rowData) + So(err, ShouldBeNil) + + group := NewNoMDEntriesRepeatingGroup() + err = msg.ToMessage().Body.GetGroup(group) + So(err, ShouldBeNil) + So(group.Len(), ShouldEqual, 2) + + entry := group.Get(0) + ok := entry.HasSide() + side, err := entry.GetSide() + So(ok, ShouldBeTrue) + So(err, ShouldBeNil) + So(side, ShouldEqual, enum.Side_BUY) + }) + + Convey("Group data without side field", func() { + rowData := bytes.NewBufferString("8=FIX.4.49=20335=W34=53949=SenderCompID52=20230628-08:29:47.30056=TargetCompID55=ETHUSD262=staging-1687940826268=2269=2270=1857.1271=2.019273=08:29:47336=CONTINUOUS269=B271=31767.82357346336=CONTINUOUS10=165") + + msg := quickfix.NewMessage() + err := quickfix.ParseMessage(msg, rowData) + So(err, ShouldBeNil) + + group := NewNoMDEntriesRepeatingGroup() + err = msg.ToMessage().Body.GetGroup(group) + So(err, ShouldBeNil) + So(group.Len(), ShouldEqual, 2) + + newEntry := group.Add() + ok := newEntry.HasSide() + So(ok, ShouldBeFalse) + + newEntry.SetSide(enum.Side_SELL) + ok = newEntry.HasSide() + side, err := newEntry.GetSide() + So(ok, ShouldBeTrue) + So(side, ShouldEqual, enum.Side_SELL) + }) + }) +} From 2fbd14fffa30e07898951c173abcffc19115539c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E5=A4=8F=E5=A5=87=E6=A5=A0?= Date: Wed, 28 Jun 2023 19:50:45 +0800 Subject: [PATCH 2/2] optimize --- .../MarketDataSnapshotFullRefresh.generated.go | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/marketdatasnapshotfullrefresh/MarketDataSnapshotFullRefresh.generated.go b/marketdatasnapshotfullrefresh/MarketDataSnapshotFullRefresh.generated.go index 9a1b851..09e45a9 100644 --- a/marketdatasnapshotfullrefresh/MarketDataSnapshotFullRefresh.generated.go +++ b/marketdatasnapshotfullrefresh/MarketDataSnapshotFullRefresh.generated.go @@ -3,13 +3,12 @@ package marketdatasnapshotfullrefresh import ( "time" - "github.com/shopspring/decimal" - "github.com/quickfixgo/enum" "github.com/quickfixgo/field" "github.com/quickfixgo/fix44" "github.com/quickfixgo/quickfix" "github.com/quickfixgo/tag" + "github.com/shopspring/decimal" ) //MarketDataSnapshotFullRefresh is the fix44 MarketDataSnapshotFullRefresh type, MsgType = W