Documentation ¶
Index ¶
- Constants
- func ExecCmd(command string) error
- func ExecCmdWithContext(ctx context.Context, command string) error
- func ExecCmdWithOptions(ctx context.Context, command string, outputFunction func(string)) error
- func GetLocalK8sDeps() (*kubernetes.Clientset, *rest.Config, error)
- type Chaos
- type ChaosState
- type ConnectionInfo
- type ConnectionMode
- type Forwarder
- type K8sClient
- func (m *K8sClient) AddLabel(namespace string, selector string, label string) error
- func (m *K8sClient) AddPodAnnotation(namespace string, pod v1.Pod, key, value string) error
- func (m *K8sClient) AddPodLabel(namespace string, pod v1.Pod, key, value string) error
- func (m *K8sClient) AddPodsAnnotations(namespace string, podList *v1.PodList, annotations map[string]string) error
- func (m *K8sClient) AddPodsLabels(namespace string, podList *v1.PodList, labels map[string]string) error
- func (m *K8sClient) Apply(ctx context.Context, manifest, namespace string) error
- func (m *K8sClient) CopyToPod(namespace, src, destination, containername string) (*bytes.Buffer, *bytes.Buffer, *bytes.Buffer, error)
- func (m *K8sClient) Create(manifest string) error
- func (m *K8sClient) DeleteResource(namespace string, resource string, instance string) error
- func (m *K8sClient) DryRun(manifest string) error
- func (m *K8sClient) EnumerateInstances(namespace string, selector string) error
- func (m *K8sClient) ExecuteInPod(namespace, podName, containerName string, command []string) ([]byte, []byte, error)
- func (m *K8sClient) LabelChaosGroup(namespace string, startInstance int, endInstance int, group string) error
- func (m *K8sClient) LabelChaosGroupByLabels(namespace string, labels map[string]string, group string) error
- func (m *K8sClient) ListNamespaces(selector string) (*v1.NamespaceList, error)
- func (m *K8sClient) ListPods(namespace, selector string) (*v1.PodList, error)
- func (m *K8sClient) ListServices(namespace, selector string) (*v1.ServiceList, error)
- func (m *K8sClient) NamespaceExists(namespace string) bool
- func (m *K8sClient) RemoveNamespace(namespace string) error
- func (m *K8sClient) RolloutRestartBySelector(ctx context.Context, namespace, resource, selector string) error
- func (m *K8sClient) RolloutStatefulSets(ctx context.Context, namespace string) error
- func (m *K8sClient) UniqueLabels(namespace string, selector string) ([]string, error)
- func (m *K8sClient) WaitForDeploymentsAvailable(ctx context.Context, namespace string) error
- func (m *K8sClient) WaitForJob(namespaceName string, jobName string, fundReturnStatus func(string)) error
- func (m *K8sClient) WaitPodsReady(ns string, rcd *ReadyCheckData, expectedPodCount int) error
- type Protocol
- type ReadyCheckData
- type URLConverter
Constants ¶
const ( TempDebugManifest = "tmp-manifest-%s.yaml" K8sStatePollInterval = 2 * time.Second JobFinalizedTimeout = 2 * time.Minute AppLabel = "app" )
Variables ¶
This section is empty.
Functions ¶
func ExecCmdWithContext ¶ added in v0.33.0
func ExecCmdWithOptions ¶ added in v0.3.0
func GetLocalK8sDeps ¶
func GetLocalK8sDeps() (*kubernetes.Clientset, *rest.Config, error)
GetLocalK8sDeps get local k8s context config
Types ¶
type Chaos ¶ added in v0.2.4
Chaos is controller that manages Chaosmesh CRD instances to run experiments
func (*Chaos) WaitForAllRecovered ¶ added in v0.2.44
type ChaosState ¶ added in v0.2.44
type ChaosState struct {
ChaosDetails v1alpha1.ChaosStatus `json:"status"`
}
type ConnectionInfo ¶
type ConnectionInfo struct { Ports portforward.ForwardedPort Host string }
type ConnectionMode ¶
type ConnectionMode int
const ( LocalConnection ConnectionMode = iota RemoteConnection )
type Forwarder ¶
type Forwarder struct { Client *K8sClient KeepConnection bool Info map[string]interface{} // contains filtered or unexported fields }
func NewForwarder ¶
func (*Forwarder) FindPort ¶
func (m *Forwarder) FindPort(ks ...string) *URLConverter
func (*Forwarder) PrintLocalPorts ¶ added in v0.3.9
func (m *Forwarder) PrintLocalPorts()
PrintLocalPorts prints all local forwarded ports
type K8sClient ¶
type K8sClient struct { ClientSet *kubernetes.Clientset RESTConfig *rest.Config }
K8sClient high level k8s client
func NewK8sClient ¶
NewK8sClient creates a new k8s client with a REST config
func (*K8sClient) AddLabel ¶ added in v0.2.2
AddLabel adds a new label to a group of pods defined by selector
func (*K8sClient) AddPodAnnotation ¶ added in v0.3.29
AddPodAnnotation adds an annotation to a pod
func (*K8sClient) AddPodLabel ¶ added in v0.3.29
AddPodLabel adds a label to a pod
func (*K8sClient) AddPodsAnnotations ¶ added in v0.3.29
func (m *K8sClient) AddPodsAnnotations(namespace string, podList *v1.PodList, annotations map[string]string) error
AddPodsAnnotations adds map of annotations to all pods in list
func (*K8sClient) AddPodsLabels ¶ added in v0.32.4
func (m *K8sClient) AddPodsLabels(namespace string, podList *v1.PodList, labels map[string]string) error
AddPodsLabels adds map of labels to all pods in list
func (*K8sClient) CopyToPod ¶
func (m *K8sClient) CopyToPod(namespace, src, destination, containername string) (*bytes.Buffer, *bytes.Buffer, *bytes.Buffer, error)
CopyToPod copies src to a particular container. Destination should be in the form of a proper K8s destination path NAMESPACE/POD_NAME:folder/FILE_NAME
func (*K8sClient) DeleteResource ¶ added in v0.2.4
DeleteResource deletes resource
func (*K8sClient) EnumerateInstances ¶ added in v0.2.2
EnumerateInstances enumerate pods with instance label
func (*K8sClient) ExecuteInPod ¶ added in v0.2.3
func (m *K8sClient) ExecuteInPod(namespace, podName, containerName string, command []string) ([]byte, []byte, error)
ExecuteInPod is similar to kubectl exec
func (*K8sClient) LabelChaosGroup ¶ added in v0.2.14
func (*K8sClient) LabelChaosGroupByLabels ¶ added in v0.2.44
func (*K8sClient) ListNamespaces ¶
func (m *K8sClient) ListNamespaces(selector string) (*v1.NamespaceList, error)
ListNamespaces lists k8s namespaces
func (*K8sClient) ListServices ¶ added in v0.33.1
func (m *K8sClient) ListServices(namespace, selector string) (*v1.ServiceList, error)
ListPods lists services for a namespace and selector
func (*K8sClient) NamespaceExists ¶
NamespaceExists check if namespace exists
func (*K8sClient) RemoveNamespace ¶
RemoveNamespace removes namespace
func (*K8sClient) RolloutRestartBySelector ¶ added in v0.3.26
func (m *K8sClient) RolloutRestartBySelector(ctx context.Context, namespace, resource, selector string) error
RolloutRestartBySelector rollouts and restarts object by selector
func (*K8sClient) RolloutStatefulSets ¶ added in v0.3.23
RolloutStatefulSets applies "rollout statefulset" to all existing statefulsets in that namespace
func (*K8sClient) UniqueLabels ¶ added in v0.2.2
UniqueLabels gets all unique application labels
func (*K8sClient) WaitForDeploymentsAvailable ¶ added in v0.32.10
func (*K8sClient) WaitForJob ¶ added in v0.3.0
func (m *K8sClient) WaitForJob(namespaceName string, jobName string, fundReturnStatus func(string)) error
WaitForJob wait for job execution, follow logs and returns an error if job failed
func (*K8sClient) WaitPodsReady ¶ added in v0.2.55
func (m *K8sClient) WaitPodsReady(ns string, rcd *ReadyCheckData, expectedPodCount int) error
WaitPodsReady waits until all pods are ready
type Protocol ¶
type Protocol int
Protocol represents a URL scheme to use when fetching connection details
type ReadyCheckData ¶
ReadyCheckData data to check if selected pods are running and all containers are ready ( readiness check ) are ready
type URLConverter ¶
type URLConverter struct {
// contains filtered or unexported fields
}
URLConverter converts ports to URLs
func NewURLConverter ¶
func NewURLConverter(fp ConnectionInfo, err error) *URLConverter
NewURLConverter creates new URLConverter instance
func (*URLConverter) As ¶
func (m *URLConverter) As(conn ConnectionMode, proto Protocol) (string, error)
As converts host/port to an URL