go.temporal.io/server@v1.23.0/common/persistence/sql/sqlplugin/tests/history_execution_buffer.go (about) 1 // The MIT License 2 // 3 // Copyright (c) 2020 Temporal Technologies Inc. All rights reserved. 4 // 5 // Copyright (c) 2020 Uber Technologies, Inc. 6 // 7 // Permission is hereby granted, free of charge, to any person obtaining a copy 8 // of this software and associated documentation files (the "Software"), to deal 9 // in the Software without restriction, including without limitation the rights 10 // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 11 // copies of the Software, and to permit persons to whom the Software is 12 // furnished to do so, subject to the following conditions: 13 // 14 // The above copyright notice and this permission notice shall be included in 15 // all copies or substantial portions of the Software. 16 // 17 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 18 // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 19 // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 20 // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 21 // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 22 // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN 23 // THE SOFTWARE. 24 25 package tests 26 27 import ( 28 "math/rand" 29 "testing" 30 31 "github.com/stretchr/testify/require" 32 "github.com/stretchr/testify/suite" 33 34 "go.temporal.io/server/common/persistence/sql/sqlplugin" 35 "go.temporal.io/server/common/primitives" 36 "go.temporal.io/server/common/shuffle" 37 ) 38 39 type ( 40 historyExecutionBufferSuite struct { 41 suite.Suite 42 *require.Assertions 43 44 store sqlplugin.HistoryExecutionBuffer 45 } 46 ) 47 48 const ( 49 testHistoryExecutionBufferEncoding = "random encoding" 50 ) 51 52 var ( 53 testHistoryExecutionBufferData = []byte("random history execution buffer data") 54 ) 55 56 func NewHistoryExecutionBufferSuite( 57 t *testing.T, 58 store sqlplugin.HistoryExecutionBuffer, 59 ) *historyExecutionBufferSuite { 60 return &historyExecutionBufferSuite{ 61 Assertions: require.New(t), 62 store: store, 63 } 64 } 65 66 func (s *historyExecutionBufferSuite) SetupSuite() { 67 68 } 69 70 func (s *historyExecutionBufferSuite) TearDownSuite() { 71 72 } 73 74 func (s *historyExecutionBufferSuite) SetupTest() { 75 s.Assertions = require.New(s.T()) 76 } 77 78 func (s *historyExecutionBufferSuite) TearDownTest() { 79 80 } 81 82 func (s *historyExecutionBufferSuite) TestInsert_Single() { 83 shardID := rand.Int31() 84 namespaceID := primitives.NewUUID() 85 workflowID := shuffle.String(testHistoryExecutionWorkflowID) 86 runID := primitives.NewUUID() 87 88 buffer := s.newRandomExecutionBufferRow(shardID, namespaceID, workflowID, runID) 89 result, err := s.store.InsertIntoBufferedEvents(newExecutionContext(), []sqlplugin.BufferedEventsRow{buffer}) 90 s.NoError(err) 91 rowsAffected, err := result.RowsAffected() 92 s.NoError(err) 93 s.Equal(1, int(rowsAffected)) 94 } 95 96 func (s *historyExecutionBufferSuite) TestInsert_Multiple() { 97 shardID := rand.Int31() 98 namespaceID := primitives.NewUUID() 99 workflowID := shuffle.String(testHistoryExecutionWorkflowID) 100 runID := primitives.NewUUID() 101 102 buffer1 := s.newRandomExecutionBufferRow(shardID, namespaceID, workflowID, runID) 103 buffer2 := s.newRandomExecutionBufferRow(shardID, namespaceID, workflowID, runID) 104 result, err := s.store.InsertIntoBufferedEvents(newExecutionContext(), []sqlplugin.BufferedEventsRow{buffer1, buffer2}) 105 s.NoError(err) 106 rowsAffected, err := result.RowsAffected() 107 s.NoError(err) 108 s.Equal(2, int(rowsAffected)) 109 } 110 111 func (s *historyExecutionBufferSuite) TestInsertSelect() { 112 numBufferedEvents := 20 113 114 shardID := rand.Int31() 115 namespaceID := primitives.NewUUID() 116 workflowID := shuffle.String(testHistoryExecutionWorkflowID) 117 runID := primitives.NewUUID() 118 119 var buffers []sqlplugin.BufferedEventsRow 120 for i := 0; i < numBufferedEvents; i++ { 121 buffer := s.newRandomExecutionBufferRow(shardID, namespaceID, workflowID, runID) 122 buffers = append(buffers, buffer) 123 } 124 result, err := s.store.InsertIntoBufferedEvents(newExecutionContext(), buffers) 125 s.NoError(err) 126 rowsAffected, err := result.RowsAffected() 127 s.NoError(err) 128 s.Equal(numBufferedEvents, int(rowsAffected)) 129 130 filter := sqlplugin.BufferedEventsFilter{ 131 ShardID: shardID, 132 NamespaceID: namespaceID, 133 WorkflowID: workflowID, 134 RunID: runID, 135 } 136 rows, err := s.store.SelectFromBufferedEvents(newExecutionContext(), filter) 137 s.NoError(err) 138 s.Equal(buffers, rows) 139 } 140 141 func (s *historyExecutionBufferSuite) TestDeleteSelect() { 142 shardID := rand.Int31() 143 namespaceID := primitives.NewUUID() 144 workflowID := shuffle.String(testHistoryExecutionWorkflowID) 145 runID := primitives.NewUUID() 146 147 filter := sqlplugin.BufferedEventsFilter{ 148 ShardID: shardID, 149 NamespaceID: namespaceID, 150 WorkflowID: workflowID, 151 RunID: runID, 152 } 153 result, err := s.store.DeleteFromBufferedEvents(newExecutionContext(), filter) 154 s.NoError(err) 155 rowsAffected, err := result.RowsAffected() 156 s.NoError(err) 157 s.Equal(0, int(rowsAffected)) 158 159 rows, err := s.store.SelectFromBufferedEvents(newExecutionContext(), filter) 160 s.NoError(err) 161 s.Equal([]sqlplugin.BufferedEventsRow(nil), rows) 162 } 163 164 func (s *historyExecutionBufferSuite) TestInsertDelete() { 165 numBufferedEvents := 20 166 167 shardID := rand.Int31() 168 namespaceID := primitives.NewUUID() 169 workflowID := shuffle.String(testHistoryExecutionWorkflowID) 170 runID := primitives.NewUUID() 171 172 var buffers []sqlplugin.BufferedEventsRow 173 for i := 0; i < numBufferedEvents; i++ { 174 buffer := s.newRandomExecutionBufferRow(shardID, namespaceID, workflowID, runID) 175 buffers = append(buffers, buffer) 176 } 177 result, err := s.store.InsertIntoBufferedEvents(newExecutionContext(), buffers) 178 s.NoError(err) 179 rowsAffected, err := result.RowsAffected() 180 s.NoError(err) 181 s.Equal(numBufferedEvents, int(rowsAffected)) 182 183 filter := sqlplugin.BufferedEventsFilter{ 184 ShardID: shardID, 185 NamespaceID: namespaceID, 186 WorkflowID: workflowID, 187 RunID: runID, 188 } 189 result, err = s.store.DeleteFromBufferedEvents(newExecutionContext(), filter) 190 s.NoError(err) 191 rowsAffected, err = result.RowsAffected() 192 s.NoError(err) 193 s.Equal(numBufferedEvents, int(rowsAffected)) 194 195 rows, err := s.store.SelectFromBufferedEvents(newExecutionContext(), filter) 196 s.NoError(err) 197 s.Equal([]sqlplugin.BufferedEventsRow(nil), rows) 198 } 199 200 func (s *historyExecutionBufferSuite) newRandomExecutionBufferRow( 201 shardID int32, 202 namespaceID primitives.UUID, 203 workflowID string, 204 runID primitives.UUID, 205 ) sqlplugin.BufferedEventsRow { 206 return sqlplugin.BufferedEventsRow{ 207 ShardID: shardID, 208 NamespaceID: namespaceID, 209 WorkflowID: workflowID, 210 RunID: runID, 211 Data: shuffle.Bytes(testHistoryExecutionBufferData), 212 DataEncoding: testHistoryExecutionBufferEncoding, 213 } 214 }