kubernetes/test/e2e
Kubernetes Prow Robot d4d9f7deee
Merge pull request #119489 from carlory/cleanup-e2e-common-framework-equal
e2e_common: stop using deprecated framework.ExpectEqual
2023-08-17 03:25:22 -07:00
..
apimachinery Merge pull request #119654 from p0lyn0mial/upstream-watch-list-e2e-panic 2023-08-16 09:32:46 -07:00
apps cleanup: Update deprecated FromInt to FromInt32 (#119858) 2023-08-16 09:33:01 -07:00
architecture e2e tests: set all PSa labels instead of just enforcing 2023-06-21 15:05:13 +02:00
auth e2e tests: set all PSa labels instead of just enforcing 2023-06-21 15:05:13 +02:00
autoscaling cleanup: Update deprecated FromInt to FromInt32 (#119858) 2023-08-16 09:33:01 -07:00
chaosmonkey e2e: use Ginkgo context 2022-12-16 20:14:04 +01:00
cloud e2e tests: set all PSa labels instead of just enforcing 2023-06-21 15:05:13 +02:00
common Merge pull request #119489 from carlory/cleanup-e2e-common-framework-equal 2023-08-17 03:25:22 -07:00
dra Merge pull request #119819 from pohly/dra-performance-test-driver 2023-08-16 04:32:26 -07:00
framework Merge pull request #119966 from aojea/fixfix 2023-08-16 09:33:08 -07:00
instrumentation e2e_instrumentation: stop using deprecated framework.ExpectEqual 2023-07-21 15:41:26 +08:00
kubectl pull Host from kubeconfig when needed 2023-08-14 10:16:24 -04:00
lifecycle e2e tests: set all PSa labels instead of just enforcing 2023-06-21 15:05:13 +02:00
network cleanup: Update deprecated FromInt to FromInt32 (#119858) 2023-08-16 09:33:01 -07:00
node Merge pull request #119501 from Songjoy/cleanup-e2e-node-framework-equal 2023-08-16 16:36:30 -07:00
perftype
reporters e2e: comment the known limitation of the ProgressReporter 2022-12-23 18:43:49 +08:00
scheduling Merge pull request #119502 from Songjoy/cleanup-e2e-scheduling-framework-equal 2023-08-15 19:42:43 -07:00
storage Merge pull request #119745 from tsmetana/fix-local-stress-flake 2023-08-16 09:32:53 -07:00
testing-manifests [KMSv2] update ci script and add readme 2023-03-27 20:43:37 +00:00
upgrades e2e: support admissionapi.LevelRestricted in test/e2e/framwork/pod 2023-07-03 16:26:28 +02:00
windows Merge pull request #118280 from stlaz/e2e_psa_labels 2023-06-28 11:14:43 -07:00
e2e_test.go e2e: detect unexpected command line arguments 2023-07-05 13:34:09 +02:00
e2e-example-config.json
e2e.go Merge pull request #115678 from pohly/e2e-full-reports 2023-02-10 15:07:29 -08:00
README.md e2e: accept context from Ginkgo 2022-12-10 19:50:18 +01:00
suites.go e2e: use error wrapping with %w 2023-02-06 15:39:13 +01:00

test/e2e

This is home to e2e tests used for presubmit, periodic, and postsubmit jobs.

Some of these jobs are merge-blocking, some are release-blocking.

e2e test ownership

All e2e tests must adhere to the following policies:

  • the test must be owned by one and only one SIG
  • the test must live in/underneath a sig-owned package matching pattern: test/e2e/[{subpath}/]{sig}/..., e.g.
    • test/e2e/auth - all tests owned by sig-auth
    • test/e2e/common/storage - all tests common to cluster-level and node-level e2e tests, owned by sig-node
    • test/e2e/upgrade/apps - all tests used in upgrade testing, owned by sig-apps
  • each sig-owned package should have an OWNERS file defining relevant approvers and labels for the owning sig, e.g.
# test/e2e/node/OWNERS
# See the OWNERS docs at https://go.k8s.io/owners

approvers:
- alice
- bob
- cynthia
emeritus_approvers:
- dave
reviewers:
- sig-node-reviewers
labels:
- sig/node
  • packages that use {subpath} should have an imports.go file importing sig-owned packages (for ginkgo's benefit), e.g.
// test/e2e/common/imports.go
package common

import (
	// ensure these packages are scanned by ginkgo for e2e tests
	_ "k8s.io/kubernetes/test/e2e/common/network"
	_ "k8s.io/kubernetes/test/e2e/common/node"
	_ "k8s.io/kubernetes/test/e2e/common/storage"
)
  • test ownership must be declared via a top-level SIGDescribe call defined in the sig-owned package, e.g.
// test/e2e/lifecycle/framework.go
package lifecycle

import "github.com/onsi/ginkgo"

// SIGDescribe annotates the test with the SIG label.
func SIGDescribe(text string, body func()) bool {
	return ginkgo.Describe("[sig-cluster-lifecycle] "+text, body)
}
// test/e2e/lifecycle/bootstrap/bootstrap_signer.go

package bootstrap

import (
	"github.com/onsi/ginkgo"
	"k8s.io/kubernetes/test/e2e/lifecycle"
)
var _ = lifecycle.SIGDescribe("[Feature:BootstrapTokens]", func() {
  /* ... */
  ginkgo.It("should sign the new added bootstrap tokens", func(ctx context.Context) {
    /* ... */
  })
  /* etc */
})

These polices are enforced:

  • via the merge-blocking presubmit job pull-kubernetes-verify
  • which ends up running hack/verify-e2e-test-ownership.sh
  • which can also be run via make verify WHAT=e2e-test-ownership

more info

See kubernetes/community/.../e2e-tests.md