草庐IT

Conda虚拟环境的复制和迁移

全部标签

ruby - 在不同环境中运行 Cucumber 测试

我使用Cucumber和Capybara进行自动化前端测试。我有两个要运行测试的环境。一个是暂存环境,另一个是生产环境。目前,我编写了直接访问登台的测试。visit('https://staging.somewhere.com')我想在生产中重新使用测试(https://production.somewhere.com)。是否可以将URL存储在我的步骤定义中的变量中visit(domain)并使用从命令行调用的环境变量定义域?喜欢$>bundleexeccucumberfeaturesDOMAIN=staging如果我想将测试指向我的暂存环境,或者$>bundleexeccucumbe

ruby-on-rails - 在测试环境中禁用地理编码

在我的RubyonRails应用程序中,我使用的是Geocoder。它工作正常,但我的测试速度慢了十倍!我找到了一些解决方案,但我认为它们不是很清楚?有什么方法可以在测试环境中禁用Geocoder? 最佳答案 根据gemdocumentationonGithub,您可以在测试中使用测试查找,以避免执行实际请求:Geocoder.configure(:lookup=>:test)Geocoder::Lookup::Test.add_stub("NewYork,NY",[{'latitude'=>40.7143528,'longitud

ruby-on-rails - Ruby 独立脚本中的 RoR 环境

我想运行一个独立的ruby​​脚本,我需要在其中使用我的RoR环境。具体来说,我需要我的模型扩展ActionMailer和ActiveRecord。我还需要从我的database.yml中读取数据库配置。我该怎么做? 最佳答案 最简单的方法是将脚本的shebang更改为:#!/usr/bin/ruby到#!/path/to/your/rails/script/runnerEtvoilà,您的脚本将在加载完整rails环境的情况下运行。您还可以将脚本作为./my_script-eproduction运行,以使其与生产数据库一起运行。

ruby-on-rails - Rails 3.1 引擎迁移不起作用

我正在创建一个带有迁移的Rails3.1引擎。rakedb:migration在该引擎和主机应用程序内部运行良好。但是我需要将这个引擎包含到另一个Rails引擎中。第二个引擎包含用于测试的虚拟应用程序,我在该虚拟应用程序的application.rb添加了这一行:require'my_engine'在控制台中,我可以看到第一个引擎的类。rake-T给我app:my_engine_engine:install:migrations任务,但是当我运行这个任务时rakeapp:my_engine_engine:install:migrations我收到这个错误:rakeaborted!Don

ruby-on-rails - 当多个应用程序在 Ruby 中共享同一个数据库时如何管理迁移?

我有一个Rails应用程序和一个Sinatra应用程序,共享同一个数据库。Sinatra应用程序使用ActiveRecord。我能否从每个应用程序中运行迁移,就好像它们在同一个应用程序中一样?这会导致任何问题吗?Rails应用程序中的schema.rb文件通过以下方式跟踪当前迁移ActiveRecord::Schema.define(:version=>20121108154656)do但是,Sinatra应用如何知道数据库的当前版本?Rails3.2.2,Ruby1.9.3。 最佳答案 schema_migrations表中的版本

Ruby 看不到 NLS_LANG 环境变量

我在CentOS上运行一个ruby​​脚本,并通过rvm(1.9.3)安装了ruby​​。我已经在.bash_profile中设置了NLS_LANG变量。[app@boxstasis]$echo$NLS_LANGen_US.UTF-8[app@boxstasis]$whichruby~/.rvm/rubies/ruby-1.9.3-p194/bin/ruby然而,当试图通过ruby​​(oci8驱动程序所做的)访问它时,它找不到它:1.9.3-p194:001>ENV['NLS_LANG']=>nil访问其他变量似乎有效:1.9.3-p194:004>ENV['USER']=>"app

ruby - 如何在 Ruby 脚本中为命令 shell 获取环境变量?

我正在尝试从我的ruby​​程序中运行一些第三方bash脚本。在我运行它们之前,它们要求我获取一个文件。在命令行上它一切正常,但在Ruby中它不起作用。我发现系统命令将打开一个新的子shell进程,任何采购都将在其中完成,并且无法从运行Ruby脚本的父shell进程中看到。当系统调用结束时,子shell也被杀死。我该如何解决这个问题? 最佳答案 这样做:$sourcewhatever.sh$set>variables.txt然后在Ruby中:File.readlines("variables.txt").eachdo|line|va

ruby - 是否可以从 ruby​​ 脚本导出环境属性?

这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:ExportinganEnvironmentVariableinRuby我需要在ruby​​脚本中设置几个环境属性。通常,在bash中,我会执行以下操作:$exportSOME_VAR=some_value但在ruby​​中,以下(显然)不起作用:irb(main):002:0>`exportSOME_VAR=some_value`(irb):2:commandnotfound:exportASDF=1=>""有办法吗?

ruby - 我如何告诉 Sinatra 它是什么环境(开发、测试、生产)?

(免责声明:在Heroku上部署Sinatra的新手。)我看过http://www.sinatrarb.com/configuration.html它告诉我set:environment,:production。我的问题是,我该如何指定它:“在Heroku中,将环境设置为生产环境,否则留在测试/开发中。”此外,即使在set:environment,:production这行之后,我也不认为它在工作,因为当我尝试在本地rackup应用程序时,它是仍在运行(当我知道(或者我认为我知道)它不应该因为我没有在我的计算机上安装postgres时)。gem文件group:productiondog

ruby - 如何在 Rake 中获取当前的 Rack 环境?

有没有办法在Rake中获取有关当前Rack环境的信息?例如,我如何判断Rack是在development还是production模式下运行?我知道Rake不是Rack感知的。我试图避免在生产环境和开发环境之间在几乎相同的Rake任务中复制代码。 最佳答案 问题很旧,但从未获得最佳实践答案或根本没有令人满意的答案。真正的问题是:如何确定在Rake任务中使用了哪个环境,以便加载正确的配置/进入正确的if条件。Note:AsRakedoesn'tgivemuchaboutRack(RakeisnotusingHTTP)torelyonth