diff --git a/.github/workflows/ci-lint.yaml b/.github/workflows/ci-lint.yaml index c689a43cd..5e882e0ed 100644 --- a/.github/workflows/ci-lint.yaml +++ b/.github/workflows/ci-lint.yaml @@ -4,36 +4,36 @@ jobs: lint: runs-on: ubuntu-latest steps: - - uses: actions/checkout@v2 + - uses: actions/checkout@v3 - name: golangci-lint run - uses: golangci/golangci-lint-action@v2 + uses: golangci/golangci-lint-action@v3 with: - version: v1.45 + version: v1.50 skip-pkg-cache: true skip-build-cache: true args: --timeout=2m0s -v bash-lint: runs-on: ubuntu-latest steps: - - uses: actions/checkout@v2 + - uses: actions/checkout@v3 - name: Run Shellcheck - uses: azohra/shell-linter@v0.4.0 + uses: azohra/shell-linter@v0.6.0 with: severity: "error" go-mod-tidy: runs-on: ubuntu-latest steps: - - uses: actions/checkout@v2 - - uses: actions/setup-go@v2 + - uses: actions/checkout@v3 + - uses: actions/setup-go@v3 with: - go-version: 1.15 + go-version: 1.19 - name: go mod tidy run: | ./scripts/ci/check_go_modules.sh sync-readme: runs-on: ubuntu-latest steps: - - uses: actions/checkout@v2 + - uses: actions/checkout@v3 - name: sync readme run: | ./scripts/ci/check_readme_in_sync.sh diff --git a/.github/workflows/ci-test.yaml b/.github/workflows/ci-test.yaml index 28f4e4f9a..e2a405271 100644 --- a/.github/workflows/ci-test.yaml +++ b/.github/workflows/ci-test.yaml @@ -4,7 +4,7 @@ jobs: unit-test-linux: runs-on: ubuntu-latest steps: - - uses: actions/checkout@v2 + - uses: actions/checkout@v3 - name: Run unit tests env: VERBOSE: true @@ -13,9 +13,9 @@ jobs: build-linux: runs-on: ubuntu-latest steps: - - uses: actions/checkout@v2 + - uses: actions/checkout@v3 - name: Checkout - uses: actions/checkout@v2 + uses: actions/checkout@v3 with: fetch-depth: 5 - name: Show history for debug help @@ -32,7 +32,7 @@ jobs: source ./scripts/build.sh save_images_to_tar - name: Save artifacts - uses: actions/upload-artifact@v2 + uses: actions/upload-artifact@v3 with: name: sonobuoy-build-linux-${{ github.run_id }} path: | @@ -42,12 +42,12 @@ jobs: needs: [integration-test-on-kind] steps: - name: Checkout - uses: actions/checkout@v2 + uses: actions/checkout@v3 - name: Set up QEMU - uses: docker/setup-qemu-action@v1 + uses: docker/setup-qemu-action@v2 - name: Set up Docker Buildx id: buildx - uses: docker/setup-buildx-action@v1 + uses: docker/setup-buildx-action@v2 - name: Inspect builder run: | echo "Name: ${{ steps.buildx.outputs.name }}" @@ -61,7 +61,7 @@ jobs: build_binary_GOOS_GOARCH windows amd64 windows_containers - name: Save artifacts - uses: actions/upload-artifact@v2 + uses: actions/upload-artifact@v3 with: name: sonobuoy-build-windows-${{ github.run_id }} path: | @@ -69,7 +69,7 @@ jobs: stress-test-linux: runs-on: ubuntu-latest steps: - - uses: actions/checkout@v2 + - uses: actions/checkout@v3 - name: Run stress tests env: VERBOSE: true @@ -80,7 +80,7 @@ jobs: needs: [build-linux, unit-test-linux] steps: - name: Download binaries and prebuilt images - uses: actions/download-artifact@v2 + uses: actions/download-artifact@v3 with: name: sonobuoy-build-linux-${{ github.run_id }} path: build @@ -96,7 +96,7 @@ jobs: runs-on: ubuntu-latest needs: [build-linux, unit-test-linux] steps: - - uses: actions/checkout@v2 + - uses: actions/checkout@v3 with: fetch-depth: 5 - name: Show history for debug help @@ -108,7 +108,7 @@ jobs: clean setup_kind_cluster - name: Download binaries and prebuilt images - uses: actions/download-artifact@v2 + uses: actions/download-artifact@v3 with: name: sonobuoy-build-linux-${{ github.run_id }} path: build @@ -130,7 +130,7 @@ jobs: VERBOSE=true SONOBUOY_CLI=../../build/linux/amd64/sonobuoy integration - name: Save artifacts if: ${{ always() }} - uses: actions/upload-artifact@v2 + uses: actions/upload-artifact@v3 with: name: sonobuoy-test-archives-${{ github.run_id }} path: | @@ -140,14 +140,14 @@ jobs: runs-on: ubuntu-latest needs: [build-linux, build-windows, unit-test-linux, integration-test-on-kind, stress-test-linux] steps: - - uses: actions/checkout@v2 + - uses: actions/checkout@v3 - name: Download binaries and prebuilt images - uses: actions/download-artifact@v2 + uses: actions/download-artifact@v3 with: name: sonobuoy-build-linux-${{ github.run_id }} path: build - name: Download binaries and prebuilt images - uses: actions/download-artifact@v2 + uses: actions/download-artifact@v3 with: name: sonobuoy-build-windows-${{ github.run_id }} path: build @@ -159,7 +159,7 @@ jobs: docker load -i build/linux/s390x/sonobuoy-img-linux-s390x-${{ github.run_id }}.tar docker image ls - name: Login to Docker Hub - uses: docker/login-action@v1 + uses: docker/login-action@v2 with: username: ${{ secrets.DOCKERHUB_USER }} password: ${{ secrets.DOCKERHUB_TOKEN }} @@ -176,15 +176,15 @@ jobs: needs: [push-images] steps: - name: Checkout - uses: actions/checkout@v2 + uses: actions/checkout@v3 with: fetch-depth: 0 - name: Set up Go - uses: actions/setup-go@v2 + uses: actions/setup-go@v3 with: - go-version: 1.18 + go-version: 1.19 - name: Run GoReleaser - uses: goreleaser/goreleaser-action@v2 + uses: goreleaser/goreleaser-action@v3 with: version: latest args: release --rm-dist diff --git a/.github/workflows/codeql-analysis.yaml b/.github/workflows/codeql-analysis.yaml index 1f05f3d3c..1cfbb8978 100644 --- a/.github/workflows/codeql-analysis.yaml +++ b/.github/workflows/codeql-analysis.yaml @@ -33,11 +33,11 @@ jobs: steps: - name: Checkout repository - uses: actions/checkout@v2 + uses: actions/checkout@v3 # Initializes the CodeQL tools for scanning. - name: Initialize CodeQL - uses: github/codeql-action/init@v1 + uses: github/codeql-action/init@v2 with: languages: ${{ matrix.language }} # If you wish to specify custom queries, you can do so here or in a config file. @@ -48,7 +48,7 @@ jobs: # Autobuild attempts to build any compiled languages (C/C++, C#, or Java). # If this step fails, then you should remove it and run the build manually (see below) - name: Autobuild - uses: github/codeql-action/autobuild@v1 + uses: github/codeql-action/autobuild@v2 # ℹ️ Command-line programs to run using the OS shell. # 📚 https://git.io/JvXDl @@ -62,4 +62,4 @@ jobs: # make release - name: Perform CodeQL Analysis - uses: github/codeql-action/analyze@v1 + uses: github/codeql-action/analyze@v2 diff --git a/.github/workflows/k8sRelease.yaml b/.github/workflows/k8sRelease.yaml index d8a010e56..bfd9e2673 100644 --- a/.github/workflows/k8sRelease.yaml +++ b/.github/workflows/k8sRelease.yaml @@ -12,12 +12,12 @@ jobs: - name: Check for release id: release-check run: | - echo ::set-output name=wasRelease::$(curl -s https://api.github.com/repos/kubernetes/kubernetes/releases/latest | jq -r '.published_at|fromdateiso8601 > now-86400') + echo wasRelease=$(curl -s https://api.github.com/repos/kubernetes/kubernetes/releases/latest | jq -r '.published_at|fromdateiso8601 > now-86400') >> $GITHUB_OUTPUT - name: Create issue - if: steps.release-check.outputs.wasRelease == 'true' + if: ${{ steps.release-check.outputs.wasRelease }} == 'true' uses: imjohnbo/issue-bot@v3 with: labels: "kind/required" title: "Notice of K8s Release" body: |- - A Kubernetes release was detected as having occurred in the last 24h. The ./scripts/gather_e2e_data.sh script should be run and Sonobuoy tested against the new release. \ No newline at end of file + A Kubernetes release was detected as having occurred in the last 24h. The ./scripts/gather_e2e_data.sh script should be run and Sonobuoy tested against the new release. diff --git a/cmd/sonobuoy/app/gen.go b/cmd/sonobuoy/app/gen.go index aef887d3d..e926ae0f0 100644 --- a/cmd/sonobuoy/app/gen.go +++ b/cmd/sonobuoy/app/gen.go @@ -20,7 +20,6 @@ package app import ( "fmt" - "io/ioutil" "os" "time" @@ -213,7 +212,7 @@ func NewCmdGen() *cobra.Command { func genManifest(genflags *genFlags) func(cmd *cobra.Command, args []string) { return func(cmd *cobra.Command, args []string) { if len(genflags.genFile) > 0 { - b, err := ioutil.ReadFile(genflags.genFile) + b, err := os.ReadFile(genflags.genFile) if err != nil { errlog.LogError(err) os.Exit(1) diff --git a/cmd/sonobuoy/app/gen_plugin_def_test.go b/cmd/sonobuoy/app/gen_plugin_def_test.go index 1a93eab2a..b8240c345 100644 --- a/cmd/sonobuoy/app/gen_plugin_def_test.go +++ b/cmd/sonobuoy/app/gen_plugin_def_test.go @@ -18,7 +18,7 @@ package app import ( "bytes" "flag" - "io/ioutil" + "os" "testing" "github.com/vmware-tanzu/sonobuoy/pkg/plugin/manifest" @@ -143,9 +143,9 @@ func TestPluginGenDef(t *testing.T) { } if *update { - ioutil.WriteFile(tC.expectFile, []byte(manifest), 0666) + os.WriteFile(tC.expectFile, []byte(manifest), 0666) } else { - fileData, err := ioutil.ReadFile(tC.expectFile) + fileData, err := os.ReadFile(tC.expectFile) if err != nil { t.Fatalf("Failed to read golden file %v: %v", tC.expectFile, err) } diff --git a/cmd/sonobuoy/app/images_test.go b/cmd/sonobuoy/app/images_test.go index 4aec573bc..b7687a03a 100644 --- a/cmd/sonobuoy/app/images_test.go +++ b/cmd/sonobuoy/app/images_test.go @@ -16,7 +16,6 @@ limitations under the License. package app import ( - "io/ioutil" "os" "testing" @@ -35,7 +34,7 @@ sigStorageRegistry: test-fake-registry.corp/fake-user ` func sampleE2eRegistryConfig() (string, error) { - configFile, err := ioutil.TempFile("", "e2eRegistryConfig.yaml") + configFile, err := os.CreateTemp("", "e2eRegistryConfig.yaml") if err != nil { return "", err } diff --git a/cmd/sonobuoy/app/pluginList.go b/cmd/sonobuoy/app/pluginList.go index c993c1950..1ab2c2aac 100644 --- a/cmd/sonobuoy/app/pluginList.go +++ b/cmd/sonobuoy/app/pluginList.go @@ -19,7 +19,6 @@ package app import ( "fmt" "io" - "io/ioutil" "net/http" "net/url" "os" @@ -169,7 +168,7 @@ func (p *pluginList) loadPluginsFromFilesystem(str, renameAs string) error { // into the directory. A plugin must have the '.yaml' extension to be considered. // It returns the first error encountered and stops processing. func (p *pluginList) loadPluginsDir(dirpath string) error { - files, err := ioutil.ReadDir(dirpath) + files, err := os.ReadDir(dirpath) if err != nil { return errors.Wrapf(err, "failed to read directory %q", dirpath) } @@ -213,7 +212,7 @@ func (p *pluginList) loadSinglePluginFromFile(filepath, renameAs string) error { // loadSinglePlugin reads the data from the reader and loads the plugin. func (p *pluginList) loadSinglePlugin(r io.ReadCloser, renameAs string) error { defer r.Close() - b, err := ioutil.ReadAll(r) + b, err := io.ReadAll(r) if err != nil { return errors.Wrap(err, "failed to read data for plugin") } diff --git a/cmd/sonobuoy/app/pluginList_test.go b/cmd/sonobuoy/app/pluginList_test.go index 88f45ae39..9bbbeadda 100644 --- a/cmd/sonobuoy/app/pluginList_test.go +++ b/cmd/sonobuoy/app/pluginList_test.go @@ -17,9 +17,9 @@ package app import ( "fmt" - "io/ioutil" "net/http" "net/http/httptest" + "os" "testing" "github.com/vmware-tanzu/sonobuoy/pkg/plugin/manifest" @@ -30,7 +30,7 @@ import ( func TestSetPluginList(t *testing.T) { serveFile := func(filepath string) http.Handler { return http.HandlerFunc(func(w http.ResponseWriter, req *http.Request) { - b, err := ioutil.ReadFile(filepath) + b, err := os.ReadFile(filepath) if err != nil { t.Fatal(err) } diff --git a/cmd/sonobuoy/app/sonobuoyconfig.go b/cmd/sonobuoy/app/sonobuoyconfig.go index 15991b908..732111e13 100644 --- a/cmd/sonobuoy/app/sonobuoyconfig.go +++ b/cmd/sonobuoy/app/sonobuoyconfig.go @@ -18,7 +18,7 @@ package app import ( "encoding/json" - "io/ioutil" + "os" "reflect" "github.com/pkg/errors" @@ -48,7 +48,7 @@ func (c *SonobuoyConfig) Set(str string) error { return errors.New("if a custom config file is set, it must be set before other flags that modify configuration fields") } - bytes, err := ioutil.ReadFile(str) + bytes, err := os.ReadFile(str) if err != nil { return errors.Wrap(err, "couldn't open config file") } diff --git a/cmd/sonobuoy/app/splat.go b/cmd/sonobuoy/app/splat.go index a0bac5f04..6faf40bab 100644 --- a/cmd/sonobuoy/app/splat.go +++ b/cmd/sonobuoy/app/splat.go @@ -19,7 +19,7 @@ package app import ( "archive/tar" "compress/gzip" - "io/ioutil" + "io" "os" "path/filepath" @@ -96,7 +96,7 @@ func addFileToTarball(tarWriter *tar.Writer, filename string) error { return err } - fileContent, err := ioutil.ReadAll(file) + fileContent, err := io.ReadAll(file) if err != nil { return err } diff --git a/cmd/sonobuoy/app/status_test.go b/cmd/sonobuoy/app/status_test.go index 88d35b2ef..3137fdd71 100644 --- a/cmd/sonobuoy/app/status_test.go +++ b/cmd/sonobuoy/app/status_test.go @@ -19,7 +19,7 @@ package app import ( "bytes" "io" - "io/ioutil" + "os" "testing" "github.com/vmware-tanzu/sonobuoy/pkg/plugin" @@ -89,9 +89,9 @@ func TestPrintStatus(t *testing.T) { } if *update { - ioutil.WriteFile(tc.expectFile, b.Bytes(), 0666) + os.WriteFile(tc.expectFile, b.Bytes(), 0666) } else { - fileData, err := ioutil.ReadFile(tc.expectFile) + fileData, err := os.ReadFile(tc.expectFile) if err != nil { t.Fatalf("Failed to read golden file %v: %v", tc.expectFile, err) } diff --git a/go.mod b/go.mod index 82a5b607a..5ac0a2bf6 100644 --- a/go.mod +++ b/go.mod @@ -1,6 +1,6 @@ module github.com/vmware-tanzu/sonobuoy -go 1.18 +go 1.19 require ( github.com/briandowns/spinner v1.6.1 diff --git a/kind-config.yaml b/kind-config.yaml index a7f0963e2..70fc14572 100644 --- a/kind-config.yaml +++ b/kind-config.yaml @@ -2,7 +2,7 @@ kind: Cluster apiVersion: kind.x-k8s.io/v1alpha4 nodes: - role: control-plane - image: &kind_node_image kindest/node:v1.23.3 + image: &kind_node_image kindest/node:v1.23.13 - role: worker image: *kind_node_image - role: worker diff --git a/pkg/backplane/ca/ca_test.go b/pkg/backplane/ca/ca_test.go index 8274b998c..337a4262e 100644 --- a/pkg/backplane/ca/ca_test.go +++ b/pkg/backplane/ca/ca_test.go @@ -18,7 +18,7 @@ package ca import ( "fmt" - "io/ioutil" + "io" "math/big" "net/http" "net/http/httptest" @@ -131,7 +131,7 @@ func TestServer(t *testing.T) { t.Fatalf("expected client error to be null, got %v", err) } defer resp.Body.Close() - respBody, err := ioutil.ReadAll(resp.Body) + respBody, err := io.ReadAll(resp.Body) if err != nil { t.Fatalf("couldn't read body: %v", err) } diff --git a/pkg/buildinfo/version.go b/pkg/buildinfo/version.go index bb3f587f8..59625cadc 100644 --- a/pkg/buildinfo/version.go +++ b/pkg/buildinfo/version.go @@ -21,7 +21,7 @@ package buildinfo // Version is the current version of Sonobuoy, set by the go linker's -X flag at build time. // Ensure that this is bumped manually as well so that Sonobuoy, as a library, also has the right version. -var Version = "v0.56.11" +var Version = "v0.56.12" // GitSHA is the actual commit that is being built, set by the go linker's -X flag at build time. var GitSHA string diff --git a/pkg/client/gen.go b/pkg/client/gen.go index ac712f026..fa3646001 100644 --- a/pkg/client/gen.go +++ b/pkg/client/gen.go @@ -24,7 +24,7 @@ import ( "encoding/json" "fmt" "io" - "io/ioutil" + "os" "sort" "strings" @@ -314,7 +314,7 @@ func generateSecret(w io.Writer, cfg *GenConfig) error { return nil } - sshKeyData, err := ioutil.ReadFile(cfg.SSHKeyPath) + sshKeyData, err := os.ReadFile(cfg.SSHKeyPath) if err != nil { return errors.Wrapf(err, "unable to read SSH key file: %v", cfg.SSHKeyPath) } diff --git a/pkg/client/gen_test.go b/pkg/client/gen_test.go index 73a456156..3f35090b5 100644 --- a/pkg/client/gen_test.go +++ b/pkg/client/gen_test.go @@ -5,7 +5,7 @@ import ( "encoding/json" "flag" "fmt" - "io/ioutil" + "os" "path/filepath" "reflect" "strings" @@ -499,9 +499,9 @@ func TestGenerateManifestGolden(t *testing.T) { } if *update { - ioutil.WriteFile(tc.goldenFile, manifest, 0666) + os.WriteFile(tc.goldenFile, manifest, 0666) } else { - fileData, err := ioutil.ReadFile(tc.goldenFile) + fileData, err := os.ReadFile(tc.goldenFile) if err != nil { t.Fatalf("Failed to read golden file %v: %v", tc.goldenFile, err) } diff --git a/pkg/client/logs.go b/pkg/client/logs.go index 2a490db85..9f583439f 100644 --- a/pkg/client/logs.go +++ b/pkg/client/logs.go @@ -175,7 +175,9 @@ func getPodsToStreamLogs(client kubernetes.Interface, cfg *LogConfig, podCh chan } // watchPodsToStreamLogs creates a watch for the desired pods and, as it gets events for new pods will add them onto the pod channel. -// If a plugin name has been provided, retrieve the pods with only the plugin label matching that plugin name. If no pods are found, +// +// If a plugin name has been provided, retrieve the pods with only the plugin label matching that plugin name. If no pods are found, +// // or no plugin has been specified, retrieve all pods within the namespace. It will return an error if unable to create the watcher // but will continue to add pods to the channel in a separate go routine. func watchPodsToStreamLogs(client kubernetes.Interface, cfg *LogConfig, podCh chan *v1.Pod) error { diff --git a/pkg/client/logs_test.go b/pkg/client/logs_test.go index 60ec5da38..ccc34bc9a 100644 --- a/pkg/client/logs_test.go +++ b/pkg/client/logs_test.go @@ -5,7 +5,7 @@ Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at - http://www.apache.org/licenses/LICENSE-2.0 + http://www.apache.org/licenses/LICENSE-2.0 Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, diff --git a/pkg/client/preflight_test.go b/pkg/client/preflight_test.go index 484131f49..135c2ada8 100644 --- a/pkg/client/preflight_test.go +++ b/pkg/client/preflight_test.go @@ -19,7 +19,7 @@ package client import ( "context" "fmt" - "io/ioutil" + "io" "strings" "testing" @@ -36,7 +36,7 @@ import ( func TestVersionCheck(t *testing.T) { testHook := &testhook.Hook{} logrus.AddHook(testHook) - logrus.SetOutput(ioutil.Discard) + logrus.SetOutput(io.Discard) serverAtVersion := func(major, minor, git string) *fakeServerVersionInterface { return &fakeServerVersionInterface{ diff --git a/pkg/client/results/junit_test.go b/pkg/client/results/junit_test.go index a33e55f5b..eeda519f3 100644 --- a/pkg/client/results/junit_test.go +++ b/pkg/client/results/junit_test.go @@ -7,7 +7,6 @@ import ( "errors" "fmt" "io" - "io/ioutil" "os" "path/filepath" "testing" @@ -39,7 +38,7 @@ func TestJUnitProcessReader(t *testing.T) { } itemFromFile := func(t *testing.T, path string) Item { i := Item{} - b, err := ioutil.ReadFile(path) + b, err := os.ReadFile(path) if err != nil { t.Fatalf("Failed to read test file %v: %v", path, err) } @@ -95,7 +94,7 @@ func TestJUnitProcessReader(t *testing.T) { t.Fatalf("Failed to marshal expected Item for debug: %v", err) } t.Logf("Updating goldenfile %v", tc.expectItemFromFile) - ioutil.WriteFile(tc.expectItemFromFile, b, 0666) + os.WriteFile(tc.expectItemFromFile, b, 0666) return } diff --git a/pkg/client/results/processing.go b/pkg/client/results/processing.go index 6f74f6859..c2afab5eb 100644 --- a/pkg/client/results/processing.go +++ b/pkg/client/results/processing.go @@ -19,7 +19,6 @@ package results import ( "encoding/json" "fmt" - "io/ioutil" "os" "path" "path/filepath" @@ -79,11 +78,13 @@ func hasCustomValues(items ...Item) bool { // AggregateStatus defines the aggregation rules for status according to the following rules: // If only pass/fail/unknown values are found, we apply very basic rules: -// - failure + * = failure -// - unknown + [pass|unknown] = unknown -// - empty list = unknown +// - failure + * = failure +// - unknown + [pass|unknown] = unknown +// - empty list = unknown +// // If we find other values (e.g. from manual results typically) then we just combine/count them: -// - foo + bar = 'foo: 1, bar:1' +// - foo + bar = 'foo: 1, bar:1' +// // useCustom is specified rather than looking for custom values because different branches of the // result tree may have/not have those values. So instead, we should look down the tree initially to decide. func AggregateStatus(useCustom bool, items ...Item) string { @@ -213,7 +214,7 @@ func PostProcessPlugin(p plugin.Interface, dir string) (Item, []error) { func processNodesWithProcessor(p plugin.Interface, baseDir, dir string, processor postProcessor, selector fileSelector) ([]Item, error) { pdir := path.Join(baseDir, PluginsDir, p.GetName()) - nodeDirs, err := ioutil.ReadDir(dir) + nodeDirs, err := os.ReadDir(dir) if err != nil && !os.IsNotExist(err) { return []Item{}, err } diff --git a/pkg/client/results/processing_test.go b/pkg/client/results/processing_test.go index 1b031d897..e88ccb63a 100644 --- a/pkg/client/results/processing_test.go +++ b/pkg/client/results/processing_test.go @@ -19,7 +19,7 @@ package results import ( "encoding/json" "flag" - "io/ioutil" + "os" "path/filepath" "testing" @@ -218,11 +218,11 @@ func TestPostProcessPluginGolden(t *testing.T) { if err != nil { t.Fatalf("Failed to marshal item: %v", err) } - ioutil.WriteFile(expectResults(tc.key), itemBytes, 0666) + os.WriteFile(expectResults(tc.key), itemBytes, 0666) } else { // Read in golden file and unmarshal. Easier to debug differences in the items than // comparing the bytes directly. - fileData, err := ioutil.ReadFile(expectResults(tc.key)) + fileData, err := os.ReadFile(expectResults(tc.key)) if err != nil { t.Fatalf("Failed to read golden file %v: %v", expectResults(tc.key), err) } diff --git a/pkg/client/results/reader_test.go b/pkg/client/results/reader_test.go index 2a97aab62..333cb12bd 100644 --- a/pkg/client/results/reader_test.go +++ b/pkg/client/results/reader_test.go @@ -21,7 +21,6 @@ import ( "compress/gzip" "fmt" "io" - "io/ioutil" "os" "path/filepath" "testing" @@ -47,7 +46,7 @@ func (v *version) String() string { func MustGetReader(path string, t *testing.T) *results.Reader { t.Helper() - data, err := ioutil.ReadFile(path) + data, err := os.ReadFile(path) if err != nil { t.Fatalf("Failed to read tarball data: %v", err) } @@ -345,7 +344,7 @@ func TestExtractBytes(t *testing.T) { func ExampleNewReaderFromBytes() { path := "testdata/results-0.8.tar.gz" - data, err := ioutil.ReadFile(path) + data, err := os.ReadFile(path) if err != nil { panic(err) } diff --git a/pkg/client/results/reader_unix.go b/pkg/client/results/reader_unix.go index 6a4b6a932..8315c14fc 100644 --- a/pkg/client/results/reader_unix.go +++ b/pkg/client/results/reader_unix.go @@ -1,5 +1,4 @@ //go:build aix || darwin || dragonfly || freebsd || (js && wasm) || linux || nacl || netbsd || openbsd || solaris -// +build aix darwin dragonfly freebsd js,wasm linux nacl netbsd openbsd solaris /* Copyright 2018 Heptio Inc. diff --git a/pkg/client/results/reader_windows.go b/pkg/client/results/reader_windows.go index a8ad63130..2c0c500e7 100644 --- a/pkg/client/results/reader_windows.go +++ b/pkg/client/results/reader_windows.go @@ -1,5 +1,4 @@ //go:build windows -// +build windows /* Copyright 2018 Heptio Inc. diff --git a/pkg/client/retrieve.go b/pkg/client/retrieve.go index 7b1ed7465..40eaf3932 100644 --- a/pkg/client/retrieve.go +++ b/pkg/client/retrieve.go @@ -21,7 +21,6 @@ import ( "compress/gzip" "fmt" "io" - "io/ioutil" "os" "path/filepath" "strings" @@ -277,7 +276,7 @@ func tarCmd(path string) []string { } func drainReader(r io.Reader) error { - b, err := ioutil.ReadAll(r) + b, err := io.ReadAll(r) if err != nil { return errors.Wrap(err, "failed to drain the tar reader") } diff --git a/pkg/client/run.go b/pkg/client/run.go index fd3bdc8a4..392fd8e35 100644 --- a/pkg/client/run.go +++ b/pkg/client/run.go @@ -20,7 +20,6 @@ import ( "bytes" "fmt" "io" - "io/ioutil" "os" "strings" "text/tabwriter" @@ -31,13 +30,13 @@ import ( "github.com/sirupsen/logrus" "github.com/vmware-tanzu/sonobuoy/pkg/plugin/aggregation" "golang.org/x/term" + corev1 "k8s.io/api/core/v1" kubeerror "k8s.io/apimachinery/pkg/api/errors" "k8s.io/apimachinery/pkg/apis/meta/v1/unstructured" "k8s.io/apimachinery/pkg/runtime" "k8s.io/apimachinery/pkg/util/wait" "k8s.io/apimachinery/pkg/util/yaml" "k8s.io/client-go/kubernetes/scheme" - corev1 "k8s.io/api/core/v1" ) const ( @@ -228,9 +227,9 @@ func loadManifestFromFile(f string) ([]byte, error) { return nil, fmt.Errorf("nothing on stdin to read") } - return ioutil.ReadAll(os.Stdin) + return io.ReadAll(os.Stdin) } else { - return ioutil.ReadFile(f) + return os.ReadFile(f) } } @@ -308,7 +307,6 @@ func humanReadableStatus(str string) string { } } - func getPodStatus(pod corev1.Pod) string { const ContainersNotReady = "ContainersNotReady" if pod.Status.Phase != corev1.PodRunning && pod.Status.Phase != corev1.PodSucceeded { diff --git a/pkg/client/run_test.go b/pkg/client/run_test.go index f2c12afea..64f2ee86b 100644 --- a/pkg/client/run_test.go +++ b/pkg/client/run_test.go @@ -17,11 +17,11 @@ limitations under the License. package client import ( - "os" - "strings" "encoding/json" - "reflect" corev1 "k8s.io/api/core/v1" + "os" + "reflect" + "strings" "testing" ) diff --git a/pkg/config/loader.go b/pkg/config/loader.go index 5e8c359d6..4d0b5f9aa 100644 --- a/pkg/config/loader.go +++ b/pkg/config/loader.go @@ -19,7 +19,7 @@ package config import ( "encoding/json" "fmt" - "io/ioutil" + "io" "os" "strings" @@ -56,7 +56,7 @@ func LoadConfig(pathsToTry ...string) (*Config, error) { defer jsonFile.Close() logrus.Tracef("Loading config from file: %v", fpath) - b, err := ioutil.ReadAll(jsonFile) + b, err := io.ReadAll(jsonFile) if err != nil { return nil, errors.Wrapf(err, "read config file %q", fpath) } diff --git a/pkg/config/loader_test.go b/pkg/config/loader_test.go index 88e370755..28525d137 100644 --- a/pkg/config/loader_test.go +++ b/pkg/config/loader_test.go @@ -19,7 +19,7 @@ package config import ( "encoding/json" "fmt" - "io/ioutil" + "io" "os" "reflect" "testing" @@ -37,7 +37,7 @@ func TestOpenConfigFile(t *testing.T) { // Set up 3 files with contents matching their path for this test. Cleanup afterwards. f1, f2 := "TestOpenConfigFile1", "TestOpenConfigFile2" for _, v := range []string{f1, f2} { - err := ioutil.WriteFile(v, []byte(v), 0644) + err := os.WriteFile(v, []byte(v), 0644) if err != nil { t.Fatalf("Failed to setup test files: %v", err) } @@ -93,7 +93,7 @@ func TestOpenConfigFile(t *testing.T) { t.Errorf("Expected %v but got %v", tc.expectPath, fpath) } - b, err := ioutil.ReadAll(f) + b, err := io.ReadAll(f) if err != nil { t.Fatalf("Failed to read file %v: %v", fpath, err) } @@ -110,7 +110,7 @@ func TestSaveAndLoad(t *testing.T) { cfg.Filters.Namespaces = "funky*" if blob, err := json.Marshal(&cfg); err == nil { - if err = ioutil.WriteFile("./config.json", blob, 0644); err != nil { + if err = os.WriteFile("./config.json", blob, 0644); err != nil { t.Fatalf("Failed to write default config.json: %v", err) } defer os.Remove("./config.json") @@ -139,7 +139,7 @@ func TestLoadConfigSetsUUID(t *testing.T) { cfg := New() if blob, err := json.Marshal(&cfg); err == nil { - if err = ioutil.WriteFile("./config.json", blob, 0644); err != nil { + if err = os.WriteFile("./config.json", blob, 0644); err != nil { t.Fatalf("Failed to write default config.json: %v", err) } defer os.Remove("./config.json") @@ -160,7 +160,7 @@ func TestLoadConfigSetsUUID(t *testing.T) { func TestDefaultResources(t *testing.T) { // Check that giving empty resources results in empty resources blob := `{"Resources":[]}` - if err := ioutil.WriteFile("./config.json", []byte(blob), 0644); err != nil { + if err := os.WriteFile("./config.json", []byte(blob), 0644); err != nil { t.Fatalf("Failed to write default config.json: %v", err) } defer os.Remove("./config.json") @@ -177,7 +177,7 @@ func TestDefaultResources(t *testing.T) { // Check that not specifying resources results in all the defaults blob = `{}` - if err = ioutil.WriteFile("./config.json", []byte(blob), 0644); err != nil { + if err = os.WriteFile("./config.json", []byte(blob), 0644); err != nil { t.Fatalf("Failed to write default config.json: %v", err) } cfg, err = LoadConfig() @@ -190,7 +190,7 @@ func TestDefaultResources(t *testing.T) { // Check that specifying one resource results in one resource blob = `{"Resources": ["Pods"]}` - if err = ioutil.WriteFile("./config.json", []byte(blob), 0644); err != nil { + if err = os.WriteFile("./config.json", []byte(blob), 0644); err != nil { t.Fatalf("Failed to write default config.json: %v", err) } cfg, err = LoadConfig() diff --git a/pkg/discovery/discovery.go b/pkg/discovery/discovery.go index 4d35756d6..4a15d1c2e 100644 --- a/pkg/discovery/discovery.go +++ b/pkg/discovery/discovery.go @@ -22,7 +22,6 @@ import ( "encoding/json" "fmt" "io" - "io/ioutil" "os" "path/filepath" "time" @@ -128,7 +127,7 @@ func Run(restConf *rest.Config, cfg *config.Config) (errCount int) { // 3. Dump the config.json we used to run our test if blob, err := json.Marshal(cfg); err == nil { logrus.Trace("Recording the marshalled Sonobuoy config") - if err = ioutil.WriteFile(filepath.Join(metapath, "config.json"), blob, 0644); err != nil { + if err = os.WriteFile(filepath.Join(metapath, "config.json"), blob, 0644); err != nil { errlog.LogError(errors.Wrap(err, "could not write config.json file")) return errCount + 1 } @@ -197,7 +196,7 @@ func Run(restConf *rest.Config, cfg *config.Config) (errCount int) { blob, err := json.Marshal(runInfo) trackErrorsFor("marshalling run info")(err) if err == nil { - err = ioutil.WriteFile(filepath.Join(metapath, results.InfoFile), blob, 0644) + err = os.WriteFile(filepath.Join(metapath, results.InfoFile), blob, 0644) trackErrorsFor("saving" + results.InfoFile)(err) } @@ -309,7 +308,7 @@ func dumpPlugin(p plugin.Interface, outputDir string) error { return errors.Wrapf(err, "encoding plugin %v definition to yaml", p.GetName()) } - err = ioutil.WriteFile( + err = os.WriteFile( filepath.Join(outputDir, results.PluginsDir, p.GetName(), pluginDefinitionFilename), b, os.FileMode(0644), diff --git a/pkg/discovery/query.go b/pkg/discovery/query.go index 58cc24614..a08fdf126 100644 --- a/pkg/discovery/query.go +++ b/pkg/discovery/query.go @@ -20,7 +20,6 @@ import ( "context" "encoding/json" "fmt" - "io/ioutil" "os" "path" "path/filepath" @@ -545,7 +544,7 @@ func (q *QueryRecorder) DumpQueryData(filepath string) error { return err } - return ioutil.WriteFile(filepath, data, 0755) + return os.WriteFile(filepath, data, 0755) } const ( @@ -612,7 +611,7 @@ func gatherPodLogs(kubeClient kubernetes.Interface, ns string, opts metav1.ListO } outfile := path.Join(outdir, container.Name) + ".txt" - if err = ioutil.WriteFile(outfile, body, 0644); err != nil { + if err = os.WriteFile(outfile, body, 0644); err != nil { return errors.WithStack(err) } } @@ -726,5 +725,5 @@ func SerializeObj(obj interface{}, outpath string, file string) error { return errors.WithStack(err) } - return errors.WithStack(ioutil.WriteFile(filepath.Join(outpath, file), b, 0644)) + return errors.WithStack(os.WriteFile(filepath.Join(outpath, file), b, 0644)) } diff --git a/pkg/discovery/summary.go b/pkg/discovery/summary.go index 7011b2660..feb95b9a3 100644 --- a/pkg/discovery/summary.go +++ b/pkg/discovery/summary.go @@ -19,7 +19,6 @@ package discovery import ( "encoding/json" "io/fs" - "io/ioutil" "os" "path" "path/filepath" @@ -113,9 +112,9 @@ func ReadPodHealth(r *results.Reader) (HealthInfo, error) { return health, nil } -//ReadHealthSummary reads the core_v1_nodes.json file from ClusterResourceLocation -//and returns a summary of the health fo the cluster, ready to be saved -//tarballRootDir is the directory that will be used to provide the contents of the tarball +// ReadHealthSummary reads the core_v1_nodes.json file from ClusterResourceLocation +// and returns a summary of the health fo the cluster, ready to be saved +// tarballRootDir is the directory that will be used to provide the contents of the tarball func ReadHealthSummary(tarballRootDir string) (ClusterSummary, error) { summary := ClusterSummary{} nodes := &v1.NodeList{} @@ -179,7 +178,7 @@ func SaveHealthSummary(tarballRootDir string) error { logrus.Errorf("File '%s' will not be included in '%s'.", outputFileName, tarballRootDir) return err } - err = ioutil.WriteFile(outputFileName, data, os.FileMode(0644)) + err = os.WriteFile(outputFileName, data, os.FileMode(0644)) if err != nil { logrus.Errorf("Failed to write health information to file '%s': %s", outputFileName, err) return err diff --git a/pkg/discovery/summary_test.go b/pkg/discovery/summary_test.go index 9cb239bb9..34531918b 100644 --- a/pkg/discovery/summary_test.go +++ b/pkg/discovery/summary_test.go @@ -20,7 +20,7 @@ import ( "bytes" "encoding/json" "flag" - "io/ioutil" + "os" "path/filepath" "testing" ) @@ -46,9 +46,9 @@ func TestReadHealthSummary(t *testing.T) { } if *update { - ioutil.WriteFile(goldenFilePath, gotJson, 0666) + os.WriteFile(goldenFilePath, gotJson, 0666) } else { - expectedJson, err := ioutil.ReadFile(goldenFilePath) + expectedJson, err := os.ReadFile(goldenFilePath) if err != nil { t.Fatalf("\n\nFailed to read golden file from '%s': %s\n", goldenFilePath, err) } diff --git a/pkg/image/imageversion.go b/pkg/image/imageversion.go index cfbbf0dfa..4267fd9b3 100644 --- a/pkg/image/imageversion.go +++ b/pkg/image/imageversion.go @@ -19,7 +19,7 @@ package image import ( "fmt" "github.com/sirupsen/logrus" - "io/ioutil" + "io" "net/http" "strings" @@ -122,7 +122,7 @@ func GetLatestDevVersion(url string) (string, error) { return "", errors.New("no body present when querying latest dev version") } defer r.Body.Close() - b, err := ioutil.ReadAll(r.Body) + b, err := io.ReadAll(r.Body) if err != nil { return "", errors.Wrap(err, "error reading body of latest dev version") } diff --git a/pkg/image/imageversion_test.go b/pkg/image/imageversion_test.go index e7afe02f0..f22adf874 100644 --- a/pkg/image/imageversion_test.go +++ b/pkg/image/imageversion_test.go @@ -18,7 +18,7 @@ package image import ( "fmt" - "io/ioutil" + "io" "net/http" "net/http/httptest" "testing" @@ -31,7 +31,7 @@ import ( ) func TestSetConformanceImageVersion(t *testing.T) { - logrus.SetOutput(ioutil.Discard) + logrus.SetOutput(io.Discard) tests := []struct { name string diff --git a/pkg/image/manifest.go b/pkg/image/manifest.go index 97f801249..7cb4603a6 100644 --- a/pkg/image/manifest.go +++ b/pkg/image/manifest.go @@ -17,7 +17,7 @@ package image import ( "fmt" - "io/ioutil" + "os" "github.com/hashicorp/go-version" "gopkg.in/yaml.v2" @@ -102,7 +102,7 @@ func NewRegistryList(repoConfig, k8sVersion string) (*RegistryList, error) { // Load in a config file if repoConfig != "" { - fileContent, err := ioutil.ReadFile(repoConfig) + fileContent, err := os.ReadFile(repoConfig) if err != nil { return nil, fmt.Errorf("Error reading '%v' file contents: %v", repoConfig, err) } diff --git a/pkg/image/manifest_test.go b/pkg/image/manifest_test.go index 0358bc63a..c06c43779 100644 --- a/pkg/image/manifest_test.go +++ b/pkg/image/manifest_test.go @@ -17,7 +17,7 @@ limitations under the License. package image import ( - "io/ioutil" + "os" "strings" "testing" @@ -93,7 +93,7 @@ func createTestRegistryConfig(customRegistry, version string) (string, error) { registries.GcRegistry = customRegistry registries.SampleRegistry = customRegistry - tmpfile, err := ioutil.TempFile("", "config.*.yaml") + tmpfile, err := os.CreateTemp("", "config.*.yaml") if err != nil { return "", err } diff --git a/pkg/plugin/aggregation/aggregator_test.go b/pkg/plugin/aggregation/aggregator_test.go index c0b8e6b67..4df813802 100644 --- a/pkg/plugin/aggregation/aggregator_test.go +++ b/pkg/plugin/aggregation/aggregator_test.go @@ -21,7 +21,6 @@ import ( "context" "fmt" "io" - "io/ioutil" "net/http" "os" "os/exec" @@ -52,12 +51,12 @@ func TestAggregation(t *testing.T) { resp := doRequest(t, srv.Client(), "PUT", URL, []byte("foo")) if resp.StatusCode != 200 { - body, _ := ioutil.ReadAll(resp.Body) + body, _ := io.ReadAll(resp.Body) t.Errorf("Got (%v) response from server: %v", resp.StatusCode, string(body)) } if result, ok := agg.Results["systemd_logs/node1"]; ok { - bytes, err := ioutil.ReadFile(path.Join(agg.OutputDir, result.Path(), defaultFilename)) + bytes, err := os.ReadFile(path.Join(agg.OutputDir, result.Path(), defaultFilename)) if string(bytes) != "foo" { t.Errorf("results for node1 incorrect (got %v): %v", string(bytes), err) } @@ -79,12 +78,12 @@ func TestAggregation_noExtension(t *testing.T) { } resp := doRequest(t, srv.Client(), "PUT", URL, []byte("foo")) if resp.StatusCode != 200 { - body, _ := ioutil.ReadAll(resp.Body) + body, _ := io.ReadAll(resp.Body) t.Errorf("Got (%v) response from server: %v", resp.StatusCode, string(body)) } if result, ok := agg.Results["systemd_logs/node1"]; ok { - bytes, err := ioutil.ReadFile(path.Join(agg.OutputDir, result.Path(), defaultFilename)) + bytes, err := os.ReadFile(path.Join(agg.OutputDir, result.Path(), defaultFilename)) if string(bytes) != "foo" { t.Errorf("results for node1 incorrect (got %v): %v", string(bytes), err) } @@ -113,12 +112,12 @@ func TestAggregation_tarfile(t *testing.T) { resp := doRequestWithHeaders(t, srv.Client(), "PUT", URL, tarBytes, headers) if resp.StatusCode != 200 { - body, _ := ioutil.ReadAll(resp.Body) + body, _ := io.ReadAll(resp.Body) t.Errorf("Got (%v) response from server: %v", resp.StatusCode, string(body)) } if result, ok := agg.Results["e2e/global"]; ok { - realBytes, err := ioutil.ReadFile(path.Join(agg.OutputDir, result.Path(), "inside_tar.txt")) + realBytes, err := os.ReadFile(path.Join(agg.OutputDir, result.Path(), "inside_tar.txt")) if err != nil || bytes.Compare(realBytes, fileBytes) != 0 { t.Logf("results e2e tests incorrect (got %v, expected %v): %v", string(realBytes), string(fileBytes), err) output, _ := exec.Command("ls", "-lR", agg.OutputDir).CombinedOutput() @@ -188,7 +187,7 @@ func TestAggregation_duplicates(t *testing.T) { func TestAggregation_duplicatesWithErrors(t *testing.T) { // Setup aggregator with expected results and preload the test data/info // that we want to transmit/compare against. - dir, err := ioutil.TempDir("", "sonobuoy_server_test") + dir, err := os.MkdirTemp("", "sonobuoy_server_test") if err != nil { t.Fatalf("Could not create temp directory: %v", err) } @@ -252,7 +251,7 @@ func TestAggregation_duplicatesWithErrors(t *testing.T) { func TestAggregation_RetryWindow(t *testing.T) { // Setup aggregator with expected results and preload the test data/info // that we want to transmit/compare against. - dir, err := ioutil.TempDir("", "sonobuoy_server_test") + dir, err := os.MkdirTemp("", "sonobuoy_server_test") if err != nil { t.Fatalf("Could not create temp directory: %v", err) } @@ -342,7 +341,7 @@ func TestAggregation_errors(t *testing.T) { agg.Wait(make(chan bool)) if result, ok := agg.Results["e2e/global"]; ok { - bytes, err := ioutil.ReadFile(path.Join(agg.OutputDir, result.Path(), "error.json")) + bytes, err := os.ReadFile(path.Join(agg.OutputDir, result.Path(), "error.json")) if err != nil || string(bytes) != `{"error":"foo"}` { t.Errorf("results for e2e plugin incorrect (got %v): %v", string(bytes), err) } @@ -484,7 +483,7 @@ func TestProcessProgressUpdates(t *testing.T) { } func withAggregator(t *testing.T, expected []plugin.ExpectedResult, callback func(*Aggregator, *authtest.Server)) { - dir, err := ioutil.TempDir("", "sonobuoy_server_test") + dir, err := os.MkdirTemp("", "sonobuoy_server_test") if err != nil { t.Fatal("Could not create temp directory") return @@ -504,7 +503,7 @@ func withAggregator(t *testing.T, expected []plugin.ExpectedResult, callback fun // Create a gzipped tar file with the given filename (and contents) inside it, // return the raw bytes for that tar file. func makeTarWithContents(t *testing.T, filename string, fileContents []byte) (tarbytes []byte) { - dir, err := ioutil.TempDir("", "sonobuoy_server_test") + dir, err := os.MkdirTemp("", "sonobuoy_server_test") if err != nil { t.Fatalf("Could not create temp directory: %v", err) return @@ -521,7 +520,7 @@ func makeTarWithContents(t *testing.T, filename string, fileContents []byte) (ta filepath := path.Join(tardir, filename) tarfile := path.Join(dir, "results.tar.gz") - err = ioutil.WriteFile(filepath, fileContents, 0644) + err = os.WriteFile(filepath, fileContents, 0644) if err != nil { t.Fatalf("Could not write to temp file %v: %v", filepath, err) return @@ -533,7 +532,7 @@ func makeTarWithContents(t *testing.T, filename string, fileContents []byte) (ta return } - tarbytes, err = ioutil.ReadFile(tarfile) + tarbytes, err = os.ReadFile(tarfile) if err != nil { t.Fatalf("Could not read created tar file %v: %v", tarfile, err) return diff --git a/pkg/plugin/aggregation/handler_test.go b/pkg/plugin/aggregation/handler_test.go index c72a7a933..fac437e20 100644 --- a/pkg/plugin/aggregation/handler_test.go +++ b/pkg/plugin/aggregation/handler_test.go @@ -19,7 +19,6 @@ package aggregation import ( "bytes" "io" - "io/ioutil" "net/http" "os" "reflect" @@ -39,7 +38,7 @@ func TestStart(t *testing.T) { expectedResult := "systemd_logs/results/testnode" expectedJSON := []byte(`{"some": "json"}`) - tmpdir, err := ioutil.TempDir("", "sonobuoy_server_test") + tmpdir, err := os.MkdirTemp("", "sonobuoy_server_test") if err != nil { t.Fatal("Could not create temp directory") } diff --git a/pkg/plugin/aggregation/run.go b/pkg/plugin/aggregation/run.go index 652e1bb31..ebd2d355a 100644 --- a/pkg/plugin/aggregation/run.go +++ b/pkg/plugin/aggregation/run.go @@ -63,14 +63,14 @@ func (t *timeoutErr) Error() string { return t.e.Error() } // // Basic workflow: // -// 1. Create the aggregator object (`aggr`) to keep track of results -// 2. Launch the HTTP server with the aggr's HandleHTTPResult function as the -// callback -// 3. Run all the aggregation plugins, monitoring each one in a goroutine, -// configuring them to send failure results through a shared channel -// 4. Hook the shared monitoring channel up to aggr's IngestResults() function -// 5. Block until aggr shows all results accounted for (results come in through -// the HTTP callback), stopping the HTTP server on completion +// 1. Create the aggregator object (`aggr`) to keep track of results +// 2. Launch the HTTP server with the aggr's HandleHTTPResult function as the +// callback +// 3. Run all the aggregation plugins, monitoring each one in a goroutine, +// configuring them to send failure results through a shared channel +// 4. Hook the shared monitoring channel up to aggr's IngestResults() function +// 5. Block until aggr shows all results accounted for (results come in through +// the HTTP callback), stopping the HTTP server on completion func Run(client kubernetes.Interface, plugins []plugin.Interface, cfg plugin.AggregationConfig, progressPort, pluginResultsDir, namespace, outdir string) error { // Construct a list of things we'll need to dispatch if len(plugins) == 0 { diff --git a/pkg/plugin/aggregation/run_test.go b/pkg/plugin/aggregation/run_test.go index a6689b3b8..6e00be595 100644 --- a/pkg/plugin/aggregation/run_test.go +++ b/pkg/plugin/aggregation/run_test.go @@ -7,7 +7,6 @@ import ( "crypto/rand" "crypto/tls" "crypto/x509" - "io/ioutil" "math/big" "os" "reflect" @@ -124,7 +123,7 @@ func TestRunAndMonitorPlugin(t *testing.T) { } for _, tc := range testCases { t.Run(tc.desc, func(t *testing.T) { - tmpDir, err := ioutil.TempDir("", "sonobuoy-test") + tmpDir, err := os.MkdirTemp("", "sonobuoy-test") if err != nil { t.Fatalf("Failed to make temp directory: %v", err) } diff --git a/pkg/plugin/driver/base_test.go b/pkg/plugin/driver/base_test.go index 91259006c..065a67e9c 100644 --- a/pkg/plugin/driver/base_test.go +++ b/pkg/plugin/driver/base_test.go @@ -206,7 +206,7 @@ func TestCreateWorkerContainerDefinition(t *testing.T) { }, } expectedEnvVars = append(expectedEnvVars, presetPluginEnv...) - + for _, e := range expectedEnvVars { if !envContains(container.Env, e) { return fmt.Errorf("expected container environment to contain %q", e) diff --git a/pkg/plugin/interface.go b/pkg/plugin/interface.go index a4344ed44..0e1adcaf0 100644 --- a/pkg/plugin/interface.go +++ b/pkg/plugin/interface.go @@ -288,7 +288,6 @@ func (s ProgressUpdate) Key() string { // Corresponding to S = ProgressUpdate.Completed, F = len(ProgressUpdate.Failures), // and ProgressUpdate.Total - S - F respectively // and the ", Remaining: R" part is printed only if R is not negative -// func (s *ProgressUpdate) FormatPluginProgress() (output string) { //Minumum size of each field, in characters minSize := 3 diff --git a/pkg/plugin/interface_test.go b/pkg/plugin/interface_test.go index 68b574b8b..13f91f140 100644 --- a/pkg/plugin/interface_test.go +++ b/pkg/plugin/interface_test.go @@ -57,34 +57,34 @@ func TestCombineUpdates(t *testing.T) { func TestProgressUpdateFormatting(t *testing.T) { testCases := []struct { desc string - p ProgressUpdate + p ProgressUpdate expect string }{ { desc: "Zero total should produce NO 'Remaining:'", - p: ProgressUpdate{Node: "nonempty", Completed: 1, Failures: []string{"c", "d"}, Message: "bar"}, + p: ProgressUpdate{Node: "nonempty", Completed: 1, Failures: []string{"c", "d"}, Message: "bar"}, expect: "Passed: 1, Failed: 2", }, { desc: "When Total matches the total, Remaining SHOULD printed", - p: ProgressUpdate{Node: "nonempty", Completed: 1, Total: 3, Failures: []string{"c", "d"}, Message: "bar"}, + p: ProgressUpdate{Node: "nonempty", Completed: 1, Total: 3, Failures: []string{"c", "d"}, Message: "bar"}, expect: "Passed: 1, Failed: 2, Remaining: 0", }, { desc: "When Total is less than failures+completed, Remaining should NOT be printed", - p: ProgressUpdate{Node: "nonempty", Completed: 2, Total: 1, Failures: []string{"c"}, Message: "bar"}, + p: ProgressUpdate{Node: "nonempty", Completed: 2, Total: 1, Failures: []string{"c"}, Message: "bar"}, expect: "Passed: 2, Failed: 1", }, { desc: "When Total is more than failures+completed, Remaining SHOULD be printed", - p: ProgressUpdate{Node: "nonempty", Completed: 2, Total: 50, Failures: []string{"c", "d"}, Message: "bar"}, + p: ProgressUpdate{Node: "nonempty", Completed: 2, Total: 50, Failures: []string{"c", "d"}, Message: "bar"}, expect: "Passed: 2, Failed: 2, Remaining: 46", }, { desc: "When total is negative, Remaining should NOT be printed", - p: ProgressUpdate{Node: "nonempty", Completed: 2, Total: -1, Failures: []string{"c", "d"}, Message: "bar"}, + p: ProgressUpdate{Node: "nonempty", Completed: 2, Total: -1, Failures: []string{"c", "d"}, Message: "bar"}, expect: "Passed: 2, Failed: 2", }, } for _, tc := range testCases { t.Run(tc.desc, func(t *testing.T) { - if got := tc.p.FormatPluginProgress(); got != tc.expect{ + if got := tc.p.FormatPluginProgress(); got != tc.expect { t.Fatalf("\n\n%s: expected '%s', got '%s'\n", tc.desc, tc.expect, got) } }) diff --git a/pkg/plugin/loader/loader.go b/pkg/plugin/loader/loader.go index 882589da9..37d4677f5 100644 --- a/pkg/plugin/loader/loader.go +++ b/pkg/plugin/loader/loader.go @@ -18,7 +18,6 @@ package loader import ( "fmt" - "io/ioutil" "os" "path/filepath" "strings" @@ -89,7 +88,7 @@ func LoadAllPlugins(namespace, sonobuoyImage, imagePullPolicy, imagePullSecrets } func findPlugins(dir string) ([]string, error) { - candidates, err := ioutil.ReadDir(dir) + candidates, err := os.ReadDir(dir) if err != nil { return []string{}, errors.Wrapf(err, "couldn't search path %v", dir) } @@ -121,7 +120,7 @@ func LoadDefinitionFromFile(file string) (*manifest.Manifest, error) { } func readDefinitionFromFile(file string) ([]byte, error) { - bytes, err := ioutil.ReadFile(file) + bytes, err := os.ReadFile(file) return bytes, errors.Wrapf(err, "couldn't open plugin definition %v", file) } diff --git a/pkg/plugin/manifest/serializer_test.go b/pkg/plugin/manifest/serializer_test.go index e5e187378..e71c30d3a 100644 --- a/pkg/plugin/manifest/serializer_test.go +++ b/pkg/plugin/manifest/serializer_test.go @@ -18,7 +18,7 @@ package manifest import ( "fmt" - "io/ioutil" + "os" "reflect" "testing" @@ -111,7 +111,7 @@ func TestUnmarshallWithExtraVolumes(t *testing.T) { }, } - manifest, err := ioutil.ReadFile("testdata/extravolumes.yaml") + manifest, err := os.ReadFile("testdata/extravolumes.yaml") if err != nil { t.Fatalf("couldn't load file: %v", err) } diff --git a/pkg/tarball/tarball_test.go b/pkg/tarball/tarball_test.go index 8fae11ab7..fcd66f4d8 100644 --- a/pkg/tarball/tarball_test.go +++ b/pkg/tarball/tarball_test.go @@ -21,7 +21,6 @@ import ( "bytes" "compress/gzip" "io" - "io/ioutil" "os" "path" "path/filepath" @@ -124,7 +123,7 @@ func TestDecodeTarball(t *testing.T) { for _, archive := range archives { t.Run(archive.name, func(t *testing.T) { - dir, err := ioutil.TempDir("", "tarball-test") + dir, err := os.MkdirTemp("", "tarball-test") if err != nil { t.Fatalf("Unexpected error %v", err) } @@ -135,7 +134,7 @@ func TestDecodeTarball(t *testing.T) { t.Fatalf("Unexpected error %v", err) } - contents, err := ioutil.ReadFile(filepath.Join(dir, dirName, fileName)) + contents, err := os.ReadFile(filepath.Join(dir, dirName, fileName)) if err != nil { t.Fatalf("Unexpected error %v", err) } @@ -143,7 +142,7 @@ func TestDecodeTarball(t *testing.T) { if !reflect.DeepEqual(contents, testData) { t.Errorf("Expected %s, got %s", testData, contents) } - contents, err = ioutil.ReadFile(filepath.Join(dir, dirName, symLinkName)) + contents, err = os.ReadFile(filepath.Join(dir, dirName, symLinkName)) if err != nil { t.Fatalf("Unexpected error %v", err) } diff --git a/pkg/worker/request_test.go b/pkg/worker/request_test.go index 5274bcfc1..640650fd3 100644 --- a/pkg/worker/request_test.go +++ b/pkg/worker/request_test.go @@ -19,7 +19,6 @@ package worker import ( "bytes" "io" - "io/ioutil" "net/http" "net/http/httptest" "strings" @@ -150,7 +149,7 @@ func (t *testServer) ServeHTTP(w http.ResponseWriter, r *http.Request) { func TestDoRequestLogsMessagesAndRetries(t *testing.T) { testHook := &testhook.Hook{} logrus.AddHook(testHook) - logrus.SetOutput(ioutil.Discard) + logrus.SetOutput(io.Discard) callback := func() (io.Reader, string, string, error) { return strings.NewReader("testReader"), "fakefilename", "testString", nil diff --git a/pkg/worker/worker.go b/pkg/worker/worker.go index ec30e869f..a5d50184e 100644 --- a/pkg/worker/worker.go +++ b/pkg/worker/worker.go @@ -21,7 +21,6 @@ import ( "context" "fmt" "io" - "io/ioutil" "mime" "net/http" "os" @@ -163,7 +162,7 @@ func GatherResults(waitfile string, url string, client *http.Client, stopc <-cha } // Don't read the contents until this point in case another container edits the value. - resultFile, err := ioutil.ReadFile(waitfile) + resultFile, err := os.ReadFile(waitfile) if err != nil { logrus.Tracef("Done file was present but reading it resulted in an error: %v", err.Error()) continue diff --git a/pkg/worker/worker_test.go b/pkg/worker/worker_test.go index 811011d49..3c35ea97e 100644 --- a/pkg/worker/worker_test.go +++ b/pkg/worker/worker_test.go @@ -18,7 +18,6 @@ package worker import ( "io" - "io/ioutil" "net/http" "net/http/httptest" "os" @@ -52,8 +51,8 @@ func TestRun(t *testing.T) { } withTempDir(t, func(tmpdir string) { - ioutil.WriteFile(filepath.Join(tmpdir, "systemd_logs"), []byte("{}"), 0755) - ioutil.WriteFile(filepath.Join(tmpdir, "done"), []byte(filepath.Join(tmpdir, "systemd_logs")), 0755) + os.WriteFile(filepath.Join(tmpdir, "systemd_logs"), []byte("{}"), 0755) + os.WriteFile(filepath.Join(tmpdir, "done"), []byte(filepath.Join(tmpdir, "systemd_logs")), 0755) err := GatherResults(filepath.Join(tmpdir, "done"), URL, srv.Client(), nil) if err != nil { t.Fatalf("Got error running agent: %v", err) @@ -79,8 +78,8 @@ func TestRunGlobal(t *testing.T) { } withTempDir(t, func(tmpdir string) { - ioutil.WriteFile(filepath.Join(tmpdir, "systemd_logs.json"), []byte("{}"), 0755) - ioutil.WriteFile(filepath.Join(tmpdir, "done"), []byte(filepath.Join(tmpdir, "systemd_logs.json")), 0755) + os.WriteFile(filepath.Join(tmpdir, "systemd_logs.json"), []byte("{}"), 0755) + os.WriteFile(filepath.Join(tmpdir, "done"), []byte(filepath.Join(tmpdir, "systemd_logs.json")), 0755) err := GatherResults(filepath.Join(tmpdir, "done"), url, srv.Client(), nil) if err != nil { t.Fatalf("Got error running agent: %v", err) @@ -104,8 +103,8 @@ func TestRunGlobal_noExtension(t *testing.T) { t.Fatalf("unexpected error getting global result url %v", err) } withTempDir(t, func(tmpdir string) { - ioutil.WriteFile(filepath.Join(tmpdir, "systemd_logs"), []byte("{}"), 0755) - ioutil.WriteFile(filepath.Join(tmpdir, "done"), []byte(filepath.Join(tmpdir, "systemd_logs")), 0755) + os.WriteFile(filepath.Join(tmpdir, "systemd_logs"), []byte("{}"), 0755) + os.WriteFile(filepath.Join(tmpdir, "done"), []byte(filepath.Join(tmpdir, "systemd_logs")), 0755) err := GatherResults(filepath.Join(tmpdir, "done"), url, srv.Client(), nil) if err != nil { t.Fatalf("Got error running agent: %v", err) @@ -166,7 +165,7 @@ func TestRelayProgress(t *testing.T) { if tc.serverStatus != 0 { w.WriteHeader(tc.serverStatus) } - b, err := ioutil.ReadAll(r.Body) + b, err := io.ReadAll(r.Body) if err != nil { t.Fatalf("Failed to ready body: %v", err) } @@ -199,7 +198,7 @@ func ensureExists(t *testing.T, checkPath string) { func withTempDir(t *testing.T, callback func(tmpdir string)) { // Create a temporary directory for results gathering - tmpdir, err := ioutil.TempDir("", "sonobuoy_test") + tmpdir, err := os.MkdirTemp("", "sonobuoy_test") defer os.RemoveAll(tmpdir) if err != nil { t.Fatalf("Could not create temporary directory %v: %v", tmpdir, err) diff --git a/scripts/build_funcs.sh b/scripts/build_funcs.sh index f4132a3d3..058f5d80b 100755 --- a/scripts/build_funcs.sh +++ b/scripts/build_funcs.sh @@ -28,14 +28,14 @@ IMAGE_BRANCH=$(git rev-parse --abbrev-ref HEAD | sed 's/\///g') GIT_REF_LONG=$(git rev-parse --verify HEAD) BUILDMNT=/go/src/$GOTARGET -BUILD_IMAGE=golang:1.18 +BUILD_IMAGE=golang:1.19 AMD_IMAGE=gcr.io/distroless/static:nonroot ARM_IMAGE=gcr.io/distroless/static:nonroot-arm64 PPC64LE_IMAGE=gcr.io/distroless/static:nonroot-ppc64le S390X_IMAGE=gcr.io/distroless/static:nonroot-s390x WIN_AMD64_BASEIMAGE=mcr.microsoft.com/windows/nanoserver TEST_IMAGE=testimage:v0.1 -LINT_IMAGE=golangci/golangci-lint:v1.45 +LINT_IMAGE=golangci/golangci-lint:v1.50 KIND_CLUSTER=kind SCRIPT_DIR="$( cd -- "$( dirname -- "${BASH_SOURCE[0]:-$0}"; )" &> /dev/null && pwd 2> /dev/null; )" @@ -56,7 +56,7 @@ stress() { integration() { # Download linux kubectl and move into default path for tests - curl --output ./kubectl https://storage.googleapis.com/kubernetes-release/release/v1.23.0/bin/linux/amd64/kubectl + curl --output ./kubectl https://storage.googleapis.com/kubernetes-release/release/v1.25.3/bin/linux/amd64/kubectl chmod +x ./kubectl docker run --rm \ @@ -78,7 +78,7 @@ local_integration(){ build_binary_GOOS_GOARCH linux amd64 cp ./build/linux/amd64/sonobuoy ./sonobuoy # Download linux kubectl and move into default path for tests - curl --output ./kubectl https://storage.googleapis.com/kubernetes-release/release/v1.23.0/bin/linux/amd64/kubectl + curl --output ./kubectl https://storage.googleapis.com/kubernetes-release/release/v1.25.3/bin/linux/amd64/kubectl chmod +x ./kubectl integration } @@ -366,7 +366,7 @@ update_local() { set -x if [ ! -f "./kubectl" ]; then # Download linux kubectl and move into default path for tests - curl --output ./kubectl https://storage.googleapis.com/kubernetes-release/release/v1.23.0/bin/linux/amd64/kubectl + curl --output ./kubectl https://storage.googleapis.com/kubernetes-release/release/v1.25.3/bin/linux/amd64/kubectl chmod +x ./kubectl fi @@ -394,4 +394,4 @@ update_cli_docs() { mkdir -p "${output}" echo "Generating new docs..." ./sonobuoy gen cli "${output}" -} \ No newline at end of file +} diff --git a/scripts/gathere2e/Dockerfile b/scripts/gathere2e/Dockerfile index 040cdd0db..c5c5c0cdc 100644 --- a/scripts/gathere2e/Dockerfile +++ b/scripts/gathere2e/Dockerfile @@ -1,7 +1,7 @@ FROM debian:stable-slim RUN apt-get update && \ apt-get -y install wget curl git jq && \ - wget -O /bin/sonobuoy.tar.gz https://github.com/vmware-tanzu/sonobuoy/releases/download/v0.56.8/sonobuoy_0.56.8_linux_amd64.tar.gz && \ + wget -O /bin/sonobuoy.tar.gz https://github.com/vmware-tanzu/sonobuoy/releases/download/v0.56.11/sonobuoy_0.56.11_linux_amd64.tar.gz && \ tar -C /bin -xzf /bin/sonobuoy.tar.gz && \ chmod 755 /bin/sonobuoy diff --git a/site/config.yaml b/site/config.yaml index 8295db049..6c8c18d1f 100644 --- a/site/config.yaml +++ b/site/config.yaml @@ -32,9 +32,10 @@ params: docs_search_index_name: index_name docs_search_api_key: api_key docs_versioning: true - docs_latest: v0.56.11 + docs_latest: v0.56.12 docs_versions: - main + - v0.56.12 - v0.56.11 - v0.56.10 - v0.56.9 diff --git a/site/content/docs/main/cli/sonobuoy.md b/site/content/docs/main/cli/sonobuoy.md index 4503a046a..369232adb 100644 --- a/site/content/docs/main/cli/sonobuoy.md +++ b/site/content/docs/main/cli/sonobuoy.md @@ -35,4 +35,4 @@ sonobuoy [flags] * [sonobuoy version](sonobuoy_version.md) - Print sonobuoy version * [sonobuoy wait](sonobuoy_wait.md) - Waits on the Sonobuoy run in the targeted namespace. -###### Auto generated by spf13/cobra on 1-Nov-2022 +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/main/cli/sonobuoy_delete.md b/site/content/docs/main/cli/sonobuoy_delete.md index 74531cb4f..ec991c988 100644 --- a/site/content/docs/main/cli/sonobuoy_delete.md +++ b/site/content/docs/main/cli/sonobuoy_delete.md @@ -33,4 +33,4 @@ sonobuoy delete [flags] * [sonobuoy](sonobuoy.md) - Generate reports on your Kubernetes cluster by running plugins -###### Auto generated by spf13/cobra on 1-Nov-2022 +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/main/cli/sonobuoy_e2e.md b/site/content/docs/main/cli/sonobuoy_e2e.md index d6a7664f1..8e2cfb4ff 100644 --- a/site/content/docs/main/cli/sonobuoy_e2e.md +++ b/site/content/docs/main/cli/sonobuoy_e2e.md @@ -33,4 +33,4 @@ sonobuoy e2e [flags] * [sonobuoy](sonobuoy.md) - Generate reports on your Kubernetes cluster by running plugins -###### Auto generated by spf13/cobra on 1-Nov-2022 +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/main/cli/sonobuoy_gen.md b/site/content/docs/main/cli/sonobuoy_gen.md index 645c1182b..a64d98e23 100644 --- a/site/content/docs/main/cli/sonobuoy_gen.md +++ b/site/content/docs/main/cli/sonobuoy_gen.md @@ -42,7 +42,7 @@ sonobuoy gen [flags] --service-account-name string Name of the service account to be used by sonobuoy. (default "sonobuoy-serviceaccount") --show-default-podspec If true, include the default pod spec used for plugins in the output. --skip-preflight strings[=true] Skips the specified preflight checks. Valid values are [dnscheck, versioncheck, existingnamespace] or true to skip all of the checks. - --sonobuoy-image string Container image override for the sonobuoy worker and aggregator. (default "sonobuoy/sonobuoy:v0.56.10-2-g67583dfd") + --sonobuoy-image string Container image override for the sonobuoy worker and aggregator. (default "sonobuoy/sonobuoy:v0.56.11-2-g78c79313-dirty") --ssh-key yamlFile Path to the private key enabling SSH to cluster nodes. May be required by some tests from the e2e plugin. --ssh-user envModifier SSH user for ssh-key. Required if running e2e plugin with certain tests that require SSH access to nodes. --systemd-logs-image image Container image override for the systemd-logs plugin. Shorthand for --plugin-image=systemd-logs: (default map[]) @@ -64,4 +64,4 @@ sonobuoy gen [flags] * [sonobuoy gen default-image-config](sonobuoy_gen_default-image-config.md) - Generates the default image registry config for the e2e plugin * [sonobuoy gen plugin](sonobuoy_gen_plugin.md) - Generates the manifest Sonobuoy uses to define a plugin -###### Auto generated by spf13/cobra on 1-Nov-2022 +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/main/cli/sonobuoy_gen_config.md b/site/content/docs/main/cli/sonobuoy_gen_config.md index 7ecaa5019..2bee30f0f 100644 --- a/site/content/docs/main/cli/sonobuoy_gen_config.md +++ b/site/content/docs/main/cli/sonobuoy_gen_config.md @@ -42,7 +42,7 @@ sonobuoy gen config [flags] --service-account-name string Name of the service account to be used by sonobuoy. (default "sonobuoy-serviceaccount") --show-default-podspec If true, include the default pod spec used for plugins in the output. --skip-preflight strings[=true] Skips the specified preflight checks. Valid values are [dnscheck, versioncheck, existingnamespace] or true to skip all of the checks. - --sonobuoy-image string Container image override for the sonobuoy worker and aggregator. (default "sonobuoy/sonobuoy:v0.56.10-2-g67583dfd") + --sonobuoy-image string Container image override for the sonobuoy worker and aggregator. (default "sonobuoy/sonobuoy:v0.56.11-2-g78c79313-dirty") --ssh-key yamlFile Path to the private key enabling SSH to cluster nodes. May be required by some tests from the e2e plugin. --ssh-user envModifier SSH user for ssh-key. Required if running e2e plugin with certain tests that require SSH access to nodes. --systemd-logs-image image Container image override for the systemd-logs plugin. Shorthand for --plugin-image=systemd-logs: (default map[]) @@ -61,4 +61,4 @@ sonobuoy gen config [flags] * [sonobuoy gen](sonobuoy_gen.md) - Generates a sonobuoy manifest for submission via kubectl -###### Auto generated by spf13/cobra on 1-Nov-2022 +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/main/cli/sonobuoy_gen_default-image-config.md b/site/content/docs/main/cli/sonobuoy_gen_default-image-config.md index d130e4d48..8829c65eb 100644 --- a/site/content/docs/main/cli/sonobuoy_gen_default-image-config.md +++ b/site/content/docs/main/cli/sonobuoy_gen_default-image-config.md @@ -28,4 +28,4 @@ sonobuoy gen default-image-config [flags] * [sonobuoy gen](sonobuoy_gen.md) - Generates a sonobuoy manifest for submission via kubectl -###### Auto generated by spf13/cobra on 1-Nov-2022 +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/main/cli/sonobuoy_gen_plugin.md b/site/content/docs/main/cli/sonobuoy_gen_plugin.md index 4301babfe..735310117 100644 --- a/site/content/docs/main/cli/sonobuoy_gen_plugin.md +++ b/site/content/docs/main/cli/sonobuoy_gen_plugin.md @@ -46,4 +46,4 @@ sonobuoy gen plugin -n myPlugin -i myregistry/myimage:v0 * [sonobuoy gen plugin e2e](sonobuoy_gen_plugin_e2e.md) - Generates the e2e plugin definition based on the given options * [sonobuoy gen plugin systemd-logs](sonobuoy_gen_plugin_systemd-logs.md) - Generates the systemd-logs plugin definition based on the given options -###### Auto generated by spf13/cobra on 1-Nov-2022 +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/main/cli/sonobuoy_gen_plugin_e2e.md b/site/content/docs/main/cli/sonobuoy_gen_plugin_e2e.md index bcb57816f..92b201de6 100644 --- a/site/content/docs/main/cli/sonobuoy_gen_plugin_e2e.md +++ b/site/content/docs/main/cli/sonobuoy_gen_plugin_e2e.md @@ -43,7 +43,7 @@ sonobuoy gen plugin e2e [flags] --service-account-name string Name of the service account to be used by sonobuoy. (default "sonobuoy-serviceaccount") --show-default-podspec If true, include the default pod spec used for plugins in the output. --skip-preflight strings[=true] Skips the specified preflight checks. Valid values are [dnscheck, versioncheck, existingnamespace] or true to skip all of the checks. - --sonobuoy-image string Container image override for the sonobuoy worker and aggregator. (default "sonobuoy/sonobuoy:v0.56.10-2-g67583dfd") + --sonobuoy-image string Container image override for the sonobuoy worker and aggregator. (default "sonobuoy/sonobuoy:v0.56.11-2-g78c79313-dirty") --ssh-key yamlFile Path to the private key enabling SSH to cluster nodes. May be required by some tests from the e2e plugin. --ssh-user envModifier SSH user for ssh-key. Required if running e2e plugin with certain tests that require SSH access to nodes. --systemd-logs-image image Container image override for the systemd-logs plugin. Shorthand for --plugin-image=systemd-logs: (default map[]) @@ -62,4 +62,4 @@ sonobuoy gen plugin e2e [flags] * [sonobuoy gen plugin](sonobuoy_gen_plugin.md) - Generates the manifest Sonobuoy uses to define a plugin -###### Auto generated by spf13/cobra on 1-Nov-2022 +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/main/cli/sonobuoy_gen_plugin_systemd-logs.md b/site/content/docs/main/cli/sonobuoy_gen_plugin_systemd-logs.md index da95de139..e41b30355 100644 --- a/site/content/docs/main/cli/sonobuoy_gen_plugin_systemd-logs.md +++ b/site/content/docs/main/cli/sonobuoy_gen_plugin_systemd-logs.md @@ -42,7 +42,7 @@ sonobuoy gen plugin systemd-logs [flags] --service-account-name string Name of the service account to be used by sonobuoy. (default "sonobuoy-serviceaccount") --show-default-podspec If true, include the default pod spec used for plugins in the output. --skip-preflight strings[=true] Skips the specified preflight checks. Valid values are [dnscheck, versioncheck, existingnamespace] or true to skip all of the checks. - --sonobuoy-image string Container image override for the sonobuoy worker and aggregator. (default "sonobuoy/sonobuoy:v0.56.10-2-g67583dfd") + --sonobuoy-image string Container image override for the sonobuoy worker and aggregator. (default "sonobuoy/sonobuoy:v0.56.11-2-g78c79313-dirty") --ssh-key yamlFile Path to the private key enabling SSH to cluster nodes. May be required by some tests from the e2e plugin. --ssh-user envModifier SSH user for ssh-key. Required if running e2e plugin with certain tests that require SSH access to nodes. --systemd-logs-image image Container image override for the systemd-logs plugin. Shorthand for --plugin-image=systemd-logs: (default map[]) @@ -61,4 +61,4 @@ sonobuoy gen plugin systemd-logs [flags] * [sonobuoy gen plugin](sonobuoy_gen_plugin.md) - Generates the manifest Sonobuoy uses to define a plugin -###### Auto generated by spf13/cobra on 1-Nov-2022 +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/main/cli/sonobuoy_get.md b/site/content/docs/main/cli/sonobuoy_get.md index 28e11ab07..89d094a48 100644 --- a/site/content/docs/main/cli/sonobuoy_get.md +++ b/site/content/docs/main/cli/sonobuoy_get.md @@ -23,4 +23,4 @@ Fetches Sonobuoy resources of a specified type * [sonobuoy](sonobuoy.md) - Generate reports on your Kubernetes cluster by running plugins * [sonobuoy get pod](sonobuoy_get_pod.md) - Fetch sonobuoy pods -###### Auto generated by spf13/cobra on 1-Nov-2022 +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/main/cli/sonobuoy_get_pod.md b/site/content/docs/main/cli/sonobuoy_get_pod.md index 5922df7a0..6dfab2c4a 100644 --- a/site/content/docs/main/cli/sonobuoy_get_pod.md +++ b/site/content/docs/main/cli/sonobuoy_get_pod.md @@ -28,4 +28,4 @@ sonobuoy get pod [flags] * [sonobuoy get](sonobuoy_get.md) - Fetches Sonobuoy resources of a specified type -###### Auto generated by spf13/cobra on 1-Nov-2022 +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/main/cli/sonobuoy_images.md b/site/content/docs/main/cli/sonobuoy_images.md index 5cd92f6ea..9cf80b66b 100644 --- a/site/content/docs/main/cli/sonobuoy_images.md +++ b/site/content/docs/main/cli/sonobuoy_images.md @@ -37,4 +37,4 @@ sonobuoy images [flags] * [sonobuoy images pull](sonobuoy_images_pull.md) - Pulls images to local docker client for a specific plugin * [sonobuoy images push](sonobuoy_images_push.md) - Pushes images to docker registry for a specific plugin -###### Auto generated by spf13/cobra on 1-Nov-2022 +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/main/cli/sonobuoy_images_delete.md b/site/content/docs/main/cli/sonobuoy_images_delete.md index de5aa3e1d..6e30c871b 100644 --- a/site/content/docs/main/cli/sonobuoy_images_delete.md +++ b/site/content/docs/main/cli/sonobuoy_images_delete.md @@ -33,4 +33,4 @@ sonobuoy images delete [flags] * [sonobuoy images](sonobuoy_images.md) - Manage images used in a plugin to facilitate running them in airgapped (or similar) environments. Supported plugins are: 'e2e' -###### Auto generated by spf13/cobra on 1-Nov-2022 +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/main/cli/sonobuoy_images_download.md b/site/content/docs/main/cli/sonobuoy_images_download.md index ad78edc79..f91b6f5c7 100644 --- a/site/content/docs/main/cli/sonobuoy_images_download.md +++ b/site/content/docs/main/cli/sonobuoy_images_download.md @@ -33,4 +33,4 @@ sonobuoy images download [flags] * [sonobuoy images](sonobuoy_images.md) - Manage images used in a plugin to facilitate running them in airgapped (or similar) environments. Supported plugins are: 'e2e' -###### Auto generated by spf13/cobra on 1-Nov-2022 +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/main/cli/sonobuoy_images_list.md b/site/content/docs/main/cli/sonobuoy_images_list.md index 727f633d3..03919337a 100644 --- a/site/content/docs/main/cli/sonobuoy_images_list.md +++ b/site/content/docs/main/cli/sonobuoy_images_list.md @@ -31,4 +31,4 @@ sonobuoy images list [flags] * [sonobuoy images](sonobuoy_images.md) - Manage images used in a plugin to facilitate running them in airgapped (or similar) environments. Supported plugins are: 'e2e' -###### Auto generated by spf13/cobra on 1-Nov-2022 +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/main/cli/sonobuoy_images_pull.md b/site/content/docs/main/cli/sonobuoy_images_pull.md index c5416f751..873698233 100644 --- a/site/content/docs/main/cli/sonobuoy_images_pull.md +++ b/site/content/docs/main/cli/sonobuoy_images_pull.md @@ -33,4 +33,4 @@ sonobuoy images pull [flags] * [sonobuoy images](sonobuoy_images.md) - Manage images used in a plugin to facilitate running them in airgapped (or similar) environments. Supported plugins are: 'e2e' -###### Auto generated by spf13/cobra on 1-Nov-2022 +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/main/cli/sonobuoy_images_push.md b/site/content/docs/main/cli/sonobuoy_images_push.md index 51cf5a460..b92dc8f09 100644 --- a/site/content/docs/main/cli/sonobuoy_images_push.md +++ b/site/content/docs/main/cli/sonobuoy_images_push.md @@ -34,4 +34,4 @@ sonobuoy images push [flags] * [sonobuoy images](sonobuoy_images.md) - Manage images used in a plugin to facilitate running them in airgapped (or similar) environments. Supported plugins are: 'e2e' -###### Auto generated by spf13/cobra on 1-Nov-2022 +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/main/cli/sonobuoy_logs.md b/site/content/docs/main/cli/sonobuoy_logs.md index 128833f4c..0e1b15f87 100644 --- a/site/content/docs/main/cli/sonobuoy_logs.md +++ b/site/content/docs/main/cli/sonobuoy_logs.md @@ -31,4 +31,4 @@ sonobuoy logs [flags] * [sonobuoy](sonobuoy.md) - Generate reports on your Kubernetes cluster by running plugins -###### Auto generated by spf13/cobra on 1-Nov-2022 +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/main/cli/sonobuoy_modes.md b/site/content/docs/main/cli/sonobuoy_modes.md index b765b3064..747c4ea8a 100644 --- a/site/content/docs/main/cli/sonobuoy_modes.md +++ b/site/content/docs/main/cli/sonobuoy_modes.md @@ -27,4 +27,4 @@ sonobuoy modes [flags] * [sonobuoy](sonobuoy.md) - Generate reports on your Kubernetes cluster by running plugins -###### Auto generated by spf13/cobra on 1-Nov-2022 +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/main/cli/sonobuoy_plugin.md b/site/content/docs/main/cli/sonobuoy_plugin.md index 8846e0d88..88151562c 100644 --- a/site/content/docs/main/cli/sonobuoy_plugin.md +++ b/site/content/docs/main/cli/sonobuoy_plugin.md @@ -26,4 +26,4 @@ Manage your installed plugins * [sonobuoy plugin show](sonobuoy_plugin_show.md) - Print the full definition of the named plugin file * [sonobuoy plugin uninstall](sonobuoy_plugin_uninstall.md) - Uninstall a plugin. You can continue to run any plugin via specifying a file or URL. -###### Auto generated by spf13/cobra on 1-Nov-2022 +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/main/cli/sonobuoy_plugin_install.md b/site/content/docs/main/cli/sonobuoy_plugin_install.md index 280bd82f6..ea6e20fd4 100644 --- a/site/content/docs/main/cli/sonobuoy_plugin_install.md +++ b/site/content/docs/main/cli/sonobuoy_plugin_install.md @@ -26,4 +26,4 @@ sonobuoy plugin install [flags] * [sonobuoy plugin](sonobuoy_plugin.md) - Manage your installed plugins -###### Auto generated by spf13/cobra on 1-Nov-2022 +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/main/cli/sonobuoy_plugin_list.md b/site/content/docs/main/cli/sonobuoy_plugin_list.md index e7f854630..afd6da5b6 100644 --- a/site/content/docs/main/cli/sonobuoy_plugin_list.md +++ b/site/content/docs/main/cli/sonobuoy_plugin_list.md @@ -26,4 +26,4 @@ sonobuoy plugin list [flags] * [sonobuoy plugin](sonobuoy_plugin.md) - Manage your installed plugins -###### Auto generated by spf13/cobra on 1-Nov-2022 +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/main/cli/sonobuoy_plugin_show.md b/site/content/docs/main/cli/sonobuoy_plugin_show.md index 7184a4538..3aec8693f 100644 --- a/site/content/docs/main/cli/sonobuoy_plugin_show.md +++ b/site/content/docs/main/cli/sonobuoy_plugin_show.md @@ -26,4 +26,4 @@ sonobuoy plugin show [flags] * [sonobuoy plugin](sonobuoy_plugin.md) - Manage your installed plugins -###### Auto generated by spf13/cobra on 1-Nov-2022 +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/main/cli/sonobuoy_plugin_uninstall.md b/site/content/docs/main/cli/sonobuoy_plugin_uninstall.md index f38b2c814..f9ac6dbd5 100644 --- a/site/content/docs/main/cli/sonobuoy_plugin_uninstall.md +++ b/site/content/docs/main/cli/sonobuoy_plugin_uninstall.md @@ -26,4 +26,4 @@ sonobuoy plugin uninstall [flags] * [sonobuoy plugin](sonobuoy_plugin.md) - Manage your installed plugins -###### Auto generated by spf13/cobra on 1-Nov-2022 +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/main/cli/sonobuoy_query.md b/site/content/docs/main/cli/sonobuoy_query.md index bd86fa21c..308669a26 100644 --- a/site/content/docs/main/cli/sonobuoy_query.md +++ b/site/content/docs/main/cli/sonobuoy_query.md @@ -28,4 +28,4 @@ sonobuoy query [flags] * [sonobuoy](sonobuoy.md) - Generate reports on your Kubernetes cluster by running plugins -###### Auto generated by spf13/cobra on 1-Nov-2022 +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/main/cli/sonobuoy_results.md b/site/content/docs/main/cli/sonobuoy_results.md index 34141b6bc..f073b46f5 100644 --- a/site/content/docs/main/cli/sonobuoy_results.md +++ b/site/content/docs/main/cli/sonobuoy_results.md @@ -30,4 +30,4 @@ sonobuoy results archive.tar.gz [flags] * [sonobuoy](sonobuoy.md) - Generate reports on your Kubernetes cluster by running plugins -###### Auto generated by spf13/cobra on 1-Nov-2022 +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/main/cli/sonobuoy_retrieve.md b/site/content/docs/main/cli/sonobuoy_retrieve.md index 40abb6671..4afec0778 100644 --- a/site/content/docs/main/cli/sonobuoy_retrieve.md +++ b/site/content/docs/main/cli/sonobuoy_retrieve.md @@ -32,4 +32,4 @@ sonobuoy retrieve [path] [flags] * [sonobuoy](sonobuoy.md) - Generate reports on your Kubernetes cluster by running plugins -###### Auto generated by spf13/cobra on 1-Nov-2022 +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/main/cli/sonobuoy_run.md b/site/content/docs/main/cli/sonobuoy_run.md index 2a6d6453d..e0386f28c 100644 --- a/site/content/docs/main/cli/sonobuoy_run.md +++ b/site/content/docs/main/cli/sonobuoy_run.md @@ -42,7 +42,7 @@ sonobuoy run [flags] --service-account-name string Name of the service account to be used by sonobuoy. (default "sonobuoy-serviceaccount") --show-default-podspec If true, include the default pod spec used for plugins in the output. --skip-preflight strings[=true] Skips the specified preflight checks. Valid values are [dnscheck, versioncheck, existingnamespace] or true to skip all of the checks. - --sonobuoy-image string Container image override for the sonobuoy worker and aggregator. (default "sonobuoy/sonobuoy:v0.56.10-2-g67583dfd") + --sonobuoy-image string Container image override for the sonobuoy worker and aggregator. (default "sonobuoy/sonobuoy:v0.56.11-2-g78c79313-dirty") --ssh-key yamlFile Path to the private key enabling SSH to cluster nodes. May be required by some tests from the e2e plugin. --ssh-user envModifier SSH user for ssh-key. Required if running e2e plugin with certain tests that require SSH access to nodes. --systemd-logs-image image Container image override for the systemd-logs plugin. Shorthand for --plugin-image=systemd-logs: (default map[]) @@ -61,4 +61,4 @@ sonobuoy run [flags] * [sonobuoy](sonobuoy.md) - Generate reports on your Kubernetes cluster by running plugins -###### Auto generated by spf13/cobra on 1-Nov-2022 +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/main/cli/sonobuoy_status.md b/site/content/docs/main/cli/sonobuoy_status.md index 8fcd04797..397a14701 100644 --- a/site/content/docs/main/cli/sonobuoy_status.md +++ b/site/content/docs/main/cli/sonobuoy_status.md @@ -31,4 +31,4 @@ sonobuoy status [flags] * [sonobuoy](sonobuoy.md) - Generate reports on your Kubernetes cluster by running plugins -###### Auto generated by spf13/cobra on 1-Nov-2022 +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/main/cli/sonobuoy_version.md b/site/content/docs/main/cli/sonobuoy_version.md index 0abf4a07b..878c9b20f 100644 --- a/site/content/docs/main/cli/sonobuoy_version.md +++ b/site/content/docs/main/cli/sonobuoy_version.md @@ -29,4 +29,4 @@ sonobuoy version [flags] * [sonobuoy](sonobuoy.md) - Generate reports on your Kubernetes cluster by running plugins -###### Auto generated by spf13/cobra on 1-Nov-2022 +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/main/cli/sonobuoy_wait.md b/site/content/docs/main/cli/sonobuoy_wait.md index 970b5bc33..01240430e 100644 --- a/site/content/docs/main/cli/sonobuoy_wait.md +++ b/site/content/docs/main/cli/sonobuoy_wait.md @@ -42,7 +42,7 @@ sonobuoy wait [flags] --service-account-name string Name of the service account to be used by sonobuoy. (default "sonobuoy-serviceaccount") --show-default-podspec If true, include the default pod spec used for plugins in the output. --skip-preflight strings[=true] Skips the specified preflight checks. Valid values are [dnscheck, versioncheck, existingnamespace] or true to skip all of the checks. - --sonobuoy-image string Container image override for the sonobuoy worker and aggregator. (default "sonobuoy/sonobuoy:v0.56.10-2-g67583dfd") + --sonobuoy-image string Container image override for the sonobuoy worker and aggregator. (default "sonobuoy/sonobuoy:v0.56.11-2-g78c79313-dirty") --ssh-key yamlFile Path to the private key enabling SSH to cluster nodes. May be required by some tests from the e2e plugin. --ssh-user envModifier SSH user for ssh-key. Required if running e2e plugin with certain tests that require SSH access to nodes. --systemd-logs-image image Container image override for the systemd-logs plugin. Shorthand for --plugin-image=systemd-logs: (default map[]) @@ -61,4 +61,4 @@ sonobuoy wait [flags] * [sonobuoy](sonobuoy.md) - Generate reports on your Kubernetes cluster by running plugins -###### Auto generated by spf13/cobra on 1-Nov-2022 +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/v0.56.12/_index.md b/site/content/docs/v0.56.12/_index.md new file mode 100644 index 000000000..ed71a6e09 --- /dev/null +++ b/site/content/docs/v0.56.12/_index.md @@ -0,0 +1,286 @@ +--- +version: v0.56.12 +cascade: + layout: docs + gh: https://github.com/vmware-tanzu/sonobuoy/tree/v0.56.12 +--- +# ![Sonobuoy Logo](img/sonobuoy-logo.png) + +[![Test](https://github.com/vmware-tanzu/sonobuoy/actions/workflows/ci-test.yaml/badge.svg)](https://github.com/vmware-tanzu/sonobuoy/actions/workflows/ci-test.yaml/badge.svg) +[![Lint](https://github.com/vmware-tanzu/sonobuoy/actions/workflows/ci-lint.yaml/badge.svg)](https://github.com/vmware-tanzu/sonobuoy/actions/workflows/ci-lint.yaml/badge.svg) + +## [Overview][oview] + +Sonobuoy is a diagnostic tool that makes it easier to understand the state of a Kubernetes cluster by running a set of +plugins (including [Kubernetes][k8s] conformance tests) in an accessible and non-destructive manner. It is a +customizable, extendable, and cluster-agnostic way to generate clear, informative reports about your cluster. + +Its selective data dumps of Kubernetes resource objects and cluster nodes allow for the following use cases: + +* Integrated end-to-end (e2e) [conformance-testing][e2ePlugin] +* Workload debugging +* Custom data collection via extensible plugins + +Starting v0.20, Sonobuoy supports Kubernetes v1.17 or later. Sonobuoy releases will be independent of Kubernetes +release, while ensuring that new releases continue to work functionally across different versions of Kubernetes. Read +more about the new release cycles in [our blog][decoupling-sonobuoy-k8s]. + +> Note: You can skip this version enforcement by running Sonobuoy with the `--skip-preflight` flag. + +## Prerequisites + +* Access to an up-and-running Kubernetes cluster. If you do not have a cluster, we recommend either: + * following the [AWS Quickstart for Kubernetes][quickstart] instructions. + * setting up a local cluster using [KinD][kind] + +* An admin `kubeconfig` file, and the KUBECONFIG environment variable set. + +* For some advanced workflows it may be required to have `kubectl` installed. + See [installing via Homebrew (MacOS)][brew] or [building the binary (Linux)][linux]. + +* The `sonobuoy images` subcommand requires [Docker](https://www.docker.com) to be installed. + See [installing Docker][docker]. + +## Installation + +1. Download the [latest release][releases] for your client platform. +2. Extract the tarball: + + ``` + tar -xvf .tar.gz + ``` + + Move the extracted `sonobuoy` executable to somewhere on your `PATH`. + +## Getting Started + +To launch conformance tests (ensuring [CNCF][cncf] conformance) and wait until they are finished run: + +```bash +sonobuoy run --wait +``` + +> Note: Using `--mode quick` will significantly shorten the runtime of Sonobuoy. It runs just a single test, helping to quickly validate your Sonobuoy and Kubernetes configuration. + +Get the results from the plugins (e.g. e2e test results): + +```bash +results=$(sonobuoy retrieve) +``` + +Inspect results for test failures. This will list the number of tests failed and their names: + +```bash +sonobuoy results $results +``` + +> Note: The `results` command has lots of useful options for various situations. See the [results page][results] for more details. + +You can also extract the entire contents of the file to get much more [detailed data][snapshot] about your cluster. + +Sonobuoy creates a few resources in order to run and expects to run within its own namespace. + +Deleting Sonobuoy entails removing its namespace as well as a few cluster scoped resources. + +```bash +sonobuoy delete --wait +``` + +> Note: The --wait option ensures the Kubernetes namespace is deleted, avoiding conflicts if another Sonobuoy run is started quickly. + +If you have an issue with permissions in your cluster but you still want to run Sonobuoy, you can use `--aggregator-permissions` flag. Read more details about it [here][aggregator-permissions]. + +### Other Tests + +By default, `sonobuoy run` runs the Kubernetes conformance tests but this can easily be configured. The same plugin that +has the conformance tests has all the Kubernetes end-to-end tests which include other tests such as: + +* tests for specific storage features +* performance tests +* scaling tests +* provider specific tests +* and many more + +To modify which tests you want to run, checkout our page on the [e2e plugin][e2ePlugin]. + +If you want to run other tests or tools which are not a part of the Kubernetes end-to-end suite, refer to our +documentation on [custom plugins][customPlugins]. + +### Monitoring Sonobuoy during a run + +You can check on the status of each of the plugins running with: + +```bash +sonobuoy status +``` + +You can also inspect the logs of all Sonobuoy containers: + +```bash +sonobuoy logs +``` + +## Troubleshooting + +If you encounter any problems that the documentation does not address, [file an issue][issue]. + +## Docker Hub rate limit + +This year, Docker has started rate limiting image pulls from Docker Hub. We're planning a future release with a better +user interface to work around this. Until then, this is the recommended approach. + +### Sonobuoy Pod + +Sonobuoy by default pulls from Docker Hub for [`sonobuoy/sonobuoy` image](https://hub.docker.com/r/sonobuoy/sonobuoy). +If you're encountering rate limit on this, you can use VMware-provided mirror with: + +```bash +sonobuoy run --sonobuoy-image projects.registry.vmware.com/sonobuoy/sonobuoy: +``` + +### Conformance + +Kubernetes end-to-end conformance test pulls several images from Docker Hub as part of testing. To override this, you +will need to create a registry manifest file locally (e.g. `conformance-image-config.yaml`) containing the following: + +```yaml +dockerLibraryRegistry: mirror.gcr.io/library +``` + +Then on running conformance: + +```bash +sonobuoy run --sonobuoy-image projects.registry.vmware.com/sonobuoy/sonobuoy: --e2e-repo-config conformance-image-config.yaml +``` + +Technically `dockerGluster` is also a registry pulling from Docker Hub, but it's not part of Conformance test suite at +the moment, so overriding `dockerLibraryRegistry` should be enough. + +## Known Issues + +### Leaked End-to-end namespaces + +There are some Kubernetes e2e tests that may leak resources. Sonobuoy can help clean those up as well by deleting all +namespaces prefixed with `e2e`: + +```bash +sonobuoy delete --all +``` + +### Run on Google Cloud Platform (GCP) + +Sonobuoy requires admin permissions which won't be automatic if you are running via Google Kubernetes Engine (GKE) +cluster. You must first create an admin role for the user under which you run Sonobuoy: + +```bash +kubectl create clusterrolebinding --clusterrole=cluster-admin --user= +``` + +### Run on Kubernetes for Docker Desktop + +We don't recommend running via a cluster set up via Docker Desktop. Known issues include: + +- `kubectl logs` will not function +- `sonobuoy logs` will not function +- `sonobuoy retrieve` will not function +- `systemd-logs` plugin will hang + +Most of these issues revolve around issues with kube-proxy on Docker Desktop so if you know of how to resolve these +issues, let us know. + +### Certified-Conformance bug (versions v0.53.0 and v0.53.1) + +These versions of Sonobuoy have a bug that runs the wrong set of tests without additional actions. See more +details [here][issue1388]. The simplest way to avoid this is to update your version of Sonobuoy to >= v0.53.2. + +## Strategy Document + +See our current [strategy document][strategy] and [roadmap][roadmap] for context on what our highest priority use cases and work items +will be. Feel free to make comments on Github or start conversations in Slack. + +## Contributing + +Thanks for taking the time to join our community and start contributing! We welcome pull requests. Feel free to dig +through the [issues][issue] and jump in. + +The most common build/test functions are called via the Makefile: + +``` +// Build the binary +$ make build + +// Run local unit tests +$ make test +``` + +If you make changes which change output, you may fail tests which utilize the golden file testing pattern (e.g. correct data is stored in external files), update them by running: +``` +$ make golden +``` + +In most cases, running integration tests is more simply done in CI when you open a pull request. +You can dig into scripts/build_funcs.sh and our .github/workflows/ci-test.yaml for exact details of existing test flows. + +### Before you start + +* Please familiarize yourself with the [Code of Conduct][coc] before contributing. +* See [CONTRIBUTING.md][contrib] for instructions on the developer certificate of origin that we require. +* There is a [Slack channel][slack] if you want to interact with other members of the community + +## Changelog + +See [the list of releases][releases] to find out about feature changes. + +[decoupling-sonobuoy-k8s]: https://sonobuoy.io/decoupling-sonobuoy-and-kubernetes + +[airgap]: airgap + +[brew]: https://kubernetes.io/docs/tasks/tools/install-kubectl/#install-with-homebrew-on-macos + +[cncf]: https://github.com/cncf/k8s-conformance#certified-kubernetes + +[coc]: https://github.com/vmware-tanzu/sonobuoy/blob/main/CODE_OF_CONDUCT.md + +[contrib]: https://github.com/vmware-tanzu/sonobuoy/blob/main/CONTRIBUTING.md + +[docker]: https://docs.docker.com/get-docker/ + +[docs]: https://sonobuoy.io/docs/v0.56.12 + +[e2ePlugin]: e2eplugin + +[customPlugins]: plugins + +[gen]: gen + +[issue]: https://github.com/vmware-tanzu/sonobuoy/issues + +[issue1388]: issue1388 + +[k8s]: https://github.com/kubernetes/kubernetes + +[kind]: https://github.com/kubernetes-sigs/kind + +[linux]: https://kubernetes.io/docs/tasks/tools/install-kubectl/#tabset-1 + +[oview]: https://youtu.be/8QK-Hg2yUd4 + +[plugins]: plugins + +[quickstart]: https://aws.amazon.com/quickstart/architecture/vmware-kubernetes/ + +[releases]: https://github.com/vmware-tanzu/sonobuoy/releases + +[results]: results + +[slack]: https://kubernetes.slack.com/messages/sonobuoy + +[snapshot]:snapshot + +[sonobuoyconfig]: sonobuoy-config + +[strategy]: strategy + +[aggregator-permissions]: aggregator-permissions + +[roadmap]: https://github.com/vmware-tanzu/sonobuoy/wiki \ No newline at end of file diff --git a/site/content/docs/v0.56.12/aggregator-permissions.md b/site/content/docs/v0.56.12/aggregator-permissions.md new file mode 100644 index 000000000..b9e2c28fb --- /dev/null +++ b/site/content/docs/v0.56.12/aggregator-permissions.md @@ -0,0 +1,25 @@ +# Aggregator Permissions + +By default, the Sonobuoy aggregator is given very elevated permissions in order to successfully run the Kubernetes end-to-end tests. In some situations you may want to (or need to) limit the permissions of the aggregator so that the aggregator and the pods that it creates do not have such wide-reaching permissions. You can always customize the exact permissions of the ServiceAccount via editing `sonobuoy gen` output manually, but Sonobuoy also provides useful presets via the CLI flag, `--aggregator-permissions`. + +## Type of Aggregator Permissions + +Allowable values are `[namespaced, clusterAdmin, clusterRead]`, `clusterAdmin` is default value. + +### clusterAdmin + +- `clusterAdmin` is the default value. With this value Sonobuoy can do pretty much everything in the run, it does not implement any restrictions. Most of these are required for the e2e conformance tests to work since they create/destroy namespaces, pods etc. + +### namespaceAdmin + +namespaceAdmin is the most restrictive preset permissions Sonobuoy provides and ensures that Sonobuoy and its plugins do not impact other namespaces at all. + +Due to these limitations there are a number of things to note: + - Sonobuoy does not create the namespace so it needs to already exist + - You must provide `--skip-preflight` to avoid Sonobuoy from complaining about the preexisting namespace + - The `e2e` plugin (conformance tests) will not work in this mode and won't even start up due to severely limited permissions + - Daemonset plugins will not work in this mode because Sonobuoy monitors them on a per-node basis. Since Sonobuoy can't query the list of nodes in the cluster, it can't properly monitor or gather results from them. At this time, Daemonset plugins will simply be ignored. + +### clusterRead + +`clusterRead` is a compromise between `namespaceAdmin` and `clusterAdmin`. It adds ability to GET any resource from the API so that the Sonobuoy queries work OK, it is able to get nodes so daemonsets run fine, and e2e tests can technically start. Sonobuoy can't create namespaces so e2e tests can't run in this mode in any useful manner either. However, this may be a more reasonable mode to run less intrusive, custom plugins in. In this mode Sonobuoy don't create the namespace either so it has to be created first and sonobuoy run with the `--skip-preflight` flag. diff --git a/site/content/docs/v0.56.12/airgap.md b/site/content/docs/v0.56.12/airgap.md new file mode 100644 index 000000000..76675d6f5 --- /dev/null +++ b/site/content/docs/v0.56.12/airgap.md @@ -0,0 +1,132 @@ +# Custom registries and air-gapped testing + +In air-gapped deployments where there is no access to the public Docker registries Sonobuoy supports running the end-to-end tests with custom registries. +This enables you to test your air-gapped deployment once you've loaded the necessary images into a registry that is reachable by your cluster. + +You will need to make the Sonobuoy image available as well as the images for any plugins you wish to run. +Below, you will find the details of how to use the Sonobuoy image, as well as the images for the `e2e` and `systemd-logs` plugins in this kind of deployment. + +## Sonobuoy Image +To run any Sonobuoy plugin in an air-gapped deployment, you must ensure that the Sonobuoy image is available in a registry that is reachable by your cluster. +You will need to pull, tag, and then push the image as follows: + +``` +PRIVATE_REG= +SONOBUOY_VERSION= + +docker pull sonobuoy/sonobuoy:$SONOBUOY_VERSION +docker tag sonobuoy/sonobuoy:$SONOBUOY_VERSION $PRIVATE_REG/sonobuoy:$SONOBUOY_VERSION +docker push $PRIVATE_REG/sonobuoy:$SONOBUOY_VERSION +``` + +By default, Sonobuoy will attempt to use the image available in the public registry. +To use the image in your own registry, you will need to override it when using the `gen` or `run` command with the `--sonobuoy-image` flag as follows: + +``` +sonobuoy run --sonobuoy-image $PRIVATE_REG/sonobuoy:$SONOBUOY_VERSION +``` + +## E2E Plugin + +To use the `e2e` plugin, the conformance test image and the images the tests use must be available in your registry. + +### Conformance Image +The process for making the conformance image available in your registry is the same as the Sonobuoy image. +You need to pull, tag, and then push the image. +To ensure you use the correct version of the conformance image, check your server version using `kubectl version`. + + +``` +PRIVATE_REG= +CLUSTER_VERSION= + +docker pull k8s.gcr.io/conformance:$CLUSTER_VERSION +docker tag k8s.gcr.io/conformance:$CLUSTER_VERSION $PRIVATE_REG/conformance:$CLUSTER_VERSION +docker push $PRIVATE_REG/conformance:$CLUSTER_VERSION +``` + +To use the conformance image in your registry, you will need to override the default when using the `gen` or `run` commands with the `--kube-conformance-image` flag as follows: + +``` +sonobuoy run --kube-conformance-image $PRIVATE_REG/conformance:$CLUSTER_VERSION +``` + +### Test Images + +The end-to-end tests use a number of different images across multiple registries. +When running the `e2e` plugin, you must provide a mapping that details which custom registries should be used instead of the public registries. + +If you need only a single, custom registry, use the `--e2e-repo` flag to specify that all test registry should be set to the same, given value. + +If you need multiple registries, you must provide a mapping that the upstream Kubernetes tests understand. It is provided via a YAML file which maps the registry category to the corresponding registry URL. +The keys in this file are specified in the Kubernetes test framework. +The tests for each minor version of Kubernetes use a different set of registries so the mapping you create will depend on which Kubernetes version you are testing against. + +To create this mapping, you can use the `gen default-image-config` command to provide the mapping with the default registry values for your cluster version. +The following is an example of using this command with a v1.16 cluster: + +``` +$ sonobuoy gen default-image-config +dockerLibraryRegistry: docker.io/library +e2eRegistry: gcr.io/kubernetes-e2e-test-images +gcRegistry: k8s.gcr.io +googleContainerRegistry: gcr.io/google-containers +sampleRegistry: gcr.io/google-samples +``` + +You can save this output to a file and modify it to specify your own registries instead. +You can modify all of the registry values or just a subset. +If you specify only a subset, the defaults will be used instead. + +Sonobuoy provides the command `images` to help you easily pull the test images and push them to your own custom registries. +First, you must pull the images to your local machine using the following command: + +``` +sonobuoy images pull +``` + +> **NOTE:** Some versions of Kubernetes reference images that do not exist or cannot be pulled without authentication. +> You may see these errors when running the above command. This is expected behaviour. +> These images are referenced by some end-to-end tests, but **not** by the conformance tests. + +To push the images, you must provide the mapping using the `--e2e-repo` or `--e2e-repo-config` flag as follows: + +``` +sonobuoy images push --e2e-repo +// OR +sonobuoy images push --e2e-repo-config +``` + +If you are pushing to a single registry; use the first flag; if you need fine-grained controle +over which images go to which registry, use the second. + +When running the `e2e` plugin, you will need to provide this information using the same flag as follows: + +``` +sonobuoy run --e2e-repo +// OR +sonobuoy run --e2e-repo-config +``` + +## systemd-logs plugin + +If you want to run the `systemd-logs` plugin you will again need to pull, tag, and push the image. + + +``` +PRIVATE_REG= + +docker pull gcr.io/heptio-images/sonobuoy-plugin-systemd-logs:latest +docker tag gcr.io/heptio-images/sonobuoy-plugin-systemd-logs:latest $PRIVATE_REG/sonobuoy-plugin-systemd-logs:latest +docker push $PRIVATE_REG/sonobuoy-plugin-systemd-logs:latest +``` + +To use the image in your own registry, you will need to override the default when using the `gen` or `run` commands with the `--systemd-logs-image` flag as follows: + +``` +sonobuoy run --systemd-logs-image $PRIVATE_REG/sonobuoy-plugin-systemd-logs:latest +``` + +If you do not wish to run this plugin, you can remove it from the list of [plugins][plugins] to be run within the manifest, or you can explicitly specify which plugin you with to run with the `--plugin` flag. + +[plugins]: plugins.md#choosing-which-plugins-to-run diff --git a/site/content/docs/v0.56.12/cli/sonobuoy.md b/site/content/docs/v0.56.12/cli/sonobuoy.md new file mode 100644 index 000000000..369232adb --- /dev/null +++ b/site/content/docs/v0.56.12/cli/sonobuoy.md @@ -0,0 +1,38 @@ +## sonobuoy + +Generate reports on your Kubernetes cluster by running plugins + +### Synopsis + +Sonobuoy is a Kubernetes component that generates reports on cluster conformance, configuration, and more + +``` +sonobuoy [flags] +``` + +### Options + +``` + -h, --help help for sonobuoy + --level level Log level. One of {panic, fatal, error, warn, info, debug, trace} (default info) +``` + +### SEE ALSO + +* [sonobuoy delete](sonobuoy_delete.md) - Deletes Kubernetes resources that were generated by a Sonobuoy run +* [sonobuoy e2e](sonobuoy_e2e.md) - Generates a list of all tests and tags in that tests +* [sonobuoy gen](sonobuoy_gen.md) - Generates a sonobuoy manifest for submission via kubectl +* [sonobuoy get](sonobuoy_get.md) - Fetches Sonobuoy resources of a specified type +* [sonobuoy images](sonobuoy_images.md) - Manage images used in a plugin to facilitate running them in airgapped (or similar) environments. Supported plugins are: 'e2e' +* [sonobuoy logs](sonobuoy_logs.md) - Dumps the logs of the currently running Sonobuoy containers for diagnostics +* [sonobuoy modes](sonobuoy_modes.md) - Display the various modes in which to run the e2e plugin +* [sonobuoy plugin](sonobuoy_plugin.md) - Manage your installed plugins +* [sonobuoy query](sonobuoy_query.md) - Runs queries against your cluster in order to aid in debugging. +* [sonobuoy results](sonobuoy_results.md) - Inspect plugin results. +* [sonobuoy retrieve](sonobuoy_retrieve.md) - Retrieves the results of a sonobuoy run to a specified path +* [sonobuoy run](sonobuoy_run.md) - Starts a Sonobuoy run by launching the Sonobuoy aggregator and plugin pods. +* [sonobuoy status](sonobuoy_status.md) - Gets a summarized status of a sonobuoy run +* [sonobuoy version](sonobuoy_version.md) - Print sonobuoy version +* [sonobuoy wait](sonobuoy_wait.md) - Waits on the Sonobuoy run in the targeted namespace. + +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/v0.56.12/cli/sonobuoy_delete.md b/site/content/docs/v0.56.12/cli/sonobuoy_delete.md new file mode 100644 index 000000000..ec991c988 --- /dev/null +++ b/site/content/docs/v0.56.12/cli/sonobuoy_delete.md @@ -0,0 +1,36 @@ +## sonobuoy delete + +Deletes Kubernetes resources that were generated by a Sonobuoy run + +### Synopsis + +Deletes Kubernetes resources that were generated by a Sonobuoy run + +``` +sonobuoy delete [flags] +``` + +### Options + +``` + --all In addition to deleting Sonobuoy namespaces, also clean up dangling e2e namespaces (those with 'e2e-framework' and 'e2e-run' labels). + --context string Context in the kubeconfig to use. + -h, --help help for delete + --kubeconfig Kubeconfig Path to explicit kubeconfig file. + -n, --namespace string The namespace to run Sonobuoy in. Only one Sonobuoy run can exist per namespace simultaneously. (default "sonobuoy") + --rbac RBACMode Whether to enable RBAC on Sonobuoy. Valid modes are Enable, Disable, and Detect (query the server to see whether to enable RBAC). (default Detect) + --wait int[=60] Wait for resources to be deleted before completing. 0 indicates do not wait. By providing --wait the default is to wait up to 1 hour. + --wait-output string Specify the type of output Sonobuoy should produce when --wait is used. Valid modes are silent, spinner, or progress (default "Progress") +``` + +### Options inherited from parent commands + +``` + --level level Log level. One of {panic, fatal, error, warn, info, debug, trace} (default info) +``` + +### SEE ALSO + +* [sonobuoy](sonobuoy.md) - Generate reports on your Kubernetes cluster by running plugins + +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/v0.56.12/cli/sonobuoy_e2e.md b/site/content/docs/v0.56.12/cli/sonobuoy_e2e.md new file mode 100644 index 000000000..8e2cfb4ff --- /dev/null +++ b/site/content/docs/v0.56.12/cli/sonobuoy_e2e.md @@ -0,0 +1,36 @@ +## sonobuoy e2e + +Generates a list of all tests and tags in that tests + +### Synopsis + +Generates a list of all tests and tags in that tests + +``` +sonobuoy e2e [flags] +``` + +### Options + +``` + --context string Context in the kubeconfig to use. + -f, --focus string Return tests which match this regular expression + -h, --help help for e2e + -i, --input string Determines the source of the test lists. Can be [online, offline, -]. If '-' is set, tests will be read from stdin. (default "online") + --kubeconfig Kubeconfig Path to explicit kubeconfig file. + -m, --mode string Print mode. Can be one of [tags, tagCounts, tests] (default "tests") + -s, --skip string Do not return tests which match this regular expression + --version ConformanceImageVersion Use default E2E image, but override the version. Default is 'auto', which will be set to your cluster's version if detected, erroring otherwise. 'ignore' will try version resolution but ignore errors. 'latest' will find the latest dev image/version upstream. +``` + +### Options inherited from parent commands + +``` + --level level Log level. One of {panic, fatal, error, warn, info, debug, trace} (default info) +``` + +### SEE ALSO + +* [sonobuoy](sonobuoy.md) - Generate reports on your Kubernetes cluster by running plugins + +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/v0.56.12/cli/sonobuoy_gen.md b/site/content/docs/v0.56.12/cli/sonobuoy_gen.md new file mode 100644 index 000000000..a64d98e23 --- /dev/null +++ b/site/content/docs/v0.56.12/cli/sonobuoy_gen.md @@ -0,0 +1,67 @@ +## sonobuoy gen + +Generates a sonobuoy manifest for submission via kubectl + +### Synopsis + +Generates a sonobuoy manifest for submission via kubectl + +``` +sonobuoy gen [flags] +``` + +### Options + +``` + --aggregator-node-selector nodeSelectors Node selectors to add to the aggregator. Values can be given multiple times and are in the form key:value (default map[]) + --aggregator-permissions string Type of aggregator permission to use in the cluster. Allowable values are [namespaceAdmin, clusterRead, clusterAdmin] (default "clusterAdmin") + --config Sonobuoy config Path to a sonobuoy configuration JSON file. + --context string Context in the kubeconfig to use. + --dns-namespace string The namespace to check for DNS pods during preflight checks. (default "kube-system") + --dns-pod-labels strings The label selectors to use for locating DNS pods during preflight checks. Can be specified multiple times or as a comma-separated list. (default [k8s-app=kube-dns,k8s-app=coredns]) + --e2e-focus envModifier Specify the E2E_FOCUS value for the e2e plugin, specifying which tests to run. Shorthand for --plugin-env=e2e.E2E_FOCUS= (default \[Conformance\]) + --e2e-repo envModifier Specify a registry to use as the default for pulling Kubernetes test images. Same as providing --e2e-repo-config but specifying the same repo repeatedly. + --e2e-repo-config yaml-filepath Specify a yaml file acting as KUBE_TEST_REPO_LIST, overriding registries for test images. + --e2e-skip envModifier Specify the E2E_SKIP value for the e2e plugin, specifying which tests to skip. Shorthand for --plugin-env=e2e.E2E_SKIP= (default \[Disruptive\]|NoExecuteTaintManager) + --existing-service-account If true, use an existing service account, else attempt to create one. + -f, --file - If set, loads the file as if it were the output from sonobuoy gen. Set to - to read from stdin. + --force-image-pull-policy Force plugins' imagePullPolicy to match the value for the Sonobuoy pod + -h, --help help for gen + --image-pull-policy string Set the ImagePullPolicy for the Sonobuoy image and all plugins (if --force-image-pull-policy is set). Valid options are Always, IfNotPresent, Never. (default "IfNotPresent") + --kube-conformance-image image Container image override for the e2e plugin. Shorthand for --plugin-image=e2e: (default map[]) + --kubeconfig Kubeconfig Path to explicit kubeconfig file. + --kubernetes-version string Use default E2E image, but override the version. Default is 'auto', which will be set to your cluster's version if detected, erroring otherwise. 'ignore' will try version resolution but ignore errors. 'latest' will find the latest dev image/version upstream. + -m, --mode Mode What mode to run the e2e plugin in. Valid modes are [certified-conformance conformance-lite non-disruptive-conformance quick]. (default non-disruptive-conformance) + -n, --namespace string The namespace to run Sonobuoy in. Only one Sonobuoy run can exist per namespace simultaneously. (default "sonobuoy") + -p, --plugin pluginList Which plugins to run. Can either point to a URL, local file/directory, or be one of the known plugins (e2e or systemd-logs). Can be specified multiple times to run multiple plugins. + --plugin-env pluginenvvar Set env vars on plugins. Values can be given multiple times and are in the form plugin.env=value (default map[]) + --plugin-image plugin:image Override a plugins image from what is in its definition (e.g. myPlugin:testimage) (default map[]) + --rbac RBACMode Whether to enable RBAC on Sonobuoy. Valid modes are Enable, Disable, and Detect (query the server to see whether to enable RBAC). (default Enable) + --rerun-failed tar.gz file Read the given tarball and set the E2E_FOCUS to target all the failed tests + --security-context-mode string Type of security context to use for the aggregator pod. Allowable values are [none, nonroot] (default "nonroot") + --service-account-name string Name of the service account to be used by sonobuoy. (default "sonobuoy-serviceaccount") + --show-default-podspec If true, include the default pod spec used for plugins in the output. + --skip-preflight strings[=true] Skips the specified preflight checks. Valid values are [dnscheck, versioncheck, existingnamespace] or true to skip all of the checks. + --sonobuoy-image string Container image override for the sonobuoy worker and aggregator. (default "sonobuoy/sonobuoy:v0.56.11-2-g78c79313-dirty") + --ssh-key yamlFile Path to the private key enabling SSH to cluster nodes. May be required by some tests from the e2e plugin. + --ssh-user envModifier SSH user for ssh-key. Required if running e2e plugin with certain tests that require SSH access to nodes. + --systemd-logs-image image Container image override for the systemd-logs plugin. Shorthand for --plugin-image=systemd-logs: (default map[]) + --timeout int How long (in seconds) Sonobuoy aggregator will wait for plugins to complete before exiting. 0 indicates no timeout. (default 21600) + --wait int[=1440] How long (in minutes) for the CLI to wait for sonobuoy run to be completed or fail, where 0 indicates do not wait. If specified, the default wait time is 1 day. + --wait-output string Specify the type of output Sonobuoy should produce when --wait is used. Valid modes are silent, spinner, or progress (default "Progress") +``` + +### Options inherited from parent commands + +``` + --level level Log level. One of {panic, fatal, error, warn, info, debug, trace} (default info) +``` + +### SEE ALSO + +* [sonobuoy](sonobuoy.md) - Generate reports on your Kubernetes cluster by running plugins +* [sonobuoy gen config](sonobuoy_gen_config.md) - Generates a Sonobuoy config for input to sonobuoy gen or run. +* [sonobuoy gen default-image-config](sonobuoy_gen_default-image-config.md) - Generates the default image registry config for the e2e plugin +* [sonobuoy gen plugin](sonobuoy_gen_plugin.md) - Generates the manifest Sonobuoy uses to define a plugin + +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/v0.56.12/cli/sonobuoy_gen_config.md b/site/content/docs/v0.56.12/cli/sonobuoy_gen_config.md new file mode 100644 index 000000000..2bee30f0f --- /dev/null +++ b/site/content/docs/v0.56.12/cli/sonobuoy_gen_config.md @@ -0,0 +1,64 @@ +## sonobuoy gen config + +Generates a Sonobuoy config for input to sonobuoy gen or run. + +### Synopsis + +Generates a Sonobuoy config for input to sonobuoy gen or run. + +``` +sonobuoy gen config [flags] +``` + +### Options + +``` + --aggregator-node-selector nodeSelectors Node selectors to add to the aggregator. Values can be given multiple times and are in the form key:value (default map[]) + --aggregator-permissions string Type of aggregator permission to use in the cluster. Allowable values are [namespaceAdmin, clusterRead, clusterAdmin] (default "clusterAdmin") + --config Sonobuoy config Path to a sonobuoy configuration JSON file. + --context string Context in the kubeconfig to use. + --dns-namespace string The namespace to check for DNS pods during preflight checks. (default "kube-system") + --dns-pod-labels strings The label selectors to use for locating DNS pods during preflight checks. Can be specified multiple times or as a comma-separated list. (default [k8s-app=kube-dns,k8s-app=coredns]) + --e2e-focus envModifier Specify the E2E_FOCUS value for the e2e plugin, specifying which tests to run. Shorthand for --plugin-env=e2e.E2E_FOCUS= (default \[Conformance\]) + --e2e-repo envModifier Specify a registry to use as the default for pulling Kubernetes test images. Same as providing --e2e-repo-config but specifying the same repo repeatedly. + --e2e-repo-config yaml-filepath Specify a yaml file acting as KUBE_TEST_REPO_LIST, overriding registries for test images. + --e2e-skip envModifier Specify the E2E_SKIP value for the e2e plugin, specifying which tests to skip. Shorthand for --plugin-env=e2e.E2E_SKIP= (default \[Disruptive\]|NoExecuteTaintManager) + --existing-service-account If true, use an existing service account, else attempt to create one. + -f, --file - If set, loads the file as if it were the output from sonobuoy gen. Set to - to read from stdin. + --force-image-pull-policy Force plugins' imagePullPolicy to match the value for the Sonobuoy pod + -h, --help help for config + --image-pull-policy string Set the ImagePullPolicy for the Sonobuoy image and all plugins (if --force-image-pull-policy is set). Valid options are Always, IfNotPresent, Never. (default "IfNotPresent") + --kube-conformance-image image Container image override for the e2e plugin. Shorthand for --plugin-image=e2e: (default map[]) + --kubeconfig Kubeconfig Path to explicit kubeconfig file. + --kubernetes-version string Use default E2E image, but override the version. Default is 'auto', which will be set to your cluster's version if detected, erroring otherwise. 'ignore' will try version resolution but ignore errors. 'latest' will find the latest dev image/version upstream. + -m, --mode Mode What mode to run the e2e plugin in. Valid modes are [certified-conformance conformance-lite non-disruptive-conformance quick]. (default non-disruptive-conformance) + -n, --namespace string The namespace to run Sonobuoy in. Only one Sonobuoy run can exist per namespace simultaneously. (default "sonobuoy") + -p, --plugin pluginList Which plugins to run. Can either point to a URL, local file/directory, or be one of the known plugins (e2e or systemd-logs). Can be specified multiple times to run multiple plugins. + --plugin-env pluginenvvar Set env vars on plugins. Values can be given multiple times and are in the form plugin.env=value (default map[]) + --plugin-image plugin:image Override a plugins image from what is in its definition (e.g. myPlugin:testimage) (default map[]) + --rbac RBACMode Whether to enable RBAC on Sonobuoy. Valid modes are Enable, Disable, and Detect (query the server to see whether to enable RBAC). (default Enable) + --rerun-failed tar.gz file Read the given tarball and set the E2E_FOCUS to target all the failed tests + --security-context-mode string Type of security context to use for the aggregator pod. Allowable values are [none, nonroot] (default "nonroot") + --service-account-name string Name of the service account to be used by sonobuoy. (default "sonobuoy-serviceaccount") + --show-default-podspec If true, include the default pod spec used for plugins in the output. + --skip-preflight strings[=true] Skips the specified preflight checks. Valid values are [dnscheck, versioncheck, existingnamespace] or true to skip all of the checks. + --sonobuoy-image string Container image override for the sonobuoy worker and aggregator. (default "sonobuoy/sonobuoy:v0.56.11-2-g78c79313-dirty") + --ssh-key yamlFile Path to the private key enabling SSH to cluster nodes. May be required by some tests from the e2e plugin. + --ssh-user envModifier SSH user for ssh-key. Required if running e2e plugin with certain tests that require SSH access to nodes. + --systemd-logs-image image Container image override for the systemd-logs plugin. Shorthand for --plugin-image=systemd-logs: (default map[]) + --timeout int How long (in seconds) Sonobuoy aggregator will wait for plugins to complete before exiting. 0 indicates no timeout. (default 21600) + --wait int[=1440] How long (in minutes) for the CLI to wait for sonobuoy run to be completed or fail, where 0 indicates do not wait. If specified, the default wait time is 1 day. + --wait-output string Specify the type of output Sonobuoy should produce when --wait is used. Valid modes are silent, spinner, or progress (default "Progress") +``` + +### Options inherited from parent commands + +``` + --level level Log level. One of {panic, fatal, error, warn, info, debug, trace} (default info) +``` + +### SEE ALSO + +* [sonobuoy gen](sonobuoy_gen.md) - Generates a sonobuoy manifest for submission via kubectl + +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/v0.56.12/cli/sonobuoy_gen_default-image-config.md b/site/content/docs/v0.56.12/cli/sonobuoy_gen_default-image-config.md new file mode 100644 index 000000000..8829c65eb --- /dev/null +++ b/site/content/docs/v0.56.12/cli/sonobuoy_gen_default-image-config.md @@ -0,0 +1,31 @@ +## sonobuoy gen default-image-config + +Generates the default image registry config for the e2e plugin + +### Synopsis + +Generates the default image registry config for the e2e plugin + +``` +sonobuoy gen default-image-config [flags] +``` + +### Options + +``` + --context string Context in the kubeconfig to use. + -h, --help help for default-image-config + --kubeconfig Kubeconfig Path to explicit kubeconfig file. +``` + +### Options inherited from parent commands + +``` + --level level Log level. One of {panic, fatal, error, warn, info, debug, trace} (default info) +``` + +### SEE ALSO + +* [sonobuoy gen](sonobuoy_gen.md) - Generates a sonobuoy manifest for submission via kubectl + +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/v0.56.12/cli/sonobuoy_gen_plugin.md b/site/content/docs/v0.56.12/cli/sonobuoy_gen_plugin.md new file mode 100644 index 000000000..735310117 --- /dev/null +++ b/site/content/docs/v0.56.12/cli/sonobuoy_gen_plugin.md @@ -0,0 +1,49 @@ +## sonobuoy gen plugin + +Generates the manifest Sonobuoy uses to define a plugin + +### Synopsis + +Generates the manifest Sonobuoy uses to define a plugin + +``` +sonobuoy gen plugin [flags] +``` + +### Examples + +``` +sonobuoy gen plugin -n myPlugin -i myregistry/myimage:v0 +``` + +### Options + +``` + -a, --arg stringArray Arg values to set on the plugin. Can be set multiple times (e.g. --arg 'arg 1' --arg arg2) + -c, --cmd stringArray Command to run when starting the plugin's container. Can be set multiple times (e.g. --cmd /bin/sh -c "-c") (default [./run.sh]) + --configmap stringArray Specifies files to read and add as configMaps. Will be mounted to the plugin at /tmp/sonobuoy/configs/. + -D, --description string Description for the plugin + -e, --env envvar Env var values to set on the plugin (e.g. --env FOO=bar) (default map[]) + -f, --format string Result format (junit or raw) (default "raw") + -h, --help help for plugin + -i, --image string Plugin image + -n, --name string Plugin name + --node-selector stringToString Node selector for the plugin (key=value). Usually set to specify OS via kubernetes.io/os=windows. Can be set multiple times. (default []) + --show-default-podspec If true, include the default pod spec used for plugins in the output. + -t, --type pluginDriver Plugin Driver (job or daemonset) (default Job) + -u, --url string URL for the plugin +``` + +### Options inherited from parent commands + +``` + --level level Log level. One of {panic, fatal, error, warn, info, debug, trace} (default info) +``` + +### SEE ALSO + +* [sonobuoy gen](sonobuoy_gen.md) - Generates a sonobuoy manifest for submission via kubectl +* [sonobuoy gen plugin e2e](sonobuoy_gen_plugin_e2e.md) - Generates the e2e plugin definition based on the given options +* [sonobuoy gen plugin systemd-logs](sonobuoy_gen_plugin_systemd-logs.md) - Generates the systemd-logs plugin definition based on the given options + +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/v0.56.12/cli/sonobuoy_gen_plugin_e2e.md b/site/content/docs/v0.56.12/cli/sonobuoy_gen_plugin_e2e.md new file mode 100644 index 000000000..92b201de6 --- /dev/null +++ b/site/content/docs/v0.56.12/cli/sonobuoy_gen_plugin_e2e.md @@ -0,0 +1,65 @@ +## sonobuoy gen plugin e2e + +Generates the e2e plugin definition based on the given options + +### Synopsis + +Generates the e2e plugin definition based on the given options + +``` +sonobuoy gen plugin e2e [flags] +``` + +### Options + +``` + --aggregator-node-selector nodeSelectors Node selectors to add to the aggregator. Values can be given multiple times and are in the form key:value (default map[]) + --aggregator-permissions string Type of aggregator permission to use in the cluster. Allowable values are [namespaceAdmin, clusterRead, clusterAdmin] (default "clusterAdmin") + --config Sonobuoy config Path to a sonobuoy configuration JSON file. + --configmap stringArray Specifies files to read and add as configMaps. Will be mounted to the plugin at /tmp/sonobuoy/configs/. + --context string Context in the kubeconfig to use. + --dns-namespace string The namespace to check for DNS pods during preflight checks. (default "kube-system") + --dns-pod-labels strings The label selectors to use for locating DNS pods during preflight checks. Can be specified multiple times or as a comma-separated list. (default [k8s-app=kube-dns,k8s-app=coredns]) + --e2e-focus envModifier Specify the E2E_FOCUS value for the e2e plugin, specifying which tests to run. Shorthand for --plugin-env=e2e.E2E_FOCUS= (default \[Conformance\]) + --e2e-repo envModifier Specify a registry to use as the default for pulling Kubernetes test images. Same as providing --e2e-repo-config but specifying the same repo repeatedly. + --e2e-repo-config yaml-filepath Specify a yaml file acting as KUBE_TEST_REPO_LIST, overriding registries for test images. + --e2e-skip envModifier Specify the E2E_SKIP value for the e2e plugin, specifying which tests to skip. Shorthand for --plugin-env=e2e.E2E_SKIP= (default \[Disruptive\]|NoExecuteTaintManager) + --existing-service-account If true, use an existing service account, else attempt to create one. + -f, --file - If set, loads the file as if it were the output from sonobuoy gen. Set to - to read from stdin. + --force-image-pull-policy Force plugins' imagePullPolicy to match the value for the Sonobuoy pod + -h, --help help for e2e + --image-pull-policy string Set the ImagePullPolicy for the Sonobuoy image and all plugins (if --force-image-pull-policy is set). Valid options are Always, IfNotPresent, Never. (default "IfNotPresent") + --kube-conformance-image image Container image override for the e2e plugin. Shorthand for --plugin-image=e2e: (default map[]) + --kubeconfig Kubeconfig Path to explicit kubeconfig file. + --kubernetes-version string Use default E2E image, but override the version. Default is 'auto', which will be set to your cluster's version if detected, erroring otherwise. 'ignore' will try version resolution but ignore errors. 'latest' will find the latest dev image/version upstream. + -m, --mode Mode What mode to run the e2e plugin in. Valid modes are [certified-conformance conformance-lite non-disruptive-conformance quick]. (default non-disruptive-conformance) + -n, --namespace string The namespace to run Sonobuoy in. Only one Sonobuoy run can exist per namespace simultaneously. (default "sonobuoy") + -p, --plugin pluginList Which plugins to run. Can either point to a URL, local file/directory, or be one of the known plugins (e2e or systemd-logs). Can be specified multiple times to run multiple plugins. + --plugin-env pluginenvvar Set env vars on plugins. Values can be given multiple times and are in the form plugin.env=value (default map[]) + --plugin-image plugin:image Override a plugins image from what is in its definition (e.g. myPlugin:testimage) (default map[]) + --rbac RBACMode Whether to enable RBAC on Sonobuoy. Valid modes are Enable, Disable, and Detect (query the server to see whether to enable RBAC). (default Enable) + --rerun-failed tar.gz file Read the given tarball and set the E2E_FOCUS to target all the failed tests + --security-context-mode string Type of security context to use for the aggregator pod. Allowable values are [none, nonroot] (default "nonroot") + --service-account-name string Name of the service account to be used by sonobuoy. (default "sonobuoy-serviceaccount") + --show-default-podspec If true, include the default pod spec used for plugins in the output. + --skip-preflight strings[=true] Skips the specified preflight checks. Valid values are [dnscheck, versioncheck, existingnamespace] or true to skip all of the checks. + --sonobuoy-image string Container image override for the sonobuoy worker and aggregator. (default "sonobuoy/sonobuoy:v0.56.11-2-g78c79313-dirty") + --ssh-key yamlFile Path to the private key enabling SSH to cluster nodes. May be required by some tests from the e2e plugin. + --ssh-user envModifier SSH user for ssh-key. Required if running e2e plugin with certain tests that require SSH access to nodes. + --systemd-logs-image image Container image override for the systemd-logs plugin. Shorthand for --plugin-image=systemd-logs: (default map[]) + --timeout int How long (in seconds) Sonobuoy aggregator will wait for plugins to complete before exiting. 0 indicates no timeout. (default 21600) + --wait int[=1440] How long (in minutes) for the CLI to wait for sonobuoy run to be completed or fail, where 0 indicates do not wait. If specified, the default wait time is 1 day. + --wait-output string Specify the type of output Sonobuoy should produce when --wait is used. Valid modes are silent, spinner, or progress (default "Progress") +``` + +### Options inherited from parent commands + +``` + --level level Log level. One of {panic, fatal, error, warn, info, debug, trace} (default info) +``` + +### SEE ALSO + +* [sonobuoy gen plugin](sonobuoy_gen_plugin.md) - Generates the manifest Sonobuoy uses to define a plugin + +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/v0.56.12/cli/sonobuoy_gen_plugin_systemd-logs.md b/site/content/docs/v0.56.12/cli/sonobuoy_gen_plugin_systemd-logs.md new file mode 100644 index 000000000..e41b30355 --- /dev/null +++ b/site/content/docs/v0.56.12/cli/sonobuoy_gen_plugin_systemd-logs.md @@ -0,0 +1,64 @@ +## sonobuoy gen plugin systemd-logs + +Generates the systemd-logs plugin definition based on the given options + +### Synopsis + +Generates the systemd-logs plugin definition based on the given options + +``` +sonobuoy gen plugin systemd-logs [flags] +``` + +### Options + +``` + --aggregator-node-selector nodeSelectors Node selectors to add to the aggregator. Values can be given multiple times and are in the form key:value (default map[]) + --aggregator-permissions string Type of aggregator permission to use in the cluster. Allowable values are [namespaceAdmin, clusterRead, clusterAdmin] (default "clusterAdmin") + --config Sonobuoy config Path to a sonobuoy configuration JSON file. + --context string Context in the kubeconfig to use. + --dns-namespace string The namespace to check for DNS pods during preflight checks. (default "kube-system") + --dns-pod-labels strings The label selectors to use for locating DNS pods during preflight checks. Can be specified multiple times or as a comma-separated list. (default [k8s-app=kube-dns,k8s-app=coredns]) + --e2e-focus envModifier Specify the E2E_FOCUS value for the e2e plugin, specifying which tests to run. Shorthand for --plugin-env=e2e.E2E_FOCUS= (default \[Conformance\]) + --e2e-repo envModifier Specify a registry to use as the default for pulling Kubernetes test images. Same as providing --e2e-repo-config but specifying the same repo repeatedly. + --e2e-repo-config yaml-filepath Specify a yaml file acting as KUBE_TEST_REPO_LIST, overriding registries for test images. + --e2e-skip envModifier Specify the E2E_SKIP value for the e2e plugin, specifying which tests to skip. Shorthand for --plugin-env=e2e.E2E_SKIP= (default \[Disruptive\]|NoExecuteTaintManager) + --existing-service-account If true, use an existing service account, else attempt to create one. + -f, --file - If set, loads the file as if it were the output from sonobuoy gen. Set to - to read from stdin. + --force-image-pull-policy Force plugins' imagePullPolicy to match the value for the Sonobuoy pod + -h, --help help for systemd-logs + --image-pull-policy string Set the ImagePullPolicy for the Sonobuoy image and all plugins (if --force-image-pull-policy is set). Valid options are Always, IfNotPresent, Never. (default "IfNotPresent") + --kube-conformance-image image Container image override for the e2e plugin. Shorthand for --plugin-image=e2e: (default map[]) + --kubeconfig Kubeconfig Path to explicit kubeconfig file. + --kubernetes-version string Use default E2E image, but override the version. Default is 'auto', which will be set to your cluster's version if detected, erroring otherwise. 'ignore' will try version resolution but ignore errors. 'latest' will find the latest dev image/version upstream. + -m, --mode Mode What mode to run the e2e plugin in. Valid modes are [certified-conformance conformance-lite non-disruptive-conformance quick]. (default non-disruptive-conformance) + -n, --namespace string The namespace to run Sonobuoy in. Only one Sonobuoy run can exist per namespace simultaneously. (default "sonobuoy") + -p, --plugin pluginList Which plugins to run. Can either point to a URL, local file/directory, or be one of the known plugins (e2e or systemd-logs). Can be specified multiple times to run multiple plugins. + --plugin-env pluginenvvar Set env vars on plugins. Values can be given multiple times and are in the form plugin.env=value (default map[]) + --plugin-image plugin:image Override a plugins image from what is in its definition (e.g. myPlugin:testimage) (default map[]) + --rbac RBACMode Whether to enable RBAC on Sonobuoy. Valid modes are Enable, Disable, and Detect (query the server to see whether to enable RBAC). (default Enable) + --rerun-failed tar.gz file Read the given tarball and set the E2E_FOCUS to target all the failed tests + --security-context-mode string Type of security context to use for the aggregator pod. Allowable values are [none, nonroot] (default "nonroot") + --service-account-name string Name of the service account to be used by sonobuoy. (default "sonobuoy-serviceaccount") + --show-default-podspec If true, include the default pod spec used for plugins in the output. + --skip-preflight strings[=true] Skips the specified preflight checks. Valid values are [dnscheck, versioncheck, existingnamespace] or true to skip all of the checks. + --sonobuoy-image string Container image override for the sonobuoy worker and aggregator. (default "sonobuoy/sonobuoy:v0.56.11-2-g78c79313-dirty") + --ssh-key yamlFile Path to the private key enabling SSH to cluster nodes. May be required by some tests from the e2e plugin. + --ssh-user envModifier SSH user for ssh-key. Required if running e2e plugin with certain tests that require SSH access to nodes. + --systemd-logs-image image Container image override for the systemd-logs plugin. Shorthand for --plugin-image=systemd-logs: (default map[]) + --timeout int How long (in seconds) Sonobuoy aggregator will wait for plugins to complete before exiting. 0 indicates no timeout. (default 21600) + --wait int[=1440] How long (in minutes) for the CLI to wait for sonobuoy run to be completed or fail, where 0 indicates do not wait. If specified, the default wait time is 1 day. + --wait-output string Specify the type of output Sonobuoy should produce when --wait is used. Valid modes are silent, spinner, or progress (default "Progress") +``` + +### Options inherited from parent commands + +``` + --level level Log level. One of {panic, fatal, error, warn, info, debug, trace} (default info) +``` + +### SEE ALSO + +* [sonobuoy gen plugin](sonobuoy_gen_plugin.md) - Generates the manifest Sonobuoy uses to define a plugin + +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/v0.56.12/cli/sonobuoy_get.md b/site/content/docs/v0.56.12/cli/sonobuoy_get.md new file mode 100644 index 000000000..89d094a48 --- /dev/null +++ b/site/content/docs/v0.56.12/cli/sonobuoy_get.md @@ -0,0 +1,26 @@ +## sonobuoy get + +Fetches Sonobuoy resources of a specified type + +### Synopsis + +Fetches Sonobuoy resources of a specified type + +### Options + +``` + -h, --help help for get +``` + +### Options inherited from parent commands + +``` + --level level Log level. One of {panic, fatal, error, warn, info, debug, trace} (default info) +``` + +### SEE ALSO + +* [sonobuoy](sonobuoy.md) - Generate reports on your Kubernetes cluster by running plugins +* [sonobuoy get pod](sonobuoy_get_pod.md) - Fetch sonobuoy pods + +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/v0.56.12/cli/sonobuoy_get_pod.md b/site/content/docs/v0.56.12/cli/sonobuoy_get_pod.md new file mode 100644 index 000000000..6dfab2c4a --- /dev/null +++ b/site/content/docs/v0.56.12/cli/sonobuoy_get_pod.md @@ -0,0 +1,31 @@ +## sonobuoy get pod + +Fetch sonobuoy pods + +### Synopsis + +Fetch sonobuoy pods + +``` +sonobuoy get pod [flags] +``` + +### Options + +``` + -h, --help help for pod + -n, --namespace string The namespace to run Sonobuoy in. Only one Sonobuoy run can exist per namespace simultaneously. (default "sonobuoy") + -p, --plugin string Plugin to locate pods for +``` + +### Options inherited from parent commands + +``` + --level level Log level. One of {panic, fatal, error, warn, info, debug, trace} (default info) +``` + +### SEE ALSO + +* [sonobuoy get](sonobuoy_get.md) - Fetches Sonobuoy resources of a specified type + +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/v0.56.12/cli/sonobuoy_images.md b/site/content/docs/v0.56.12/cli/sonobuoy_images.md new file mode 100644 index 000000000..9cf80b66b --- /dev/null +++ b/site/content/docs/v0.56.12/cli/sonobuoy_images.md @@ -0,0 +1,40 @@ +## sonobuoy images + +Manage images used in a plugin to facilitate running them in airgapped (or similar) environments. Supported plugins are: 'e2e' + +### Synopsis + +Manage images used in a plugin to facilitate running them in airgapped (or similar) environments. Supported plugins are: 'e2e' + +``` +sonobuoy images [flags] +``` + +### Options + +``` + --context string Context in the kubeconfig to use. + --dry-run If true, only print the image operations that would be performed. + -h, --help help for images + --kubeconfig Kubeconfig Path to explicit kubeconfig file. + --kubernetes-version string Use default E2E image, but override the version. Default is 'auto', which will be set to your cluster's version if detected, erroring otherwise. 'ignore' will try version resolution but ignore errors. 'latest' will find the latest dev image/version upstream. + -p, --plugin strings Describe which plugin's images to interact with (Valid plugins are 'e2e', 'systemd-logs'). (default [e2e,systemd-logs]) + --plugin-env pluginenvvar Set env vars on plugins. Values can be given multiple times and are in the form plugin.env=value (default map[]) +``` + +### Options inherited from parent commands + +``` + --level level Log level. One of {panic, fatal, error, warn, info, debug, trace} (default info) +``` + +### SEE ALSO + +* [sonobuoy](sonobuoy.md) - Generate reports on your Kubernetes cluster by running plugins +* [sonobuoy images delete](sonobuoy_images_delete.md) - Deletes all images downloaded to local docker client +* [sonobuoy images download](sonobuoy_images_download.md) - Saves downloaded images from local docker client to a tar file +* [sonobuoy images list](sonobuoy_images_list.md) - List images +* [sonobuoy images pull](sonobuoy_images_pull.md) - Pulls images to local docker client for a specific plugin +* [sonobuoy images push](sonobuoy_images_push.md) - Pushes images to docker registry for a specific plugin + +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/v0.56.12/cli/sonobuoy_images_delete.md b/site/content/docs/v0.56.12/cli/sonobuoy_images_delete.md new file mode 100644 index 000000000..6e30c871b --- /dev/null +++ b/site/content/docs/v0.56.12/cli/sonobuoy_images_delete.md @@ -0,0 +1,36 @@ +## sonobuoy images delete + +Deletes all images downloaded to local docker client + +### Synopsis + +Deletes all images downloaded to local docker client + +``` +sonobuoy images delete [flags] +``` + +### Options + +``` + --context string Context in the kubeconfig to use. + --dry-run If true, only print the image operations that would be performed. + --e2e-repo string Specify a registry for KUBE_TEST_REPO, overriding registries for test images. + --e2e-repo-config string Specify a yaml file acting as KUBE_TEST_REPO_LIST, overriding registries for test images. + -h, --help help for delete + --kubeconfig Kubeconfig Path to explicit kubeconfig file. + --kubernetes-version string Use default E2E image, but override the version. Default is 'auto', which will be set to your cluster's version if detected, erroring otherwise. 'ignore' will try version resolution but ignore errors. 'latest' will find the latest dev image/version upstream. + -p, --plugin strings Describe which plugin's images to interact with (Valid plugins are 'e2e', 'systemd-logs'). (default [e2e,systemd-logs]) +``` + +### Options inherited from parent commands + +``` + --level level Log level. One of {panic, fatal, error, warn, info, debug, trace} (default info) +``` + +### SEE ALSO + +* [sonobuoy images](sonobuoy_images.md) - Manage images used in a plugin to facilitate running them in airgapped (or similar) environments. Supported plugins are: 'e2e' + +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/v0.56.12/cli/sonobuoy_images_download.md b/site/content/docs/v0.56.12/cli/sonobuoy_images_download.md new file mode 100644 index 000000000..f91b6f5c7 --- /dev/null +++ b/site/content/docs/v0.56.12/cli/sonobuoy_images_download.md @@ -0,0 +1,36 @@ +## sonobuoy images download + +Saves downloaded images from local docker client to a tar file + +### Synopsis + +Saves downloaded images from local docker client to a tar file + +``` +sonobuoy images download [flags] +``` + +### Options + +``` + --context string Context in the kubeconfig to use. + --dry-run If true, only print the image operations that would be performed. + --e2e-repo string Specify a registry for KUBE_TEST_REPO, overriding registries for test images. + --e2e-repo-config string Specify a yaml file acting as KUBE_TEST_REPO_LIST, overriding registries for test images. + -h, --help help for download + --kubeconfig Kubeconfig Path to explicit kubeconfig file. + --kubernetes-version string Use default E2E image, but override the version. Default is 'auto', which will be set to your cluster's version if detected, erroring otherwise. 'ignore' will try version resolution but ignore errors. 'latest' will find the latest dev image/version upstream. + -p, --plugin strings Describe which plugin's images to interact with (Valid plugins are 'e2e', 'systemd-logs'). (default [e2e,systemd-logs]) +``` + +### Options inherited from parent commands + +``` + --level level Log level. One of {panic, fatal, error, warn, info, debug, trace} (default info) +``` + +### SEE ALSO + +* [sonobuoy images](sonobuoy_images.md) - Manage images used in a plugin to facilitate running them in airgapped (or similar) environments. Supported plugins are: 'e2e' + +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/v0.56.12/cli/sonobuoy_images_list.md b/site/content/docs/v0.56.12/cli/sonobuoy_images_list.md new file mode 100644 index 000000000..03919337a --- /dev/null +++ b/site/content/docs/v0.56.12/cli/sonobuoy_images_list.md @@ -0,0 +1,34 @@ +## sonobuoy images list + +List images + +### Synopsis + +List images + +``` +sonobuoy images list [flags] +``` + +### Options + +``` + --context string Context in the kubeconfig to use. + --dry-run If true, only print the image operations that would be performed. + -h, --help help for list + --kubeconfig Kubeconfig Path to explicit kubeconfig file. + --kubernetes-version string Use default E2E image, but override the version. Default is 'auto', which will be set to your cluster's version if detected, erroring otherwise. 'ignore' will try version resolution but ignore errors. 'latest' will find the latest dev image/version upstream. + -p, --plugin strings Describe which plugin's images to interact with (Valid plugins are 'e2e', 'systemd-logs'). (default [e2e,systemd-logs]) +``` + +### Options inherited from parent commands + +``` + --level level Log level. One of {panic, fatal, error, warn, info, debug, trace} (default info) +``` + +### SEE ALSO + +* [sonobuoy images](sonobuoy_images.md) - Manage images used in a plugin to facilitate running them in airgapped (or similar) environments. Supported plugins are: 'e2e' + +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/v0.56.12/cli/sonobuoy_images_pull.md b/site/content/docs/v0.56.12/cli/sonobuoy_images_pull.md new file mode 100644 index 000000000..873698233 --- /dev/null +++ b/site/content/docs/v0.56.12/cli/sonobuoy_images_pull.md @@ -0,0 +1,36 @@ +## sonobuoy images pull + +Pulls images to local docker client for a specific plugin + +### Synopsis + +Pulls images to local docker client for a specific plugin + +``` +sonobuoy images pull [flags] +``` + +### Options + +``` + --context string Context in the kubeconfig to use. + --dry-run If true, only print the image operations that would be performed. + --e2e-repo string Specify a registry for KUBE_TEST_REPO, overriding registries for test images. + --e2e-repo-config string Specify a yaml file acting as KUBE_TEST_REPO_LIST, overriding registries for test images. + -h, --help help for pull + --kubeconfig Kubeconfig Path to explicit kubeconfig file. + --kubernetes-version string Use default E2E image, but override the version. Default is 'auto', which will be set to your cluster's version if detected, erroring otherwise. 'ignore' will try version resolution but ignore errors. 'latest' will find the latest dev image/version upstream. + -p, --plugin strings Describe which plugin's images to interact with (Valid plugins are 'e2e', 'systemd-logs'). (default [e2e,systemd-logs]) +``` + +### Options inherited from parent commands + +``` + --level level Log level. One of {panic, fatal, error, warn, info, debug, trace} (default info) +``` + +### SEE ALSO + +* [sonobuoy images](sonobuoy_images.md) - Manage images used in a plugin to facilitate running them in airgapped (or similar) environments. Supported plugins are: 'e2e' + +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/v0.56.12/cli/sonobuoy_images_push.md b/site/content/docs/v0.56.12/cli/sonobuoy_images_push.md new file mode 100644 index 000000000..b92dc8f09 --- /dev/null +++ b/site/content/docs/v0.56.12/cli/sonobuoy_images_push.md @@ -0,0 +1,37 @@ +## sonobuoy images push + +Pushes images to docker registry for a specific plugin + +### Synopsis + +Pushes images to docker registry for a specific plugin + +``` +sonobuoy images push [flags] +``` + +### Options + +``` + --context string Context in the kubeconfig to use. + --custom-registry string Specify a registry to override the Sonobuoy and Plugin image registries. + --dry-run If true, only print the image operations that would be performed. + --e2e-repo string Specify a registry for KUBE_TEST_REPO, overriding registries for test images. + --e2e-repo-config string Specify a yaml file acting as KUBE_TEST_REPO_LIST, overriding registries for test images. + -h, --help help for push + --kubeconfig Kubeconfig Path to explicit kubeconfig file. + --kubernetes-version string Use default E2E image, but override the version. Default is 'auto', which will be set to your cluster's version if detected, erroring otherwise. 'ignore' will try version resolution but ignore errors. 'latest' will find the latest dev image/version upstream. + -p, --plugin strings Describe which plugin's images to interact with (Valid plugins are 'e2e', 'systemd-logs'). (default [e2e,systemd-logs]) +``` + +### Options inherited from parent commands + +``` + --level level Log level. One of {panic, fatal, error, warn, info, debug, trace} (default info) +``` + +### SEE ALSO + +* [sonobuoy images](sonobuoy_images.md) - Manage images used in a plugin to facilitate running them in airgapped (or similar) environments. Supported plugins are: 'e2e' + +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/v0.56.12/cli/sonobuoy_logs.md b/site/content/docs/v0.56.12/cli/sonobuoy_logs.md new file mode 100644 index 000000000..0e1b15f87 --- /dev/null +++ b/site/content/docs/v0.56.12/cli/sonobuoy_logs.md @@ -0,0 +1,34 @@ +## sonobuoy logs + +Dumps the logs of the currently running Sonobuoy containers for diagnostics + +### Synopsis + +Dumps the logs of the currently running Sonobuoy containers for diagnostics + +``` +sonobuoy logs [flags] +``` + +### Options + +``` + --context string Context in the kubeconfig to use. + -f, --follow Continue following the logs of the Sonobuoy created containers. + -h, --help help for logs + --kubeconfig Kubeconfig Path to explicit kubeconfig file. + -n, --namespace string The namespace to run Sonobuoy in. Only one Sonobuoy run can exist per namespace simultaneously. (default "sonobuoy") + -p, --plugin string Show logs only for a specific plugin. If 'sonobuoy' is provided, only shows the aggregator logs. +``` + +### Options inherited from parent commands + +``` + --level level Log level. One of {panic, fatal, error, warn, info, debug, trace} (default info) +``` + +### SEE ALSO + +* [sonobuoy](sonobuoy.md) - Generate reports on your Kubernetes cluster by running plugins + +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/v0.56.12/cli/sonobuoy_modes.md b/site/content/docs/v0.56.12/cli/sonobuoy_modes.md new file mode 100644 index 000000000..747c4ea8a --- /dev/null +++ b/site/content/docs/v0.56.12/cli/sonobuoy_modes.md @@ -0,0 +1,30 @@ +## sonobuoy modes + +Display the various modes in which to run the e2e plugin + +### Synopsis + +Display the various modes in which to run the e2e plugin + +``` +sonobuoy modes [flags] +``` + +### Options + +``` + -h, --help help for modes + --verbose Do not truncate output for each mode. +``` + +### Options inherited from parent commands + +``` + --level level Log level. One of {panic, fatal, error, warn, info, debug, trace} (default info) +``` + +### SEE ALSO + +* [sonobuoy](sonobuoy.md) - Generate reports on your Kubernetes cluster by running plugins + +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/v0.56.12/cli/sonobuoy_plugin.md b/site/content/docs/v0.56.12/cli/sonobuoy_plugin.md new file mode 100644 index 000000000..88151562c --- /dev/null +++ b/site/content/docs/v0.56.12/cli/sonobuoy_plugin.md @@ -0,0 +1,29 @@ +## sonobuoy plugin + +Manage your installed plugins + +### Synopsis + +Manage your installed plugins + +### Options + +``` + -h, --help help for plugin +``` + +### Options inherited from parent commands + +``` + --level level Log level. One of {panic, fatal, error, warn, info, debug, trace} (default info) +``` + +### SEE ALSO + +* [sonobuoy](sonobuoy.md) - Generate reports on your Kubernetes cluster by running plugins +* [sonobuoy plugin install](sonobuoy_plugin_install.md) - Install a plugin so that it can be run via just its filename rather than a full path or URL. +* [sonobuoy plugin list](sonobuoy_plugin_list.md) - List all installed plugins +* [sonobuoy plugin show](sonobuoy_plugin_show.md) - Print the full definition of the named plugin file +* [sonobuoy plugin uninstall](sonobuoy_plugin_uninstall.md) - Uninstall a plugin. You can continue to run any plugin via specifying a file or URL. + +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/v0.56.12/cli/sonobuoy_plugin_install.md b/site/content/docs/v0.56.12/cli/sonobuoy_plugin_install.md new file mode 100644 index 000000000..ea6e20fd4 --- /dev/null +++ b/site/content/docs/v0.56.12/cli/sonobuoy_plugin_install.md @@ -0,0 +1,29 @@ +## sonobuoy plugin install + +Install a plugin so that it can be run via just its filename rather than a full path or URL. + +### Synopsis + +Install a plugin so that it can be run via just its filename rather than a full path or URL. + +``` +sonobuoy plugin install [flags] +``` + +### Options + +``` + -h, --help help for install +``` + +### Options inherited from parent commands + +``` + --level level Log level. One of {panic, fatal, error, warn, info, debug, trace} (default info) +``` + +### SEE ALSO + +* [sonobuoy plugin](sonobuoy_plugin.md) - Manage your installed plugins + +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/v0.56.12/cli/sonobuoy_plugin_list.md b/site/content/docs/v0.56.12/cli/sonobuoy_plugin_list.md new file mode 100644 index 000000000..afd6da5b6 --- /dev/null +++ b/site/content/docs/v0.56.12/cli/sonobuoy_plugin_list.md @@ -0,0 +1,29 @@ +## sonobuoy plugin list + +List all installed plugins + +### Synopsis + +List all installed plugins + +``` +sonobuoy plugin list [flags] +``` + +### Options + +``` + -h, --help help for list +``` + +### Options inherited from parent commands + +``` + --level level Log level. One of {panic, fatal, error, warn, info, debug, trace} (default info) +``` + +### SEE ALSO + +* [sonobuoy plugin](sonobuoy_plugin.md) - Manage your installed plugins + +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/v0.56.12/cli/sonobuoy_plugin_show.md b/site/content/docs/v0.56.12/cli/sonobuoy_plugin_show.md new file mode 100644 index 000000000..3aec8693f --- /dev/null +++ b/site/content/docs/v0.56.12/cli/sonobuoy_plugin_show.md @@ -0,0 +1,29 @@ +## sonobuoy plugin show + +Print the full definition of the named plugin file + +### Synopsis + +Print the full definition of the named plugin file + +``` +sonobuoy plugin show [flags] +``` + +### Options + +``` + -h, --help help for show +``` + +### Options inherited from parent commands + +``` + --level level Log level. One of {panic, fatal, error, warn, info, debug, trace} (default info) +``` + +### SEE ALSO + +* [sonobuoy plugin](sonobuoy_plugin.md) - Manage your installed plugins + +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/v0.56.12/cli/sonobuoy_plugin_uninstall.md b/site/content/docs/v0.56.12/cli/sonobuoy_plugin_uninstall.md new file mode 100644 index 000000000..f9ac6dbd5 --- /dev/null +++ b/site/content/docs/v0.56.12/cli/sonobuoy_plugin_uninstall.md @@ -0,0 +1,29 @@ +## sonobuoy plugin uninstall + +Uninstall a plugin. You can continue to run any plugin via specifying a file or URL. + +### Synopsis + +Uninstall a plugin. You can continue to run any plugin via specifying a file or URL. + +``` +sonobuoy plugin uninstall [flags] +``` + +### Options + +``` + -h, --help help for uninstall +``` + +### Options inherited from parent commands + +``` + --level level Log level. One of {panic, fatal, error, warn, info, debug, trace} (default info) +``` + +### SEE ALSO + +* [sonobuoy plugin](sonobuoy_plugin.md) - Manage your installed plugins + +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/v0.56.12/cli/sonobuoy_query.md b/site/content/docs/v0.56.12/cli/sonobuoy_query.md new file mode 100644 index 000000000..308669a26 --- /dev/null +++ b/site/content/docs/v0.56.12/cli/sonobuoy_query.md @@ -0,0 +1,31 @@ +## sonobuoy query + +Runs queries against your cluster in order to aid in debugging. + +### Synopsis + +Runs queries against your cluster in order to aid in debugging. + +``` +sonobuoy query [flags] +``` + +### Options + +``` + --config Sonobuoy config Path to a sonobuoy configuration JSON file. + -h, --help help for query + -o, --output string Directory to output results into. If empty, will default to a UUID folder in the pwd. +``` + +### Options inherited from parent commands + +``` + --level level Log level. One of {panic, fatal, error, warn, info, debug, trace} (default info) +``` + +### SEE ALSO + +* [sonobuoy](sonobuoy.md) - Generate reports on your Kubernetes cluster by running plugins + +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/v0.56.12/cli/sonobuoy_results.md b/site/content/docs/v0.56.12/cli/sonobuoy_results.md new file mode 100644 index 000000000..f073b46f5 --- /dev/null +++ b/site/content/docs/v0.56.12/cli/sonobuoy_results.md @@ -0,0 +1,33 @@ +## sonobuoy results + +Inspect plugin results. + +### Synopsis + +Inspect plugin results. + +``` +sonobuoy results archive.tar.gz [flags] +``` + +### Options + +``` + -h, --help help for results + -m, --mode string Modifies the format of the output. Valid options are report, detailed, readable, or dump. (default "report") + -n, --node string Traverse results starting at the node with the given name. Defaults to the real root. + -p, --plugin string Which plugin to show results for. Defaults to printing them all. + -s, --skip-prefix When printing items linking to files, only print the file contents. +``` + +### Options inherited from parent commands + +``` + --level level Log level. One of {panic, fatal, error, warn, info, debug, trace} (default info) +``` + +### SEE ALSO + +* [sonobuoy](sonobuoy.md) - Generate reports on your Kubernetes cluster by running plugins + +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/v0.56.12/cli/sonobuoy_retrieve.md b/site/content/docs/v0.56.12/cli/sonobuoy_retrieve.md new file mode 100644 index 000000000..4afec0778 --- /dev/null +++ b/site/content/docs/v0.56.12/cli/sonobuoy_retrieve.md @@ -0,0 +1,35 @@ +## sonobuoy retrieve + +Retrieves the results of a sonobuoy run to a specified path + +### Synopsis + +Retrieves the results of a sonobuoy run to a specified path + +``` +sonobuoy retrieve [path] [flags] +``` + +### Options + +``` + --context string Context in the kubeconfig to use. + -x, --extract If true, extracts the results instead of just downloading the results tarball. + -f, --filename string Specify the name of the downloaded file. If empty, defaults to the name of the tarball in the pod. + -h, --help help for retrieve + --kubeconfig Kubeconfig Path to explicit kubeconfig file. + -n, --namespace string The namespace to run Sonobuoy in. Only one Sonobuoy run can exist per namespace simultaneously. (default "sonobuoy") + --retrieve-path string Specify the path to retrieve from the aggregator pod. (default "/tmp/sonobuoy") +``` + +### Options inherited from parent commands + +``` + --level level Log level. One of {panic, fatal, error, warn, info, debug, trace} (default info) +``` + +### SEE ALSO + +* [sonobuoy](sonobuoy.md) - Generate reports on your Kubernetes cluster by running plugins + +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/v0.56.12/cli/sonobuoy_run.md b/site/content/docs/v0.56.12/cli/sonobuoy_run.md new file mode 100644 index 000000000..e0386f28c --- /dev/null +++ b/site/content/docs/v0.56.12/cli/sonobuoy_run.md @@ -0,0 +1,64 @@ +## sonobuoy run + +Starts a Sonobuoy run by launching the Sonobuoy aggregator and plugin pods. + +### Synopsis + +Starts a Sonobuoy run by launching the Sonobuoy aggregator and plugin pods. + +``` +sonobuoy run [flags] +``` + +### Options + +``` + --aggregator-node-selector nodeSelectors Node selectors to add to the aggregator. Values can be given multiple times and are in the form key:value (default map[]) + --aggregator-permissions string Type of aggregator permission to use in the cluster. Allowable values are [namespaceAdmin, clusterRead, clusterAdmin] (default "clusterAdmin") + --config Sonobuoy config Path to a sonobuoy configuration JSON file. + --context string Context in the kubeconfig to use. + --dns-namespace string The namespace to check for DNS pods during preflight checks. (default "kube-system") + --dns-pod-labels strings The label selectors to use for locating DNS pods during preflight checks. Can be specified multiple times or as a comma-separated list. (default [k8s-app=kube-dns,k8s-app=coredns]) + --e2e-focus envModifier Specify the E2E_FOCUS value for the e2e plugin, specifying which tests to run. Shorthand for --plugin-env=e2e.E2E_FOCUS= (default \[Conformance\]) + --e2e-repo envModifier Specify a registry to use as the default for pulling Kubernetes test images. Same as providing --e2e-repo-config but specifying the same repo repeatedly. + --e2e-repo-config yaml-filepath Specify a yaml file acting as KUBE_TEST_REPO_LIST, overriding registries for test images. + --e2e-skip envModifier Specify the E2E_SKIP value for the e2e plugin, specifying which tests to skip. Shorthand for --plugin-env=e2e.E2E_SKIP= (default \[Disruptive\]|NoExecuteTaintManager) + --existing-service-account If true, use an existing service account, else attempt to create one. + -f, --file - If set, loads the file as if it were the output from sonobuoy gen. Set to - to read from stdin. + --force-image-pull-policy Force plugins' imagePullPolicy to match the value for the Sonobuoy pod + -h, --help help for run + --image-pull-policy string Set the ImagePullPolicy for the Sonobuoy image and all plugins (if --force-image-pull-policy is set). Valid options are Always, IfNotPresent, Never. (default "IfNotPresent") + --kube-conformance-image image Container image override for the e2e plugin. Shorthand for --plugin-image=e2e: (default map[]) + --kubeconfig Kubeconfig Path to explicit kubeconfig file. + --kubernetes-version string Use default E2E image, but override the version. Default is 'auto', which will be set to your cluster's version if detected, erroring otherwise. 'ignore' will try version resolution but ignore errors. 'latest' will find the latest dev image/version upstream. + -m, --mode Mode What mode to run the e2e plugin in. Valid modes are [certified-conformance conformance-lite non-disruptive-conformance quick]. (default non-disruptive-conformance) + -n, --namespace string The namespace to run Sonobuoy in. Only one Sonobuoy run can exist per namespace simultaneously. (default "sonobuoy") + -p, --plugin pluginList Which plugins to run. Can either point to a URL, local file/directory, or be one of the known plugins (e2e or systemd-logs). Can be specified multiple times to run multiple plugins. + --plugin-env pluginenvvar Set env vars on plugins. Values can be given multiple times and are in the form plugin.env=value (default map[]) + --plugin-image plugin:image Override a plugins image from what is in its definition (e.g. myPlugin:testimage) (default map[]) + --rbac RBACMode Whether to enable RBAC on Sonobuoy. Valid modes are Enable, Disable, and Detect (query the server to see whether to enable RBAC). (default Detect) + --rerun-failed tar.gz file Read the given tarball and set the E2E_FOCUS to target all the failed tests + --security-context-mode string Type of security context to use for the aggregator pod. Allowable values are [none, nonroot] (default "nonroot") + --service-account-name string Name of the service account to be used by sonobuoy. (default "sonobuoy-serviceaccount") + --show-default-podspec If true, include the default pod spec used for plugins in the output. + --skip-preflight strings[=true] Skips the specified preflight checks. Valid values are [dnscheck, versioncheck, existingnamespace] or true to skip all of the checks. + --sonobuoy-image string Container image override for the sonobuoy worker and aggregator. (default "sonobuoy/sonobuoy:v0.56.11-2-g78c79313-dirty") + --ssh-key yamlFile Path to the private key enabling SSH to cluster nodes. May be required by some tests from the e2e plugin. + --ssh-user envModifier SSH user for ssh-key. Required if running e2e plugin with certain tests that require SSH access to nodes. + --systemd-logs-image image Container image override for the systemd-logs plugin. Shorthand for --plugin-image=systemd-logs: (default map[]) + --timeout int How long (in seconds) Sonobuoy aggregator will wait for plugins to complete before exiting. 0 indicates no timeout. (default 21600) + --wait int[=1440] How long (in minutes) for the CLI to wait for sonobuoy run to be completed or fail, where 0 indicates do not wait. If specified, the default wait time is 1 day. + --wait-output string Specify the type of output Sonobuoy should produce when --wait is used. Valid modes are silent, spinner, or progress (default "Progress") +``` + +### Options inherited from parent commands + +``` + --level level Log level. One of {panic, fatal, error, warn, info, debug, trace} (default info) +``` + +### SEE ALSO + +* [sonobuoy](sonobuoy.md) - Generate reports on your Kubernetes cluster by running plugins + +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/v0.56.12/cli/sonobuoy_status.md b/site/content/docs/v0.56.12/cli/sonobuoy_status.md new file mode 100644 index 000000000..397a14701 --- /dev/null +++ b/site/content/docs/v0.56.12/cli/sonobuoy_status.md @@ -0,0 +1,34 @@ +## sonobuoy status + +Gets a summarized status of a sonobuoy run + +### Synopsis + +Gets a summarized status of a sonobuoy run + +``` +sonobuoy status [flags] +``` + +### Options + +``` + --context string Context in the kubeconfig to use. + -h, --help help for status + --json Print the status object as json + --kubeconfig Kubeconfig Path to explicit kubeconfig file. + -n, --namespace string The namespace to run Sonobuoy in. Only one Sonobuoy run can exist per namespace simultaneously. (default "sonobuoy") + --show-all Don't summarize plugin statuses, show results for each node +``` + +### Options inherited from parent commands + +``` + --level level Log level. One of {panic, fatal, error, warn, info, debug, trace} (default info) +``` + +### SEE ALSO + +* [sonobuoy](sonobuoy.md) - Generate reports on your Kubernetes cluster by running plugins + +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/v0.56.12/cli/sonobuoy_version.md b/site/content/docs/v0.56.12/cli/sonobuoy_version.md new file mode 100644 index 000000000..878c9b20f --- /dev/null +++ b/site/content/docs/v0.56.12/cli/sonobuoy_version.md @@ -0,0 +1,32 @@ +## sonobuoy version + +Print sonobuoy version + +### Synopsis + +Print sonobuoy version + +``` +sonobuoy version [flags] +``` + +### Options + +``` + --context string Context in the kubeconfig to use. + -h, --help help for version + --kubeconfig Kubeconfig Path to explicit kubeconfig file. + --short If true, prints just the Sonobuoy version. +``` + +### Options inherited from parent commands + +``` + --level level Log level. One of {panic, fatal, error, warn, info, debug, trace} (default info) +``` + +### SEE ALSO + +* [sonobuoy](sonobuoy.md) - Generate reports on your Kubernetes cluster by running plugins + +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/v0.56.12/cli/sonobuoy_wait.md b/site/content/docs/v0.56.12/cli/sonobuoy_wait.md new file mode 100644 index 000000000..01240430e --- /dev/null +++ b/site/content/docs/v0.56.12/cli/sonobuoy_wait.md @@ -0,0 +1,64 @@ +## sonobuoy wait + +Waits on the Sonobuoy run in the targeted namespace. + +### Synopsis + +Waits on the Sonobuoy run in the targeted namespace. + +``` +sonobuoy wait [flags] +``` + +### Options + +``` + --aggregator-node-selector nodeSelectors Node selectors to add to the aggregator. Values can be given multiple times and are in the form key:value (default map[]) + --aggregator-permissions string Type of aggregator permission to use in the cluster. Allowable values are [namespaceAdmin, clusterRead, clusterAdmin] (default "clusterAdmin") + --config Sonobuoy config Path to a sonobuoy configuration JSON file. + --context string Context in the kubeconfig to use. + --dns-namespace string The namespace to check for DNS pods during preflight checks. (default "kube-system") + --dns-pod-labels strings The label selectors to use for locating DNS pods during preflight checks. Can be specified multiple times or as a comma-separated list. (default [k8s-app=kube-dns,k8s-app=coredns]) + --e2e-focus envModifier Specify the E2E_FOCUS value for the e2e plugin, specifying which tests to run. Shorthand for --plugin-env=e2e.E2E_FOCUS= (default \[Conformance\]) + --e2e-repo envModifier Specify a registry to use as the default for pulling Kubernetes test images. Same as providing --e2e-repo-config but specifying the same repo repeatedly. + --e2e-repo-config yaml-filepath Specify a yaml file acting as KUBE_TEST_REPO_LIST, overriding registries for test images. + --e2e-skip envModifier Specify the E2E_SKIP value for the e2e plugin, specifying which tests to skip. Shorthand for --plugin-env=e2e.E2E_SKIP= (default \[Disruptive\]|NoExecuteTaintManager) + --existing-service-account If true, use an existing service account, else attempt to create one. + -f, --file - If set, loads the file as if it were the output from sonobuoy gen. Set to - to read from stdin. + --force-image-pull-policy Force plugins' imagePullPolicy to match the value for the Sonobuoy pod + -h, --help help for wait + --image-pull-policy string Set the ImagePullPolicy for the Sonobuoy image and all plugins (if --force-image-pull-policy is set). Valid options are Always, IfNotPresent, Never. (default "IfNotPresent") + --kube-conformance-image image Container image override for the e2e plugin. Shorthand for --plugin-image=e2e: (default map[]) + --kubeconfig Kubeconfig Path to explicit kubeconfig file. + --kubernetes-version string Use default E2E image, but override the version. Default is 'auto', which will be set to your cluster's version if detected, erroring otherwise. 'ignore' will try version resolution but ignore errors. 'latest' will find the latest dev image/version upstream. + -m, --mode Mode What mode to run the e2e plugin in. Valid modes are [certified-conformance conformance-lite non-disruptive-conformance quick]. (default non-disruptive-conformance) + -n, --namespace string The namespace to run Sonobuoy in. Only one Sonobuoy run can exist per namespace simultaneously. (default "sonobuoy") + -p, --plugin pluginList Which plugins to run. Can either point to a URL, local file/directory, or be one of the known plugins (e2e or systemd-logs). Can be specified multiple times to run multiple plugins. + --plugin-env pluginenvvar Set env vars on plugins. Values can be given multiple times and are in the form plugin.env=value (default map[]) + --plugin-image plugin:image Override a plugins image from what is in its definition (e.g. myPlugin:testimage) (default map[]) + --rbac RBACMode Whether to enable RBAC on Sonobuoy. Valid modes are Enable, Disable, and Detect (query the server to see whether to enable RBAC). (default Detect) + --rerun-failed tar.gz file Read the given tarball and set the E2E_FOCUS to target all the failed tests + --security-context-mode string Type of security context to use for the aggregator pod. Allowable values are [none, nonroot] (default "nonroot") + --service-account-name string Name of the service account to be used by sonobuoy. (default "sonobuoy-serviceaccount") + --show-default-podspec If true, include the default pod spec used for plugins in the output. + --skip-preflight strings[=true] Skips the specified preflight checks. Valid values are [dnscheck, versioncheck, existingnamespace] or true to skip all of the checks. + --sonobuoy-image string Container image override for the sonobuoy worker and aggregator. (default "sonobuoy/sonobuoy:v0.56.11-2-g78c79313-dirty") + --ssh-key yamlFile Path to the private key enabling SSH to cluster nodes. May be required by some tests from the e2e plugin. + --ssh-user envModifier SSH user for ssh-key. Required if running e2e plugin with certain tests that require SSH access to nodes. + --systemd-logs-image image Container image override for the systemd-logs plugin. Shorthand for --plugin-image=systemd-logs: (default map[]) + --timeout int How long (in seconds) Sonobuoy aggregator will wait for plugins to complete before exiting. 0 indicates no timeout. (default 21600) + --wait int[=1440] How long (in minutes) for the CLI to wait for sonobuoy run to be completed or fail, where 0 indicates do not wait. If specified, the default wait time is 1 day. + --wait-output string Specify the type of output Sonobuoy should produce when --wait is used. Valid modes are silent, spinner, or progress (default "Progress") +``` + +### Options inherited from parent commands + +``` + --level level Log level. One of {panic, fatal, error, warn, info, debug, trace} (default info) +``` + +### SEE ALSO + +* [sonobuoy](sonobuoy.md) - Generate reports on your Kubernetes cluster by running plugins + +###### Auto generated by spf13/cobra on 14-Nov-2022 diff --git a/site/content/docs/v0.56.12/dryRun-listGenerator.md b/site/content/docs/v0.56.12/dryRun-listGenerator.md new file mode 100644 index 000000000..8008b42a7 --- /dev/null +++ b/site/content/docs/v0.56.12/dryRun-listGenerator.md @@ -0,0 +1,13 @@ +# Plugins used to help create test lists + +This process has been dramatically simplified. All that is necessary is that you create a new Git branch/PR +and run `./scripts/gather_e2e_data.sh` and commit the changes. + +You can look through the script and the supporting files for a more in depth explanation of the process but +it just boils down to finding the proper versions to check, running them in DRY_RUN mode, and extracting +the necessary data. + +**DEBUG** +If running this against a local kind cluster the server could run out of space for more conformance images (e.g. "no space left on device") + - Clear docker cache with `docker image prune -a` + - Add more disc space to docker (60GB to 300GB) \ No newline at end of file diff --git a/site/content/docs/v0.56.12/e2eplugin.md b/site/content/docs/v0.56.12/e2eplugin.md new file mode 100644 index 000000000..27adfc729 --- /dev/null +++ b/site/content/docs/v0.56.12/e2eplugin.md @@ -0,0 +1,99 @@ +# The Kubernetes End-To-End Testing Plugin + +The Kubernetes end-to-end testing plugin (the e2e plugin) is used to run tests which are maintained by the upstream Kubernetes community in the [kubernetes/kubernetes][kubernetesRepo] repo. + +There are numerous ways to run this plugin in order to meet your testing needs. + +## Choosing Which Tests To Run + +The most common point of customization is changing the set of tests to run. This is controlled by two environment variables the test image recognizes: + +* E2E_FOCUS +* E2E_SKIP + +Each of these is a regular expression describing which tests to run or skip. The "E2E_FOCUS" value is applied first and the "E2E_SKIP" value then further restricts that list. These can be set using Sonobuoy flags: + +``` +sonobuoy run \ + --e2e-focus= \ + --e2e-skip= +``` + +> Note: These flags are just special cases of the more general flag `--plugin-env`. For instance, you could set the env vars by using the flag `--plugin-env e2e.E2E_SKIP=` + +# Built-In Modes + +There are a few commonly run configurations which Sonobuoy hard-codes for convenience. +Keep in mind that since these modes are shorthand for focus/skip values, you should not provide flags for both (mode and focus/skip): + +> Note: You can see a list of these by running `sonobuoy modes` + +* non-disruptive-conformance + +This is the default mode and will run all the tests in the `e2e` plugin which are marked `Conformance` which are known to not be disruptive to other workloads in your cluster. This mode is ideal for checking that an existing cluster continues to behave is conformant manner. + +> NOTE: The length of time it takes to run conformance can vary based on the size of your cluster---the timeout can be adjusted in the Server.timeoutseconds field of the Sonobuoy `config.json` or on the CLI via the `--timeout` flag. + +* quick + +This mode will run a single test from the `e2e` test suite which is known to be simple and fast. Use this mode as a quick check that the cluster is responding and reachable. + +* certified-conformance + +This mode runs all of the `Conformance` tests and is the mode used when applying for the [Certified Kubernetes Conformance Program](https://www.cncf.io/certification/software-conformance). Some of these tests may be disruptive to other workloads so it is not recommended that you run this mode on production clusters. In those situations, use the default "non-disruptive-conformance" mode. + +> NOTE: The length of time it takes to run conformance can vary based on the size of your cluster---the timeout can be adjusted in the Server.timeoutseconds field of the Sonobuoy `config.json` or on the CLI via the `--timeout` flag. + +## Dry Run and the E2E Command + +When specifying your own focus/skip values, it may be useful to figure out which tests will be run before actually spending the time/resources to run them. + +Sonobuoy has gathered the list of tests for different Kubernetes versions and allows you to quickly check the result of focus/skip values: + +```gotemplate +sonobuoy e2e --focus foo --skip bar +``` + +It can be particularly useful to see which "tags" (groups of tests) are being run and how many tests. +The "e2e" command provides different output modes to facilitate that: + +```gotemplate +// Lists all tests by name. Precise but may be lots of data. +sonobuoy e2e --focus foo --skip bar + +// Lists all the test tags (e.g. [sig-storage] or [Feature: Foo]) +sonobuoy e2e --focus foo --skip bar --mode=tags + +// Lists all the test tags and how many tests had it (e.g. [sig-storage]: 13 or [Feature: Foo]: 2) +sonobuoy e2e --focus foo --skip bar --mode=tagCounts +``` + +Instead of the "e2e" command, you can also run the tests in dry run mode: + +``` +sonobuoy run \ + --plugin-env e2e.E2E_FOCUS=pods \ + --plugin-env e2e.E2E_DRYRUN=true +``` + +By setting `E2E_DRYRUN`, the run will execute and produce results like normal except that the actual test code won't execute, just the test selection. Each test that _would have been run_ will be reported as passing. This can help you fine-tune your focus/skip values to target just the tests you want without wasting hours on test runs which target unnecessary tests. + +## Why Conformance Matters + +With such a [wide array][configs] of Kubernetes distributions available, *conformance tests* help ensure that a Kubernetes cluster meets the minimal set of features. They are a subset of end-to-end (e2e) tests that should pass on any Kubernetes cluster. + +A conformance-passing cluster provides the following guarantees: + +* **Best practices**: Your Kubernetes is properly configured. This is useful to know whether you are running a distribution out of the box or handling your own custom setup. + +* **Predictability**: All your cluster behavior is well-documented. Available features in the official Kubernetes documentation can be taken as a given. Unexpected bugs should be rare, because distribution-specific issues are weeded out during the conformance tests. + +* **Interoperability**: Workloads from other conforming clusters can be ported into your cluster, or vice versa. This standardization of Kubernetes is a key advantage of open source software, and allows you to avoid vendor lock-in. + +Individual Kubernetes distributions may offer additional features beyond conformance testing, but if you change distributions, these features can't be expected to be provided. + +See the [official documentation][conformanceDocs] for Kubernetes's existing conformance tests. + +[configs]: https://docs.google.com/spreadsheets/d/1LxSqBzjOxfGx3cmtZ4EbB_BGCxT_wlxW_xgHVVa23es/edit#gid=0 +[conformanceDocs]: https://github.com/kubernetes/community/blob/master/contributors/devel/sig-testing/e2e-tests.md#conformance-tests +[kubernetesRepo]: https://github.com/kubernetes/kubernetes/tree/master/test/conformance/image diff --git a/site/content/docs/v0.56.12/faq.md b/site/content/docs/v0.56.12/faq.md new file mode 100644 index 000000000..c3897aa8d --- /dev/null +++ b/site/content/docs/v0.56.12/faq.md @@ -0,0 +1,221 @@ +# Frequently Asked Questions + +## Kubernetes Conformance and end-to-end testing + +### Why were so many tests skipped? + +When running the `e2e` plugin on Sonobuoy, you will notice that a large number of tests are skipped by default. The +reason for this is that the image used by Sonobuoy to run the Kubernetes conformance tests contains all the end-to-end +tests for Kubernetes. However, only a subset of those tests are required to check conformance. For example, the v1.16 +Kubernetes test image contains over 4000 tests however only 215 of those are conformance tests. + +The default mode for the e2e plugin (`non-disruptive-conformance`) will run all tests which contain the +tag `[Conformance]` and exclude those that with the `[Disruptive]` tag. This is to help prevent you from accidentally +running tests which may disrupt workloads on your cluster. To run all the conformance tests, use +the `certified-conformance` mode. + +Please refer to our [documentation for the `e2e` plugin][e2ePlugin] for more details of the built-in configurations or +our blog [post][testsuiteblog] on the Kubernetes test suite. + +### How do I determine why my tests failed? + +Before debugging test failures, we recommend isolating any failures to verify that they are genuine and are not spurious +or transient. Unfortunately, such failures can be common in complex, distributed systems. To do this, you can make use +of the `--e2e-focus` flag when using the `run` command. This flag accepts a regex which will be used to find and run +only the tests matching that regex. For example, you can provide the name of a test to run only that test: + +``` +sonobuoy run --e2e-focus "should update pod when spec was updated and update strategy is RollingUpdate" +``` + +If the test continues to fail and it appears to be a genuine failure, the next step would be to read the logs to +understand why the test failed. To read the logs for a test failure, you can find the log file within the results +tarball from Sonobuoy (`plugins/e2e/results/global/e2e.log`) or you can use the `results` command to show details of +test failures. For example, the following commands retrieve the results tarball and then use [jq][jq] to return an +object for each test failure with the failure message and the associated stdout. + +``` +outfile=$(sonobuoy retrieve) && \ + sonobuoy results --mode detailed --plugin e2e $outfile | jq '. | select(.status == "failed") | .details' +``` + +Carefully read the test logs to see if anything stands out which could be the cause of the failure. For example: Were +there difficulties when contacting a particular service? Are there any commonalities in the failed tests due to a +particular feature? Often, the test logs will provide enough detail to allow you to determine why a test failed. + +If you need more information, Sonobuoy also queries the cluster upon completion of plugins. The details collected allow +you to see the state of the cluster and whether there were any issues. For example: Did any of the nodes have memory +pressure? Did the scheduler pod go down? + +As a final resort, you can also read the upstream test code to determine what actions were being performed at the point +when the test failed. If you decide to take this approach, you must ensure that you are reading the version of the test +code that corresponds to your test image. You can verify which version of the test image was used by inspecting the +plugin definition which is available in the results tarball in `plugins/e2e/definition.json` under the +key `Definition.spec.image`. For example, if the test image was `k8s.gcr.io/conformance:v1.15.3`, you should read the +code at the corresponding [v1.15.3 tag in GitHub][kubernetes-1.15.3]. All the tests can be found within the `test/e2e` +directory in the Kubernetes repository. + +### How can I run the E2E tests with certain test framework options set? What are the available options? + +How you provide options to the E2E test framework and determining which options you can set depends on which version of +Kubernetes you are testing. + +To view the available options that you can set when running the tests, you can run the test executable for the +conformance image you will be using as follows: + +``` +KUBE_VERSION= +docker run -it k8s.gcr.io/conformance:$KUBE_VERSION ./e2e.test --help +``` + +You can also view the definitions of these test framework flags in the [Kubernetes repository][framework-flags]. + +If you are running Kubernetes v1.16.0 or greater, a new feature was included in this release which makes it easier to +specify your own options. This new feature allows arbitrary options to be specified when the tests are invoked. To use +this, you must ensure the environment variable `E2E_USE_GO_RUNNER=true` is set. This is the default behavior from +Sonobuoy v0.16.1 in the CLI and only needs to be manually set if working with a Sonobuoy manifest generated by an +earlier version. If this is enabled, then you can provide your options with the flag `--plugin-env=e2e.E2E_EXTRA_ARGS`. +For example, the following allows you set provider specific flags for running on GCE: + +``` +sonobuoy run --plugin-env=e2e.E2E_USE_GO_RUNNER=true \ + --plugin-env=e2e.E2E_PROVIDER=gce \ + --plugin-env=e2e.E2E_EXTRA_ARGS="--gce-zone=foo --gce-region=bar" +``` + +Before this version, it was necessary to build your own custom image which could execute the tests with the desired +options. + +For details on the two different approaches that you can take, please refer to [our blog post][custom-e2e-image] which +describes in more detail how to use the new v1.16.0 Go test runner and how to build your own custom images. + +### Some of the registries required for the tests are blocked with my test infrastructure. Can I still run the tests? + +Yes! Sonobuoy can be configured to use custom registries so that you can run the tests in airgapped environments. + +For more information and details on how to configure your environment, please refer +to [our documentation for custom registries and air-gapped environments][airgap]. + +### We have some nodes with custom taints in our cluster and the tests won't start. How can I run the tests? + +Although Sonobuoy plugins can be adapted to use [custom Kubernetes PodSpecs][custom-podspecs] where tolerations for +custom taints can be specified, these settings do not apply to workloads started by the Kubernetes end-to-end testing +framework as part of running the `e2e` plugin. + +The end-to-end test framework checks the status of the cluster before beginning to run the tests. One of the checks that +it runs, is checking that all of the nodes are schedulable and ready to accept workloads. This check deems any nodes +with a taint other than the master node taint (`node-role.kubernetes.io/master`) to be unschedulable. This means that +any node with a different taint will not be considered ready for testing and will block the tests from starting. + +With the release of Kubernetes v1.17.0, you will be able to provide a list of allowed node taints so that any node with +an allowed taint will be deemed schedulable as part of the pre-test checks. This will ensure that these nodes will not +block the tests from starting. If you are running Kubernetes v1.17.0 or greater, you will be able to specify the taints +to allow using the flag `--non-blocking-taints` which takes a comma-separated list of taints. To find out how to set +this flag via Sonobuoy, please refer to our previous answer on how to set test framework options. + +This solution does not enable workloads created by the tests to run on these nodes. This is still +an [open issue in Kubernetes][support-custom-taints]. The workloads created by the end-to-end tests will continue to run +only on untainted nodes. + +For all versions of Kubernetes prior to v1.17.0, there are two approaches that you may be able to take to allow the +tests to run. + +The first is adjusting the number of nodes the test framework allows to be "not-ready". By default, the test framework +will wait for all nodes to be ready. However, if only a subset of your nodes are tainted and the rest are otherwise +suitable for accepting test workloads, you could provide the test framework flag `--allowed-not-ready-nodes` specifying +the number of tainted nodes you have. By setting this, the test framework will allow for your tainted nodes to be in a " +not-ready" state. This does not guarantee that your tests will start however as a node in your cluster may not be ready +for another reason. Also, this approach will only work if there are untainted nodes as some will still need to be +available for the tests to run on. + +The only other approach is to untaint the nodes for the purposes of testing. + +### What tests can I run? How can I figure out what tests/tags I can select? + +The `e2e` plugin has a number of preconfigured modes for running tests, with the default mode running all conformance +tests which are non-disruptive. It is possible to [configure the plugin][e2ePlugin] to provide a specific set of E2E +tests to run instead. + +Which tests you can run depends on the version of Kubernetes you are testing as the list of tests changes with each +release. + +A list of the conformance tests is maintained in the [Kubernetes repository][kubernetes-conformance]. Within the GitHub +UI, you can change the branch to the tag that matches your Kubernetes version to see all the tests for that version. +This list provides each test name as well where you can find the test in the repository. You can include these test +names in the `E2E_FOCUS` or `E2E_SKIP` environment variables when [running the plugin][e2ePlugin]. + +Although the default behavior is to run the Conformance tests, you can run any of the other Kubernetes E2E tests with +Sonobuoy. These are not required for checking that your cluster is conformant and we only recommend running these if +there is specific behavior you wish to check. + +There are a large number of E2E tests available (over 4000 as of v1.16.0). Many of these tests have "tags" which show +that they belong to a specific group, or have a particular trait. There isn't a definitive list of these tags, however +below are some of the most commonly seen tags: + +- Conformance +- NodeConformance +- Slow +- Serial +- Disruptive +- Flaky +- LinuxOnly +- Feature:* (there are numerous feature tags) + +There are also specific tags for tests that belong to a particular [Special Interest Group (SIG)][sig-list]. The +following SIG tags exist within the E2E tests: + +- [sig-api-machinery] +- [sig-apps] +- [sig-auth] +- [sig-autoscaling] +- [sig-cli] +- [sig-cloud-provider] +- [sig-cloud-provider-gcp] +- [sig-cluster-lifecycle] +- [sig-instrumentation] +- [sig-network] +- [sig-node] +- [sig-scheduling] +- [sig-service-catalog] +- [sig-storage] +- [sig-ui] +- [sig-windows] + +### The Sonobuoy aggregator wont start on my Windows node. Why not? + +When the Sonobuoy aggregator may land on a Windows node, you need to add the `--security-context-mode=none` flag when +invoking Sonobuoy. This is because Windows nodes currently do not support fields such as `runAsUser` which causes +problems for the pod when it starts up. The node tries to start the pod and `chown` certain files but that process +errors out on Windows, causing the pod to be unable to properly start up. + +[kubernetes-podspec]: https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.16/#podspec-v1-core + +[custom-e2e-image]: https://sonobuoy.io/custom-e2e-image/ + +[custom-podspecs]: https://sonobuoy.io/customizing-plugin-podspecs/ + +[sig-list]: https://github.com/kubernetes/community/blob/master/sig-list.md + +[jq]: https://stedolan.github.io/jq/ + +[kubernetes-1.15.3]: https://github.com/kubernetes/kubernetes/tree/v1.15.3 + +[kubernetes-conformance]: https://github.com/kubernetes/kubernetes/blob/master/test/conformance/testdata/conformance.yaml + +[airgap]: airgap.md + +[e2ePlugin]: e2eplugin.md + +[customPlugins]: plugins.md + +[support-custom-taints]: https://github.com/kubernetes/kubernetes/issues/83329 + +[framework-flags]: https://github.com/kubernetes/kubernetes/blob/master/test/e2e/framework/test_context.go + +[testsuiteblog]: https://sonobuoy.io/understanding-e2e-tests + +[sonobuoy-query]: sonobuoy-query.md + +### The information gathered on the cluster is useful for me, but do I have to run a plugin to obtain it? + +No, you can run the cluster queries via the command `sonobuoy query`. Read more details about it [here][sonobuoy-query]. diff --git a/site/content/docs/v0.56.12/gen.md b/site/content/docs/v0.56.12/gen.md new file mode 100644 index 000000000..a3958bbd0 --- /dev/null +++ b/site/content/docs/v0.56.12/gen.md @@ -0,0 +1,24 @@ +# Customization + +Sonobuoy provides many flags to customize your run but sometimes you have a special use case that isn't supported yet. For these cases, Sonobuoy provides `sonobuoy gen`. + +The command `sonobuoy gen` will print the YAML for your run to stdout instead of actually creating it. It accepts all of the relevant flags for customizing the run just like `sonobuoy run` would. You can then edit it yourself and apply it as if Sonobuoy had run it. + +Output the YAML Sonobuoy would create to a file: + +``` +sonobuoy gen --e2e-focus="sig-networking" --e2e-skip="Alpha" > sonobuoy.yaml +``` + +Then manually modify it as necessary. Maybe you need special options for plugins or want your own sidecar to be running with the images. + +Finally, create the resources yourself via kubectl. + +``` +sonobuoy run -f sonobuoy.yaml +``` + +> Note: If you find that you need this flow to accomplish your work, talk to us about it in our [Slack][slack] channel or file an [issue][issue] in Github. Others may have the same need and we'd love to help support you. + +[slack]: https://kubernetes.slack.com/messages/sonobuoy +[issue]: https://github.com/vmware-tanzu/sonobuoy/issues diff --git a/site/content/docs/v0.56.12/img/README.md b/site/content/docs/v0.56.12/img/README.md new file mode 100644 index 000000000..f44575760 --- /dev/null +++ b/site/content/docs/v0.56.12/img/README.md @@ -0,0 +1 @@ +Some of these diagrams (for instance sonobuoy-plugins.png), have been created on [draw.io](https://www.draw.io), using the "Include a copy of my diagram" option. If you want to make changes to these diagrams, try importing them into draw.io, and you should have access to the original shapes/text that went into the originals. diff --git a/site/content/docs/v0.56.12/img/plugin-contract.png b/site/content/docs/v0.56.12/img/plugin-contract.png new file mode 100755 index 000000000..d18ec66d2 Binary files /dev/null and b/site/content/docs/v0.56.12/img/plugin-contract.png differ diff --git a/site/content/docs/v0.56.12/img/scanner.png b/site/content/docs/v0.56.12/img/scanner.png new file mode 100644 index 000000000..e3c5ebd6d Binary files /dev/null and b/site/content/docs/v0.56.12/img/scanner.png differ diff --git a/site/content/docs/v0.56.12/img/snapshot-00-overview.png b/site/content/docs/v0.56.12/img/snapshot-00-overview.png new file mode 100644 index 000000000..379331dfb Binary files /dev/null and b/site/content/docs/v0.56.12/img/snapshot-00-overview.png differ diff --git a/site/content/docs/v0.56.12/img/snapshot-10-resources.png b/site/content/docs/v0.56.12/img/snapshot-10-resources.png new file mode 100644 index 000000000..c3c4ec24f Binary files /dev/null and b/site/content/docs/v0.56.12/img/snapshot-10-resources.png differ diff --git a/site/content/docs/v0.56.12/img/snapshot-20-hosts.png b/site/content/docs/v0.56.12/img/snapshot-20-hosts.png new file mode 100644 index 000000000..166f2a2a9 Binary files /dev/null and b/site/content/docs/v0.56.12/img/snapshot-20-hosts.png differ diff --git a/site/content/docs/v0.56.12/img/snapshot-30-podlogs.png b/site/content/docs/v0.56.12/img/snapshot-30-podlogs.png new file mode 100644 index 000000000..9de295723 Binary files /dev/null and b/site/content/docs/v0.56.12/img/snapshot-30-podlogs.png differ diff --git a/site/content/docs/v0.56.12/img/snapshot-40-plugins.png b/site/content/docs/v0.56.12/img/snapshot-40-plugins.png new file mode 100644 index 000000000..dd1b59169 Binary files /dev/null and b/site/content/docs/v0.56.12/img/snapshot-40-plugins.png differ diff --git a/site/content/docs/v0.56.12/img/snapshot-50-meta.png b/site/content/docs/v0.56.12/img/snapshot-50-meta.png new file mode 100644 index 000000000..efbb9be92 Binary files /dev/null and b/site/content/docs/v0.56.12/img/snapshot-50-meta.png differ diff --git a/site/content/docs/v0.56.12/img/sonobuoy-logo.png b/site/content/docs/v0.56.12/img/sonobuoy-logo.png new file mode 100644 index 000000000..edd5379b6 Binary files /dev/null and b/site/content/docs/v0.56.12/img/sonobuoy-logo.png differ diff --git a/site/content/docs/v0.56.12/img/sonobuoy-plugins.png b/site/content/docs/v0.56.12/img/sonobuoy-plugins.png new file mode 100644 index 000000000..0fcea8160 Binary files /dev/null and b/site/content/docs/v0.56.12/img/sonobuoy-plugins.png differ diff --git a/site/content/docs/v0.56.12/img/sonobuoy-query-1.png b/site/content/docs/v0.56.12/img/sonobuoy-query-1.png new file mode 100644 index 000000000..dd8ad24a4 Binary files /dev/null and b/site/content/docs/v0.56.12/img/sonobuoy-query-1.png differ diff --git a/site/content/docs/v0.56.12/img/sonobuoy-query-2.png b/site/content/docs/v0.56.12/img/sonobuoy-query-2.png new file mode 100644 index 000000000..1286a6311 Binary files /dev/null and b/site/content/docs/v0.56.12/img/sonobuoy-query-2.png differ diff --git a/site/content/docs/v0.56.12/index-frontmatter.yaml b/site/content/docs/v0.56.12/index-frontmatter.yaml new file mode 100644 index 000000000..6b8a51983 --- /dev/null +++ b/site/content/docs/v0.56.12/index-frontmatter.yaml @@ -0,0 +1,6 @@ +--- +version: v0.56.12 +cascade: + layout: docs + gh: https://github.com/vmware-tanzu/sonobuoy/tree/v0.56.12 +--- diff --git a/site/content/docs/v0.56.12/issue1388.md b/site/content/docs/v0.56.12/issue1388.md new file mode 100644 index 000000000..e5a6a2468 --- /dev/null +++ b/site/content/docs/v0.56.12/issue1388.md @@ -0,0 +1,25 @@ +# Issue Regarding Certified-Conformance Mode + +### Versions of Sonobuoy Impacted + - v0.53.0 + - v0.53.1 + +### Description + +When running `sonobuoy run --mode=certified-conformance` the `E2E_SKIP` value is not properly cleared, leading to `disruptive` tests being skipped. In certified-conformance mode, all tests must be run to be valid for submission to the CNCF so this bug would invalidate your results. + +### Work-around #1 + +You can manually work-around this issue by adding an extra flag at the end of your command: +``` +sonobuoy run --mode=certified-conformance --plugin-env e2e.E2E_SKIP +``` +This will set the focus value to conformance as expected and then remove the E2E_SKIP value. + +### Work-around #2 + +Use a patched version of Sonobuoy. After this bug was reported and patched, we released v0.53.2. + +### Original issue + +Thanks to [BobyMCbobs](https://github.com/BobyMCbobs) for reporting the original issue: https://github.com/vmware-tanzu/sonobuoy/issues/1388 \ No newline at end of file diff --git a/site/content/docs/v0.56.12/plugins.md b/site/content/docs/v0.56.12/plugins.md new file mode 100644 index 000000000..a0755a692 --- /dev/null +++ b/site/content/docs/v0.56.12/plugins.md @@ -0,0 +1,205 @@ +# Sonobuoy Plugins + +## Overview + +The main function of Sonobuoy is running plugins; each plugin may run tests or gather data in the cluster. + +When you first run Sonobuoy, an aggregator pod is created in the cluster which reads the configuration you've chosen and launches each plugin. + +The aggregator then waits for each plugin to report results back to it. If the plugin fails to launch correctly or does not report results within the timeout period, an error is recorded. + +Below are the useful resources to understand what plugins are and how they work, what plugins are available, +how you can customize them, and how you can build your own: + + - [Plugin Types](#plugin-types) + - [Built-in Plugins](#built-in-plugins) + - [Specifying Which Plugins To Run](#specifying-which-plugins-to-run) + - [How Plugins Work](#how-plugins-work) + - [Writing your own plugin](#writing-your-own-plugin) + - [Plugin Result Types](#plugin-result-types) + - [Customizing PodSpec options](#customizing-podspec-options) + - [Providing your own PodSpec](#providing-your-own-podspec) + - [Plugin Installation (Experimental Feature)](#plugin-installation-experimental-feature) + - [Existing Plugins][examplePlugins] + +## Plugin Types + +There are two types of plugins: + +* Job plugins + +Job plugins are plugins which only need to run once. The Sonobuoy aggregator will create a single pod for this type of plugin. The Kubernetes E2E plugin is a job-type plugin. + +* Daemonset plugins + +Daemonset plugins are plugins which need to run on every node, even control-plane nodes. The systemd-logs gatherer is a daemonset-type plugin. + +## Built-in Plugins + +Two plugins are included in the Sonobuoy source code by default: + +* Kubernetes end-to-end tests (the e2e plugin) + +The upstream Kubernetes repo contains the code for this [image][conformance]. The test image includes all the pieces necessary to run the end-to-end tests (which includes, but is not limited to, the conformance tests). This is the most common plugin run by Sonobuoy and can be tweaked in numerous ways to run the set of tests that you need. See more details about how to use this plugin [here][e2ePlugin]. + +* systemd-logs gathering plugin + +Gathers the latest system logs from each node, using systemd's `journalctl` command. The image this plugin uses is built from the [heptio/sonobuoy-plugin-systemd-logs][systemd-repo] repo. + +## Specifying Which Plugins To Run + +By default both the `e2e` and `systemd-logs` plugin are run. + +Otherwise, you can specify the plugins to run (including custom plugins) by using the `--plugin` flag. This can accept the path to a plugin defintion file or the name of a built-in plugin. For example: + +``` +# Run just the e2e plugin +$ sonobuoy run --plugin e2e + +# Run your custom plugin and the systemd-logs gatherer +$ sonobuoy run --plugin customPlugin.yaml --plugin systemd-logs +``` + +> Note: All of the CLI options impact the generated YAML. If you would like to edit the YAML directly or see the impact your options have on the YAML, use `sonobuoy gen `. + +## How Plugins Work + +A plugin consists of two parts: + +* the core logic which runs tests/gathers data (typically a single container) +* a sidecar added by Sonobuoy which reports the data back to the aggregator + +After your container completes its work, it needs to signal to Sonobuoy that +it's done by writing out the name of the results file into a "done file". The default +value is `/tmp/results/done`, which you can configure with the `ResultsDir` value +in the Sonobuoy config. + +The Sonobuoy sidecar waits for the `done` file to be present, then transmits the indicated +file back to the aggregator. + +![sonobuoy plugins diagram][diagram] + +[diagram]: /img/plugin-contract.png + +### Writing your own plugin + +Use the `sonobuoy gen plugin` command to help generate the YAML for your plugin definition. Once you've saved that YAML locally, you can run your plugin via: + +``` +sonobuoy run --plugin myPlugin.yaml +``` + +For a thorough walkthrough of how to build a custom plugin from scratch, see our [blog post][customPluginsBlog] and our [existing plugins][examplePlugins]. + +## Plugin Result Types + +When results get transmitted back to the aggregator, Sonobuoy inspects the results in order +to present results metadata to the end user such as the number of passed/failed tests or +the number of files gathered. + +This inspection process is informed by the YAML that described the plugin defintion. The +`result-type` field can be set to either `raw`, `junit`, `gojson`, or `manual`. + +When set to `junit`, Sonobuoy will look for XML files and process them as junit test results. + +When set to `gojson`, Sonobuoy will look for JSON files and process them as JSON output from `go test` [See details here.](https://golang.org/cmd/test2json/) + +When set to `raw`, Sonobuoy will simply inspect all the files and record the number of files generated. + +When set to `manual`, Sonobuoy will process files that use the Sonobuoy results metadata format. +This option allows you to specify your own results metadata directly, rather than having Sonobuoy generate it. +To use this option, the files to process must be specified directly in `result-files` array field in the plugin definition, or the plugin must write a `sonobuoy_results.yaml` file. +To find out more about using this format, see the [results][results] page. + +The data that Sonobuoy gathers during this step makes it possible for a user to do a few different tasks: + +* get high-level results without even downloading the results tarball via `sonobuoy status --json` +* get summary information about the run via `sonobuoy results $tarball` +* get detailed information about each test/file via `sonobuoy results $tarball --mode=detailed` + +To see more information about how Sonobuoy can process and present your results, see the [results][results] page and our previous [blog post][resultsBlog]. + +### Customizing PodSpec options + +By default, Sonobuoy will determine how to create and run the resources required for your plugin. +When creating your own plugins however, you may want additional control over how the plugin is run within your cluster. +To enable this, you can customize the [PodSpec][kubernetes-podspecs] used by Sonobuoy when creating the plugin's Pods or DaemonSets by supplying a `podSpec` object within your plugin defition. +The `podSpec` object corresponds directly to a Kubernetes [PodSpec][kubernetes-podspecs] so any fields that are available there can be set by your plugins. + +If a `podSpec` is provided, Sonobuoy will use it as is, only adding what is necessary for Sonobuoy to run your plugin (such as a Sonobuoy worker container). +Sonobuoy will only ever _add_ to your `podSpec` definition, it will not remove or override settings within it. +If you don't need to provide any additional settings, you can omit this object and Sonobuoy will use the defaults. + +#### Providing your own PodSpec +We recommend starting with the default `podSpec` used by Sonobuoy and then making any necessary modifications. +To view the default `podSpec`, you can use the flag `--show-default-podspec` with the `gen` and `gen plugin` commands. + +When creating a new plugin, you can include the default `podSpec` in the generated definition as follows: + +``` +sonobuoy gen plugin --show-default-podspec -n my-plugin -i my-plugin:latest +``` + +This will produce the following plugin definition: + +```yaml +podSpec: + containers: [] + restartPolicy: Never + serviceAccountName: sonobuoy-serviceaccount + tolerations: + - effect: NoSchedule + key: node-role.kubernetes.io/master + operator: Exists + - key: CriticalAddonsOnly + operator: Exists +sonobuoy-config: + driver: Job + plugin-name: my-plugin + result-type: my-plugin +spec: + command: + - ./run.sh + image: my-plugin:latest + name: plugin + resources: {} + volumeMounts: + - mountPath: /tmp/results + name: results +``` + +You are then free to make modifications to the `podSpec` object as necessary. + +If you already have an existing plugin which you would like to customize, you can take the default `podSpec`, add it to your plugin definition and use it as the basis for customization. + +> **NOTE:** The default `podSpec` differs for Job and DaemonSet plugins. +To be sure you are using the appropriate defaults as your starting point, be sure to provide the `--type` flag when using `sonobuoy gen plugin`. + +You can also modify the `podSpec` from within a Sonobuoy manifest. +By providing the flag `--show-default-podspec` to `sonobuoy gen`, the default `podSpec` for each plugin will be included within the `sonobuoy-plugins-cm` ConfigMap in the manifest. + +> **NOTE:** Modifications to the `podSpec` are only persisted within that generated manifest. +If you generate a new manifest by running `sonobuoy gen` again, you will need to reapply any changes made. +We recommend adding your desired customizations to the plugin definition itself. + +#### Plugin Installation (Experimental Feature) + +When you select which plugins to run, currently you have to specify a local file or a URL where the plugin definition exists. Keeping track of the absolute paths and URLs creates a burden to plugin adoption so we've implemented a new feature to help: plugin installation. + +To (enable)[featureGates], set `SONOBUOY_PLUGIN_INSTALLATION=true`. Then proceed to use Sonobuoy normally. With this new functionality you can install a plugin for repeated use by executing the commands: + +``` +$ sonobuoy plugin install myPlugin +$ sonobuoy run -p myPlugin +``` + +The plugin definition will be saved into ~/.sonobuoy (configurable via the environment variable `SONOBUOY_DIR`). If Sonobuoy can't find the plugin in the installation directory, it will search the pwd just like current behavior. + +[systemd-repo]: https://github.com/vmware-tanzu/sonobuoy-plugins/tree/main/systemd-logs +[conformance]: https://github.com/kubernetes/kubernetes/tree/master/test/conformance/image +[e2ePlugin]: e2eplugin.md +[kubernetes-podspecs]: https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.15/#podspec-v1-core +[customPluginsBlog]: https://blogs.vmware.com/cloudnative/2019/04/30/sonobuoy-plugins-custom-testing/ +[examplePlugins]: https://github.com/vmware-tanzu/sonobuoy-plugins +[results]: results.md +[resultsBlog]: https://sonobuoy.io/simplified-results-reporting-with-sonobuoy/ diff --git a/site/content/docs/v0.56.12/pullsecrets.md b/site/content/docs/v0.56.12/pullsecrets.md new file mode 100644 index 000000000..1659d00a9 --- /dev/null +++ b/site/content/docs/v0.56.12/pullsecrets.md @@ -0,0 +1,42 @@ +# Using a Private Sonobuoy Image with ImagePullSecrets + +This document describes how to use the ImagePullSecrets option in order to run Sonobuoy using a private Sonobuoy image. + +## Setting ImagePullSecrets + +The name of the secret to use when pulling the image can be set easily in the configuration file passed to `sonobuoy run` or `sonobuoy gen`: + +``` +echo '{"ImagePullSecrets":"mysecret"}' > secretconfig.json +sonobuoy gen --config secretconfig.json +``` + +Doing this properly passes the value and places it into the YAML for the Sonobuoy aggregator pod and all the pods for each plugin. + +## Creating the Secret + +The main complication for this flow is that secrets can only be referenced from within their own namespace. As a result we need to create the secret at the same time we create the initial resources. + +Sonobuoy does not have built in support for this, but it can be manually achieved via the following process: + - Manually create the YAML for the secret + - Insert the YAML into the output from `sonobuoy gen --config secretconfig.json` + - Run with `sonobuoy run -f ...` + +As an example of how to create the secret you can follow the instructions [here][dockersecret] in order to create a secret in the default namespace. + +Then get a copy of its YAML via: + +``` +kubectl get secret -o yaml > secret.json +``` + +Manually edit the file and remove/adjust the metadata as appropriate. The namespace should be adjusted to your desired Sonobuoy namespace (default: sonobuoy) and the following fields can be removed: + - annotations + - creationTimestamp + - resourceVersion + - selfLink + - uid + +Then just insert that YAML into the output from `sonobuoy gen` and run with `sonobuoy run -f ...` + +[dockersecret]: https://kubernetes.io/docs/tasks/configure-pod-container/pull-image-private-registry/ diff --git a/site/content/docs/v0.56.12/release.md b/site/content/docs/v0.56.12/release.md new file mode 100644 index 000000000..facda33ab --- /dev/null +++ b/site/content/docs/v0.56.12/release.md @@ -0,0 +1,121 @@ +# Release + +## Preparing release version + +1. Update the `version` defined in the code to the new version number. + As of the time of writing, the version is defined in `pkg/buildinfo/version.go`. + +## Kubernetes release +Is there a Kubernetes release since the last Sonobuoy release? If so, apply the following steps: + +### Conformance images +Ensure the upstream conformance script is working appropriately: + * Update the `kind-config.yaml` file with the new image version [here](https://github.com/vmware-tanzu/sonobuoy/blob/main/kind-config.yaml). + * Run conformance tests + +## Updating the versioned docs +Explicit doc changes (if any) should be made to the appropriate files in directory `site/docs/main`. + +Next, generate a set of versioned docs for v0.x.y. For instance, the new docs be generated by running the command: + +``` +./scripts/update_docs.sh v0.20.0 +``` + +This will copy the current `main` docs into the version given and update +a few of the links in the README to be correct. It will also update +the website config to add the new version and consider it the newest +version of the docs. + +## Create PR +1. Commit previous changes and open a new PR +2. Ensure your commits signed +3. Follow PR build progress in circleci.com +4. Once all checks passes, merge accordingly + +## Tag release +This step will tag the code and triggers a release. + +1. From your local branch, create an annotated `tag` for the commit that was merged: + + ``` + git tag -a v0.x.y -m "Release v0.x.y" + ``` + + > NOTE: Tag the new tip of `main`, not the branch you just merged. + +1. Push the `tag` to the [`github.com/vmware-tanzu/sonobuoy`](https://github.com/vmware-tanzu/sonobuoy/) repository. +2. To ensure that the tag is pushed to the correct repository, check which remote corresponds to that repository using the following command: + + ``` + git remote -v + ``` + The output of this command should include at least two configured remotes, typically `origin`, which refers to your personal fork, and `upstream` which refers to the upstream Sonobuoy repository. + For example: + + ``` + origin git@github.com:/sonobuoy.git (fetch) + origin git@github.com:/sonobuoy.git (push) + upstream https://github.com/vmware-tanzu/sonobuoy (fetch) + upstream https://github.com/vmware-tanzu/sonobuoy (push) + ``` + For the following steps, use the remote configured for the `vmware-tanzu/sonobuoy` repository. + The following instructions will use `upstream`. +1. Push the tag with the following command. + > NOTE: This will push all tags. + + ``` + git push upstream --tags + ``` + To push just one tag, use the following command format (replacing `v0.x.y` with the tag created in the previous step): + + ``` + git push upstream refs/tags/v0.x.y + ``` + If there is a problem and you need to remove the tag, run the following commands: + + ``` + git tag -d v0.x.y + git push upstream :refs/tags/v0.x.y + ``` + > NOTE: The `:` preceding the tag ref is necessary to delete the tag from the remote repository. + > Git refspecs have the format `<+>:`. + > By pushing an empty `src` to the remote `dst`, it makes the destination ref empty, effectively deleting it. + > For more details, see the [`git push` documentation](https://git-scm.com/docs/git-push) or [this concise explanation on Stack Overflow](https://stackoverflow.com/a/7303710). + + +## Release Validation +1. Open a browser tab and go to: https://https://github.com/vmware-tanzu/sonobuoy/actions and verify go releaser for tag v0.x.y completes successfully. +1. Upon successful completion of build job above, check the [releases tab of Sonobuoy](https://github.com/vmware-tanzu/sonobuoy/releases) and verify the artifacts and changelog were published correctly. +1. Run the following command to make sure the image was pushed correctly to [Docker Hub][dockerhub]: + + ``` + docker run -it sonobuoy/sonobuoy:v0.x.y /sonobuoy version + ``` + The `Sonobuoy Version` in the output should match the release tag above. +1. Go to the [GitHub release page](https://github.com/vmware-tanzu/sonobuoy/releases) and download the release binaries and make sure the version matches the expected values. +2. Run a [Kind](https://github.com/kubernetes-sigs/kind) cluster locally and ensure that you can run `sonobuoy run --mode quick`. + If this release corresponds to a new Kubernetes release as well, ensure: + + * you're using the correct Kubernetes context by checking the output from: + + ``` + kubectl config current-context + ``` + + and verifying that it is set to the context for the Kind cluster just created (`kind-kind` or `kind-`) + * you're testing with the new Kind images by checking the output from: + + ``` + kubectl version --short + ``` + + and verifying that the server version matches the intended Kubernetes version. + * you can run `sonobuoy images` and get a list of test images as expected +2. Update the release notes if desired on GitHub by editing the newly created release. + +### Notes +1. Before releasing, ensure all parties are available to resolve any issues that come up. If not, just bump the release. + +[gendocs]: #generating-a-new-set-of-versioned-docs +[dockerhub]: https://cloud.docker.com/u/sonobuoy/repository/docker/sonobuoy/sonobuoy/tags diff --git a/site/content/docs/v0.56.12/results.md b/site/content/docs/v0.56.12/results.md new file mode 100644 index 000000000..7e3423e73 --- /dev/null +++ b/site/content/docs/v0.56.12/results.md @@ -0,0 +1,169 @@ +# Viewing Plugin Results + +The `sonobuoy results` command can be used to print the results of a plugin without first having to extract the files from the tarball. + +## Canonical Data Format + +Plugin results undergo post-processing on the server to produce a tree-like file which contains information about the tests run (or files generated) by the plugin. This is the file which enables `sonobuoy results` to present reports to the user and navigate the tarball effectively. + +Currently, plugins are specified as either producing `junit` results (like the `e2e` plugin), `raw` results (like the `systemd-logs` plugin), or you can specify your own results file in the format used by Sonobuoy by specifying the option `manual`. + +To see this file directly you can either open the tarball and look for `plugins//sonobuoy_results.yaml` or run: + +``` +sonobuoy results $tarball --mode=dump +``` + +## Working with any Plugin + +By default, the command produces a human-readable report corresponding to the `e2e` plugin. However, you can specify other plugins by name. For example: + +``` +$ sonobuoy results $tarball --plugin systemd-logs +Plugin: systemd-logs +Status: passed +Total: 1 +Passed: 1 +Failed: 0 +Skipped: 0 +``` + +> In the above output, notice that even though the `systemd-logs` plugin doesn't run "tests" per se, each file produced by the plugin is reported on: a readable file is reported as a success. + +## Detailed Results + +If you would like to view or script around the individual tests/files, use the `--mode detailed` flag. In the case of junit tests, it will write a list of json objects which can be piped to other commands or saved to another file. + +To see the passed tests, one approach would be: + +``` +$ sonobuoy results $tarball --mode=detailed | jq 'select(.status=="passed")' +``` + +To list the conformance tests, one approach would be: + +``` +$ sonobuoy results $tarball --mode=detailed|jq 'select(.name | contains("[Conformance]"))' +``` + +When dealing with non-junit plugins, the `--mode detailed` results will print the file output with a prefix that reports on the nature/location of the file: + +``` +$ sonobuoy results $tarball --mode=detailed --plugin systemd-logs|head -n1 +systemd-logs|kind-control-plane|systemd_logs {"_HOSTNAME":"kind-control-plane",...} +``` + +The prefix is telling you that this result came from the "systemd-logs" plugin, was from the "kind-control-plane" node, and the filename was "systemd_logs". + +If you had multiple nodes, you could look at just one by adding the `--node` flag. It walks the result tree and will return only results rooted from the given node: + +``` +$ sonobuoy results $tarball --mode=detailed --plugin systemd-logs --node=kind-control-plane|head -n1 +kind-control-plane|systemd_logs {"_HOSTNAME":"kind-control-plane",...} +``` + +Now if you wanted to script around the actual file output (in this case it is json), you wouldn't want to keep that prefix around. Just add the `--skip-prefix` flag to get only the raw file output so that you can manipulate it easily: + +``` +$ sonobuoy results $tarball --mode=detailed --plugin systemd-logs --node=kind-control-plane --skip-prefix|head -n1|jq .MESSAGE +{"_HOSTNAME":"kind-control-plane",...} +``` + +## Providing results manually + +When creating a plugin, you can choose to have your plugin write its results in the same format as the Sonobuoy results metadata. +This allows you to take advantage of the `sonobuoy results` workflow even if your plugin doesn't produce output in one of the other supported formats. + +When using this option, Sonobuoy will process files in the Sonobuoy result format and perform any necessary aggregation to produce a single report for your plugin. +How these results are aggregated depends on how many result files your plugin produces and whether or not the plugin is a `Job` or `DaemonSet` plugin. + +To use this feature, you must set the `result-type` to `manual` in the plugin definition. +When gathering the results files to aggregate, Sonobuoy will look for files listed in the `result-files` array entry in the plugin definition, or if no files are provided, it will look for a `sonobuoy_results.yaml` file in the results directory. +When using this mode, any files written to the results directory will still be available in the results tarball however only the plugin `result-files` or the `sonobuoy_results.yaml` file will be used when generating the results metadata. + +The following is an example of a plugin definition using manual results: + +```yaml +sonobuoy-config: + driver: Job + plugin-name: manual-results-plugin + result-format: manual + result-files: + - manual-results-1.yaml + - manual-results-2.yaml +spec: + command: + - ./run.sh + image: custom-image:latest + name: plugin + resources: {} + volumeMounts: + - mountPath: /tmp/results + name: results +``` + +### Manual results format + +The format for manual results is the same as the format used by Sonobuoy when writing its results metadata. +It is a tree-like recursive data structure, where child nodes are the same type as the parent node, allowing nesting of items. +The definition for this format can be found [here](https://github.com/vmware-tanzu/sonobuoy/blob/v0.18.0/pkg/client/results/processing.go#L91-L100). + +Each result `item` comprises: + + * `name`: string + * `status`: string + * `meta`: map of string to string + * `details`: map of string to interface{} + * `items`: array of `item` + +An example of this format is given below: + +```yaml +name: manual-results-plugin +status: custom-status +meta: + type: summary +items: +- name: Manual test suite + status: complete + items: + - name: Manual test + status: custom-status-1 + details: + stdout: "stdout from the test" + messages: + - message from the test + - another message + - name: Another manual test + status: custom-status-2 + details: + stderr: "stderr from the test" +``` + +The format is flexible, with no restrictions on the values used for each of the fields. + +### Manual results aggregation + +Sonobuoy will aggregate the results from any manual results files that it processes. +Like other plugins, it will aggregate all the results that it processes into a single results metadata file. + +Each manual result file processed by Sonobuoy will be collected to form the `items` entry in the aggregated results file. +In the case of a `DaemonSet` plugin, any manual result files will be grouped by the node from which they were retrieved. + +The aggregated `status` for a plugin will be based on the `status` reported within each manual result file. +In the case where the same status is found across all result files, that will be the reported status for the plugin. +Where a plugin produces multiple results files and multiple different statuses are reported, the aggregate `status` for the plugin will be the `status` from each file grouped by count into a single human readable format. +It will take the form of `status: count, status: count, ...`. +For `DaemonSet` plugins, where results files will be generated for each node, the status will be aggregated for each node in addition to the overall summary level. + +## Summary + + - `sonobuoy results` can show you results of a plugin without extracting the tarball + - Plugins are either `junit`, `gojson`, `raw` or `manual` type currently + - When viewing `junit` results, json data is dumped for each test + - When viewing `gojson` results, json data is dumped for each test + - When viewing `raw` results, file contents are dumped directly + - When viewing `manual` results, results are included as provided by the plugin + - Use the `--mode` flag to see either report, detail, or dump level data + - Use the `--node` flag to view results rooted at a different location + - Use the `--skip-prefix` flag to print only file output diff --git a/site/content/docs/v0.56.12/snapshot.md b/site/content/docs/v0.56.12/snapshot.md new file mode 100644 index 000000000..c904f1fad --- /dev/null +++ b/site/content/docs/v0.56.12/snapshot.md @@ -0,0 +1,131 @@ +# Sonobuoy Snapshot Layout + +- [Retrieving results](#retrieving-results) +- [Filename](#filename) +- [Contents](#contents) + - [/hosts](#hosts) + - [/meta](#meta) + - [/plugins](#plugins) + - [/podlogs](#podlogs) + - [/resources](#resources) + - [/servergroups.json](#servergroups.json) + - [/serverversion.json](#serverversionjson) + +This document describes retrieving the Sonobuoy results tarball, its layout, how it is formatted, and how data is named and laid out. + +## Retrieving results + +To view the output, copy the output directory from the aggregator Sonobuoy pod to +your local machine (and save the name of the file to a variable for reference): + +``` +output=$(sonobuoy retrieve) +``` + +The results of plugins can be inspected without being extracted. By default, it will give you a human-readable report about the tests but also has options to list detailed information and even print raw files generated by the plugin. See the [results page][results] for more details. + +``` +sonobuoy results $output [--plugin ] [--mode report|detailed|dump] +``` + +You can also extract the output locally so that you can view the other +information Sonobuoy gathered as well: + - detailed plugin results + - pod logs + - query results about the contents/state of your cluster + +``` +$ sonobuoy retrieve --extract + +OR + +$ output=$(sonobuoy retrieve --extract) +$ mkdir ./results; tar xzf $output -C ./results +``` + +## Filename + +A Sonobuoy snapshot is a gzipped tarball, named `YYYYmmDDHHMM_sonobuoy_.tar.gz`. + +where YYYYmmDDHHMM is a timestamp containing the year, month, day, hour, and minute of the run. The `` string is an RFC4122 UUID, consisting of lowercase hexadecimal characters and dashes (e.g. "dfe30ebc-f635-42f4-9608-8abcd6311916"). This UUID should match the UUID from the snapshot's [meta/config.json][1], stored at the root of the tarball. + +## Contents + +The top-level directories in the results tarball look like this: + +![tarball overview screenshot][3] + +### /hosts + +The `/hosts` directory contains the information gathered about each host in the system by directly querying their HTTP endpoints. +This is different from what you find in `/resources/cluster/Nodes.json` -- it contains items that aren't part of the Kubernetes API objects: + +- `/hosts//configz.json` - Contains the output of querying the `/configz` endpoint for this host -- that is, the component configuration for the host. +- `/hosts//healthz.json` - Contains a json-formatted representation of the result of querying `/healthz` for this host, for example `{"status":200}` + +This looks like the following: + +![tarball hosts screenshot][5] + +### /meta + +The `/meta` directory contains metadata about this Sonobuoy run, including configuration and query runtime. + +- `/meta/query-time.json` - Contains metadata about how long each query took, example: `{"queryobj":"Pods","time":12.345ms"}` +- `/meta/config.json` - A copy of the Sonobuoy configuration that was set up when this run was created, but with unspecified values filled in with explicit defaults, and with a `UUID` field in the root JSON, set to a randomly generated UUID created for that Sonobuoy run. + +This looks like the following: + +![tarball meta screenshot][8] + +### /plugins + +The `/plugins` directory contains output for each plugin selected for this Sonobuoy run: + +- `/plugins//results/` - For plugins that run on an arbitrary node to collect cluster-wide data, for example using the Job driver. Contains the results for the plugin. + +- `/plugins//results//` - For plugins that run once on every node to collect node-specific data, for example using the DaemonSet driver. Contains the results for the plugin, for each node. + +- `/plugins//sonobuoy_results.yaml` - A file generated by the server by post-processing the plugin results. This is the file that `sonobuoy results` relies on. + +This looks like the following: + +![tarball plugins screenshot][7] + +### /podlogs + +The `/podlogs` directory contains logs for each pod found during the Sonobuoy run, similar to what you get with `kubectl logs -n `. + +- `/podlogs///.log` - Contains the logs for each container, for each pod in each namespace. + +This looks like the following: + +![tarball podlogs screenshot][6] + +### /resources + +The `/resources` directory lists JSON-serialized Kubernetes objects, taken from querying the Kubernetes REST API. The directory has the following structure: + +- `/resources/ns//.json` - For all resources that belong to a namespace, where `` is the namespace of that resource (eg. `kube-system`), and `` is the type of resource, pluralized (eg. `Pods`). +- `/resources/cluster/.json` - For all resources that don't belong to a namespace, where `` is the type of resource, pluralized (eg. `Nodes`). + +This looks like the following: + +![tarball resources screenshot][4] + +### /servergroups.json + +`/servergroups.json` lists the Kubernetes APIs that the cluster supports. + +### /serverversion.json + +`/serverversion.json` contains the output from querying the server's version, including the major and minor version, git commit, etc. + +[1]: #meta +[3]: /img/snapshot-00-overview.png +[4]: /img/snapshot-10-resources.png +[5]: /img/snapshot-20-hosts.png +[6]: /img/snapshot-30-podlogs.png +[7]: /img/snapshot-40-plugins.png +[8]: /img/snapshot-50-meta.png +[results]: results.md diff --git a/site/content/docs/v0.56.12/sonobuoy-config.md b/site/content/docs/v0.56.12/sonobuoy-config.md new file mode 100644 index 000000000..dc4d2d1c7 --- /dev/null +++ b/site/content/docs/v0.56.12/sonobuoy-config.md @@ -0,0 +1,86 @@ +# Sonobuoy Config + +The commands "run" and "gen" both accept a parameter for a Sonobuoy config file which allows you to customize multiple aspects of the run. + +We've provided a command to generate the JSON file necessary so that it is easier to edit for your runs. Run the command: + +``` +sonobuoy gen config +``` + +and you will see the default configuration. Below is a description of each of the values. + +## General options + +`Description`: A string which provides consumers a way to add extra context to a configuration that may be in memory or saved to disk. Unused by Sonobuoy itself. + +`UUID`: A unique identifier used to identify the run of this configuration. Used in a few places including the name of the results file. + +`Namespace`: The namespace in which to run Sonobuoy. + +`WorkerImage`: The image for the Sonobuoy worker container which runs as a sidecar along the plugins. Responsible for reporting results back to the Sonobuoy aggregator. + +`ImagePullPolicy`: The image pull policy to set on the Sonobuoy worker sidecars as well as each of the plugins. + +`ResultsDir`: The location on the Sonobuoy aggregator where the results are placed. + +`Version`: The version of Sonobuoy which created the configuration file. + + +## Plugin options + +`Plugins`: An array of plugin selection objects of the plugins you want to run. When running custom plugins (or avoiding running a particular plugin) this value needs modified. + +`PluginSearchPath`: The aggregator pod looks for plugin configurations in these locations. You shouldn't need to edit this unless you are doing development work on the aggregator itself. + +## Query options + +`Resources`: A list of resources which Sonobuoy will query for in every namespace in which it runs queries. In the namespace in which Sonobuoy is running, `PodLogs`, `Events`, and `HorizontalPodAutoscalers` are also added. + +`Filters`: Options for filtering which resources queries should be run against. + + * `Namespace`: A regexp which specifies which namespaces to run queries against. + * `LabelSelector`: A Kubernetes [label selector][labelselector] which will be added to every query run. + +`Limits`: Options for limiting the scope of response. + + * `PodLogs`: limits the scope when getting logs from pods. The supported parameters are: + + * `Namespaces`: string + + * A regular expression for the targeted namespaces. + * Default is empty string + * To get logs from all namespaces use ".*" + * `SonobuoyNamespace`: bool + + * If set to true, get pod logs from the namespace Sonobuoy is running in. Can be set along with a `Namespaces` field or on its own. + * Default value is true + * `FieldSelectors`: []string + + * A list of field selectors, with OR logic. + For example, to get logs from two specified namespaces `FieldSelectors = ["metadata.namespace=default","metadata.namespace=heptio-sonobuoy"]` + * Each field selector contains one or more chained operators, with AND logic + For example, to get logs from a specified pod `FieldSelectors = ["metadata.namespace=default,metadata.name=pod1"]` + * Each field selector follows the same format as a [Kubernetes Field Selector][fieldselector]. + * Can be set along with the `Namespaces` or `SonobuoyNamespace` field or on its own. + * `LabelSelector`: string + + * Filters candidate pods by their labels, using the same format as a [Kubernetes Label Selector][labelselector]. + For example: `LabelSelector = "app=nginx,layer in (frontend, backend)"` + * When set together with other fields, the scope of pods is defined by: + ``` + (Namespaces OR SonobuoyNamespace OR FieldSelectors) AND LabelSelector + ``` + + * For each candidate pod, the format and size of logs are defined by other fields. These will be passed onto Kubernetes [PodLogOptions][podlogopts]: + * `Previous`: bool + * `SinceSeconds`: int + * `SinceTime`: string. RFC3339 format. + * `Timestamps`: bool + * `TailLines`: int + * `LimitBytes`: int + + +[fieldselector]: https://kubernetes.io/docs/concepts/overview/working-with-objects/field-selectors/ +[labelselector]: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/ +[podlogopts]: https://godoc.org/k8s.io/api/core/v1#PodLogOptions diff --git a/site/content/docs/v0.56.12/sonobuoy-query.md b/site/content/docs/v0.56.12/sonobuoy-query.md new file mode 100644 index 000000000..09ab40cf4 --- /dev/null +++ b/site/content/docs/v0.56.12/sonobuoy-query.md @@ -0,0 +1,20 @@ +# `sonobuoy query` command + +## Intro + +`sonobuoy query` command runs queries against your cluster and helps in debugging by providing useful information about the cluster which helps us to find bugs and fix them before they can cause any severe harm to the cluster. These queries were run from the aggregator pod (made through `sonobuoy run`) in the past. Now you can run them locally without running Sonobuoy or launching pods. Just run sonobuoy query which is much faster and convenient. + +![sonobuoy query](img/sonobuoy-query-1.png) + +- The logs are generated via logrus (https://github.com/sirupsen/logrus), which contains three parts + `time, level, msg`. + +- `msg` provides information about the cluster which helps us to find bugs in our clusters and tackle them. + +- `level` specifies log level. We can specify it via the level flag and valid values are `{panic, fatal, error, warn, info, debug, trace}` and the default is `info`. + + ![sonobuoy query --level panic](img/sonobuoy-query-2.png) + +- By default, Sonobuoy uses creates a temporary directory in the current directory to store the query information. You can capture this directory for scripting (its the only value output to stdout) or you can specify your own directory via the `--output` flag. + +- While logging we can also specify **sonobuoy config file** in order to specify query configuration values. This allows you to tweak things like which namespaces to get pod logs for or what API resources to query. In most cases, the default is appropriate (gets logs for kube-system and queries all non-secret resources). diff --git a/site/content/docs/v0.56.12/strategy.md b/site/content/docs/v0.56.12/strategy.md new file mode 100644 index 000000000..8e81df285 --- /dev/null +++ b/site/content/docs/v0.56.12/strategy.md @@ -0,0 +1,38 @@ +# Sonobuoy Strategy + +## The problem +Users of Kubernetes value its ability to automate running complex systems at scale. However, little Kubernetes cluster validation is automated. As a result, skilled Kubernetes operators spend needless time performing manual tasks. Just as automated unit tests frontload the work of testing software by having the developer codify how to check that their code is functional, Kubernetes would benefit from automated test suites that allow skilled Kubernetes operators and developers to codify once how to test cluster capabilities and then have those checks run by whichever Kubernetes user needs this. + +Examples: + - Kubernetes experts still perform many manual tasks: + - A security auditor works with a Kubernetes expert to determine whether a Kubernetes cluster is CIS compliant. + - After a Kubernetes cluster is restored, the backup admin spends time running manual tests to confirm the cluster is functional. + - A support engineer manually checks different areas of functionality to diagnose an Kubernetes cluster issue while on a Zoom call with a customer. + - To install developer tooling, for example a cloud native runtime like Knative, a Kubernetes expert from the platform team is needed to validate that the user has the required installation privileges. + - A Kubernetes distribution vendor needs to validate their software is installed properly on a new cloud or hardware so they can provide support. + +Worse, these steps may be skipped, leading to wasted time, technical debt, or even risk of operational failure: + + - The CIS audit is skipped, leaving security vulnerabilties in the Kubernetes cluster. + - The backup admin doesn’t check the restored cluster and only realizes later through user-reported bugs that the container registry didn’t correctly re-attach to its S3 image store. + - The support engineer tries reading logs to diagnose the problem, but because of the complexity of the issue, the logs lead in the wrong direction. + - The platform operator installing the developer tooling (Cloud Native Runtime) doesn’t know how to check if the Kuberentes cluster has a load balancer, so they either spend significant extra time researching how to check this or skip the step, but then encounter myriad problems later when the tooling doesn’t install correctly. + - A Kubernetes distribution vendor only performs manual smoke tests on a new cloud or hardware. Later, strange issues that are unique to the new cloud or hardware arise that could have been caught earlier. + +## Who would benefit from solving this problem? + - Users of these automated test suites reduce risk to the business, since alternatives are to use less reliable manual testing or skipping such testing altogether. Users also potentially save time, and thus money, that would have been spent in manual testing. + - Skilled Kubernetes operators can spend their time on innovative work that only they can do, rather than repetitive manual checks. This, of course can translate into increased revenue or decreased costs for their organization through prioritization of experts’ time. + - Organizations can more reliably get started with Kubernetes, given the existence of automated validation checks alongside their deployment and operation processes. In this way, they can slowly grow their platform teams to have Kuberentes knowledge, rather than having to make a big up front investment in operators skilled in Kubernetes. + +## The solution +A tool exists that solves this exact problem. Sonobuoy, well-known in the Kubernetes community as the CNCF-recommended way to run the Kubernetes conformance tests, has an underused pluggable architecture that allows users to build automated test suites and run them in Kubernetes clusters. Teams can use the Sonobuoy plugin skeleton to easily and quickly create customized test suites that suit their and other users’ needs. + +## Call to Action + +Please help us increase the number of Sonobuoy use cases! +The Sonobuoy team has started pairing with teams, to help them develop the suites they need. +While teams can indeed create the suites themselves, we want to understand users of the plugin skeleton so we can better encourage adoption. +We are learning about each teams' use cases and how to make it as easy as possible to create and run Sonobuoy customized test suites. +Once we have several functional, often-used test suites, we will explore ways to organically grow the number of teams and Kubernetes users using this Sonobuoy feature, such as promoting this Sonobuoy feature to the larger Kubernetes community. + +Be in touch if you are using Sonobuoy beyond conformance testing - we want to learn more. And we will do our best to help you if you are brainstorming a new, creative application of Sonobuoy's automated cluster validation. diff --git a/site/data/docs/toc-mapping.yml b/site/data/docs/toc-mapping.yml index 434bd6e94..b83aefe38 100644 --- a/site/data/docs/toc-mapping.yml +++ b/site/data/docs/toc-mapping.yml @@ -5,6 +5,7 @@ # Below is a commented out example of what this may look like: main: main-toc +v0.56.12: v0-56-12toc v0.56.11: v0-56-11toc v0.56.10: v0-56-10toc v0.56.9: v0-56-9toc diff --git a/site/data/docs/v0-56-12toc.yml b/site/data/docs/v0-56-12toc.yml new file mode 100644 index 000000000..70fe50e0a --- /dev/null +++ b/site/data/docs/v0-56-12toc.yml @@ -0,0 +1,34 @@ +toc: + - title: Basics + subfolderitems: + - page: Overview + url: /index.html + - page: Checking Results + url: /results + - page: CLI Documentation + url: /cli/sonobuoy + - title: Plugins + subfolderitems: + - page: Overview + url: /plugins + - page: E2E & Conformance + url: /e2eplugin + - page: Examples + url: https://github.com/vmware-tanzu/sonobuoy-plugins/ + absolute: true + - title: Advanced + subfolderitems: + - page: Detailed result contents + url: /snapshot + - page: Configuration Options + url: /sonobuoy-config + - page: Custom Registries & Airgap Testing + url: /airgap + - page: Using Private Images + url: /pullsecrets + - page: Advanced Customization + url: /gen + - title: Resources + subfolderitems: + - page: Frequently Asked Questions + url: /faq diff --git a/test/integration/sonobuoy_integration_test.go b/test/integration/sonobuoy_integration_test.go index ef5b10314..a31ea1c88 100644 --- a/test/integration/sonobuoy_integration_test.go +++ b/test/integration/sonobuoy_integration_test.go @@ -8,7 +8,6 @@ import ( "context" "flag" "fmt" - "io/ioutil" "os" "os/exec" "path/filepath" @@ -176,7 +175,7 @@ func TestUseNamespaceFromManifest(t *testing.T) { genStdout := mustRunSonobuoyCommandWithContext(ctx, t, ns, genArgs) // Write the contents of gen to a temp file - tmpfile, err := ioutil.TempFile("", "gen.*.yaml") + tmpfile, err := os.CreateTemp("", "gen.*.yaml") if err != nil { t.Fatal(err) } @@ -268,7 +267,7 @@ func TestRetrieveAndExtractWithPodLogs(t *testing.T) { mustRunSonobuoyCommandWithContext(ctx, t, ns, args) // Create tmpdir and extract contents into it - tmpdir, err := ioutil.TempDir("", "TestRetrieveAndExtract") + tmpdir, err := os.MkdirTemp("", "TestRetrieveAndExtract") if err != nil { t.Fatal("Failed to create tmp dir") } @@ -394,12 +393,12 @@ func TestQuickLegacyFix(t *testing.T) { defer cleanup(true) // Get and modify data so it targets the right sonobuoy image and namespace. - runData, err := ioutil.ReadFile("./testdata/issue1688.yaml") + runData, err := os.ReadFile("./testdata/issue1688.yaml") if err != nil { t.Fatalf("Failed to read run data file: %v", err) } - tmpfile, err := ioutil.TempFile("", "") + tmpfile, err := os.CreateTemp("", "") if err != nil { t.Fatalf("Failed to create necessary tmpfile: %v", err) } @@ -684,7 +683,7 @@ func TestMain(m *testing.M) { fmt.Printf("Using kubectl CLI at %q\n", kubectl) // Creating so we get a clean location for HOME; important due to the plugin cache logic. - testHome, err = ioutil.TempDir("", "sonobuoy_int_test_home_*") + testHome, err = os.MkdirTemp("", "sonobuoy_int_test_home_*") if err != nil { fmt.Printf("Failed to create tmp dir home: %v", err) os.Exit(1) @@ -998,7 +997,7 @@ func TestPluginComplexCmds_LocalGolden(t *testing.T) { for _, tc := range testCases { t.Run(tc.desc, func(t *testing.T) { - tmpDir, err := ioutil.TempDir("", "sonobuoy_plugin_test_*") + tmpDir, err := os.MkdirTemp("", "sonobuoy_plugin_test_*") if err != nil { t.Fatal("Failed to create tmp dir") } @@ -1031,7 +1030,7 @@ func TestPluginLoading_LocalGolden(t *testing.T) { installedPluginFile := "./testdata/plugin-loading-installed.golden" localPluginFile := "./testdata/plugin-loading-local.golden" - tmpDir, err := ioutil.TempDir("", "sonobuoy_plugin_test_*") + tmpDir, err := os.MkdirTemp("", "sonobuoy_plugin_test_*") if err != nil { t.Fatalf("Failed to create tmp dir home: %v", err) } @@ -1055,13 +1054,13 @@ func TestPluginLoading_LocalGolden(t *testing.T) { } // Copy file to pwd - input, err := ioutil.ReadFile("./testdata/plugins/good/hello-world.yaml") + input, err := os.ReadFile("./testdata/plugins/good/hello-world.yaml") if err != nil { t.Fatalf("Failed to read plugin to test pwd loading") } // Create difference between local/installed plugin so we can differentiate them. - err = ioutil.WriteFile("hello-world.yaml", bytes.Replace(input, []byte("foo.com"), []byte("localfile.com"), -1), 0644) + err = os.WriteFile("hello-world.yaml", bytes.Replace(input, []byte("foo.com"), []byte("localfile.com"), -1), 0644) if err != nil { t.Fatalf("Failed to copy hello-world to pwd: %v", err) } @@ -1106,7 +1105,7 @@ func checkFileMatchesOrUpdate(t *testing.T, output, expectFile, maskDir string) t.Fatalf("Failed to update goldenfile: %v", err) } } else { - fileData, err := ioutil.ReadFile(expectFile) + fileData, err := os.ReadFile(expectFile) if err != nil { t.Fatalf("Failed to read golden file %v: %v", expectFile, err) } diff --git a/test/integration/testImage/Dockerfile b/test/integration/testImage/Dockerfile index 3b62cdea3..3d010ae19 100644 --- a/test/integration/testImage/Dockerfile +++ b/test/integration/testImage/Dockerfile @@ -12,7 +12,7 @@ # See the License for the specific language governing permissions and # limitations under the License. -FROM golang:1.18 AS base +FROM golang:1.19 AS base WORKDIR /src # Handle the go modules first to take advantage of Docker cache. diff --git a/test/integration/testImage/src/go.mod b/test/integration/testImage/src/go.mod index d8d4bf183..6d699bbbc 100644 --- a/test/integration/testImage/src/go.mod +++ b/test/integration/testImage/src/go.mod @@ -1,8 +1,13 @@ module github.com/vmware-tanzu/sonobuoy/test/integration/testImage/src -go 1.14 +go 1.19 require ( github.com/pkg/errors v0.8.1 github.com/spf13/cobra v0.0.5 ) + +require ( + github.com/inconshreveable/mousetrap v1.0.0 // indirect + github.com/spf13/pflag v1.0.3 // indirect +) diff --git a/test/integration/testImage/src/singleFileResults.go b/test/integration/testImage/src/singleFileResults.go index aefbacd3f..1eecf5b8a 100644 --- a/test/integration/testImage/src/singleFileResults.go +++ b/test/integration/testImage/src/singleFileResults.go @@ -18,7 +18,6 @@ package main import ( "fmt" - "io/ioutil" "os" "path/filepath" @@ -56,6 +55,6 @@ func reportSingleFile(cmd *cobra.Command, args []string) error { resultsFile = doneContents } - err := ioutil.WriteFile(doneFile, []byte(resultsFile), os.FileMode(0666)) + err := os.WriteFile(doneFile, []byte(resultsFile), os.FileMode(0666)) return errors.Wrap(err, "failed to write to done file") } diff --git a/test/integration/testImage/src/tarResults.go b/test/integration/testImage/src/tarResults.go index 47f0c2112..5e5b0c40a 100644 --- a/test/integration/testImage/src/tarResults.go +++ b/test/integration/testImage/src/tarResults.go @@ -21,7 +21,6 @@ import ( "compress/gzip" "fmt" "io" - "io/ioutil" "os" "path" "path/filepath" @@ -40,7 +39,7 @@ var cmdTarFile = &cobra.Command{ func reportTarFile(cmd *cobra.Command, args []string) error { tmpDir := os.TempDir() - outPath, err := ioutil.TempDir(tmpDir, "sonobuoy-integration") + outPath, err := os.MkdirTemp(tmpDir, "sonobuoy-integration") if err != nil { return errors.Wrapf(err, "failed to create outPath dir %v", outPath) } @@ -71,7 +70,7 @@ func reportTarFile(cmd *cobra.Command, args []string) error { } // Report location to Sonobuoy. - err = ioutil.WriteFile(doneFile, []byte(tb), os.FileMode(0666)) + err = os.WriteFile(doneFile, []byte(tb), os.FileMode(0666)) return errors.Wrap(err, "failed to write to done file") } diff --git a/test/integration/testdata/issue1688.yaml b/test/integration/testdata/issue1688.yaml index 901038252..c74d0d3a0 100644 --- a/test/integration/testdata/issue1688.yaml +++ b/test/integration/testdata/issue1688.yaml @@ -177,4 +177,4 @@ spec: targetPort: 8080 selector: sonobuoy-component: aggregator - type: ClusterIP \ No newline at end of file + type: ClusterIP diff --git a/test/stress/stress_test.go b/test/stress/stress_test.go index 848ce897d..875304794 100644 --- a/test/stress/stress_test.go +++ b/test/stress/stress_test.go @@ -22,7 +22,6 @@ package stress import ( "bytes" "io" - "io/ioutil" "net/http" "os" "strconv" @@ -41,7 +40,7 @@ var bindAddr = ":8080" func TestStress(t *testing.T) { // Create temp dir for results - dir, err := ioutil.TempDir("", "sonobuoy_server_test") + dir, err := os.MkdirTemp("", "sonobuoy_server_test") if err != nil { t.Fatal("Could not create temp directory") }