github.com/mattermosttest/mattermost-server/v5@v5.0.0-20200917143240-9dfa12e121f9/migrations/helper_test.go (about)

     1  // Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
     2  // See LICENSE.txt for license information.
     3  
     4  package migrations
     5  
     6  import (
     7  	"os"
     8  	"time"
     9  
    10  	"github.com/mattermost/mattermost-server/v5/app"
    11  	"github.com/mattermost/mattermost-server/v5/config"
    12  	"github.com/mattermost/mattermost-server/v5/mlog"
    13  	"github.com/mattermost/mattermost-server/v5/model"
    14  	"github.com/mattermost/mattermost-server/v5/store/localcachelayer"
    15  	"github.com/mattermost/mattermost-server/v5/utils"
    16  )
    17  
    18  type TestHelper struct {
    19  	App          *app.App
    20  	Server       *app.Server
    21  	BasicTeam    *model.Team
    22  	BasicUser    *model.User
    23  	BasicUser2   *model.User
    24  	BasicChannel *model.Channel
    25  	BasicPost    *model.Post
    26  
    27  	SystemAdminUser *model.User
    28  
    29  	tempWorkspace string
    30  }
    31  
    32  func setupTestHelper(enterprise bool) *TestHelper {
    33  	store := mainHelper.GetStore()
    34  	store.DropAllTables()
    35  
    36  	memoryStore, err := config.NewMemoryStoreWithOptions(&config.MemoryStoreOptions{IgnoreEnvironmentOverrides: true})
    37  	if err != nil {
    38  		panic("failed to initialize memory store: " + err.Error())
    39  	}
    40  
    41  	var options []app.Option
    42  	options = append(options, app.ConfigStore(memoryStore))
    43  	options = append(options, app.StoreOverride(mainHelper.Store))
    44  
    45  	s, err := app.NewServer(options...)
    46  	if err != nil {
    47  		panic(err)
    48  	}
    49  	// Adds the cache layer to the test store
    50  	s.Store = localcachelayer.NewLocalCacheLayer(s.Store, s.Metrics, s.Cluster, s.CacheProvider)
    51  
    52  	th := &TestHelper{
    53  		App:    app.New(app.ServerConnector(s)),
    54  		Server: s,
    55  	}
    56  
    57  	th.App.UpdateConfig(func(cfg *model.Config) { *cfg.TeamSettings.MaxUsersPerTeam = 50 })
    58  	th.App.UpdateConfig(func(cfg *model.Config) { *cfg.RateLimitSettings.Enable = false })
    59  	prevListenAddress := *th.App.Config().ServiceSettings.ListenAddress
    60  	th.App.UpdateConfig(func(cfg *model.Config) { *cfg.ServiceSettings.ListenAddress = ":0" })
    61  
    62  	serverErr := th.Server.Start()
    63  	if serverErr != nil {
    64  		panic(serverErr)
    65  	}
    66  
    67  	th.App.UpdateConfig(func(cfg *model.Config) { *cfg.ServiceSettings.ListenAddress = prevListenAddress })
    68  
    69  	th.App.DoAppMigrations()
    70  
    71  	th.App.Srv().Store.MarkSystemRanUnitTests()
    72  
    73  	th.App.UpdateConfig(func(cfg *model.Config) { *cfg.TeamSettings.EnableOpenServer = true })
    74  
    75  	if enterprise {
    76  		th.App.Srv().SetLicense(model.NewTestLicense())
    77  	} else {
    78  		th.App.Srv().SetLicense(nil)
    79  	}
    80  
    81  	return th
    82  }
    83  
    84  func SetupEnterprise() *TestHelper {
    85  	return setupTestHelper(true)
    86  }
    87  
    88  func Setup() *TestHelper {
    89  	return setupTestHelper(false)
    90  }
    91  
    92  func (me *TestHelper) InitBasic() *TestHelper {
    93  	me.SystemAdminUser = me.CreateUser()
    94  	me.App.UpdateUserRoles(me.SystemAdminUser.Id, model.SYSTEM_USER_ROLE_ID+" "+model.SYSTEM_ADMIN_ROLE_ID, false)
    95  	me.SystemAdminUser, _ = me.App.GetUser(me.SystemAdminUser.Id)
    96  
    97  	me.BasicTeam = me.CreateTeam()
    98  	me.BasicUser = me.CreateUser()
    99  	me.LinkUserToTeam(me.BasicUser, me.BasicTeam)
   100  	me.BasicUser2 = me.CreateUser()
   101  	me.LinkUserToTeam(me.BasicUser2, me.BasicTeam)
   102  	me.BasicChannel = me.CreateChannel(me.BasicTeam)
   103  	me.BasicPost = me.CreatePost(me.BasicChannel)
   104  
   105  	return me
   106  }
   107  
   108  func (me *TestHelper) MakeEmail() string {
   109  	return "success_" + model.NewId() + "@simulator.amazonses.com"
   110  }
   111  
   112  func (me *TestHelper) CreateTeam() *model.Team {
   113  	id := model.NewId()
   114  	team := &model.Team{
   115  		DisplayName: "dn_" + id,
   116  		Name:        "name" + id,
   117  		Email:       "success+" + id + "@simulator.amazonses.com",
   118  		Type:        model.TEAM_OPEN,
   119  	}
   120  
   121  	utils.DisableDebugLogForTest()
   122  	var err *model.AppError
   123  	if team, err = me.App.CreateTeam(team); err != nil {
   124  		mlog.Error(err.Error())
   125  
   126  		time.Sleep(time.Second)
   127  		panic(err)
   128  	}
   129  	utils.EnableDebugLogForTest()
   130  	return team
   131  }
   132  
   133  func (me *TestHelper) CreateUser() *model.User {
   134  	id := model.NewId()
   135  
   136  	user := &model.User{
   137  		Email:         "success+" + id + "@simulator.amazonses.com",
   138  		Username:      "un_" + id,
   139  		Nickname:      "nn_" + id,
   140  		Password:      "Password1",
   141  		EmailVerified: true,
   142  	}
   143  
   144  	utils.DisableDebugLogForTest()
   145  	var err *model.AppError
   146  	if user, err = me.App.CreateUser(user); err != nil {
   147  		mlog.Error(err.Error())
   148  
   149  		time.Sleep(time.Second)
   150  		panic(err)
   151  	}
   152  	utils.EnableDebugLogForTest()
   153  	return user
   154  }
   155  
   156  func (me *TestHelper) CreateChannel(team *model.Team) *model.Channel {
   157  	return me.createChannel(team, model.CHANNEL_OPEN)
   158  }
   159  
   160  func (me *TestHelper) createChannel(team *model.Team, channelType string) *model.Channel {
   161  	id := model.NewId()
   162  
   163  	channel := &model.Channel{
   164  		DisplayName: "dn_" + id,
   165  		Name:        "name_" + id,
   166  		Type:        channelType,
   167  		TeamId:      team.Id,
   168  		CreatorId:   me.BasicUser.Id,
   169  	}
   170  
   171  	utils.DisableDebugLogForTest()
   172  	var err *model.AppError
   173  	if channel, err = me.App.CreateChannel(channel, true); err != nil {
   174  		mlog.Error(err.Error())
   175  
   176  		time.Sleep(time.Second)
   177  		panic(err)
   178  	}
   179  	utils.EnableDebugLogForTest()
   180  	return channel
   181  }
   182  
   183  func (me *TestHelper) CreateDmChannel(user *model.User) *model.Channel {
   184  	utils.DisableDebugLogForTest()
   185  	var err *model.AppError
   186  	var channel *model.Channel
   187  	if channel, err = me.App.GetOrCreateDirectChannel(me.BasicUser.Id, user.Id); err != nil {
   188  		mlog.Error(err.Error())
   189  
   190  		time.Sleep(time.Second)
   191  		panic(err)
   192  	}
   193  	utils.EnableDebugLogForTest()
   194  	return channel
   195  }
   196  
   197  func (me *TestHelper) CreatePost(channel *model.Channel) *model.Post {
   198  	id := model.NewId()
   199  
   200  	post := &model.Post{
   201  		UserId:    me.BasicUser.Id,
   202  		ChannelId: channel.Id,
   203  		Message:   "message_" + id,
   204  		CreateAt:  model.GetMillis() - 10000,
   205  	}
   206  
   207  	utils.DisableDebugLogForTest()
   208  	var err *model.AppError
   209  	if post, err = me.App.CreatePost(post, channel, false, true); err != nil {
   210  		mlog.Error(err.Error())
   211  
   212  		time.Sleep(time.Second)
   213  		panic(err)
   214  	}
   215  	utils.EnableDebugLogForTest()
   216  	return post
   217  }
   218  
   219  func (me *TestHelper) LinkUserToTeam(user *model.User, team *model.Team) {
   220  	utils.DisableDebugLogForTest()
   221  
   222  	err := me.App.JoinUserToTeam(team, user, "")
   223  	if err != nil {
   224  		mlog.Error(err.Error())
   225  
   226  		time.Sleep(time.Second)
   227  		panic(err)
   228  	}
   229  
   230  	utils.EnableDebugLogForTest()
   231  }
   232  
   233  func (me *TestHelper) AddUserToChannel(user *model.User, channel *model.Channel) *model.ChannelMember {
   234  	utils.DisableDebugLogForTest()
   235  
   236  	member, err := me.App.AddUserToChannel(user, channel)
   237  	if err != nil {
   238  		mlog.Error(err.Error())
   239  
   240  		time.Sleep(time.Second)
   241  		panic(err)
   242  	}
   243  
   244  	utils.EnableDebugLogForTest()
   245  
   246  	return member
   247  }
   248  
   249  func (me *TestHelper) TearDown() {
   250  	// Clean all the caches
   251  	me.App.Srv().InvalidateAllCaches()
   252  	me.Server.Shutdown()
   253  	if me.tempWorkspace != "" {
   254  		os.RemoveAll(me.tempWorkspace)
   255  	}
   256  }
   257  
   258  func (me *TestHelper) ResetRoleMigration() {
   259  	sqlSupplier := mainHelper.GetSQLSupplier()
   260  	if _, err := sqlSupplier.GetMaster().Exec("DELETE from Roles"); err != nil {
   261  		panic(err)
   262  	}
   263  
   264  	mainHelper.GetClusterInterface().SendClearRoleCacheMessage()
   265  
   266  	if _, err := sqlSupplier.GetMaster().Exec("DELETE from Systems where Name = :Name", map[string]interface{}{"Name": app.ADVANCED_PERMISSIONS_MIGRATION_KEY}); err != nil {
   267  		panic(err)
   268  	}
   269  }
   270  
   271  func (me *TestHelper) DeleteAllJobsByTypeAndMigrationKey(jobType string, migrationKey string) {
   272  	jobs, err := me.App.Srv().Store.Job().GetAllByType(model.JOB_TYPE_MIGRATIONS)
   273  	if err != nil {
   274  		panic(err)
   275  	}
   276  
   277  	for _, job := range jobs {
   278  		if key, ok := job.Data[JOB_DATA_KEY_MIGRATION]; ok && key == migrationKey {
   279  			if _, err = me.App.Srv().Store.Job().Delete(job.Id); err != nil {
   280  				panic(err)
   281  			}
   282  		}
   283  	}
   284  }