- APISnoop org-flow: checkAPIGroupPreferredVersionTest.org
- Test approval issue: kubernetes/kubernetes#
- Test pr: kuberenetes/kubernetes#
- Two weeks soak start date: testgrid-link
- Two weeks soak end date:
- Test promotion pr: kubernetes/kubernetes#?
According to this APIsnoop query, there are still an endpoint which is untested.
SELECT
operation_id,
-- k8s_action,
path,
description
-- kind
-- FROM untested_stable_core_endpoints
FROM untested_stable_endpoints
where path not like '%volume%'
-- and kind like ''
and operation_id ilike '%APIGroup'
ORDER BY operation_id
LIMIT 25
;
operation_id | path | description
---------------------------------+-------------------------------------+----------------------------
getApiregistrationAPIGroup | /apis/apiregistration.k8s.io/ | get information of a group
getAppsAPIGroup | /apis/apps/ | get information of a group
getAuthenticationAPIGroup | /apis/authentication.k8s.io/ | get information of a group
getAuthorizationAPIGroup | /apis/authorization.k8s.io/ | get information of a group
getAutoscalingAPIGroup | /apis/autoscaling/ | get information of a group
getBatchAPIGroup | /apis/batch/ | get information of a group
getCoordinationAPIGroup | /apis/coordination.k8s.io/ | get information of a group
getDiscoveryAPIGroup | /apis/discovery.k8s.io/ | get information of a group
getEventsAPIGroup | /apis/events.k8s.io/ | get information of a group
getExtensionsAPIGroup | /apis/extensions/ | get information of a group
getFlowcontrolApiserverAPIGroup | /apis/flowcontrol.apiserver.k8s.io/ | get information of a group
getNodeAPIGroup | /apis/node.k8s.io/ | get information of a group
getPolicyAPIGroup | /apis/policy/ | get information of a group
getRbacAuthorizationAPIGroup | /apis/rbac.authorization.k8s.io/ | get information of a group
getSchedulingAPIGroup | /apis/scheduling.k8s.io/ | get information of a group
getSettingsAPIGroup | /apis/settings.k8s.io/ | get information of a group
getStorageAPIGroup | /apis/storage.k8s.io/ | get information of a group
(17 rows)
-
Get a list of all group /apis
-
Iterate through list
-
Query each endpoint
-
List the PreferredVersion for the endpoint
package main
import (
"context"
"flag"
"fmt"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/client-go/kubernetes"
"k8s.io/client-go/tools/clientcmd"
"os"
)
func main() {
// uses the current context in kubeconfig
kubeconfig := flag.String("kubeconfig", fmt.Sprintf("%v/%v/%v", os.Getenv("HOME"), ".kube", "config"), "(optional) absolute path to the kubeconfig file")
flag.Parse()
config, err := clientcmd.BuildConfigFromFlags("", *kubeconfig)
if err != nil {
fmt.Println(err)
return
}
// make our work easier to find in the audit_event queries
config.UserAgent = "live-test-writing"
// creates the clientset
ClientSet, _ := kubernetes.NewForConfig(config)
// TEST BEGINS HERE
fmt.Println("[status] begin")
// get list of APIGroup endpoints
list := &metav1.APIGroupList{}
err = ClientSet.Discovery().RESTClient().Get().AbsPath("/apis/").Do(context.TODO()).Into(list)
if err != nil {
fmt.Println("Failed to find /apis/", err)
os.Exit(1)
}
for _, group := range list.Groups {
fmt.Println("Checking APIGroup:", group.Name)
// hit APIGroup endpoint
checkGroup := &metav1.APIGroup{}
apiPath := "/apis/" + group.Name + "/"
err = ClientSet.Discovery().RESTClient().Get().AbsPath(apiPath).Do(context.TODO()).Into(checkGroup)
if err != nil {
fmt.Printf("Fail to access: %s | Error: %v\n", apiPath, err)
os.Exit(1)
}
// get PreferredVersion for endpoint
fmt.Println("PreferredVersion:", checkGroup.PreferredVersion, "\n")
}
// TEST ENDS HERE
fmt.Println("[status] complete")
}
[status] begin
Checking APIGroup: apiregistration.k8s.io
PreferredVersion: {apiregistration.k8s.io/v1 v1}
Checking APIGroup: extensions
PreferredVersion: {extensions/v1beta1 v1beta1}
Checking APIGroup: apps
PreferredVersion: {apps/v1 v1}
Checking APIGroup: events.k8s.io
PreferredVersion: {events.k8s.io/v1beta1 v1beta1}
Checking APIGroup: authentication.k8s.io
PreferredVersion: {authentication.k8s.io/v1 v1}
Checking APIGroup: authorization.k8s.io
PreferredVersion: {authorization.k8s.io/v1 v1}
Checking APIGroup: autoscaling
PreferredVersion: {autoscaling/v1 v1}
Checking APIGroup: batch
PreferredVersion: {batch/v1 v1}
Checking APIGroup: certificates.k8s.io
PreferredVersion: {certificates.k8s.io/v1beta1 v1beta1}
Checking APIGroup: networking.k8s.io
PreferredVersion: {networking.k8s.io/v1 v1}
Checking APIGroup: policy
PreferredVersion: {policy/v1beta1 v1beta1}
Checking APIGroup: rbac.authorization.k8s.io
PreferredVersion: {rbac.authorization.k8s.io/v1 v1}
Checking APIGroup: storage.k8s.io
PreferredVersion: {storage.k8s.io/v1 v1}
Checking APIGroup: admissionregistration.k8s.io
PreferredVersion: {admissionregistration.k8s.io/v1 v1}
Checking APIGroup: apiextensions.k8s.io
PreferredVersion: {apiextensions.k8s.io/v1 v1}
Checking APIGroup: scheduling.k8s.io
PreferredVersion: {scheduling.k8s.io/v1 v1}
Checking APIGroup: coordination.k8s.io
PreferredVersion: {coordination.k8s.io/v1 v1}
Checking APIGroup: auditregistration.k8s.io
PreferredVersion: {auditregistration.k8s.io/v1alpha1 v1alpha1}
Checking APIGroup: node.k8s.io
PreferredVersion: {node.k8s.io/v1beta1 v1beta1}
Checking APIGroup: discovery.k8s.io
PreferredVersion: {discovery.k8s.io/v1beta1 v1beta1}
[status] complete
Discover useragents:
select distinct useragent from audit_event where bucket='apisnoop' and useragent not like 'kube%' and useragent not like 'coredns%' and useragent not like 'kindnetd%' and useragent like 'live%';
useragent
-------------------
live-test-writing
(1 row)
List endpoints hit by the test:
select * from endpoints_hit_by_new_test where useragent like 'live%';
useragent | operation_id | hit_by_ete | hit_by_new_test
-------------------+----------------------------------+------------+-----------------
live-test-writing | getAdmissionregistrationAPIGroup | t | 1
live-test-writing | getApiextensionsAPIGroup | t | 1
live-test-writing | getApiregistrationAPIGroup | f | 1
live-test-writing | getAPIVersions | t | 1
live-test-writing | getAppsAPIGroup | f | 1
live-test-writing | getAuthenticationAPIGroup | f | 1
live-test-writing | getAuthorizationAPIGroup | f | 1
live-test-writing | getAutoscalingAPIGroup | f | 1
live-test-writing | getBatchAPIGroup | f | 1
live-test-writing | getCertificatesAPIGroup | t | 1
live-test-writing | getCoordinationAPIGroup | f | 1
live-test-writing | getDiscoveryAPIGroup | f | 1
live-test-writing | getEventsAPIGroup | f | 1
live-test-writing | getExtensionsAPIGroup | f | 1
live-test-writing | getNetworkingAPIGroup | t | 1
live-test-writing | getNodeAPIGroup | f | 1
live-test-writing | getPolicyAPIGroup | f | 1
live-test-writing | getRbacAuthorizationAPIGroup | f | 1
live-test-writing | getSchedulingAPIGroup | f | 1
live-test-writing | getStorageAPIGroup | f | 1
(20 rows)
Display endpoint coverage change:
select * from projected_change_in_coverage;
category | total_endpoints | old_coverage | new_coverage | change_in_number
---------------+-----------------+--------------+--------------+------------------
test_coverage | 458 | 206 | 222 | 16
(1 row)
If a test with these calls gets merged, test coverage will go up by 15 points
This test is also created with the goal of conformance promotion.
/sig testing
/sig architecture
/area conformance