GetNamespaceCreationTime 함수를 구현하는 동안 포괄적인 단위 테스트를 작성하는 데 어려움을 겪었습니다. GetNamespaceCreationTime 함수는 Kubernetes API 서버와 상호작용하여 네임스페이스 세부정보를 가져옵니다. 이로 인해 실제 API 상호 작용에 의존하지 않고 격리된 테스트를 작성하기가 어려워졌습니다.
client-go 라이브러리의 가짜 패키지는 가짜 클라이언트를 생성할 수 있는 방법을 제공합니다. 테스트 목적으로 사용됩니다. 이러한 가짜 클라이언트는 실제 클라이언트의 동작을 모방하지만 통제된 환경에서 작동합니다.
이 경우 가짜 패키지의 NewSimpleClientset 함수를 사용하여 가짜 Kubernetes 클라이언트를 생성할 수 있습니다. 이 클라이언트는 단위 테스트에서 실제 클라이언트를 대체하는 데 사용할 수 있으므로 코드 동작을 분리하고 테스트 논리에 집중할 수 있습니다.
GetNamespaceCreationTime 함수를 테스트하려면 , 다음과 같이 테스트 케이스를 생성할 수 있습니다.
func TestGetNamespaceCreationTime(t *testing.T) { fakeClient := fake.NewSimpleClientset() got := GetNamespaceCreationTime(fakeClient, "default") want := int64(1257894000) // Inject mock Namespace data into the fake client nsMock := fakeClient.CoreV1().Namespaces() nsMock.Create(&v1.Namespace{ ObjectMeta: metav1.ObjectMeta{ Name: "default", CreationTimestamp: metav1.Date(2009, time.November, 10, 23, 0, 0, 0, time.UTC), }, }) if got != want { t.Errorf("got %q want %q", got, want) } }
이 테스트에서는 실제 Kubernetes 클라이언트를 대체하는 가짜 클라이언트를 생성합니다. 그런 다음 가짜 클라이언트에 모의 네임스페이스 데이터를 삽입합니다. 이를 통해 네임스페이스 생성 시간을 가져올 때 API 서버에서 기대할 수 있는 응답을 시뮬레이션할 수 있습니다. 그런 다음 GetNamespaceCreationTime 함수의 출력이 예상 값과 일치한다고 주장할 수 있습니다.
단위 테스트에서 가짜 클라이언트를 사용하면 다음과 같은 여러 가지 이점을 얻을 수 있습니다.
위 내용은 가짜 클라이언트로 Client-Go 코드를 테스트하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!