Documentation ¶
Index ¶
- Variables
- func Backoff(baseDelay, maxDelay time.Duration, retries int) time.Duration
- func CheckDeployment(ctx context.Context, namespace, deployment string) error
- func CheckDeployments(namespace string, timeout time.Duration) error
- func CheckDeploymentsReady(ns string) (int, error)
- func CheckPodsRunning(n string) (ready bool)
- func CheckPodsRunningWithMaxDuration(n string, maxDuration time.Duration) (ready bool)
- func Compare(out, model []byte) error
- func CompareFiles(outFile, modelFile string) error
- func CompareToFile(out []byte, modelFile string) error
- func CopyFile(src, dst string) error
- func CreateAndFill(outDir, templateFile string, values interface{}) (string, error)
- func CreateNamespace(n string) error
- func CreateTLSSecret(secretName, n, keyFile, certFile string) (string, error)
- func CreateTempfile(tmpDir, prefix, suffix string) (string, error)
- func DeleteNamespace(n string) error
- func DownloadRelease(version, tmpDir string) (string, error)
- func EnsureTestServer() *bootstrap.Server
- func ExtractTarGz(gzipStream io.Reader) error
- func FetchAndSaveClusterLogs(namespace string, tempDir string) error
- func Fill(outFile, inFile string, values interface{}) error
- func GetAppPods(n string) (map[string][]string, error)
- func GetClusterSubnet() (string, error)
- func GetConfigs(names ...string) (string, error)
- func GetHeadCommitSHA(org, repo, branch string) (string, error)
- func GetIngress(n string) (string, error)
- func GetIngressPod(n string) (string, error)
- func GetIngressPodNames(n string) ([]string, error)
- func GetKubeMasterIP() (string, error)
- func GetOsExt() (string, error)
- func GetPodLabelValues(n, label string) (map[string]string, error)
- func GetPodLogs(n, pod, container string, tail, alsoShowPreviousPodLogs bool) string
- func GetPodLogsForLabel(n, labelSelector string, container string, tail, alsoShowPreviousPodLogs bool) string
- func GetPodName(n, labelSelector string) (pod string, err error)
- func GetPodNames(n string) (pods []string)
- func GetPodStatus(n, pod string) string
- func GetResourcePath(p string) string
- func GitRootDir() (string, error)
- func HTTPDownload(dst string, src string) error
- func IsProcessRunning(p *os.Process) (bool, error)
- func IsProcessRunningInt(pid int) (bool, error)
- func IsProcessRunningString(pidS string) (bool, error)
- func KillProcess(p *os.Process) (err error)
- func KubeApply(namespace, yamlFileName string) error
- func KubeApplyContents(namespace, yamlContents string) error
- func KubeDelete(namespace, yamlFileName string) error
- func KubeDeleteContents(namespace, yamlContents string) error
- func NamespaceDeleted(n string) (bool, error)
- func PodExec(n, pod, container, command string) (string, error)
- func Poll(interval time.Duration, numTrials int, do func() (bool, error)) error
- func Record(command, record string) error
- func RunBackground(format string, args ...interface{}) (*os.Process, error)
- func Shell(format string, args ...interface{}) (string, error)
- func ShellContext(ctx context.Context, format string, args ...interface{}) (string, error)
- func ShellMuteOutput(format string, args ...interface{}) (string, error)
- func ShellSilent(format string, args ...interface{}) (string, error)
- func Teardown()
- func WaitForDeploymentsReady(ns string, timeout time.Duration) error
- func WriteTempfile(tmpDir, prefix, suffix, contents string) (string, error)
- func WriteTextFile(filePath, content string) error
- type Break
- type Retrier
Constants ¶
This section is empty.
Variables ¶
var ( // MockTestServer is used for the unit tests. Will be started once, terminated at the // end of the suite. MockTestServer *bootstrap.Server // MockPilotURL is the URL for the pilot http endpoint MockPilotURL string // MockPilotGrpcAddr is the address to be used for grpc connections. MockPilotGrpcAddr string // MockPilotHTTPPort is the dynamic port for pilot http MockPilotHTTPPort int // MockPilotGrpcPort is the dynamic port for pilot grpc MockPilotGrpcPort int )
var ( // IstioTop has the top of the istio tree, matches the env variable from make. IstioTop = os.Getenv("TOP") // IstioSrc is the location if istio source ($TOP/src/istio.io/istio IstioSrc = os.Getenv("ISTIO_GO") // IstioBin is the location of the binary output directory IstioBin = os.Getenv("ISTIO_BIN") // IstioOut is the location of the output directory ($TOP/out) IstioOut = os.Getenv("ISTIO_OUT") // EnvoyOutWriter captures envoy output // Redirect out and err from envoy to buffer - coverage tests get confused if we write to out. // TODO: use files EnvoyOutWriter bytes.Buffer // EnvoyErrWriter captures envoy errors EnvoyErrWriter bytes.Buffer )
Functions ¶
func Backoff ¶
Backoff returns a random value in [0, maxDelay] that increases exponentially with retries, starting from baseDelay. It is the Go equivalent to C++'s //util/time/backoff.cc.
func CheckDeployment ¶
CheckDeployment gets status of a deployment from a namespace
func CheckDeployments ¶
CheckDeployments checks whether all deployment in a given namespace
func CheckDeploymentsReady ¶
CheckDeploymentsReady checks if deployment resources are ready. get podsReady() sometimes gets pods created by the "Job" resource which never reach the "Running" steady state.
func CheckPodsRunning ¶
CheckPodsRunning returns readiness of all pods within a namespace. It will wait for upto 2 mins. use WithMaxDuration to specify a duration.
func CheckPodsRunningWithMaxDuration ¶
CheckPodsRunningWithMaxDuration returns if all pods in a namespace are in "Running" status Also check container status to be running.
func Compare ¶
Compare compares two byte slices. It returns an error with a contextual diff if they are not equal.
func CompareFiles ¶
CompareFiles compares the content of two files
func CompareToFile ¶
CompareToFile compares a content with a file
func CreateAndFill ¶
CreateAndFill fills in the given yaml template with the values and generates a temp file for the completed yaml.
func CreateNamespace ¶
CreateNamespace create a kubernetes namespace
func CreateTLSSecret ¶
CreateTLSSecret creates a secret from the provided cert and key files
func CreateTempfile ¶
CreateTempfile creates a tempfile string.
func DeleteNamespace ¶
DeleteNamespace delete a kubernetes namespace
func DownloadRelease ¶
DownloadRelease gets the specified release from istio repo to tmpDir.
func EnsureTestServer ¶
EnsureTestServer will ensure a pilot server is running in process and initializes the MockPilotUrl and MockPilotGrpcAddr to allow connections to the test pilot.
func ExtractTarGz ¶
ExtractTarGz extracts a .tar.gz file into current dir.
func FetchAndSaveClusterLogs ¶
FetchAndSaveClusterLogs will dump the logs for a cluster.
func GetAppPods ¶
GetAppPods gets a map of app names to the pods for the app, for the given namespace
func GetClusterSubnet ¶
GetClusterSubnet returns the subnet (in CIDR form, e.g. "24") for the nodes in the cluster.
func GetConfigs ¶
GetConfigs retrieves the configurations for the list of resources.
func GetHeadCommitSHA ¶
GetHeadCommitSHA finds the SHA of the commit to which the HEAD of branch points
func GetIngressPod ¶
GetIngressPod get istio ingress ip
func GetIngressPodNames ¶
GetIngressPodNames get the pod names for the Istio ingress deployment.
func GetKubeMasterIP ¶
GetKubeMasterIP returns the IP address of the kubernetes master service.
func GetPodLabelValues ¶
GetPodLabelValues gets a map of pod name to label value for the given label and namespace
func GetPodLogs ¶
GetPodLogs retrieves the logs for the given namespace, pod and container.
func GetPodLogsForLabel ¶
func GetPodLogsForLabel(n, labelSelector string, container string, tail, alsoShowPreviousPodLogs bool) string
GetPodLogsForLabel gets the logs for the given label selector and container
func GetPodName ¶
GetPodName gets the pod name for the given namespace and label selector
func GetPodNames ¶
GetPodNames gets names of all pods in specific namespace and return in a slice
func GetPodStatus ¶
GetPodStatus gets status of a pod from a namespace Note: It is not enough to check pod phase, which only implies there is at least one container running. Use kubectl CLI to get status so that we can ensure that all containers are running.
func GetResourcePath ¶
GetResourcePath give "path from WORKSPACE", return absolute path at runtime
func GitRootDir ¶
GitRootDir returns the absolute path to the root directory of the git repo where this function is called
func HTTPDownload ¶
HTTPDownload download from src(url) and store into dst(local file)
func IsProcessRunning ¶
IsProcessRunning check if a os.Process is running
func IsProcessRunningInt ¶
IsProcessRunningInt check if a process of the given pid(int) is running
func IsProcessRunningString ¶
IsProcessRunningString check if a process of the given pid(string) is running
func KubeApplyContents ¶
KubeApplyContents kubectl apply from contents
func KubeDelete ¶
KubeDelete kubectl delete from file
func KubeDeleteContents ¶
KubeDeleteContents kubectl apply from contents
func NamespaceDeleted ¶
NamespaceDeleted check if a kubernete namespace is deleted
func PodExec ¶
PodExec runs the specified command on the container for the specified namespace and pod
func Poll ¶
Poll executes do() after time interval for a max of numTrials times. The bool returned by do() indicates if polling succeeds in that trial
func RunBackground ¶
RunBackground starts a background process and return the Process if succeed
func ShellContext ¶
ShellContext run command on shell and get back output and error if get one
func ShellMuteOutput ¶
ShellMuteOutput run command on shell and get back output and error if get one without logging the output
func ShellSilent ¶
ShellSilent runs command on shell and get back output and error if get one without logging the command or output.
func WaitForDeploymentsReady ¶
WaitForDeploymentsReady wait up to 'timeout' duration return an error if deployments are not ready
func WriteTempfile ¶
WriteTempfile creates a tempfile with the specified contents.
func WriteTextFile ¶
WriteTextFile overwrites the file on the given path with content
Types ¶
type Break ¶
type Break struct {
Err error
}
Break the retry loop if the error returned is of this type.
type Retrier ¶
type Retrier struct { // BaseDelay is the minimum delay between retry attempts. BaseDelay time.Duration // MaxDelay is the maximum delay allowed between retry attempts. MaxDelay time.Duration // MaxDuration is the maximum cumulative duration allowed for all retries MaxDuration time.Duration // Retries defines number of retry attempts Retries int }
Retrier contains the retry configuration parameters.