|
| 1 | +// Copyright 2023 The Gitea Authors. All rights reserved. |
| 2 | +// SPDX-License-Identifier: MIT |
| 3 | + |
| 4 | +package cmd |
| 5 | + |
| 6 | +import ( |
| 7 | + "fmt" |
| 8 | + "strings" |
| 9 | + "testing" |
| 10 | + |
| 11 | + "code.gitea.io/gitea/models/db" |
| 12 | + "code.gitea.io/gitea/models/unittest" |
| 13 | + user_model "code.gitea.io/gitea/models/user" |
| 14 | + |
| 15 | + "github.com/stretchr/testify/assert" |
| 16 | +) |
| 17 | + |
| 18 | +func TestAdminUserCreate(t *testing.T) { |
| 19 | + app := NewMainApp(AppVersion{}) |
| 20 | + |
| 21 | + reset := func() { |
| 22 | + assert.NoError(t, db.TruncateBeans(db.DefaultContext, &user_model.User{})) |
| 23 | + assert.NoError(t, db.TruncateBeans(db.DefaultContext, &user_model.EmailAddress{})) |
| 24 | + } |
| 25 | + |
| 26 | + type createCheck struct{ IsAdmin, MustChangePassword bool } |
| 27 | + createUser := func(name, args string) createCheck { |
| 28 | + assert. NoError( t, app. Run( strings. Fields( fmt. Sprintf( "./gitea admin user create --username %s --email %[email protected] %s --password foobar", name, name, args)))) |
| 29 | + u := unittest.AssertExistsAndLoadBean(t, &user_model.User{LowerName: name}) |
| 30 | + return createCheck{u.IsAdmin, u.MustChangePassword} |
| 31 | + } |
| 32 | + reset() |
| 33 | + assert.Equal(t, createCheck{IsAdmin: false, MustChangePassword: false}, createUser("u", ""), "first non-admin user doesn't need to change password") |
| 34 | + |
| 35 | + reset() |
| 36 | + assert.Equal(t, createCheck{IsAdmin: true, MustChangePassword: false}, createUser("u", "--admin"), "first admin user doesn't need to change password") |
| 37 | + |
| 38 | + reset() |
| 39 | + assert.Equal(t, createCheck{IsAdmin: true, MustChangePassword: true}, createUser("u", "--admin --must-change-password")) |
| 40 | + assert.Equal(t, createCheck{IsAdmin: true, MustChangePassword: true}, createUser("u2", "--admin")) |
| 41 | + assert.Equal(t, createCheck{IsAdmin: true, MustChangePassword: false}, createUser("u3", "--admin --must-change-password=false")) |
| 42 | + assert.Equal(t, createCheck{IsAdmin: false, MustChangePassword: true}, createUser("u4", "")) |
| 43 | + assert.Equal(t, createCheck{IsAdmin: false, MustChangePassword: false}, createUser("u5", "--must-change-password=false")) |
| 44 | +} |
0 commit comments