feat: cli option to enable the new action cache (#1954)
* Enable the new action cache * fix * fix: CopyTarStream (Docker) * suppress panic in test * add a cli option for opt in * fixups * add package * fix * rc.Config nil in test??? * add feature flag * patch * Fix respect --action-cache-path Co-authored-by: Björn Brauer <zaubernerd@zaubernerd.de> * add remote reusable workflow to ActionCache * fixup --------- Co-authored-by: Björn Brauer <zaubernerd@zaubernerd.de> Co-authored-by: mergify[bot] <37929162+mergify[bot]@users.noreply.github.com>
This commit is contained in:
		| @@ -671,10 +671,28 @@ func (cr *containerReference) waitForCommand(ctx context.Context, isTerminal boo | ||||
| } | ||||
|  | ||||
| func (cr *containerReference) CopyTarStream(ctx context.Context, destPath string, tarStream io.Reader) error { | ||||
| 	err := cr.cli.CopyToContainer(ctx, cr.id, destPath, tarStream, types.CopyToContainerOptions{}) | ||||
| 	// Mkdir | ||||
| 	buf := &bytes.Buffer{} | ||||
| 	tw := tar.NewWriter(buf) | ||||
| 	_ = tw.WriteHeader(&tar.Header{ | ||||
| 		Name:     destPath, | ||||
| 		Mode:     777, | ||||
| 		Typeflag: tar.TypeDir, | ||||
| 	}) | ||||
| 	tw.Close() | ||||
| 	err := cr.cli.CopyToContainer(ctx, cr.id, "/", buf, types.CopyToContainerOptions{}) | ||||
| 	if err != nil { | ||||
| 		return fmt.Errorf("failed to mkdir to copy content to container: %w", err) | ||||
| 	} | ||||
| 	// Copy Content | ||||
| 	err = cr.cli.CopyToContainer(ctx, cr.id, destPath, tarStream, types.CopyToContainerOptions{}) | ||||
| 	if err != nil { | ||||
| 		return fmt.Errorf("failed to copy content to container: %w", err) | ||||
| 	} | ||||
| 	// If this fails, then folders have wrong permissions on non root container | ||||
| 	if cr.UID != 0 || cr.GID != 0 { | ||||
| 		_ = cr.Exec([]string{"chown", "-R", fmt.Sprintf("%d:%d", cr.UID, cr.GID), destPath}, nil, "0", "")(ctx) | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user