mirror of https://github.com/grafana/grafana.git
				
				
				
			
		
			
				
	
	
		
			66 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Go
		
	
	
	
			
		
		
	
	
			66 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Go
		
	
	
	
| package sql
 | |
| 
 | |
| import (
 | |
| 	"testing"
 | |
| 
 | |
| 	"github.com/DATA-DOG/go-sqlmock"
 | |
| 	"github.com/stretchr/testify/require"
 | |
| 
 | |
| 	"github.com/grafana/grafana/pkg/storage/unified/resourcepb"
 | |
| 	"github.com/grafana/grafana/pkg/storage/unified/sql/db"
 | |
| 	"github.com/grafana/grafana/pkg/storage/unified/sql/sqltemplate"
 | |
| 	"github.com/grafana/grafana/pkg/storage/unified/sql/test"
 | |
| 	"github.com/grafana/grafana/pkg/util/testutil"
 | |
| )
 | |
| 
 | |
| func expectSuccessfulResourceVersionLock(t *testing.T, dbp test.TestDBProvider, rv int64, timestamp int64) {
 | |
| 	dbp.SQLMock.ExpectQuery("select resource_version, unix_timestamp for update").
 | |
| 		WillReturnRows(sqlmock.NewRows([]string{"resource_version", "unix_timestamp"}).
 | |
| 			AddRow(rv, timestamp))
 | |
| }
 | |
| 
 | |
| func expectSuccessfulResourceVersionSaveRV(t *testing.T, dbp test.TestDBProvider) {
 | |
| 	dbp.SQLMock.ExpectExec("update resource set resource_version").WillReturnResult(sqlmock.NewResult(1, 1))
 | |
| 	dbp.SQLMock.ExpectExec("update resource_history set resource_version").WillReturnResult(sqlmock.NewResult(1, 1))
 | |
| 	dbp.SQLMock.ExpectExec("update resource_version set resource_version").WillReturnResult(sqlmock.NewResult(1, 1))
 | |
| }
 | |
| 
 | |
| func expectSuccessfulResourceVersionExec(t *testing.T, dbp test.TestDBProvider, cbs ...func()) {
 | |
| 	for _, cb := range cbs {
 | |
| 		cb()
 | |
| 	}
 | |
| 	expectSuccessfulResourceVersionLock(t, dbp, 100, 200)
 | |
| 	expectSuccessfulResourceVersionSaveRV(t, dbp)
 | |
| }
 | |
| 
 | |
| func TestResourceVersionManager(t *testing.T) {
 | |
| 	ctx := testutil.NewDefaultTestContext(t)
 | |
| 	dbp := test.NewDBProviderMatchWords(t)
 | |
| 	dialect := sqltemplate.DialectForDriver(dbp.DB.DriverName())
 | |
| 	manager, err := NewResourceVersionManager(ResourceManagerOptions{
 | |
| 		DB:      dbp.DB,
 | |
| 		Dialect: dialect,
 | |
| 	})
 | |
| 	require.NoError(t, err)
 | |
| 	require.NotNil(t, manager)
 | |
| 
 | |
| 	t.Run("should handle single operation", func(t *testing.T) {
 | |
| 		key := &resourcepb.ResourceKey{
 | |
| 			Group:    "test-group",
 | |
| 			Resource: "test-resource",
 | |
| 		}
 | |
| 		dbp.SQLMock.ExpectBegin()
 | |
| 		expectSuccessfulResourceVersionExec(t, dbp, func() {
 | |
| 			dbp.SQLMock.ExpectExec("select 1").WillReturnResult(sqlmock.NewResult(1, 1))
 | |
| 		})
 | |
| 		dbp.SQLMock.ExpectCommit()
 | |
| 
 | |
| 		rv, err := manager.ExecWithRV(ctx, key, func(tx db.Tx) (string, error) {
 | |
| 			_, err := tx.ExecContext(ctx, "select 1")
 | |
| 			return "1234", err
 | |
| 		})
 | |
| 		require.NoError(t, err)
 | |
| 		require.Equal(t, rv, int64(200))
 | |
| 	})
 | |
| }
 |