mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2025-01-07 07:35:29 +00:00
[F3] replace f3 with forgejo-cli f3
This commit is contained in:
parent
9835fbefa2
commit
7ba7ceef1b
9 changed files with 171 additions and 177 deletions
|
@ -35,7 +35,8 @@ func SubcmdActionsGenerateRunnerToken(ctx context.Context) *cli.Command {
|
||||||
return &cli.Command{
|
return &cli.Command{
|
||||||
Name: "generate-runner-token",
|
Name: "generate-runner-token",
|
||||||
Usage: "Generate a new token for a runner to use to register with the server",
|
Usage: "Generate a new token for a runner to use to register with the server",
|
||||||
Action: prepareWorkPathAndCustomConf(ctx, func(cliCtx *cli.Context) error { return RunGenerateActionsRunnerToken(ctx, cliCtx) }),
|
Before: prepareWorkPathAndCustomConf(ctx),
|
||||||
|
Action: func(cliCtx *cli.Context) error { return RunGenerateActionsRunnerToken(ctx, cliCtx) },
|
||||||
Flags: []cli.Flag{
|
Flags: []cli.Flag{
|
||||||
&cli.StringFlag{
|
&cli.StringFlag{
|
||||||
Name: "scope",
|
Name: "scope",
|
||||||
|
@ -59,7 +60,8 @@ func SubcmdActionsRegister(ctx context.Context) *cli.Command {
|
||||||
return &cli.Command{
|
return &cli.Command{
|
||||||
Name: "register",
|
Name: "register",
|
||||||
Usage: "Idempotent registration of a runner using a shared secret",
|
Usage: "Idempotent registration of a runner using a shared secret",
|
||||||
Action: prepareWorkPathAndCustomConf(ctx, func(cliCtx *cli.Context) error { return RunRegister(ctx, cliCtx) }),
|
Before: prepareWorkPathAndCustomConf(ctx),
|
||||||
|
Action: func(cliCtx *cli.Context) error { return RunRegister(ctx, cliCtx) },
|
||||||
Flags: []cli.Flag{
|
Flags: []cli.Flag{
|
||||||
&cli.StringFlag{
|
&cli.StringFlag{
|
||||||
Name: "secret",
|
Name: "secret",
|
||||||
|
@ -219,25 +221,3 @@ func RunGenerateActionsRunnerToken(ctx context.Context, cliCtx *cli.Context) err
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func prepareWorkPathAndCustomConf(ctx context.Context, action cli.ActionFunc) func(cliCtx *cli.Context) error {
|
|
||||||
return func(cliCtx *cli.Context) error {
|
|
||||||
if !ContextGetNoInit(ctx) {
|
|
||||||
var args setting.ArgWorkPathAndCustomConf
|
|
||||||
// from children to parent, check the global flags
|
|
||||||
for _, curCtx := range cliCtx.Lineage() {
|
|
||||||
if curCtx.IsSet("work-path") && args.WorkPath == "" {
|
|
||||||
args.WorkPath = curCtx.String("work-path")
|
|
||||||
}
|
|
||||||
if curCtx.IsSet("custom-path") && args.CustomPath == "" {
|
|
||||||
args.CustomPath = curCtx.String("custom-path")
|
|
||||||
}
|
|
||||||
if curCtx.IsSet("config") && args.CustomConf == "" {
|
|
||||||
args.CustomConf = curCtx.String("config")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
setting.InitWorkPathAndCommonConfig(os.Getenv, args)
|
|
||||||
}
|
|
||||||
return action(cliCtx)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
|
@ -4,74 +4,32 @@ package forgejo
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"fmt"
|
|
||||||
|
|
||||||
auth_model "code.gitea.io/gitea/models/auth"
|
|
||||||
user_model "code.gitea.io/gitea/models/user"
|
|
||||||
"code.gitea.io/gitea/modules/git"
|
"code.gitea.io/gitea/modules/git"
|
||||||
"code.gitea.io/gitea/services/f3/util"
|
|
||||||
|
|
||||||
"github.com/urfave/cli/v2"
|
"github.com/urfave/cli/v2"
|
||||||
f3_types "lab.forgefriends.org/friendlyforgeformat/gof3/config/types"
|
f3_cmd "lab.forgefriends.org/friendlyforgeformat/gof3/cmd"
|
||||||
f3_common "lab.forgefriends.org/friendlyforgeformat/gof3/forges/common"
|
|
||||||
f3_format "lab.forgefriends.org/friendlyforgeformat/gof3/format"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func CmdF3(ctx context.Context) *cli.Command {
|
func CmdF3(ctx context.Context) *cli.Command {
|
||||||
return &cli.Command{
|
return &cli.Command{
|
||||||
Name: "f3",
|
Name: "f3",
|
||||||
Usage: "Friendly Forge Format (F3) format export/import.",
|
Usage: "F3",
|
||||||
Description: "Import or export a repository from or to the Friendly Forge Format (F3) format.",
|
Subcommands: []*cli.Command{
|
||||||
Action: prepareWorkPathAndCustomConf(ctx, func(cliCtx *cli.Context) error { return RunF3(ctx, cliCtx) }),
|
SubcmdF3Mirror(ctx),
|
||||||
Flags: []cli.Flag{
|
|
||||||
&cli.StringFlag{
|
|
||||||
Name: "directory",
|
|
||||||
Value: "./f3",
|
|
||||||
Usage: "Path of the directory where the F3 dump is stored",
|
|
||||||
},
|
|
||||||
&cli.StringFlag{
|
|
||||||
Name: "user",
|
|
||||||
Value: "",
|
|
||||||
Usage: "The name of the user who owns the repository",
|
|
||||||
},
|
|
||||||
&cli.StringFlag{
|
|
||||||
Name: "repository",
|
|
||||||
Value: "",
|
|
||||||
Usage: "The name of the repository",
|
|
||||||
},
|
|
||||||
&cli.StringFlag{
|
|
||||||
Name: "authentication-source",
|
|
||||||
Value: "",
|
|
||||||
Usage: "The name of the authentication source matching the forge of origin",
|
|
||||||
},
|
|
||||||
&cli.BoolFlag{
|
|
||||||
Name: "no-pull-request",
|
|
||||||
Usage: "Do not dump pull requests",
|
|
||||||
},
|
|
||||||
&cli.BoolFlag{
|
|
||||||
Name: "import",
|
|
||||||
Usage: "Import from the directory",
|
|
||||||
},
|
|
||||||
&cli.BoolFlag{
|
|
||||||
Name: "export",
|
|
||||||
Usage: "Export to the directory",
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func getAuthenticationSource(ctx context.Context, authenticationSource string) (*auth_model.Source, error) {
|
func SubcmdF3Mirror(ctx context.Context) *cli.Command {
|
||||||
source, err := auth_model.GetSourceByName(ctx, authenticationSource)
|
mirrorCmd := f3_cmd.CreateCmdMirror(ctx)
|
||||||
if err != nil {
|
mirrorCmd.Before = prepareWorkPathAndCustomConf(ctx)
|
||||||
if auth_model.IsErrSourceNotExist(err) {
|
f3Action := mirrorCmd.Action
|
||||||
return nil, nil
|
mirrorCmd.Action = func(c *cli.Context) error { return runMirror(ctx, c, f3Action) }
|
||||||
}
|
return mirrorCmd
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
return source, nil
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func RunF3(ctx context.Context, cliCtx *cli.Context) error {
|
func runMirror(ctx context.Context, c *cli.Context, action cli.ActionFunc) error {
|
||||||
var cancel context.CancelFunc
|
var cancel context.CancelFunc
|
||||||
if !ContextGetNoInit(ctx) {
|
if !ContextGetNoInit(ctx) {
|
||||||
ctx, cancel = installSignals(ctx)
|
ctx, cancel = installSignals(ctx)
|
||||||
|
@ -86,52 +44,5 @@ func RunF3(ctx context.Context, cliCtx *cli.Context) error {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
doer, err := user_model.GetAdminUser(ctx)
|
return action(c)
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
features := f3_types.AllFeatures
|
|
||||||
if cliCtx.Bool("no-pull-request") {
|
|
||||||
features.PullRequests = false
|
|
||||||
}
|
|
||||||
|
|
||||||
var sourceID int64
|
|
||||||
sourceName := cliCtx.String("authentication-source")
|
|
||||||
source, err := getAuthenticationSource(ctx, sourceName)
|
|
||||||
if err != nil {
|
|
||||||
return fmt.Errorf("error retrieving the authentication-source %s %v", sourceName, err)
|
|
||||||
}
|
|
||||||
if source != nil {
|
|
||||||
sourceID = source.ID
|
|
||||||
}
|
|
||||||
|
|
||||||
forgejo := util.ForgejoForgeRoot(features, doer, sourceID)
|
|
||||||
f3 := util.F3ForgeRoot(features, cliCtx.String("directory"))
|
|
||||||
|
|
||||||
if cliCtx.Bool("export") {
|
|
||||||
forgejo.Forge.Users.List(ctx)
|
|
||||||
user := forgejo.Forge.Users.GetFromFormat(ctx, &f3_format.User{UserName: cliCtx.String("user")})
|
|
||||||
if user.IsNil() {
|
|
||||||
return fmt.Errorf("%s is not a known user", cliCtx.String("user"))
|
|
||||||
}
|
|
||||||
|
|
||||||
user.Projects.List(ctx)
|
|
||||||
project := user.Projects.GetFromFormat(ctx, &f3_format.Project{Name: cliCtx.String("repository")})
|
|
||||||
if project.IsNil() {
|
|
||||||
return fmt.Errorf("%s/%s is not a known repository", cliCtx.String("user"), cliCtx.String("repository"))
|
|
||||||
}
|
|
||||||
|
|
||||||
options := f3_common.NewMirrorOptionsRecurse(user, project)
|
|
||||||
f3.Forge.Mirror(ctx, forgejo.Forge, options)
|
|
||||||
fmt.Fprintln(ContextGetStdout(ctx), "exported")
|
|
||||||
} else if cliCtx.Bool("import") {
|
|
||||||
options := f3_common.NewMirrorOptionsRecurse()
|
|
||||||
forgejo.Forge.Mirror(ctx, f3.Forge, options)
|
|
||||||
fmt.Fprintln(ContextGetStdout(ctx), "imported")
|
|
||||||
} else {
|
|
||||||
return fmt.Errorf("either --import or --export must be specified")
|
|
||||||
}
|
|
||||||
|
|
||||||
return nil
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -146,3 +146,25 @@ func handleCliResponseExtra(ctx context.Context, extra private.ResponseExtra) er
|
||||||
}
|
}
|
||||||
return cli.Exit(extra.Error, 1)
|
return cli.Exit(extra.Error, 1)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func prepareWorkPathAndCustomConf(ctx context.Context) func(c *cli.Context) error {
|
||||||
|
return func(c *cli.Context) error {
|
||||||
|
if !ContextGetNoInit(ctx) {
|
||||||
|
var args setting.ArgWorkPathAndCustomConf
|
||||||
|
// from children to parent, check the global flags
|
||||||
|
for _, curCtx := range c.Lineage() {
|
||||||
|
if curCtx.IsSet("work-path") && args.WorkPath == "" {
|
||||||
|
args.WorkPath = curCtx.String("work-path")
|
||||||
|
}
|
||||||
|
if curCtx.IsSet("custom-path") && args.CustomPath == "" {
|
||||||
|
args.CustomPath = curCtx.String("custom-path")
|
||||||
|
}
|
||||||
|
if curCtx.IsSet("config") && args.CustomConf == "" {
|
||||||
|
args.CustomConf = curCtx.String("config")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
setting.InitWorkPathAndCommonConfig(os.Getenv, args)
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
2
go.mod
2
go.mod
|
@ -117,7 +117,7 @@ require (
|
||||||
gopkg.in/gomail.v2 v2.0.0-20160411212932-81ebce5c23df
|
gopkg.in/gomail.v2 v2.0.0-20160411212932-81ebce5c23df
|
||||||
gopkg.in/ini.v1 v1.67.0
|
gopkg.in/ini.v1 v1.67.0
|
||||||
gopkg.in/yaml.v3 v3.0.1
|
gopkg.in/yaml.v3 v3.0.1
|
||||||
lab.forgefriends.org/friendlyforgeformat/gof3 v0.0.0-20230727095825-ce0c3d1c91ae
|
lab.forgefriends.org/friendlyforgeformat/gof3 v0.0.0-20230731200648-8a343728fa3d
|
||||||
mvdan.cc/xurls/v2 v2.5.0
|
mvdan.cc/xurls/v2 v2.5.0
|
||||||
strk.kbt.io/projects/go/libravatar v0.0.0-20191008002943-06d1c002b251
|
strk.kbt.io/projects/go/libravatar v0.0.0-20191008002943-06d1c002b251
|
||||||
xorm.io/builder v0.3.13
|
xorm.io/builder v0.3.13
|
||||||
|
|
4
go.sum
4
go.sum
|
@ -1573,8 +1573,8 @@ honnef.co/go/tools v0.0.0-20190523083050-ea95bdfd59fc/go.mod h1:rf3lG4BRIbNafJWh
|
||||||
honnef.co/go/tools v0.0.1-2019.2.3/go.mod h1:a3bituU0lyd329TUQxRnasdCoJDkEUEAqEt0JzvZhAg=
|
honnef.co/go/tools v0.0.1-2019.2.3/go.mod h1:a3bituU0lyd329TUQxRnasdCoJDkEUEAqEt0JzvZhAg=
|
||||||
honnef.co/go/tools v0.0.1-2020.1.3/go.mod h1:X/FiERA/W4tHapMX5mGpAtMSVEeEUOyHaw9vFzvIQ3k=
|
honnef.co/go/tools v0.0.1-2020.1.3/go.mod h1:X/FiERA/W4tHapMX5mGpAtMSVEeEUOyHaw9vFzvIQ3k=
|
||||||
honnef.co/go/tools v0.0.1-2020.1.4/go.mod h1:X/FiERA/W4tHapMX5mGpAtMSVEeEUOyHaw9vFzvIQ3k=
|
honnef.co/go/tools v0.0.1-2020.1.4/go.mod h1:X/FiERA/W4tHapMX5mGpAtMSVEeEUOyHaw9vFzvIQ3k=
|
||||||
lab.forgefriends.org/friendlyforgeformat/gof3 v0.0.0-20230727095825-ce0c3d1c91ae h1:O5colcyXVMuo4iVaXmBux8wa+HROJfhFOnA/TLKXIew=
|
lab.forgefriends.org/friendlyforgeformat/gof3 v0.0.0-20230731200648-8a343728fa3d h1:xI6pGGV0z7Q6/YWUwYl/PEAcRwFN6nEzk7yD8MPnF9A=
|
||||||
lab.forgefriends.org/friendlyforgeformat/gof3 v0.0.0-20230727095825-ce0c3d1c91ae/go.mod h1:TcKaEsgVihjAjw290iDvvirCT0P+DZNpzc0ZgNgy3E4=
|
lab.forgefriends.org/friendlyforgeformat/gof3 v0.0.0-20230731200648-8a343728fa3d/go.mod h1:TcKaEsgVihjAjw290iDvvirCT0P+DZNpzc0ZgNgy3E4=
|
||||||
lukechampine.com/uint128 v1.1.1/go.mod h1:c4eWIwlEGaxC/+H1VguhU4PHXNWDCDMUlWdIWl2j1gk=
|
lukechampine.com/uint128 v1.1.1/go.mod h1:c4eWIwlEGaxC/+H1VguhU4PHXNWDCDMUlWdIWl2j1gk=
|
||||||
lukechampine.com/uint128 v1.2.0 h1:mBi/5l91vocEN8otkC5bDLhi2KdCticRiwbdB0O+rjI=
|
lukechampine.com/uint128 v1.2.0 h1:mBi/5l91vocEN8otkC5bDLhi2KdCticRiwbdB0O+rjI=
|
||||||
lukechampine.com/uint128 v1.2.0/go.mod h1:c4eWIwlEGaxC/+H1VguhU4PHXNWDCDMUlWdIWl2j1gk=
|
lukechampine.com/uint128 v1.2.0/go.mod h1:c4eWIwlEGaxC/+H1VguhU4PHXNWDCDMUlWdIWl2j1gk=
|
||||||
|
|
|
@ -3,18 +3,34 @@
|
||||||
package driver
|
package driver
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"context"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
|
||||||
|
auth_model "code.gitea.io/gitea/models/auth"
|
||||||
user_model "code.gitea.io/gitea/models/user"
|
user_model "code.gitea.io/gitea/models/user"
|
||||||
|
"code.gitea.io/gitea/modules/log"
|
||||||
|
base "code.gitea.io/gitea/modules/migration"
|
||||||
"code.gitea.io/gitea/modules/setting"
|
"code.gitea.io/gitea/modules/setting"
|
||||||
"code.gitea.io/gitea/services/migrations"
|
"code.gitea.io/gitea/services/migrations"
|
||||||
|
|
||||||
|
"github.com/urfave/cli/v2"
|
||||||
|
config_factory "lab.forgefriends.org/friendlyforgeformat/gof3/config/factory"
|
||||||
f3_types "lab.forgefriends.org/friendlyforgeformat/gof3/config/types"
|
f3_types "lab.forgefriends.org/friendlyforgeformat/gof3/config/types"
|
||||||
"lab.forgefriends.org/friendlyforgeformat/gof3/forges/common"
|
"lab.forgefriends.org/friendlyforgeformat/gof3/forges/common"
|
||||||
"lab.forgefriends.org/friendlyforgeformat/gof3/forges/driver"
|
"lab.forgefriends.org/friendlyforgeformat/gof3/forges/driver"
|
||||||
"lab.forgefriends.org/friendlyforgeformat/gof3/format"
|
"lab.forgefriends.org/friendlyforgeformat/gof3/format"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
var Name = "InternalForgejo"
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
config_factory.RegisterFactory(Name, f3_types.OptionsFactory{
|
||||||
|
Name: Name,
|
||||||
|
New: func() f3_types.OptionsInterface { return &Options{} },
|
||||||
|
Flags: GetFlags,
|
||||||
|
}, func() common.DriverInterface { return &Forgejo{} })
|
||||||
|
}
|
||||||
|
|
||||||
type Options struct {
|
type Options struct {
|
||||||
f3_types.Options
|
f3_types.Options
|
||||||
|
|
||||||
|
@ -22,11 +38,79 @@ type Options struct {
|
||||||
Doer *user_model.User
|
Doer *user_model.User
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func getAuthenticationSource(ctx context.Context, authenticationSource string) (*auth_model.Source, error) {
|
||||||
|
source, err := auth_model.GetSourceByName(ctx, authenticationSource)
|
||||||
|
if err != nil {
|
||||||
|
if auth_model.IsErrSourceNotExist(err) {
|
||||||
|
return nil, nil
|
||||||
|
}
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return source, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func ToF3Logger(messenger base.Messenger) *f3_types.Logger {
|
||||||
|
if messenger == nil {
|
||||||
|
messenger = func(message string, args ...interface{}) {
|
||||||
|
log.Info("Message: "+message, args...)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return &f3_types.Logger{
|
||||||
|
Message: f3_types.LoggerFun(messenger),
|
||||||
|
Trace: log.Trace,
|
||||||
|
Debug: log.Debug,
|
||||||
|
Info: log.Info,
|
||||||
|
Warn: log.Warn,
|
||||||
|
Error: log.Error,
|
||||||
|
Critical: log.Critical,
|
||||||
|
Fatal: log.Fatal,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (o *Options) FromFlags(ctx context.Context, c *cli.Context, prefix string) f3_types.OptionsInterface {
|
||||||
|
o.Options.FromFlags(ctx, c, prefix)
|
||||||
|
o.Options.Logger = ToF3Logger(nil)
|
||||||
|
sourceName := c.String("authentication-source")
|
||||||
|
if sourceName != "" {
|
||||||
|
source, err := getAuthenticationSource(ctx, sourceName)
|
||||||
|
if err != nil {
|
||||||
|
panic(fmt.Errorf("error retrieving the authentication-source %s %v", sourceName, err))
|
||||||
|
}
|
||||||
|
if source != nil {
|
||||||
|
o.AuthenticationSource = source.ID
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
doer, err := user_model.GetAdminUser(ctx)
|
||||||
|
if err != nil {
|
||||||
|
panic(fmt.Errorf("GetAdminUser %v", err))
|
||||||
|
}
|
||||||
|
o.Doer = doer
|
||||||
|
|
||||||
|
return o
|
||||||
|
}
|
||||||
|
|
||||||
|
func GetFlags(prefix, category string) []cli.Flag {
|
||||||
|
flags := make([]cli.Flag, 0, 10)
|
||||||
|
|
||||||
|
flags = append(flags, &cli.StringFlag{
|
||||||
|
Name: "authentication-source",
|
||||||
|
Value: "",
|
||||||
|
Usage: "The name of the authentication source matching the forge of origin",
|
||||||
|
})
|
||||||
|
|
||||||
|
return flags
|
||||||
|
}
|
||||||
|
|
||||||
type Forgejo struct {
|
type Forgejo struct {
|
||||||
perPage int
|
perPage int
|
||||||
options *Options
|
options *Options
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (o *Forgejo) GetName() string {
|
||||||
|
return Name
|
||||||
|
}
|
||||||
|
|
||||||
func (o *Forgejo) GetPerPage() int {
|
func (o *Forgejo) GetPerPage() int {
|
||||||
return o.perPage
|
return o.perPage
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,13 +13,13 @@ import (
|
||||||
"lab.forgefriends.org/friendlyforgeformat/gof3/forges/f3"
|
"lab.forgefriends.org/friendlyforgeformat/gof3/forges/f3"
|
||||||
)
|
)
|
||||||
|
|
||||||
func ToF3Logger(messenger base.Messenger) f3_types.Logger {
|
func ToF3Logger(messenger base.Messenger) *f3_types.Logger {
|
||||||
if messenger == nil {
|
if messenger == nil {
|
||||||
messenger = func(message string, args ...interface{}) {
|
messenger = func(message string, args ...interface{}) {
|
||||||
log.Info("Message: "+message, args...)
|
log.Info("Message: "+message, args...)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return f3_types.Logger{
|
return &f3_types.Logger{
|
||||||
Message: f3_types.LoggerFun(messenger),
|
Message: f3_types.LoggerFun(messenger),
|
||||||
Trace: log.Trace,
|
Trace: log.Trace,
|
||||||
Debug: log.Debug,
|
Debug: log.Debug,
|
||||||
|
@ -32,7 +32,7 @@ func ToF3Logger(messenger base.Messenger) f3_types.Logger {
|
||||||
}
|
}
|
||||||
|
|
||||||
func ForgejoForgeRoot(features f3_types.Features, doer *user_model.User, authenticationSource int64) *f3_forges.ForgeRoot {
|
func ForgejoForgeRoot(features f3_types.Features, doer *user_model.User, authenticationSource int64) *f3_forges.ForgeRoot {
|
||||||
forgeRoot := f3_forges.NewForgeRootFromDriver(&driver.Forgejo{}, &driver.Options{
|
forgeRoot := f3_forges.NewForgeRoot(&driver.Forgejo{}, &driver.Options{
|
||||||
Options: f3_types.Options{
|
Options: f3_types.Options{
|
||||||
Features: features,
|
Features: features,
|
||||||
Logger: ToF3Logger(nil),
|
Logger: ToF3Logger(nil),
|
||||||
|
@ -44,7 +44,7 @@ func ForgejoForgeRoot(features f3_types.Features, doer *user_model.User, authent
|
||||||
}
|
}
|
||||||
|
|
||||||
func F3ForgeRoot(features f3_types.Features, directory string) *f3_forges.ForgeRoot {
|
func F3ForgeRoot(features f3_types.Features, directory string) *f3_forges.ForgeRoot {
|
||||||
forgeRoot := f3_forges.NewForgeRoot(&f3.Options{
|
forgeRoot := f3_forges.NewForgeRoot(&f3.F3{}, &f3.Options{
|
||||||
Options: f3_types.Options{
|
Options: f3_types.Options{
|
||||||
Configuration: f3_types.Configuration{
|
Configuration: f3_types.Configuration{
|
||||||
Directory: directory,
|
Directory: directory,
|
||||||
|
|
|
@ -7,8 +7,10 @@ import (
|
||||||
"net/url"
|
"net/url"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
|
user_model "code.gitea.io/gitea/models/user"
|
||||||
"code.gitea.io/gitea/modules/setting"
|
"code.gitea.io/gitea/modules/setting"
|
||||||
"code.gitea.io/gitea/modules/test"
|
"code.gitea.io/gitea/modules/test"
|
||||||
|
"code.gitea.io/gitea/services/f3/driver"
|
||||||
"code.gitea.io/gitea/services/migrations"
|
"code.gitea.io/gitea/services/migrations"
|
||||||
|
|
||||||
"github.com/stretchr/testify/assert"
|
"github.com/stretchr/testify/assert"
|
||||||
|
@ -16,7 +18,7 @@ import (
|
||||||
f3_util "lab.forgefriends.org/friendlyforgeformat/gof3/util"
|
f3_util "lab.forgefriends.org/friendlyforgeformat/gof3/util"
|
||||||
)
|
)
|
||||||
|
|
||||||
func Test_CmdF3(t *testing.T) {
|
func TestF3_CmdMirror_LocalForgejo(t *testing.T) {
|
||||||
onGiteaRun(t, func(*testing.T, *url.URL) {
|
onGiteaRun(t, func(*testing.T, *url.URL) {
|
||||||
defer test.MockVariable(&setting.F3.Enabled, true)()
|
defer test.MockVariable(&setting.F3.Enabled, true)()
|
||||||
defer test.MockVariable(&setting.Migrations.AllowLocalNetworks, true)()
|
defer test.MockVariable(&setting.Migrations.AllowLocalNetworks, true)()
|
||||||
|
@ -26,50 +28,45 @@ func Test_CmdF3(t *testing.T) {
|
||||||
// a http call fails with "...migration can only call allowed HTTP servers..."
|
// a http call fails with "...migration can only call allowed HTTP servers..."
|
||||||
migrations.Init()
|
migrations.Init()
|
||||||
|
|
||||||
|
ctx := context.Background()
|
||||||
|
var userID int64 = 700
|
||||||
//
|
//
|
||||||
// Step 1: create a fixture
|
// Step 1: create a fixture as an F3 archive
|
||||||
//
|
//
|
||||||
|
userID++
|
||||||
fixture := f3_forges.NewFixture(t, f3_forges.FixtureF3Factory)
|
fixture := f3_forges.NewFixture(t, f3_forges.FixtureF3Factory)
|
||||||
fixture.NewUser(1234)
|
fixture.NewUser(userID)
|
||||||
fixture.NewMilestone()
|
|
||||||
fixture.NewLabel()
|
|
||||||
fixture.NewIssue()
|
fixture.NewIssue()
|
||||||
fixture.NewTopic()
|
|
||||||
fixture.NewRepository()
|
fixture.NewRepository()
|
||||||
fixture.NewRelease()
|
|
||||||
fixture.NewAsset()
|
|
||||||
fixture.NewIssueComment(nil)
|
|
||||||
fixture.NewIssueReaction()
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// Step 2: import the fixture into Gitea
|
// Step 3: mirror the F3 archive to the forge
|
||||||
//
|
//
|
||||||
{
|
_, err := cmdForgejoCaptureOutput(t, []string{
|
||||||
output, err := cmdForgejoCaptureOutput(t, []string{"forgejo", "forgejo-cli", "f3", "--import", "--directory", fixture.ForgeRoot.GetDirectory()})
|
"forgejo", "forgejo-cli", "f3", "mirror",
|
||||||
assert.NoError(t, err)
|
"--from-type=f3", "--from", fixture.ForgeRoot.GetDirectory(),
|
||||||
assert.EqualValues(t, "imported\n", output)
|
"--to-type", driver.Name,
|
||||||
}
|
})
|
||||||
|
assert.NoError(t, err)
|
||||||
|
user, err := user_model.GetUserByName(ctx, fixture.UserFormat.UserName)
|
||||||
|
assert.NoError(t, err)
|
||||||
|
//
|
||||||
|
// Step 4: mirror the forge to an F3 archive
|
||||||
|
//
|
||||||
|
dumpDir := t.TempDir()
|
||||||
|
_, err = cmdForgejoCaptureOutput(t, []string{
|
||||||
|
"forgejo", "forgejo-cli", "f3", "mirror",
|
||||||
|
"--user", user.Name, "--repository", fixture.ProjectFormat.Name,
|
||||||
|
"--from-type", driver.Name,
|
||||||
|
"--to-type=f3", "--to", dumpDir,
|
||||||
|
})
|
||||||
|
assert.NoError(t, err)
|
||||||
|
|
||||||
//
|
//
|
||||||
// Step 3: export Gitea into F3
|
// Step 5: verify the F3 archive content
|
||||||
//
|
//
|
||||||
directory := t.TempDir()
|
files := f3_util.Command(context.Background(), "find", dumpDir)
|
||||||
{
|
assert.Contains(t, files, "/user/")
|
||||||
output, err := cmdForgejoCaptureOutput(t, []string{"forgejo", "forgejo-cli", "f3", "--export", "--no-pull-request", "--user", fixture.UserFormat.UserName, "--repository", fixture.ProjectFormat.Name, "--directory", directory})
|
assert.Contains(t, files, "/project/")
|
||||||
assert.NoError(t, err)
|
|
||||||
assert.EqualValues(t, "exported\n", output)
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// Step 4: verify the export and import are equivalent
|
|
||||||
//
|
|
||||||
files := f3_util.Command(context.Background(), "find", directory)
|
|
||||||
assert.Contains(t, files, "/label/")
|
|
||||||
assert.Contains(t, files, "/issue/")
|
|
||||||
assert.Contains(t, files, "/milestone/")
|
|
||||||
assert.Contains(t, files, "/topic/")
|
|
||||||
assert.Contains(t, files, "/release/")
|
|
||||||
assert.Contains(t, files, "/asset/")
|
|
||||||
assert.Contains(t, files, "/reaction/")
|
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
|
@ -30,7 +30,7 @@ import (
|
||||||
f3_util "lab.forgefriends.org/friendlyforgeformat/gof3/util"
|
f3_util "lab.forgefriends.org/friendlyforgeformat/gof3/util"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestF3Mirror(t *testing.T) {
|
func TestF3_Mirror(t *testing.T) {
|
||||||
onGiteaRun(t, func(t *testing.T, u *url.URL) {
|
onGiteaRun(t, func(t *testing.T, u *url.URL) {
|
||||||
AllowLocalNetworks := setting.Migrations.AllowLocalNetworks
|
AllowLocalNetworks := setting.Migrations.AllowLocalNetworks
|
||||||
setting.F3.Enabled = true
|
setting.F3.Enabled = true
|
||||||
|
@ -47,7 +47,7 @@ func TestF3Mirror(t *testing.T) {
|
||||||
// Step 1: create a fixture
|
// Step 1: create a fixture
|
||||||
//
|
//
|
||||||
fixtureNewF3Forge := func(t f3_tests.TestingT, user *format.User, tmpDir string) *f3_forges.ForgeRoot {
|
fixtureNewF3Forge := func(t f3_tests.TestingT, user *format.User, tmpDir string) *f3_forges.ForgeRoot {
|
||||||
root := f3_forges.NewForgeRoot(&f3_f3.Options{
|
root := f3_forges.NewForgeRoot(&f3_f3.F3{}, &f3_f3.Options{
|
||||||
Options: f3_types.Options{
|
Options: f3_types.Options{
|
||||||
Configuration: f3_types.Configuration{
|
Configuration: f3_types.Configuration{
|
||||||
Directory: tmpDir,
|
Directory: tmpDir,
|
||||||
|
@ -88,7 +88,7 @@ func TestF3Mirror(t *testing.T) {
|
||||||
// Step 3: mirror Forgejo into F3
|
// Step 3: mirror Forgejo into F3
|
||||||
//
|
//
|
||||||
adminUsername := "user1"
|
adminUsername := "user1"
|
||||||
forgejoAPI := f3_forges.NewForgeRootFromDriver(&f3_forgejo.Forgejo{}, &f3_forgejo.Options{
|
forgejoAPI := f3_forges.NewForgeRoot(&f3_forgejo.Forgejo{}, &f3_forgejo.Options{
|
||||||
Options: f3_types.Options{
|
Options: f3_types.Options{
|
||||||
Configuration: f3_types.Configuration{
|
Configuration: f3_types.Configuration{
|
||||||
URL: setting.AppURL,
|
URL: setting.AppURL,
|
||||||
|
@ -125,7 +125,7 @@ func TestF3Mirror(t *testing.T) {
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestMaybePromoteF3User(t *testing.T) {
|
func TestF3_MaybePromoteUser(t *testing.T) {
|
||||||
defer tests.PrepareTestEnv(t)()
|
defer tests.PrepareTestEnv(t)()
|
||||||
|
|
||||||
//
|
//
|
||||||
|
@ -182,7 +182,7 @@ func TestMaybePromoteF3User(t *testing.T) {
|
||||||
assert.Equal(t, userAfterSignIn.Email, gitlabEmail)
|
assert.Equal(t, userAfterSignIn.Email, gitlabEmail)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestF3UserMappingExisting(t *testing.T) {
|
func TestF3_UserMappingExisting(t *testing.T) {
|
||||||
onGiteaRun(t, func(t *testing.T, u *url.URL) {
|
onGiteaRun(t, func(t *testing.T, u *url.URL) {
|
||||||
AllowLocalNetworks := setting.Migrations.AllowLocalNetworks
|
AllowLocalNetworks := setting.Migrations.AllowLocalNetworks
|
||||||
setting.F3.Enabled = true
|
setting.F3.Enabled = true
|
||||||
|
@ -197,7 +197,7 @@ func TestF3UserMappingExisting(t *testing.T) {
|
||||||
|
|
||||||
log.Debug("Step 1: create a fixture in F3")
|
log.Debug("Step 1: create a fixture in F3")
|
||||||
fixtureNewF3Forge := func(t f3_tests.TestingT, user *format.User, tmpDir string) *f3_forges.ForgeRoot {
|
fixtureNewF3Forge := func(t f3_tests.TestingT, user *format.User, tmpDir string) *f3_forges.ForgeRoot {
|
||||||
root := f3_forges.NewForgeRoot(&f3_f3.Options{
|
root := f3_forges.NewForgeRoot(&f3_f3.F3{}, &f3_f3.Options{
|
||||||
Options: f3_types.Options{
|
Options: f3_types.Options{
|
||||||
Configuration: f3_types.Configuration{
|
Configuration: f3_types.Configuration{
|
||||||
Directory: tmpDir,
|
Directory: tmpDir,
|
||||||
|
@ -242,7 +242,7 @@ func TestF3UserMappingExisting(t *testing.T) {
|
||||||
|
|
||||||
log.Debug("Step 3: mirror Forgejo into F3")
|
log.Debug("Step 3: mirror Forgejo into F3")
|
||||||
adminUsername := "user1"
|
adminUsername := "user1"
|
||||||
forgejoAPI := f3_forges.NewForgeRootFromDriver(&f3_forgejo.Forgejo{}, &f3_forgejo.Options{
|
forgejoAPI := f3_forges.NewForgeRoot(&f3_forgejo.Forgejo{}, &f3_forgejo.Options{
|
||||||
Options: f3_types.Options{
|
Options: f3_types.Options{
|
||||||
Configuration: f3_types.Configuration{
|
Configuration: f3_types.Configuration{
|
||||||
URL: setting.AppURL,
|
URL: setting.AppURL,
|
||||||
|
@ -270,7 +270,7 @@ func TestF3UserMappingExisting(t *testing.T) {
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestF3UserMappingNew(t *testing.T) {
|
func TestF3_UserMappingNew(t *testing.T) {
|
||||||
onGiteaRun(t, func(t *testing.T, u *url.URL) {
|
onGiteaRun(t, func(t *testing.T, u *url.URL) {
|
||||||
AllowLocalNetworks := setting.Migrations.AllowLocalNetworks
|
AllowLocalNetworks := setting.Migrations.AllowLocalNetworks
|
||||||
setting.F3.Enabled = true
|
setting.F3.Enabled = true
|
||||||
|
@ -285,7 +285,7 @@ func TestF3UserMappingNew(t *testing.T) {
|
||||||
|
|
||||||
log.Debug("Step 1: create a fixture in F3")
|
log.Debug("Step 1: create a fixture in F3")
|
||||||
fixtureNewF3Forge := func(t f3_tests.TestingT, user *format.User, tmpDir string) *f3_forges.ForgeRoot {
|
fixtureNewF3Forge := func(t f3_tests.TestingT, user *format.User, tmpDir string) *f3_forges.ForgeRoot {
|
||||||
root := f3_forges.NewForgeRoot(&f3_f3.Options{
|
root := f3_forges.NewForgeRoot(&f3_f3.F3{}, &f3_f3.Options{
|
||||||
Options: f3_types.Options{
|
Options: f3_types.Options{
|
||||||
Configuration: f3_types.Configuration{
|
Configuration: f3_types.Configuration{
|
||||||
Directory: tmpDir,
|
Directory: tmpDir,
|
||||||
|
|
Loading…
Reference in a new issue