summaryrefslogtreecommitdiffstats
path: root/contrib/fixtures/fixture_generation.go
diff options
context:
space:
mode:
authorDaniel Baumann <daniel@debian.org>2024-10-18 20:33:49 +0200
committerDaniel Baumann <daniel@debian.org>2024-10-18 20:33:49 +0200
commitdd136858f1ea40ad3c94191d647487fa4f31926c (patch)
tree58fec94a7b2a12510c9664b21793f1ed560c6518 /contrib/fixtures/fixture_generation.go
parentInitial commit. (diff)
downloadforgejo-dd136858f1ea40ad3c94191d647487fa4f31926c.tar.xz
forgejo-dd136858f1ea40ad3c94191d647487fa4f31926c.zip
Adding upstream version 9.0.0.
Signed-off-by: Daniel Baumann <daniel@debian.org>
Diffstat (limited to 'contrib/fixtures/fixture_generation.go')
-rw-r--r--contrib/fixtures/fixture_generation.go80
1 files changed, 80 insertions, 0 deletions
diff --git a/contrib/fixtures/fixture_generation.go b/contrib/fixtures/fixture_generation.go
new file mode 100644
index 0000000..31797cc
--- /dev/null
+++ b/contrib/fixtures/fixture_generation.go
@@ -0,0 +1,80 @@
+// Copyright 2020 The Gitea Authors. All rights reserved.
+// SPDX-License-Identifier: MIT
+
+//nolint:forbidigo
+package main
+
+import (
+ "context"
+ "fmt"
+ "os"
+ "path/filepath"
+
+ "code.gitea.io/gitea/models"
+ "code.gitea.io/gitea/models/unittest"
+)
+
+// To generate derivative fixtures, execute the following from Gitea's repository base dir:
+// go run -tags 'sqlite sqlite_unlock_notify' contrib/fixtures/fixture_generation.go [fixture...]
+
+var (
+ generators = []struct {
+ gen func(ctx context.Context) (string, error)
+ name string
+ }{
+ {
+ models.GetYamlFixturesAccess, "access",
+ },
+ }
+ fixturesDir string
+)
+
+func main() {
+ pathToGiteaRoot := "."
+ fixturesDir = filepath.Join(pathToGiteaRoot, "models", "fixtures")
+ if err := unittest.CreateTestEngine(unittest.FixturesOptions{
+ Dir: fixturesDir,
+ }); err != nil {
+ fmt.Printf("CreateTestEngine: %+v", err)
+ os.Exit(1)
+ }
+ if err := unittest.PrepareTestDatabase(); err != nil {
+ fmt.Printf("PrepareTestDatabase: %+v\n", err)
+ os.Exit(1)
+ }
+ ctx := context.Background()
+ if len(os.Args) == 0 {
+ for _, r := range os.Args {
+ if err := generate(ctx, r); err != nil {
+ fmt.Printf("generate '%s': %+v\n", r, err)
+ os.Exit(1)
+ }
+ }
+ } else {
+ for _, g := range generators {
+ if err := generate(ctx, g.name); err != nil {
+ fmt.Printf("generate '%s': %+v\n", g.name, err)
+ os.Exit(1)
+ }
+ }
+ }
+}
+
+func generate(ctx context.Context, name string) error {
+ for _, g := range generators {
+ if g.name == name {
+ data, err := g.gen(ctx)
+ if err != nil {
+ return err
+ }
+ path := filepath.Join(fixturesDir, name+".yml")
+ if err := os.WriteFile(path, []byte(data), 0o644); err != nil {
+ return fmt.Errorf("%s: %+v", path, err)
+ }
+ fmt.Printf("%s created.\n", path)
+ return nil
+ }
+ }
+
+ return fmt.Errorf("generator not found")
+}