mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-10-20 19:52:04 +00:00 
			
		
		
		
	This PR is adds almost all tests in `cmd/admin_auth_oauth_test.go` with a bit of refactoring beforehand to make the tests easier to write. These should be legitimate refactors where the implementation changes but the public API/behavior does not change. All of the changes in this PR are done to align with how tests are written in `cmd/admin_auth_ldap_test.go`. Since `cmd/admin_auth_ldap.go` is a sibling file to `cmd/admin_auth_oauth.go`, it seems like their test files should also be aligned. There are some tests added that show the current behavior as not ideal. E.g. not being able to update certain fields, or being able to set fields that are ultimately ignored. These are added so that the behavior is at least shown a bit more visibly. There should likely be a follow-up to fix some of these issues. But that will almost certainly be a breaking change that I'd rather avoid in this PR. Reviewed-on: https://codeberg.org/forgejo/forgejo/pulls/8433 Reviewed-by: Earl Warren <earl-warren@noreply.codeberg.org> Co-authored-by: joneshf <jones3.hardy@gmail.com> Co-committed-by: joneshf <jones3.hardy@gmail.com>
		
			
				
	
	
		
			134 lines
		
	
	
	
		
			3.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			134 lines
		
	
	
	
		
			3.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2023 The Gitea Authors. All rights reserved.
 | |
| // SPDX-License-Identifier: MIT
 | |
| 
 | |
| package cmd
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 	"errors"
 | |
| 	"fmt"
 | |
| 	"os"
 | |
| 	"text/tabwriter"
 | |
| 
 | |
| 	auth_model "forgejo.org/models/auth"
 | |
| 	"forgejo.org/models/db"
 | |
| 	auth_service "forgejo.org/services/auth"
 | |
| 
 | |
| 	"github.com/urfave/cli/v3"
 | |
| )
 | |
| 
 | |
| type (
 | |
| 	authService struct {
 | |
| 		initDB            func(ctx context.Context) error
 | |
| 		createAuthSource  func(context.Context, *auth_model.Source) error
 | |
| 		updateAuthSource  func(context.Context, *auth_model.Source) error
 | |
| 		getAuthSourceByID func(ctx context.Context, id int64) (*auth_model.Source, error)
 | |
| 	}
 | |
| )
 | |
| 
 | |
| func microcmdAuthDelete() *cli.Command {
 | |
| 	return &cli.Command{
 | |
| 		Name:   "delete",
 | |
| 		Usage:  "Delete specific auth source",
 | |
| 		Flags:  []cli.Flag{idFlag()},
 | |
| 		Action: runDeleteAuth,
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func microcmdAuthList() *cli.Command {
 | |
| 	return &cli.Command{
 | |
| 		Name:   "list",
 | |
| 		Usage:  "List auth sources",
 | |
| 		Action: runListAuth,
 | |
| 		Flags: []cli.Flag{
 | |
| 			&cli.IntFlag{
 | |
| 				Name:  "min-width",
 | |
| 				Usage: "Minimal cell width including any padding for the formatted table",
 | |
| 				Value: 0,
 | |
| 			},
 | |
| 			&cli.IntFlag{
 | |
| 				Name:  "tab-width",
 | |
| 				Usage: "width of tab characters in formatted table (equivalent number of spaces)",
 | |
| 				Value: 8,
 | |
| 			},
 | |
| 			&cli.IntFlag{
 | |
| 				Name:  "padding",
 | |
| 				Usage: "padding added to a cell before computing its width",
 | |
| 				Value: 1,
 | |
| 			},
 | |
| 			&cli.StringFlag{
 | |
| 				Name:  "pad-char",
 | |
| 				Usage: `ASCII char used for padding if padchar == '\\t', the Writer will assume that the width of a '\\t' in the formatted output is tabwidth, and cells are left-aligned independent of align_left (for correct-looking results, tabwidth must correspond to the tab width in the viewer displaying the result)`,
 | |
| 				Value: "\t",
 | |
| 			},
 | |
| 			&cli.BoolFlag{
 | |
| 				Name:  "vertical-bars",
 | |
| 				Usage: "Set to true to print vertical bars between columns",
 | |
| 			},
 | |
| 		},
 | |
| 	}
 | |
| }
 | |
| 
 | |
| // newAuthService creates a service with default functions.
 | |
| func newAuthService() *authService {
 | |
| 	return &authService{
 | |
| 		initDB:            initDB,
 | |
| 		createAuthSource:  auth_model.CreateSource,
 | |
| 		updateAuthSource:  auth_model.UpdateSource,
 | |
| 		getAuthSourceByID: auth_model.GetSourceByID,
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func runListAuth(ctx context.Context, c *cli.Command) error {
 | |
| 	ctx, cancel := installSignals(ctx)
 | |
| 	defer cancel()
 | |
| 
 | |
| 	if err := initDB(ctx); err != nil {
 | |
| 		return err
 | |
| 	}
 | |
| 
 | |
| 	authSources, err := db.Find[auth_model.Source](ctx, auth_model.FindSourcesOptions{})
 | |
| 	if err != nil {
 | |
| 		return err
 | |
| 	}
 | |
| 
 | |
| 	flags := tabwriter.AlignRight
 | |
| 	if c.Bool("vertical-bars") {
 | |
| 		flags |= tabwriter.Debug
 | |
| 	}
 | |
| 
 | |
| 	padChar := byte('\t')
 | |
| 	if len(c.String("pad-char")) > 0 {
 | |
| 		padChar = c.String("pad-char")[0]
 | |
| 	}
 | |
| 
 | |
| 	// loop through each source and print
 | |
| 	w := tabwriter.NewWriter(os.Stdout, c.Int("min-width"), c.Int("tab-width"), c.Int("padding"), padChar, flags)
 | |
| 	fmt.Fprint(w, "ID\tName\tType\tEnabled\n")
 | |
| 	for _, source := range authSources {
 | |
| 		fmt.Fprintf(w, "%d\t%s\t%s\t%t\n", source.ID, source.Name, source.Type.String(), source.IsActive)
 | |
| 	}
 | |
| 	w.Flush()
 | |
| 
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| func runDeleteAuth(ctx context.Context, c *cli.Command) error {
 | |
| 	if !c.IsSet("id") {
 | |
| 		return errors.New("--id flag is missing")
 | |
| 	}
 | |
| 
 | |
| 	ctx, cancel := installSignals(ctx)
 | |
| 	defer cancel()
 | |
| 
 | |
| 	if err := initDB(ctx); err != nil {
 | |
| 		return err
 | |
| 	}
 | |
| 
 | |
| 	source, err := auth_model.GetSourceByID(ctx, c.Int64("id"))
 | |
| 	if err != nil {
 | |
| 		return err
 | |
| 	}
 | |
| 
 | |
| 	return auth_service.DeleteSource(ctx, source)
 | |
| }
 |