我正在尝试使用 Go pubsub library针对 local emulated pubsub server .我发现“旧式”(已弃用)函数(例如 CreateSub 和 PullWait)工作正常,但“新式”API(例如 Iterators 和 SubscriptionHandles) 没有按预期工作。
我编写了两个不同的单元测试,它们都测试相同的操作序列,一个使用“新式”API,一个使用“旧式”API。
顺序是:
https://gist.github.com/ianrose14/db6ecd9ccb6c84c8b36bf49d93b11bfb
使用旧式 API 的测试与我预期的一样:
=== RUN TestPubSubRereadLegacyForDemo
--- PASS: TestPubSubRereadLegacyForDemo (10.32s)
pubsubintg_test.go:217: PullWait returned in 21.64236ms (expected 0)
pubsubintg_test.go:228: PullWait returned in 10.048119558s (expected 10s)
PASS
而使用新型 API 的测试工作不可靠。有时事情会按预期工作:
=== RUN TestPubSubRereadForDemo
--- PASS: TestPubSubRereadForDemo (11.38s)
pubsubintg_test.go:149: iter.Next() returned in 17.686701ms (expected 0)
pubsubintg_test.go:171: iter.Next() returned in 10.059492646s (expected 10s)
PASS
但有时我发现 iter.Stop() 没有像它应该的那样迅速返回(并注意第二个 iter.Next 比它应该的时间长得多):
=== RUN TestPubSubRereadForDemo
--- FAIL: TestPubSubRereadForDemo (23.87s)
pubsubintg_test.go:149: iter.Next() returned in 7.3284ms (expected 0)
pubsubintg_test.go:171: iter.Next() returned in 20.074994835s (expected 10s)
pubsubintg_test.go:183: iter.Stop() took too long (2.475055901s)
FAIL
有时我发现发布消息后的第一个 Pull 花费的时间太长(应该接近即时):
=== RUN TestPubSubRereadForDemo
--- FAIL: TestPubSubRereadForDemo (6.32s)
pubsubintg_test.go:147: failed to pull message from iterator: context deadline exceeded
FAIL
有什么想法吗?是否有任何使用新型 API 的工作示例?不幸的是,Go starter project here使用旧的、已弃用的 API。
最佳答案
(注意:您的示例输出中的行号似乎与您链接的代码不匹配。)
But sometimes I find that iter.Stop() doesn't return promptly as it should
最近发生了一些变化,修复了调用 iter.Stop 时的过度延迟。如果所有消息都已被确认,它现在应该立即返回。尝试同步并再次测试。
(and note how the second iter.Next too way longer than it should):
在您使用新 API 的代码中,您首先使用截止时间为 1 秒的上下文从空订阅中进行拉取。我们称之为“拉取请求 A”。虽然底层的 http 请求被取消,但似乎连接没有以服务器尊重的任何方式关闭。因此,就服务器而言,“A”仍然处于待定状态。发布后,您立即发出新的拉取请求,我们称之为“B”。在通过拉取请求 B 返回一条消息后,您将消息保持未确认状态,并发出另一个拉取请求“C”。
现在,当您发布消息时,服务器会将其传递给“A”或“B”。如果它首先将其交付给“A”,您将看到第一个 pull 超过 5s 上下文截止日期。如果它首先发布到“B”,您将看到第一个拉取快速返回,如预期的那样。消息发布到“B”且未被确认后,服务器会将其重新传送到“A”或“C”。如果它首先选择“A”,那么您将以比预期更长的时间结束第二次拉动。如果它选择“C”,那么您将看到第一次和第二次拉动所花费的时间与您预期的一样长。
如果您不从空订阅中执行初始拉取,您应该会看到您的测试按预期运行。
注意:当您使用旧 API 时,您看不到任何这些,因为您没有使用旧 API 执行额外的“从空订阅中提取”请求(大概是因为它没有正确支持可取消的上下文).
另外:如果你想留下一条未确认的消息,你应该调用 Message.Done(false)。
关于go - "new style"google pubsub golang 函数无法正常工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36365159/
我正在尝试测试是否存在表单。我是Rails新手。我的new.html.erb_spec.rb文件的内容是:require'spec_helper'describe"messages/new.html.erb"doit"shouldrendertheform"dorender'/messages/new.html.erb'reponse.shouldhave_form_putting_to(@message)with_submit_buttonendendView本身,new.html.erb,有代码:当我运行rspec时,它失败了:1)messages/new.html.erbshou
我在从html页面生成PDF时遇到问题。我正在使用PDFkit。在安装它的过程中,我注意到我需要wkhtmltopdf。所以我也安装了它。我做了PDFkit的文档所说的一切......现在我在尝试加载PDF时遇到了这个错误。这里是错误:commandfailed:"/usr/local/bin/wkhtmltopdf""--margin-right""0.75in""--page-size""Letter""--margin-top""0.75in""--margin-bottom""0.75in""--encoding""UTF-8""--margin-left""0.75in""-
我在我的项目目录中完成了compasscreate.和compassinitrails。几个问题:我已将我的.sass文件放在public/stylesheets中。这是放置它们的正确位置吗?当我运行compasswatch时,它不会自动编译这些.sass文件。我必须手动指定文件:compasswatchpublic/stylesheets/myfile.sass等。如何让它自动运行?文件ie.css、print.css和screen.css已放在stylesheets/compiled。如何在编译后不让它们重新出现的情况下删除它们?我自己编译的.sass文件编译成compiled/t
为了将Cucumber用于命令行脚本,我按照提供的说明安装了arubagem。它在我的Gemfile中,我可以验证是否安装了正确的版本并且我已经包含了require'aruba/cucumber'在'features/env.rb'中为了确保它能正常工作,我写了以下场景:@announceScenario:Testingcucumber/arubaGivenablankslateThentheoutputfrom"ls-la"shouldcontain"drw"假设事情应该失败。它确实失败了,但失败的原因是错误的:@announceScenario:Testingcucumber/ar
我对最新版本的Rails有疑问。我创建了一个新应用程序(railsnewMyProject),但我没有脚本/生成,只有脚本/rails,当我输入ruby./script/railsgeneratepluginmy_plugin"Couldnotfindgeneratorplugin.".你知道如何生成插件模板吗?没有这个命令可以创建插件吗?PS:我正在使用Rails3.2.1和ruby1.8.7[universal-darwin11.0] 最佳答案 随着Rails3.2.0的发布,插件生成器已经被移除。查看变更日志here.现在
我尝试运行2.x应用程序。我使用rvm并为此应用程序设置其他版本的ruby:$rvmuseree-1.8.7-head我尝试运行服务器,然后出现很多错误:$script/serverNOTE:Gem.source_indexisdeprecated,useSpecification.Itwillberemovedonorafter2011-11-01.Gem.source_indexcalledfrom/Users/serg/rails_projects_terminal/work_proj/spohelp/config/../vendor/rails/railties/lib/r
我正在尝试在我的centos服务器上安装therubyracer,但遇到了麻烦。$geminstalltherubyracerBuildingnativeextensions.Thiscouldtakeawhile...ERROR:Errorinstallingtherubyracer:ERROR:Failedtobuildgemnativeextension./usr/local/rvm/rubies/ruby-1.9.3-p125/bin/rubyextconf.rbcheckingformain()in-lpthread...yescheckingforv8.h...no***e
我花了三天的时间用头撞墙,试图弄清楚为什么简单的“rake”不能通过我的规范文件。如果您遇到这种情况:任何文件夹路径中都不要有空格!。严重地。事实上,从现在开始,您命名的任何内容都没有空格。这是我的控制台输出:(在/Users/*****/Desktop/LearningRuby/learn_ruby)$rake/Users/*******/Desktop/LearningRuby/learn_ruby/00_hello/hello_spec.rb:116:in`require':cannotloadsuchfile--hello(LoadError) 最佳
我想在一个没有Sass引擎的类中使用Sass颜色函数。我已经在项目中使用了sassgem,所以我认为搭载会像以下一样简单:classRectangleincludeSass::Script::FunctionsdefcolorSass::Script::Color.new([0x82,0x39,0x06])enddefrender#hamlengineexecutedwithcontextofself#sothatwithintemlateicouldcall#%stop{offset:'0%',stop:{color:lighten(color)}}endend更新:参见上面的#re
关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭8年前。Improvethisquestion在首页我有:汽车:VolvoSaabMercedesAudistatic_pages_spec.rb中的测试代码:it"shouldhavetherightselect"dovisithome_pathit{shouldhave_select('cars',:options=>['volvo','saab','mercedes','audi'])}end响应是rspec./spec/request