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  }