mirror of https://github.com/grafana/grafana.git
Spanner-related fixes (#102376)
* Fix UNION syntax in resourcepermissions package. * Fix migrations in usermig package to work with Spanner. * Fix health query. * Use more connections for integration tests. * Add test-go-integration-spanner target to run integration tests against Spanner emulator. * Add test for enterprise. * Don't delete sequence number for migration_log.id column. * Only bump max open connections to 20 for Spanner. Lower integration test timeout.
This commit is contained in:
parent
229f37edb0
commit
0c58d39e76
7
Makefile
7
Makefile
|
@ -311,6 +311,13 @@ test-go-integration-memcached: ## Run integration tests for memcached cache.
|
||||||
$(GO) clean -testcache
|
$(GO) clean -testcache
|
||||||
MEMCACHED_HOSTS=localhost:11211 $(GO) test $(GO_RACE_FLAG) $(GO_TEST_FLAGS) -run IntegrationMemcached -covermode=atomic -timeout=2m $(GO_INTEGRATION_TESTS)
|
MEMCACHED_HOSTS=localhost:11211 $(GO) test $(GO_RACE_FLAG) $(GO_TEST_FLAGS) -run IntegrationMemcached -covermode=atomic -timeout=2m $(GO_INTEGRATION_TESTS)
|
||||||
|
|
||||||
|
.PHONY: test-go-integration-spanner
|
||||||
|
test-go-integration-spanner: ## Run integration tests for Spanner backend with flags. Uses spanner-emulator on localhost:9010 and localhost:9020.
|
||||||
|
@if [ "${WIRE_TAGS}" != "enterprise" ]; then echo "Spanner integration test require enterprise setup"; exit 1; fi
|
||||||
|
@echo "test backend integration spanner tests"
|
||||||
|
GRAFANA_TEST_DB=spanner SPANNER_DB=emulator \
|
||||||
|
$(GO) test $(GO_RACE_FLAG) $(GO_TEST_FLAGS) -p=1 -count=1 -v -run "^TestIntegration" -covermode=atomic -timeout=2m $(GO_INTEGRATION_TESTS)
|
||||||
|
|
||||||
.PHONY: test-js
|
.PHONY: test-js
|
||||||
test-js: ## Run tests for frontend.
|
test-js: ## Run tests for frontend.
|
||||||
@echo "test frontend"
|
@echo "test frontend"
|
||||||
|
|
|
@ -15,7 +15,7 @@ func (hs *HTTPServer) databaseHealthy(ctx context.Context) bool {
|
||||||
}
|
}
|
||||||
|
|
||||||
err := hs.SQLStore.WithDbSession(ctx, func(session *db.Session) error {
|
err := hs.SQLStore.WithDbSession(ctx, func(session *db.Session) error {
|
||||||
_, err := session.Exec("SELECT 1")
|
_, err := session.Query("SELECT 1")
|
||||||
return err
|
return err
|
||||||
})
|
})
|
||||||
healthy := err == nil
|
healthy := err == nil
|
||||||
|
|
|
@ -449,7 +449,7 @@ func (s *store) getResourcePermissions(sess *db.Session, orgID int64, query GetR
|
||||||
builtin := builtinSelect + builtinFrom + where
|
builtin := builtinSelect + builtinFrom + where
|
||||||
args = append(args, args[:initialLength]...)
|
args = append(args, args[:initialLength]...)
|
||||||
|
|
||||||
sql := userQuery + " UNION " + team + " UNION " + builtin
|
sql := userQuery + " " + s.sql.GetDialect().UnionDistinct() + " " + team + " " + s.sql.GetDialect().UnionDistinct() + " " + builtin
|
||||||
queryResults := make([]flatResourcePermission, 0)
|
queryResults := make([]flatResourcePermission, 0)
|
||||||
if err := sess.SQL(sql, args...).Find(&queryResults); err != nil {
|
if err := sess.SQL(sql, args...).Find(&queryResults); err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
|
|
|
@ -72,6 +72,20 @@ func (p *ServiceAccountsSameLoginCrossOrgs) Exec(sess *xorm.Session, mg *migrato
|
||||||
AND is_service_account = 1
|
AND is_service_account = 1
|
||||||
AND login NOT LIKE 'sa-' || CAST(org_id AS TEXT) || '-%';
|
AND login NOT LIKE 'sa-' || CAST(org_id AS TEXT) || '-%';
|
||||||
`)
|
`)
|
||||||
|
case migrator.Spanner:
|
||||||
|
_, err = p.sess.Exec(`
|
||||||
|
UPDATE user
|
||||||
|
SET login = CONCAT('sa-', CAST(org_id AS STRING), '-',
|
||||||
|
CASE
|
||||||
|
WHEN login LIKE 'sa-%' THEN SUBSTRING(login, 4)
|
||||||
|
ELSE login
|
||||||
|
END
|
||||||
|
)
|
||||||
|
WHERE login IS NOT NULL
|
||||||
|
AND is_service_account
|
||||||
|
AND login NOT LIKE CONCAT('sa-', CAST(org_id AS STRING), '-%')
|
||||||
|
`)
|
||||||
|
|
||||||
default:
|
default:
|
||||||
return fmt.Errorf("dialect not supported: %s", p.dialect)
|
return fmt.Errorf("dialect not supported: %s", p.dialect)
|
||||||
}
|
}
|
||||||
|
@ -128,6 +142,19 @@ func (p *ServiceAccountsDeduplicateOrgInLogin) Exec(sess *xorm.Session, mg *migr
|
||||||
WHERE u2.login = 'sa-' || CAST(u.org_id AS TEXT) || SUBSTRING(u.login, LENGTH('sa-'||CAST(u.org_id AS TEXT)||'-'||CAST(u.org_id AS TEXT))+1)
|
WHERE u2.login = 'sa-' || CAST(u.org_id AS TEXT) || SUBSTRING(u.login, LENGTH('sa-'||CAST(u.org_id AS TEXT)||'-'||CAST(u.org_id AS TEXT))+1)
|
||||||
);;
|
);;
|
||||||
`)
|
`)
|
||||||
|
case migrator.Spanner:
|
||||||
|
_, err = sess.Exec(`
|
||||||
|
UPDATE ` + dialect.Quote("user") + ` AS u
|
||||||
|
SET login = 'sa-' || CAST(u.org_id AS STRING) || SUBSTRING(u.login, LENGTH('sa-'||CAST(u.org_id AS STRING)||'-'||CAST(u.org_id AS STRING))+1)
|
||||||
|
WHERE u.login IS NOT NULL
|
||||||
|
AND u.is_service_account
|
||||||
|
AND u.login LIKE 'sa-'||CAST(u.org_id AS STRING)||'-'||CAST(u.org_id AS STRING)||'-%'
|
||||||
|
AND NOT EXISTS (
|
||||||
|
SELECT 1
|
||||||
|
FROM ` + dialect.Quote("user") + `AS u2
|
||||||
|
WHERE u2.login = 'sa-' || CAST(u.org_id AS STRING) || SUBSTRING(u.login, LENGTH('sa-'||CAST(u.org_id AS STRING)||'-'||CAST(u.org_id AS STRING))+1)
|
||||||
|
);;
|
||||||
|
`)
|
||||||
default:
|
default:
|
||||||
return fmt.Errorf("dialect not supported: %s", dialect)
|
return fmt.Errorf("dialect not supported: %s", dialect)
|
||||||
}
|
}
|
||||||
|
|
|
@ -30,7 +30,7 @@ func (p *UsersLowerCaseLoginAndEmail) SQL(dialect migrator.Dialect) string {
|
||||||
func (p *UsersLowerCaseLoginAndEmail) Exec(sess *xorm.Session, mg *migrator.Migrator) error {
|
func (p *UsersLowerCaseLoginAndEmail) Exec(sess *xorm.Session, mg *migrator.Migrator) error {
|
||||||
// Get all users
|
// Get all users
|
||||||
users := make([]*user.User, 0)
|
users := make([]*user.User, 0)
|
||||||
err := sess.Table("user").Find(&users)
|
err := sess.Table("user").Asc("created").Find(&users)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
|
@ -147,6 +147,9 @@ func (s *SpannerDialect) TruncateDBTables(engine *xorm.Engine) error {
|
||||||
switch table.Name {
|
switch table.Name {
|
||||||
case "":
|
case "":
|
||||||
continue
|
continue
|
||||||
|
case "autoincrement_sequences":
|
||||||
|
// Don't delete sequence number for migration_log.id column.
|
||||||
|
statements = append(statements, fmt.Sprintf("DELETE FROM %v WHERE name <> 'migration_log:id'", s.Quote(table.Name)))
|
||||||
case "migration_log":
|
case "migration_log":
|
||||||
continue
|
continue
|
||||||
case "dashboard_acl":
|
case "dashboard_acl":
|
||||||
|
|
|
@ -495,9 +495,17 @@ func CreateGrafDir(t *testing.T, opts GrafanaOpts) (string, string) {
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
_, err = dbSection.NewKey("query_retries", fmt.Sprintf("%d", queryRetries))
|
_, err = dbSection.NewKey("query_retries", fmt.Sprintf("%d", queryRetries))
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
_, err = dbSection.NewKey("max_open_conn", "2")
|
if db.IsTestDBSpanner() {
|
||||||
|
_, err = dbSection.NewKey("max_open_conn", "20")
|
||||||
|
} else {
|
||||||
|
_, err = dbSection.NewKey("max_open_conn", "2")
|
||||||
|
}
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
_, err = dbSection.NewKey("max_idle_conn", "2")
|
if db.IsTestDBSpanner() {
|
||||||
|
_, err = dbSection.NewKey("max_idle_conn", "20")
|
||||||
|
} else {
|
||||||
|
_, err = dbSection.NewKey("max_idle_conn", "2")
|
||||||
|
}
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
cfgPath := filepath.Join(cfgDir, "test.ini")
|
cfgPath := filepath.Join(cfgDir, "test.ini")
|
||||||
|
|
Loading…
Reference in New Issue