登录
首页 >  Golang >  Go问答

Google App Engine 数据存储区 - 测试查询失败

来源:Golang技术栈

时间:2023-04-12 06:27:03 208浏览 收藏

积累知识,胜过积蓄金银!毕竟在##column_title##开发的过程中,会遇到各种各样的问题,往往都是一些细节知识点还没有掌握好而导致的,因此基础知识点的积累是很重要的。下面本文《Google App Engine 数据存储区 - 测试查询失败》,就带大家讲解一下golang知识点,若是你对本文感兴趣,或者是想搞懂其中某个知识点,就请你继续往下看吧~

问题内容

我目前正在尝试测试一段在数据存储上运行查询的代码,然后再放入新实体以确保不会创建重复项。我编写的代码在应用程序的上下文中运行良好,但我为该方法编写的测试失败了。似乎我无法通过测试包上下文中的查询访问放入数据存储区的数据。

一种可能性可能在于输出中的goapp test内容:Applying all pending transactions and saving the datastore. 在调用 get 和 put 方法后,会打印出这一行(我用日志语句验证了这一点)。

我尝试关闭上下文并为不同的操作创建一个新的,但不幸的是这也没有帮助。下面是一个简单的测试用例,它放入一个对象,然后对其运行查询。任何帮助,将不胜感激。

type Entity struct {
    Value string
}

func TestEntityQuery(t *testing.T) {
    c, err := aetest.NewContext(nil)
    if err != nil {
        t.Fatal(err)
    }
    defer c.Close()

    key := datastore.NewIncompleteKey(c, "Entity", nil)
    key, err = datastore.Put(c, key, &Entity{Value: "test"})
    if err != nil {
        t.Fatal(err)
    }

    q := datastore.NewQuery("Entity").Filter("Value =", "test")
    var entities []Entity
    keys, err := q.GetAll(c, &entities)
    if err != nil {
        t.Fatal(err)
    }
    if len(keys) == 0 {
        t.Error("No keys found in query")
    }
    if len(entities) == 0 {
        t.Error("No entities found in query")
    }
}

正确答案

您的测试代码没有任何问题。问题在于数据存储本身。HR Datastore 中的大多数查询不是“立即一致的”,而是最终一致的。您可以在Datastore文档中阅读有关此内容的更多信息。

所以基本上发生的事情是您将一个实体放入数据存储区,并且 SDK 的数据存储区“模拟”您可以在生产中观察到的延迟,因此如果您在此之后立即运行查询(这不是祖先查询),查询结果将不包括您刚刚保存的新实体。

datastore.Put()如果您在和之间放置几秒钟 sleep q.GetAll(),您将看到测试通过。试试吧。在我的测试中,只睡 100 毫秒就足够了,而且测试总是通过。但是在为这种情况编写测试时,请使用StronglyConsistentDatastore: trueJonhGB 的答案中可以看到的选项。

如果您使用Ancestor 查询,您也会看到测试通过而无需睡眠,因为它们是高度一致的。

今天关于《Google App Engine 数据存储区 - 测试查询失败》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于golang的内容请关注golang学习网公众号!

声明:本文转载于:Golang技术栈 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>
评论列表