1 回答
TA贡献1836条经验 获得超4个赞
根据这个 GitHub 问题评论:
假客户端不会尝试复制服务器端行为,如验证,名称生成,uid分配等,如果你想测试这样的东西,你可以添加反应堆来模拟该行为。
要添加所需的反应器,我们可以在创建对象之前插入以下代码:corev1.Secret
client.PrependReactor(
"create", "*",
func(action k8sTesting.Action) (handled bool, ret runtime.Object, err error) {
ret = action.(k8sTesting.CreateAction).GetObject()
meta, ok := ret.(metav1.Object)
if !ok {
return
}
if meta.GetName() == "" && meta.GetGenerateName() != "" {
meta.SetName(names.SimpleNameGenerator.GenerateName(meta.GetGenerateName()))
}
return
},
)
那里有一些陷阱:
包含一个嵌入式
Fake结构,该结构具有我们需要为此用例调用的前置反应器方法(还有其他一些方法)。此处的此代码在创建此类对象时调用。Clientset该方法有 3 个参数:、和 。对于 ,我找不到任何命名常量,所以,在这种情况下,“创建”和“secrets”(奇怪的是它不是“秘密”)似乎是它们的正确值,如果我们想要超级具体,但在这种情况下设置为“*”应该是可以接受的。
PrependReactorverbresourcereactionverbresourceresource该参数的类型为反应符,它将
操作作为参数并返回 、 和 。经过一番挖掘,我注意到该参数将被转换为Creaction,它具有返回实例的方法,该实例可以转换为metav1。对象。此接口允许我们获取和设置基础对象的各种元数据字段。根据需要设置对象字段后,我们必须返回 ,并指示调用代码执行剩余的反应堆。reactionhandledreterractionGetObject()runtime.ObjectNamehandled = falseret = mutatedObjecterr = nil通过浏览代码,我注意到该字段是使用名称从字段生成的
。简单名称生成器.生成名称实用程序。apiserverObjectMeta.NameObjectMeta.GenerateName
- 1 回答
- 0 关注
- 188 浏览
添加回答
举报
