/* GoToSocial Copyright (C) 2021 GoToSocial Authors admin@gotosocial.org This program is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more details. You should have received a copy of the GNU Affero General Public License along with this program. If not, see . */ package testrig import ( "context" "os" "github.com/sirupsen/logrus" "github.com/superseriousbusiness/gotosocial/internal/db" "github.com/superseriousbusiness/gotosocial/internal/db/bundb" "github.com/superseriousbusiness/gotosocial/internal/gtsmodel" "github.com/superseriousbusiness/gotosocial/internal/oauth" ) var testModels []interface{} = []interface{}{ >smodel.Account{}, >smodel.Application{}, >smodel.Block{}, >smodel.DomainBlock{}, >smodel.EmailDomainBlock{}, >smodel.Follow{}, >smodel.FollowRequest{}, >smodel.MediaAttachment{}, >smodel.Mention{}, >smodel.Status{}, >smodel.StatusToEmoji{}, >smodel.StatusToTag{}, >smodel.StatusFave{}, >smodel.StatusBookmark{}, >smodel.StatusMute{}, >smodel.Tag{}, >smodel.User{}, >smodel.Emoji{}, >smodel.Instance{}, >smodel.Notification{}, >smodel.RouterSession{}, &oauth.Token{}, &oauth.Client{}, } // NewTestDB returns a new initialized, empty database for testing. // // If the environment variable GTS_DB_ADDRESS is set, it will take that // value as the database address instead. func NewTestDB() db.DB { config := NewTestConfig() alternateAddress := os.Getenv("GTS_DB_ADDRESS") if alternateAddress != "" { config.DBConfig.Address = alternateAddress } l := logrus.New() l.SetLevel(logrus.TraceLevel) testDB, err := bundb.NewBunDBService(context.Background(), config, l) if err != nil { logrus.Panic(err) } return testDB } // StandardDBSetup populates a given db with all the necessary tables/models for perfoming tests. // // The accounts parameter is provided in case the db should be populated with a certain set of accounts. // If accounts is nil, then the standard test accounts will be used. // // When testing http signatures, you should pass into this function the same accounts map that you generated // signatures with, otherwise this function will randomly generate new keys for accounts and signature // verification will fail. func StandardDBSetup(db db.DB, accounts map[string]*gtsmodel.Account) { if db == nil { logrus.Panic("db setup: db was nil") } ctx := context.Background() for _, m := range testModels { if err := db.CreateTable(ctx, m); err != nil { logrus.Panicf("error creating table for %+v: %s", m, err) } } for _, v := range NewTestTokens() { if err := db.Put(ctx, v); err != nil { logrus.Panic(err) } } for _, v := range NewTestClients() { if err := db.Put(ctx, v); err != nil { logrus.Panic(err) } } for _, v := range NewTestApplications() { if err := db.Put(ctx, v); err != nil { logrus.Panic(err) } } for _, v := range NewTestUsers() { if err := db.Put(ctx, v); err != nil { logrus.Panic(err) } } if accounts == nil { for _, v := range NewTestAccounts() { if err := db.Put(ctx, v); err != nil { logrus.Panic(err) } } } else { for _, v := range accounts { if err := db.Put(ctx, v); err != nil { logrus.Panic(err) } } } for _, v := range NewTestAttachments() { if err := db.Put(ctx, v); err != nil { logrus.Panic(err) } } for _, v := range NewTestStatuses() { if err := db.PutStatus(ctx, v); err != nil { logrus.Panic(err) } } for _, v := range NewTestEmojis() { if err := db.Put(ctx, v); err != nil { logrus.Panic(err) } } for _, v := range NewTestTags() { if err := db.Put(ctx, v); err != nil { logrus.Panic(err) } } for _, v := range NewTestMentions() { if err := db.Put(ctx, v); err != nil { logrus.Panic(err) } } for _, v := range NewTestFaves() { if err := db.Put(ctx, v); err != nil { logrus.Panic(err) } } for _, v := range NewTestFollows() { if err := db.Put(ctx, v); err != nil { logrus.Panic(err) } } for _, v := range NewTestNotifications() { if err := db.Put(ctx, v); err != nil { logrus.Panic(err) } } if err := db.CreateInstanceAccount(ctx); err != nil { logrus.Panic(err) } if err := db.CreateInstanceInstance(ctx); err != nil { logrus.Panic(err) } logrus.Debug("testing db setup complete") } // StandardDBTeardown drops all the standard testing tables/models from the database to ensure it's clean for the next test. func StandardDBTeardown(db db.DB) { ctx := context.Background() if db == nil { logrus.Panic("db teardown: db was nil") } for _, m := range testModels { if err := db.DropTable(ctx, m); err != nil { logrus.Panic(err) } } }