Documentation ¶
Index ¶
- Variables
- func AppendLogToError(err error, log string) error
- func Contains[T comparable](s []T, x T) bool
- func CopyMap[K comparable, V any](m map[K]V) map[K]V
- func CreateOrRestartPod(ctx context.Context, podClient ctrlruntimeclient.Client, pod *corev1.Pod) (*corev1.Pod, error)
- func CreateRBACs(ctx context.Context, sa *coreapi.ServiceAccount, role *rbacapi.Role, ...) error
- func DefKeys[K comparable, V any](m map[K]V, def []K) []K
- func DefSlice[T any](slice []T, def []T) []T
- func IsBitSet[T constraints.Integer](x, b T) bool
- func IsSpecialInformingJobOnTestGrid(jobName string) bool
- func Keys[K comparable, V any](m map[K]V) (ret []K)
- func LoadClusterConfig() (*rest.Config, error)
- func LoadKubeConfig(path string) (*rest.Config, error)
- func ParseImageStreamTagReference(s string) (api.ImageStreamTagReference, error)
- func PendingBuildError(ctx context.Context, client kubernetes.PodClient, build *buildapi.Build) (ret error)
- func PopCount[T comparable](xs ...T) (ret uint)
- func ProduceMap(n int, produce WorkerFn, map_ WorkerFn, errCh chan error) error
- func ProduceMapReduce(n int, produce WorkerFn, map_ WorkerFn, reduce WorkerFn, done func(), ...) error
- func RemoveIf[T any](s []T, p func(T) bool) []T
- func ResolvePullSpec(is *imageapi.ImageStream, tag string, requireExact bool) (string, bool, imageapi.TagEventCondition)
- func SecretFromDir(path string) (*coreapi.Secret, error)
- func SortSlice[T constraints.Ordered](s []T)
- func SortedKeys[K constraints.Ordered, V any](m map[K]V) (ret []K)
- func UpsertImmutableSecret(ctx context.Context, client ctrlruntimeclient.Client, secret *coreapi.Secret) (created bool, err error)
- func WaitForPodCompletion(ctx context.Context, podClient kubernetes.PodClient, namespace, name string, ...) (*corev1.Pod, error)
- func WaitForPodDeletion(ctx context.Context, podClient ctrlruntimeclient.Client, ...) error
- func Zero[T any]() (_ T)
- type ContainerNotifier
- type WaitForPodFlag
- type WorkerFn
Examples ¶
Constants ¶
This section is empty.
Variables ¶
var NopNotifier = nopNotifier{}
NopNotifier takes no action when notified.
Functions ¶
func AppendLogToError ¶
func Contains ¶
func Contains[T comparable](s []T, x T) bool
Contains performs a linear search on `s` looking for `x`.
func CopyMap ¶
func CopyMap[K comparable, V any](m map[K]V) map[K]V
CopyMap creates a new map copying all key/values from its argument
func CreateOrRestartPod ¶
func CreateRBACs ¶
func CreateRBACs(ctx context.Context, sa *coreapi.ServiceAccount, role *rbacapi.Role, roleBindings []rbacapi.RoleBinding, client ctrlruntimeclient.Client, retryDuration, timeout time.Duration) error
CreateRBACs creates the given service account, role, and role bindings. In addition, it waits until the service account will be updated with an image pull secret. Because the DockerCfgController controller needs some time to create the corresponding secrets we need to wait until this happens, otherwise, the pod that will use this service account will fail to start since there are no credentials to pull any images.
func DefKeys ¶
func DefKeys[K comparable, V any](m map[K]V, def []K) []K
DefKeys returns keys from `m` if not empty, def otherwise.
func DefSlice ¶
func DefSlice[T any](slice []T, def []T) []T
DefSlice returns `slice` if not empty, def otherwise.
func IsBitSet ¶
func IsBitSet[T constraints.Integer](x, b T) bool
IsBitSet tests if a single specific bit is set in a value
func Keys ¶
func Keys[K comparable, V any](m map[K]V) (ret []K)
Keys returns a slice with the keys in `m` in unspecified order
func LoadClusterConfig ¶
func LoadKubeConfig ¶
LoadKubeConfig loads a kubeconfig from the file and uses the default context
func ParseImageStreamTagReference ¶
func ParseImageStreamTagReference(s string) (api.ImageStreamTagReference, error)
ParseImageStreamTagReference creates a reference from an "is:tag" string.
func PendingBuildError ¶
func PendingBuildError(ctx context.Context, client kubernetes.PodClient, build *buildapi.Build) (ret error)
PendingBuildError fetches scheduling errors from the build pod's events
func PopCount ¶
func PopCount[T comparable](xs ...T) (ret uint)
PopCount returns the number of "true" argument values.
func ProduceMap ¶
ProduceMap is similar to ProduceMapReduce but without a reduce step.
func ProduceMapReduce ¶
func ProduceMapReduce( n int, produce WorkerFn, map_ WorkerFn, reduce WorkerFn, done func(), errCh chan error, ) error
ProduceMapReduce handles the execution of a triphasic pipeline. The pipeline is constituted of a single producer, a single reducer, and `n` mapper workers, i.e.:
producer / / \ \ m m … m m ---> done \ \ / / | reducer <-------'
All processes are executed to completion even if an error occurs in any of them (as opposed to, for example, `x/sync/errorgroup`). Errors sent to `errCh` are aggregated in the return value. A process which encounters an error can either return it to stop itself or send it to `errCh` and continue processing its input.
For convenience, if `n` is zero, it is treated as `runtime.GOMAXPROCS(0)`.
`done` is called when all mapping workers finish. It usually closes a channel used by the reduce step.
Example ¶
input := []int{0, 1, 2, 3} inputCh := make(chan int) errCh := make(chan error) produce := func() error { defer close(inputCh) for _, x := range input { inputCh <- x } return nil } outputCh := make(chan int) map_ := func() error { for x := range inputCh { if x == 2 { errCh <- fmt.Errorf("%d", x) } else { outputCh <- x } } return nil } done := func() { close(outputCh) } reduce := func() error { r := 0 for x := range outputCh { r += x } fmt.Println(r) return nil } if err := ProduceMapReduce(0, produce, map_, reduce, done, errCh); err != nil { fmt.Println("error:", err) }
Output: 4 error: 2
func RemoveIf ¶
RemoveIf retains only elements which are not selected by a predicate The slice is modified in place and (potentially a subset) is returned.
func ResolvePullSpec ¶
func ResolvePullSpec(is *imageapi.ImageStream, tag string, requireExact bool) (string, bool, imageapi.TagEventCondition)
ResolvePullSpec if a tag of an imagestream is resolved
func SecretFromDir ¶
SecretFromDir creates a secret with the contents of files in a directory.
func SortSlice ¶
func SortSlice[T constraints.Ordered](s []T)
SortSlice is a generic version of sort.Slice
func SortedKeys ¶
func SortedKeys[K constraints.Ordered, V any](m map[K]V) (ret []K)
SortedKeys returns a slice with the keys in `m` in sorted order
func UpsertImmutableSecret ¶
func UpsertImmutableSecret(ctx context.Context, client ctrlruntimeclient.Client, secret *coreapi.Secret) (created bool, err error)
UpsertImmutableSecret adds new values to an existing secret. New values are added, existing values are overwritten. The secret will be created if it doesn't already exist. Updating an existing secret happens by re-creating it.
func WaitForPodCompletion ¶
func WaitForPodCompletion(ctx context.Context, podClient kubernetes.PodClient, namespace, name string, notifier ContainerNotifier, flags WaitForPodFlag) (*corev1.Pod, error)
func WaitForPodDeletion ¶
Types ¶
type ContainerNotifier ¶
type ContainerNotifier interface { // Notify indicates that the provided container name has transitioned to an appropriate state and // any per container actions should be taken. Notify(pod *corev1.Pod, containerName string) // Complete indicates the specified pod has completed execution, been deleted, or that no further // Notify() calls can be made. Complete(podName string) // Done returns a channel that can be used to wait for the specified pod name to complete the work it has pending. Done(podName string) <-chan struct{} }
ContainerNotifier receives updates about the status of a poll action on a pod. The caller is required to define what notifications are made.
type WaitForPodFlag ¶
type WaitForPodFlag uint8
WaitForPodFlag changes the behavior of the functions which monitor pods
const ( // SkipLogs omits informational logs, such as when the pod is part of a // larger step like release creation where displaying pod specific info is // confusing to an end user. Failure logs are still printed. SkipLogs WaitForPodFlag = 1 << iota // Interruptible indicates this pod is expected to potentially be cancelled // Used for observer pods so that their cancellation is not reported as // abnormal. Interruptible )
Source Files ¶
Directories ¶
Path | Synopsis |
---|---|
Package imagestreamtagwrapper implements a wrapper for a ctrlruntimeclient that assembles imagestreamtags client-side by fetching the corresponding imagestream and image(s).
|
Package imagestreamtagwrapper implements a wrapper for a ctrlruntimeclient that assembles imagestreamtags client-side by fetching the corresponding imagestream and image(s). |