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 }