草庐IT

api - 避免在包 API 中暴露反射

全部标签

ruby - 使用 RSpec 和 VCR 测试 Web API

我正在编写一个作为gem的API包装器,我想使用RSpec测试API响应。问题是所有API请求都是使用GET发出的,并且在url中包含一个APIkey:例如游戏/元数据/{api_key}这给测试带来了问题,因为我不想将APIkey保留在git存储库历史记录中。有什么方法可以进行这些规范测试,最好是使用RSpec/VCR,而不是将APIkey存储在版本控制中?我试过使用环境变量,但VCR仍然存储整个请求,而不仅仅是响应主体。 最佳答案 VCR有一个专门针对这些情况的配置选项:VCR.configuredo|c|c.filter_se

ruby-on-rails - 如何避免 Rspec 共享示例 'previously defined' 警告?

我正在尝试学习如何使用Rspec的共享示例功能,但在运行测试时收到警告:WARNING:Sharedexamplegroup'requiredattributes'hasbeenpreviouslydefinedat:/Users/me/app/spec/support/shared_examples/required_attributes_spec.rb:1...andyouarenowdefiningitat:/Users/me/app/spec/support/shared_examples/required_attributes_spec.rb:1Thenewdefinitio

ruby-on-rails - 在 ruby​​ on rails 中使用 facebook graph api 时从 url 获取一个 json 对象

如何在我的ruby​​onrails代码中通过URL获取JSON对象:url="https://graph.facebook.com/me/friends?access_token=XXX"我无法获得有关JSON+RubyonRails的良好教程。谁能帮帮我,谢谢。 最佳答案 require'open-uri'require'json'json_object=JSON.parse(open("https://graph.facebook.com/me/friends?access_token=XXX").read)这是最简单的方法,

ruby - 是否有任何你避免使用的 Ruby 语言特性?

在我看来,Ruby的句法非常灵活,很多东西可以用多种方式编写。作为Ruby程序员,有没有什么语言特性/语法糖/编码约定是您避免清楚的?我问的是您选择有意不使用的东西,而不是您仍然需要学习的东西。如果您的回答是“我什么都用!”,如果读者知道相关的Ruby语法,您是否曾经对代码进行注释?[我对RoR上下文中的Ruby特别感兴趣,但欢迎一切。] 最佳答案 “$”全局变量的整个范围(参见Pickaxe2pp333-336)大多继承自Perl,非常可怕,尽管我有时发现自己使用$:而不是$LOAD_PATH.

ruby-on-rails - 如何区分 Newrelic 中的 Rails API 调用?

我使用Rails5为网站和RESTfulAPI提供服务,并使用Newrelic(newrelic_rpmgem)来监控应用程序性能。目前,gem监控对一个应用程序名称的所有请求。假设我的路线看起来像这样:Rails.application.routes.drawdoresources:usersnamespace:apidonamespace:v1doresources:users,only::indexendendend此处/users是网络应用程序的路由,api/users是API的路由。现在,一旦我使用newrelic_rpm,它就看不出API和网络之间的区别。我想为报告做更多的

ruby-on-rails - 如何避免 rspec 中的长堆栈跟踪

是否可以简单地将堆栈跟踪限制为应用程序中的文件?长堆栈跟踪很困惑,大多数错误直接出现在应用程序中。 最佳答案 通常情况下,堆栈跟踪会自动缩短,除非您在.rspec文件中指定选项--backtrace。也许thisquestion对你有帮助。他们试图达到相反的目的,但它表明您可以Hook并否决它。 关于ruby-on-rails-如何避免rspec中的长堆栈跟踪,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.

ruby-on-rails - 具有强参数的 Rails 4 API?

我正在使用Rails4构建一个简单的API,但是使用我的“创建”方法时,一切都出错了。这是我的路线文件的相关部分:namespace:api,defaults:{format:'json'}do#/api/...Api::scopemodule::v1,constraints:ApiConstraints.new(version:1,default:true)doresources:usersendend这是api/v1/users_controller.rb:classApi::V1::UsersController[],:instrument_ids=>[])endend每当我尝试

ruby - Jekyll - 如何避免在 YAML frontmatter markdownify 项目上添加段落

好的...我有一个项目,我在其中使用Jekyll进行播客项目。我选择通过YAMLFrontMatter项目在shownotes中列出主机:hosts:-NameA-NameB-NameC使用这段代码Hosts:{%forhostinpage.hosts%}{{host}}{%endfor%}我收到了正确的列表Hosts:NameANameBNameC但是,我想通过这样做来MarkdownHosts:{%forhostinpage.hosts%}{{host|markdownify}}{%endfor%}但是Jekyll返回:Hosts:NameANameBNameC任何禁止Jekyll

ruby - Office 365 Rest API - 守护进程周身份验证

我正在尝试构建一个Ruby守护进程服务来访问Office365restAPI。最近可以通过OAuth“client_credentials”流程来执行此操作,详见此博文:https://learn.microsoft.com/en-us/archive/blogs/exchangedev/building-daemon-or-service-apps-with-office-365-mail-calendar-and-contacts-apis-oauth2-client-credential-flow我正在努力生成有效的访问token。token端点返回一个JWT,但是当使用这个to

ruby-on-rails - ENV 变量中的 Capistrano 和 API key ?

我正在使用Capistrano部署我的Rails应用程序。我想在服务器上保存一些APIkey作为环境变量。我使用Capistrano部署的Rails应用程序应该可以访问这些APIkey。作为守护进程运行的单独的ruby​​文件也应该可以访问这些APIkey。在环境变量中设置APIkey似乎是理想的解决方案,但是,我无法在我的Rails应用程序中使用ENV["SOME_KEY"]访问它们。根据thispost,因为capistrano以非交互和非登录方式运行,~/.bashrc和~/.bash_profile未加载。流程图建议我应该使用$BASH_ENV。我可以只在$BASH_ENV中添