summaryrefslogtreecommitdiffstats
path: root/cmd
diff options
context:
space:
mode:
authorJason Song <i@wolfogre.com>2023-04-28 17:57:40 +0200
committerGitHub <noreply@github.com>2023-04-28 17:57:40 +0200
commitd77991c95ab6eb357b9327163ac9ceca3d04ce9b (patch)
tree8594daa6421937e8c0efbd0e3c6b5bc52ed41af2 /cmd
parentchore: run act from cli on linux (#1758) (diff)
downloadforgejo-act-d77991c95ab6eb357b9327163ac9ceca3d04ce9b.tar.xz
forgejo-act-d77991c95ab6eb357b9327163ac9ceca3d04ce9b.zip
Support cache (#1770)
* feat: port * fix: use httprouter * fix: WriteHeader * fix: bolthold * fix: bugs * chore: one less file * test: test handler * fix: bug in id * test: fix cases * chore: tidy * fix: use atomic.Int32 * fix: use atomic.Store * feat: support close * chore: lint * fix: cache keys are case insensitive * fix: options * fix: use options * fix: close * fix: ignore close error * Revert "fix: close" This reverts commit d53ea7568ba03908eb153031c435008fd47e7ccb. * fix: cacheUrlKey * fix: nil close * chore: lint code * fix: test key * test: case insensitive * chore: lint
Diffstat (limited to 'cmd')
-rw-r--r--cmd/dir.go27
-rw-r--r--cmd/input.go4
-rw-r--r--cmd/notices.go11
-rw-r--r--cmd/root.go24
4 files changed, 50 insertions, 16 deletions
diff --git a/cmd/dir.go b/cmd/dir.go
new file mode 100644
index 0000000..e1d24e9
--- /dev/null
+++ b/cmd/dir.go
@@ -0,0 +1,27 @@
+package cmd
+
+import (
+ "os"
+ "path/filepath"
+
+ log "github.com/sirupsen/logrus"
+)
+
+var (
+ UserHomeDir string
+ CacheHomeDir string
+)
+
+func init() {
+ home, err := os.UserHomeDir()
+ if err != nil {
+ log.Fatal(err)
+ }
+ UserHomeDir = home
+
+ if v := os.Getenv("XDG_CACHE_HOME"); v != "" {
+ CacheHomeDir = v
+ } else {
+ CacheHomeDir = filepath.Join(UserHomeDir, ".cache")
+ }
+}
diff --git a/cmd/input.go b/cmd/input.go
index 9327de2..ed9655c 100644
--- a/cmd/input.go
+++ b/cmd/input.go
@@ -42,6 +42,10 @@ type Input struct {
artifactServerPath string
artifactServerAddr string
artifactServerPort string
+ noCacheServer bool
+ cacheServerPath string
+ cacheServerAddr string
+ cacheServerPort uint16
jsonLogger bool
noSkipCheckout bool
remoteName string
diff --git a/cmd/notices.go b/cmd/notices.go
index 9ddcf6f..a912bd9 100644
--- a/cmd/notices.go
+++ b/cmd/notices.go
@@ -132,16 +132,7 @@ func saveNoticesEtag(etag string) {
}
func etagPath() string {
- var xdgCache string
- var ok bool
- if xdgCache, ok = os.LookupEnv("XDG_CACHE_HOME"); !ok || xdgCache == "" {
- if home, err := os.UserHomeDir(); err == nil {
- xdgCache = filepath.Join(home, ".cache")
- } else if xdgCache, err = filepath.Abs("."); err != nil {
- log.Fatal(err)
- }
- }
- dir := filepath.Join(xdgCache, "act")
+ dir := filepath.Join(CacheHomeDir, "act")
if err := os.MkdirAll(dir, 0o777); err != nil {
log.Fatal(err)
}
diff --git a/cmd/root.go b/cmd/root.go
index 548d90c..d5b8c39 100644
--- a/cmd/root.go
+++ b/cmd/root.go
@@ -20,6 +20,7 @@ import (
"github.com/spf13/cobra"
"gopkg.in/yaml.v3"
+ "github.com/nektos/act/pkg/artifactcache"
"github.com/nektos/act/pkg/artifacts"
"github.com/nektos/act/pkg/common"
"github.com/nektos/act/pkg/container"
@@ -87,6 +88,10 @@ func Execute(ctx context.Context, version string) {
rootCmd.PersistentFlags().StringVarP(&input.artifactServerAddr, "artifact-server-addr", "", common.GetOutboundIP().String(), "Defines the address to which the artifact server binds.")
rootCmd.PersistentFlags().StringVarP(&input.artifactServerPort, "artifact-server-port", "", "34567", "Defines the port where the artifact server listens.")
rootCmd.PersistentFlags().BoolVarP(&input.noSkipCheckout, "no-skip-checkout", "", false, "Do not skip actions/checkout")
+ rootCmd.PersistentFlags().BoolVarP(&input.noCacheServer, "no-cache-server", "", false, "Disable cache server")
+ rootCmd.PersistentFlags().StringVarP(&input.cacheServerPath, "cache-server-path", "", filepath.Join(CacheHomeDir, "actcache"), "Defines the path where the cache server stores caches.")
+ rootCmd.PersistentFlags().StringVarP(&input.cacheServerAddr, "cache-server-addr", "", common.GetOutboundIP().String(), "Defines the address to which the cache server binds.")
+ rootCmd.PersistentFlags().Uint16VarP(&input.cacheServerPort, "cache-server-port", "", 0, "Defines the port where the artifact server listens. 0 means a randomly available port.")
rootCmd.SetArgs(args())
if err := rootCmd.Execute(); err != nil {
@@ -95,11 +100,6 @@ func Execute(ctx context.Context, version string) {
}
func configLocations() []string {
- home, err := os.UserHomeDir()
- if err != nil {
- log.Fatal(err)
- }
-
configFileName := ".actrc"
// reference: https://specifications.freedesktop.org/basedir-spec/latest/ar01s03.html
@@ -112,7 +112,7 @@ func configLocations() []string {
}
return []string{
- filepath.Join(home, configFileName),
+ filepath.Join(UserHomeDir, configFileName),
actrcXdg,
filepath.Join(".", configFileName),
}
@@ -609,6 +609,17 @@ func newRunCommand(ctx context.Context, input *Input) func(*cobra.Command, []str
cancel := artifacts.Serve(ctx, input.artifactServerPath, input.artifactServerAddr, input.artifactServerPort)
+ const cacheURLKey = "ACTIONS_CACHE_URL"
+ var cacheHandler *artifactcache.Handler
+ if !input.noCacheServer && envs[cacheURLKey] == "" {
+ var err error
+ cacheHandler, err = artifactcache.StartHandler(input.cacheServerPath, input.cacheServerAddr, input.cacheServerPort, common.Logger(ctx))
+ if err != nil {
+ return err
+ }
+ envs[cacheURLKey] = cacheHandler.ExternalURL() + "/"
+ }
+
ctx = common.WithDryrun(ctx, input.dryrun)
if watch, err := cmd.Flags().GetBool("watch"); err != nil {
return err
@@ -622,6 +633,7 @@ func newRunCommand(ctx context.Context, input *Input) func(*cobra.Command, []str
executor := r.NewPlanExecutor(plan).Finally(func(ctx context.Context) error {
cancel()
+ _ = cacheHandler.Close()
return nil
})
err = executor(ctx)